/* GENERATED FILE. Edit apps/lineup/src/* and run npm run build. */
:root {
  color-scheme: dark;
  --bg: #070a0b;
  --panel: #101416;
  --panel-2: #151a1d;
  --panel-3: #1b2024;
  --line: #293137;
  --line-strong: #39434a;
  --text: #f4f7f5;
  --muted: #9ba5aa;
  --soft: #69767d;
  --green: #5b92ff;
  --green-2: #2f68d8;
  --blue: #5b92ff;
  --accent-rgb: 91 146 255;
  --accent-secondary-rgb: 155 99 216;
  --accent-bg-dark: #08101d;
  --accent-bg-deep: #05070b;
  --accent-bg-light: #eaf2ff;
  --accent-bg-light-2: #dfeaff;
  --amber: #f3ae22;
  --violet: #9b63d8;
  --red: #db594f;
  --danger: #ff5d55;
  --shadow: 0 24px 80px rgba(0, 0, 0, 0.42);
  --radius: 8px;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

/* v397: compact phone export controls, stable slide selection, and smoother bank/editor behavior. */
.phone-export-compact-controls {
  display: none;
}

.slides-export-include-control {
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: 6;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 30px;
  border: 1px solid rgba(248, 251, 255, 0.22);
  border-radius: 999px;
  padding: 0 10px;
  color: #f8fbff;
  background: rgba(7, 17, 31, 0.78);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.24);
  font-size: 0.68rem;
  font-weight: 900;
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
}

.slides-export-include-control input {
  width: 15px;
  height: 15px;
  accent-color: var(--green);
}

.slides-object-mini-menu {
  position: absolute;
  z-index: 12;
  display: inline-grid;
  grid-auto-flow: column;
  grid-auto-columns: 30px;
  gap: 4px;
  padding: 4px;
  border: 1px solid rgba(248, 251, 255, 0.2);
  border-radius: 999px;
  background: rgba(7, 17, 31, 0.82);
  box-shadow: 0 8px 22px rgba(0, 0, 0, 0.28);
  transform: translate(-50%, 0);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
}

.slides-object-mini-menu button {
  display: grid;
  place-items: center;
  width: 30px;
  min-width: 30px;
  height: 30px;
  min-height: 30px;
  border: 1px solid rgba(248, 251, 255, 0.18);
  border-radius: 999px;
  color: #f8fbff;
  background: rgba(255, 255, 255, 0.06);
  cursor: pointer;
}

.slides-object-mini-menu svg {
  width: 16px;
  height: 16px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.bank-panel {
  container-type: inline-size;
}

.bank-row-more {
  display: none;
  position: relative;
  min-width: 30px;
  z-index: 8;
}

.bank-row-more summary {
  display: grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border: 1px solid var(--line);
  border-radius: 9px;
  color: var(--muted);
  background: rgba(255, 255, 255, 0.035);
  font-size: 0.88rem;
  font-weight: 950;
  list-style: none;
  cursor: pointer;
}

.bank-row-more summary::-webkit-details-marker {
  display: none;
}

.bank-row-more-menu {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  z-index: 30;
  display: grid;
  min-width: 132px;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 5px;
  background: color-mix(in srgb, var(--panel) 96%, #05070b);
  box-shadow: 0 16px 34px rgba(0, 0, 0, 0.32);
}

.bank-row-more-menu button {
  min-height: 32px;
  border: 0;
  border-radius: 8px;
  color: var(--text);
  background: transparent;
  text-align: left;
  font-size: 0.76rem;
  font-weight: 850;
  cursor: pointer;
}

.bank-row-more-menu button:hover,
.bank-row-more-menu button:focus-visible {
  background: color-mix(in srgb, var(--green) 12%, transparent);
  outline: none;
}

@container (max-width: 390px) {
  .bank-song .bank-song-main-content {
    grid-template-columns: minmax(0, 1fr) 30px !important;
  }

  .bank-song .banger-toggle,
  .bank-slides-button,
  .bank-sheets-button,
  .bank-edit-button,
  .bank-recording-cluster {
    display: none !important;
  }

  .bank-song .bank-row-more {
    display: block !important;
  }
}

@media (max-width: 760px) {
  .export-dialog-inner {
    grid-template-rows: auto auto auto minmax(0, 1fr) auto !important;
  }

  .export-settings {
    display: none !important;
  }

  .phone-export-compact-controls:not([hidden]) {
    grid-column: 1 !important;
    grid-row: 3 !important;
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 5px;
    border: 1px solid color-mix(in srgb, var(--line) 80%, transparent);
    border-radius: 12px;
    padding: 6px;
    background: color-mix(in srgb, var(--panel) 72%, transparent);
  }

  .phone-export-compact-controls label {
    display: grid;
    gap: 3px;
    min-width: 0;
    color: var(--muted);
    font-size: 0.54rem;
    font-weight: 950;
    line-height: 1;
    letter-spacing: 0;
    text-transform: uppercase;
  }

  .phone-export-compact-controls select,
  .phone-export-compact-controls .compact-check {
    width: 100%;
    min-width: 0;
    min-height: 32px;
    border: 1px solid var(--line);
    border-radius: 9px;
    color: var(--text);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.02));
    font-size: 0.76rem;
    font-weight: 900;
  }

  .phone-export-compact-controls select {
    padding: 0 8px;
  }

  .phone-export-compact-controls .compact-check {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
    padding: 0 6px;
    color: var(--text);
    text-transform: none;
  }

  .phone-export-compact-controls .compact-check input {
    width: 15px;
    height: 15px;
    accent-color: var(--green);
  }

  .phone-export-compact-controls .compact-check span {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .export-preview {
    display: grid !important;
    align-items: center !important;
    justify-items: center !important;
    overflow: hidden !important;
  }

  .export-sheet-preview-stack {
    display: grid !important;
    width: 100% !important;
    height: 100% !important;
    align-items: center !important;
    justify-items: center !important;
    overflow: hidden !important;
  }

  .export-sheet-preview.image-preview {
    width: auto !important;
    height: min(100%, 62dvh) !important;
    max-width: 100% !important;
    max-height: 100% !important;
    aspect-ratio: 595 / 842 !important;
  }

  .export-sheet-preview.image-preview.landscape {
    width: min(100%, 72dvw) !important;
    height: auto !important;
    aspect-ratio: 842 / 595 !important;
  }

  .export-sheet-preview.image-preview img {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
  }

  #exportSlidesPanel .theme-export-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  #exportSlidesPanel .theme-icon-card {
    min-height: 34px !important;
    padding: 4px 7px !important;
  }

  #exportSlidesPanel .theme-icon-wrap {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
  }

  #exportSlidesPanel .theme-icon-wrap svg,
  #exportSlidesPanel .slides-other-tools svg {
    width: 17px;
    height: 17px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
  }

  #exportSlidesPanel .slides-other-tools {
    display: grid !important;
    grid-template-columns: auto repeat(3, 34px);
    align-items: center;
    gap: 6px;
    min-height: 40px;
    border: 1px solid color-mix(in srgb, var(--line) 76%, transparent);
    border-radius: 11px;
    padding: 5px 7px;
    background: rgba(255, 255, 255, 0.028);
  }

  #exportSlidesPanel .slides-other-tools > span {
    color: var(--muted);
    font-size: 0.62rem;
    font-weight: 950;
    text-transform: uppercase;
  }

  #exportSlidesPanel .icon-color-control,
  #exportSlidesPanel .icon-background-button {
    position: relative;
    display: grid;
    place-items: center;
    width: 34px !important;
    min-width: 34px !important;
    height: 34px !important;
    min-height: 34px !important;
    border: 1px solid var(--line);
    border-radius: 10px;
    color: var(--text);
    background: rgba(255, 255, 255, 0.035);
    padding: 0 !important;
    overflow: hidden;
  }

  #exportSlidesPanel .icon-color-control input[type="radio"] {
    position: absolute;
    inset: 0;
    opacity: 0;
  }

  #exportSlidesPanel .icon-color-control input[type="color"] {
    position: absolute;
    inset: auto 2px 2px auto;
    width: 14px !important;
    height: 14px !important;
    border: 0;
    border-radius: 999px;
    padding: 0 !important;
    opacity: 0.88;
  }

  #exportSlidesPanel .slide-export-options {
    grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.1fr) minmax(0, 0.9fr) minmax(0, 0.9fr) !important;
    align-items: stretch !important;
  }

  #exportSlidesPanel .slide-title-size-control {
    display: grid;
    gap: 3px;
    min-width: 0;
    color: var(--muted);
    font-size: 0.56rem;
    font-weight: 950;
    text-transform: uppercase;
  }

  #exportSlidesPanel .slide-title-size-control select {
    width: 100%;
    min-width: 0;
    min-height: 32px;
    border-radius: 9px;
    font-size: 0.7rem;
    font-weight: 900;
  }

  #exportSlidesPanel .slide-title-option {
    min-width: 0;
    justify-content: center !important;
    gap: 5px !important;
  }

  #exportSlidesPanel .slide-title-option input {
    width: 15px !important;
    height: 15px !important;
  }

  #exportSlidesPanel .slide-title-option span {
    font-size: 0.66rem !important;
    line-height: 1 !important;
  }

  #exportSlidesPanel .slides-export-preview-shell {
    overflow: hidden !important;
  }

  #exportSlidesPanel .dialog-actions.compact {
    position: sticky !important;
    bottom: 0 !important;
    z-index: 12 !important;
    border: 1px solid color-mix(in srgb, var(--line) 82%, transparent) !important;
    border-radius: 12px !important;
    padding: 6px !important;
    background: color-mix(in srgb, var(--panel) 98%, #05070b) !important;
    box-shadow: 0 -10px 24px rgba(0, 0, 0, 0.24) !important;
  }

  .slides-editor-dialog.note-slide-editor .slides-line-control-panel,
  .slides-editor-dialog.note-slide-editor #slidesSentencePreviousButton,
  .slides-editor-dialog.note-slide-editor #slidesSentenceNextButton {
    display: none !important;
  }

  .slides-editor-dialog .slides-object-panel {
    display: none !important;
  }

  .slides-editor-dialog .slides-workspace-view {
    grid-template-rows: minmax(164px, 31dvh) 92px minmax(134px, 1fr) 70px !important;
  }

  .slides-editor-dialog .slides-edit-panel {
    overflow: hidden !important;
  }

  .slides-editor-dialog .slides-design-panel {
    display: grid !important;
    gap: 6px !important;
  }

  .slides-editor-dialog .slides-current-text textarea {
    min-height: 72px !important;
  }

  .bank-panel,
  .bank-header {
    touch-action: pan-y;
    -webkit-touch-callout: none;
    user-select: none;
  }

  .app-shell.mobile-library-dragging .lineup-add-actions:not([hidden]),
  .app-shell.mobile-library-settling .lineup-add-actions:not([hidden]) {
    transition: none !important;
  }

  .lineup-add-actions:not([hidden]) {
    bottom: max(
      env(safe-area-inset-bottom, 0px),
      calc(var(--lineup-add-actions-bottom, var(--mobile-library-height, var(--lineup-add-bar-bank-height, 0px))) + 10px)
    ) !important;
  }

  html.lineup-native-ios-shell .lineup-add-actions:not([hidden]) {
    bottom: max(
      env(safe-area-inset-bottom, 0px),
      calc(
        var(--lineup-add-actions-bottom, var(--mobile-library-height, var(--lineup-add-bar-bank-height, 0px)))
        + max(14px, env(safe-area-inset-bottom, 0px))
        + 8px
      )
    ) !important;
  }
}

@media (min-width: 761px) {
  .phone-export-compact-controls {
    display: none !important;
  }
}

:root[data-theme="light"] {
  color-scheme: light;
  --bg: #eef3f8;
  --panel: #ffffff;
  --panel-2: #f7f9fc;
  --panel-3: #e8eef6;
  --line: #cfd8e4;
  --line-strong: #aebdce;
  --text: #152236;
  --muted: #5f6f83;
  --soft: #7b8999;
  --green: #3c78e6;
  --green-2: #245bb8;
  --blue: #3c78e6;
  --amber: #c88705;
  --violet: #8257c2;
  --red: #c74339;
  --danger: #d83a32;
  --shadow: 0 24px 70px rgba(36, 58, 86, 0.18);
}

:root[data-skin="premium"] {
  --bg: #090908;
  --panel: #12110f;
  --panel-2: #191713;
  --panel-3: #231f18;
  --line: #3a3328;
  --line-strong: #60513b;
  --text: #fffaf0;
  --muted: #b8ac98;
  --soft: #847866;
  --green: #d6aa51;
  --green-2: #ad7d28;
  --blue: #d6aa51;
  --amber: #f0c46a;
  --violet: #8f7ddb;
  --shadow: 0 30px 95px rgba(0, 0, 0, 0.58);
}

:root[data-theme="light"][data-skin="premium"] {
  --bg: #f4efe5;
  --panel: #fffaf0;
  --panel-2: #f4ead8;
  --panel-3: #eadcc5;
  --line: #d5c3a4;
  --line-strong: #a4895c;
  --text: #221b12;
  --muted: #6c5f4d;
  --soft: #8a7b66;
  --green: #b98730;
  --green-2: #8c641f;
  --blue: #b98730;
  --amber: #d29a34;
  --violet: #745fb7;
  --shadow: 0 28px 80px rgba(96, 74, 41, 0.2);
}

:root[data-skin="playful"] {
  --bg: #071021;
  --panel: #0f1830;
  --panel-2: #152241;
  --panel-3: #1d2d54;
  --line: #30446d;
  --line-strong: #4e6fa8;
  --text: #f7fbff;
  --muted: #a9bad4;
  --soft: #7f94b7;
  --green: #40b8ff;
  --green-2: #5e7cff;
  --blue: #40b8ff;
  --amber: #ffba2e;
  --violet: #d579ff;
  --shadow: 0 28px 90px rgba(3, 9, 26, 0.5);
}

:root[data-theme="light"][data-skin="playful"] {
  --bg: #e9f3ff;
  --panel: #ffffff;
  --panel-2: #eff7ff;
  --panel-3: #dceeff;
  --line: #bdd2ed;
  --line-strong: #82a7dc;
  --text: #10223d;
  --muted: #617693;
  --soft: #7c91ad;
  --green: #4d8dff;
  --green-2: #2469db;
  --blue: #4d8dff;
  --amber: #e79900;
  --violet: #b564e6;
  --shadow: 0 28px 80px rgba(65, 111, 175, 0.19);
}

:root[data-accent="blue"] {
  --green: #5b92ff;
  --green-2: #2f68d8;
  --blue: #5b92ff;
  --accent-rgb: 91 146 255;
  --accent-secondary-rgb: 155 99 216;
  --accent-bg-dark: #08101d;
  --accent-bg-deep: #05070b;
  --accent-bg-light: #eaf2ff;
  --accent-bg-light-2: #dfeaff;
}

:root[data-accent="green"] {
  --green: #31c46b;
  --green-2: #158f48;
  --blue: #31c46b;
  --accent-rgb: 49 196 107;
  --accent-secondary-rgb: 34 199 184;
  --accent-bg-dark: #06170e;
  --accent-bg-deep: #030807;
  --accent-bg-light: #e8f8ef;
  --accent-bg-light-2: #d9f3e5;
}

:root[data-accent="yellow"] {
  --green: #f2b632;
  --green-2: #bd7d10;
  --blue: #f2b632;
  --accent-rgb: 242 182 50;
  --accent-secondary-rgb: 214 170 81;
  --accent-bg-dark: #1d1505;
  --accent-bg-deep: #080603;
  --accent-bg-light: #fff6df;
  --accent-bg-light-2: #f4e6bf;
}

:root[data-accent="teal"] {
  --green: #22c7b8;
  --green-2: #0d8f88;
  --blue: #22c7b8;
  --accent-rgb: 34 199 184;
  --accent-secondary-rgb: 64 184 255;
  --accent-bg-dark: #041817;
  --accent-bg-deep: #020908;
  --accent-bg-light: #e4fbf8;
  --accent-bg-light-2: #d3f1ef;
}

:root[data-accent="rose"] {
  --green: #f06a8c;
  --green-2: #c93e64;
  --blue: #f06a8c;
  --accent-rgb: 240 106 140;
  --accent-secondary-rgb: 166 120 255;
  --accent-bg-dark: #1d0711;
  --accent-bg-deep: #090308;
  --accent-bg-light: #fff0f4;
  --accent-bg-light-2: #f6dbe4;
}

:root[data-accent="purple"] {
  --green: #a678ff;
  --green-2: #7146d8;
  --blue: #a678ff;
  --accent-rgb: 166 120 255;
  --accent-secondary-rgb: 213 121 255;
  --accent-bg-dark: #12091e;
  --accent-bg-deep: #06030b;
  --accent-bg-light: #f3edff;
  --accent-bg-light-2: #e8ddff;
}

[hidden] {
  display: none !important;
}

* {
  box-sizing: border-box;
}

html {
  width: 100%;
  height: 100%;
  min-height: -webkit-fill-available;
  overflow: hidden;
  overscroll-behavior: none;
  background: var(--bg);
  --lineup-viewport-height: 100vh;
}

body {
  height: var(--lineup-viewport-height, 100vh);
  min-height: var(--lineup-viewport-height, 100vh);
  min-height: -webkit-fill-available;
  margin: 0;
  overflow: hidden;
  overscroll-behavior: none;
  background:
    radial-gradient(circle at 72% 20%, rgb(var(--accent-rgb) / 0.12), transparent 28rem),
    linear-gradient(135deg, color-mix(in srgb, var(--accent-bg-dark) 42%, #0c0f10) 0%, #050707 100%);
  color: var(--text);
}

@supports (height: 100dvh) {
  html {
    --lineup-viewport-height: 100dvh;
  }

  body {
    height: var(--lineup-viewport-height, 100dvh);
    min-height: var(--lineup-viewport-height, 100dvh);
  }
}

:root[data-theme="light"] body {
  background:
    radial-gradient(circle at 76% 16%, rgb(var(--accent-rgb) / 0.18), transparent 28rem),
    linear-gradient(135deg, #f9fbfe 0%, var(--accent-bg-light) 48%, var(--accent-bg-light-2) 100%);
}

:root[data-skin="premium"] body {
  background:
    radial-gradient(circle at 78% 18%, rgb(var(--accent-rgb) / 0.2), transparent 30rem),
    radial-gradient(circle at 22% 82%, rgb(var(--accent-secondary-rgb) / 0.11), transparent 24rem),
    linear-gradient(135deg, color-mix(in srgb, var(--accent-bg-dark) 58%, #15110b) 0%, #050403 100%);
}

:root[data-theme="light"][data-skin="premium"] body {
  background:
    radial-gradient(circle at 74% 14%, rgb(var(--accent-rgb) / 0.22), transparent 29rem),
    linear-gradient(135deg, #fffdf8 0%, var(--accent-bg-light) 100%);
}

:root[data-skin="playful"] body {
  background:
    radial-gradient(circle at 82% 18%, rgb(var(--accent-rgb) / 0.24), transparent 30rem),
    radial-gradient(circle at 18% 78%, rgb(var(--accent-secondary-rgb) / 0.16), transparent 26rem),
    linear-gradient(135deg, var(--accent-bg-dark) 0%, var(--accent-bg-deep) 100%);
}

:root[data-theme="light"][data-skin="playful"] body {
  background:
    radial-gradient(circle at 80% 14%, rgb(var(--accent-rgb) / 0.24), transparent 29rem),
    radial-gradient(circle at 18% 76%, rgb(var(--accent-secondary-rgb) / 0.16), transparent 24rem),
    linear-gradient(135deg, #fbfdff 0%, var(--accent-bg-light) 100%);
}

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

button {
  cursor: pointer;
}

svg {
  width: 20px;
  height: 20px;
  fill: none;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 2;
}

.app-shell {
  display: grid;
  grid-template-columns: clamp(260px, var(--bank-width, 360px), min(560px, 45vw)) 10px minmax(420px, 1fr);
  height: calc(var(--lineup-viewport-height, 100vh) - 32px);
  min-height: 0;
  margin: 16px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.09);
  border-radius: 28px;
  background: rgba(7, 10, 11, 0.92);
  box-shadow: var(--shadow);
}

@supports (height: 100dvh) {
  .app-shell {
    height: calc(var(--lineup-viewport-height, 100dvh) - 32px);
  }
}

:root[data-theme="light"] .app-shell {
  border-color: rgba(74, 94, 118, 0.24);
  background: #f2f6fb;
}

:root[data-skin="premium"] .app-shell {
  border-color: color-mix(in srgb, var(--green) 28%, transparent);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.035), transparent 18rem),
    color-mix(in srgb, var(--accent-bg-dark) 30%, rgba(8, 7, 6, 0.94));
}

:root[data-theme="light"][data-skin="premium"] .app-shell {
  background: color-mix(in srgb, var(--accent-bg-light) 42%, rgba(255, 250, 240, 0.86));
}

:root[data-skin="playful"] .app-shell {
  border-color: color-mix(in srgb, var(--green) 34%, transparent);
  background:
    linear-gradient(135deg, rgb(var(--accent-rgb) / 0.1), rgb(var(--accent-secondary-rgb) / 0.055)),
    color-mix(in srgb, var(--accent-bg-dark) 54%, rgba(6, 12, 26, 0.93));
}

:root[data-theme="light"][data-skin="playful"] .app-shell {
  background:
    linear-gradient(135deg, rgb(var(--accent-rgb) / 0.1), rgb(var(--accent-secondary-rgb) / 0.065)),
    color-mix(in srgb, var(--accent-bg-light) 34%, rgba(247, 251, 255, 0.92));
}

.app-shell.bank-collapsed {
  grid-template-columns: minmax(520px, 1fr);
}

.app-shell.bank-collapsed .bank-panel {
  display: none;
}

.app-shell.bank-collapsed .panel-resizer {
  display: none;
}

.app-shell.manage-songs-open {
  grid-template-columns: minmax(0, 1fr);
}

.app-shell.manage-songs-open .show-panel,
.app-shell.manage-songs-open .panel-resizer {
  display: none;
}

.app-shell.manage-songs-open .bank-panel {
  grid-column: 1;
  border-right: 0;
}

.panel-resizer {
  grid-column: 2;
  grid-row: 1;
  position: relative;
  z-index: 2;
  min-width: 10px;
  cursor: col-resize;
  background: transparent;
}

.panel-resizer::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 50%;
  width: 1px;
  background: var(--line);
  transform: translateX(-50%);
  transition:
    width 140ms ease,
    background 140ms ease,
    box-shadow 140ms ease;
}

.panel-resizer::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 4px;
  height: 44px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--line-strong) 65%, transparent);
  opacity: 0;
  transform: translate(-50%, -50%);
  transition: opacity 140ms ease;
}

.panel-resizer:hover::before,
.app-shell.resizing-panels .panel-resizer::before {
  width: 3px;
  background: var(--green);
  box-shadow: 0 0 18px color-mix(in srgb, var(--green) 34%, transparent);
}

.panel-resizer:hover::after,
.app-shell.resizing-panels .panel-resizer::after {
  opacity: 1;
}

body.resizing-panels {
  cursor: col-resize;
  user-select: none;
}

.rail {
  position: relative;
  z-index: 20;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 34px;
  padding: 28px 0;
  border-right: 1px solid var(--line);
  background: #060909;
  min-height: 0;
  overflow: visible;
}

:root[data-theme="light"] .rail {
  border-right-color: #c6d1dd;
  background: #e6edf5;
  box-shadow: inset -1px 0 0 rgba(255, 255, 255, 0.72);
}

:root[data-skin="premium"] .rail {
  background:
    linear-gradient(180deg, rgb(var(--accent-rgb) / 0.1), transparent 34%),
    color-mix(in srgb, var(--accent-bg-dark) 38%, #070604);
}

:root[data-theme="light"][data-skin="premium"] .rail {
  background:
    linear-gradient(180deg, rgb(var(--accent-rgb) / 0.16), transparent 38%),
    color-mix(in srgb, var(--accent-bg-light) 42%, #efe5d3);
}

:root[data-skin="playful"] .rail {
  background:
    linear-gradient(180deg, rgb(var(--accent-rgb) / 0.14), rgb(var(--accent-secondary-rgb) / 0.08)),
    color-mix(in srgb, var(--accent-bg-dark) 52%, #071023);
}

:root[data-theme="light"][data-skin="playful"] .rail {
  background:
    linear-gradient(180deg, rgb(var(--accent-rgb) / 0.16), rgb(var(--accent-secondary-rgb) / 0.09)),
    var(--accent-bg-light);
}

.brand-mark {
  display: grid;
  align-items: center;
  width: 44px;
  height: 48px;
  place-items: center;
  justify-content: center;
  color: var(--green);
}

.brand-mark svg {
  width: 44px;
  height: 44px;
  filter: drop-shadow(0 0 16px rgba(91, 146, 255, 0.26));
}

.brand-mark .mark-page,
.brand-mark .mark-fold {
  stroke: currentColor;
}

.brand-mark .mark-page {
  fill: rgba(91, 146, 255, 0.08);
}

.brand-mark .mark-fold,
.brand-mark .mark-line,
.brand-mark .mark-note {
  fill: none;
}

.brand-mark .mark-line {
  stroke: color-mix(in srgb, currentColor 74%, white);
}

.brand-mark .mark-note,
.brand-mark .mark-dot {
  stroke: var(--amber);
}

.brand-mark .mark-dot {
  fill: rgba(243, 174, 34, 0.2);
}

.lineup-intro {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: grid;
  place-items: center;
  background:
    radial-gradient(circle at 50% 42%, color-mix(in srgb, var(--green) 20%, transparent), transparent 30%),
    var(--bg);
  overflow: hidden;
}

.lineup-intro[hidden] {
  display: none !important;
  pointer-events: none;
}

body.intro-active {
  overflow: hidden;
}

body.intro-active .app-shell {
  visibility: hidden;
  opacity: 0;
  pointer-events: none;
}

body.intro-complete .app-shell {
  animation: app-shell-arrive 360ms cubic-bezier(0.2, 0.8, 0.2, 1) both;
}

.lineup-intro::before,
.lineup-intro::after {
  position: absolute;
  width: min(56vw, 620px);
  height: min(56vw, 620px);
  border-radius: 999px;
  content: "";
  filter: blur(18px);
  opacity: 0.34;
  pointer-events: none;
}

.lineup-intro::before {
  top: -18%;
  left: -10%;
  background: radial-gradient(circle, color-mix(in srgb, var(--green) 50%, transparent), transparent 68%);
  animation: intro-orbit 1200ms ease-out both;
}

.lineup-intro::after {
  right: -14%;
  bottom: -18%;
  background: radial-gradient(circle, color-mix(in srgb, var(--amber) 38%, transparent), transparent 70%);
  animation: intro-orbit 1200ms 120ms ease-out both reverse;
}

.lineup-intro-card {
  display: flex;
  align-items: center;
  gap: 14px;
  border: 1px solid color-mix(in srgb, var(--green) 28%, var(--line));
  border-radius: 22px;
  padding: 18px 22px;
  background: color-mix(in srgb, var(--panel) 92%, transparent);
  box-shadow: 0 22px 70px rgba(0, 0, 0, 0.34);
  animation: intro-pop 900ms cubic-bezier(0.19, 1, 0.22, 1) both;
}

.lineup-intro-card strong,
.lineup-intro-card span {
  display: block;
}

.lineup-intro-card strong {
  color: var(--text);
  font-size: 1.7rem;
  font-weight: 950;
  line-height: 1;
}

.lineup-intro-card span {
  margin-top: 2px;
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 850;
}

.intro-mark {
  animation: intro-mark 1100ms ease-in-out infinite alternate;
}

.lineup-intro.is-leaving {
  animation: intro-leave 420ms cubic-bezier(0.2, 0.8, 0.2, 1) forwards;
}

@keyframes intro-pop {
  from {
    opacity: 0;
    transform: translateY(14px) scale(0.96);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes intro-mark {
  from {
    transform: translateY(0);
    filter: drop-shadow(0 0 12px color-mix(in srgb, var(--green) 24%, transparent));
  }
  to {
    transform: translateY(-3px);
    filter: drop-shadow(0 0 22px color-mix(in srgb, var(--green) 42%, transparent));
  }
}

@keyframes intro-leave {
  to {
    opacity: 0;
    transform: scale(1.08);
  }
}

@keyframes intro-orbit {
  from {
    transform: translate3d(0, 0, 0) scale(0.75);
  }
  to {
    transform: translate3d(8%, -5%, 0) scale(1.08);
  }
}

@keyframes app-shell-arrive {
  from {
    opacity: 0;
    transform: translateY(8px) scale(0.992);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.bank-heading {
  display: flex;
  align-items: center;
  min-width: 0;
  gap: 10px;
}

.brand-copy {
  display: grid;
  min-width: 0;
  gap: 1px;
  line-height: 1.02;
}

.brand-copy strong {
  color: var(--text);
  font-size: 1.12rem;
  font-weight: 950;
}

.brand-copy small {
  color: var(--muted);
  font-size: 0.7rem;
  font-weight: 850;
}

.side-panel-heading {
  margin: 0 0 8px;
}

.bank-logo {
  width: 38px;
  height: 38px;
  color: var(--green);
  flex: 0 0 auto;
}

.bank-logo svg {
  width: 38px;
  height: 38px;
  filter: drop-shadow(0 0 14px color-mix(in srgb, var(--green) 30%, transparent));
}

#closeBankButton {
  display: none;
}

.rail-nav {
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: 12px;
}

.rail-button,
.icon-button {
  display: inline-grid;
  place-items: center;
  width: 48px;
  height: 48px;
  border: 1px solid transparent;
  border-radius: var(--radius);
  background: transparent;
  color: #d5dbde;
}

:root[data-theme="light"] .rail-button,
:root[data-theme="light"] .icon-button {
  color: #506175;
}

.rail-button:hover,
.icon-button:hover {
  border-color: var(--line-strong);
  background: rgba(255, 255, 255, 0.04);
}

.rail-button.active {
  border-color: var(--green);
  color: var(--green);
  box-shadow: inset 0 0 0 1px rgba(91, 146, 255, 0.14);
}

.theme-toggle .sun-icon {
  display: none;
}

:root[data-theme="light"] .theme-toggle .moon-icon {
  display: none;
}

:root[data-theme="light"] .theme-toggle .sun-icon {
  display: block;
}

.logout {
  margin-top: auto;
}

.show-panel,
.bank-panel {
  padding: 30px 26px;
  min-height: 0;
  overflow: hidden;
}

.show-panel {
  position: relative;
  container: show-panel / inline-size;
  grid-column: 3;
  display: flex;
  flex-direction: column;
  min-width: 0;
}

:root[data-theme="light"] .show-panel {
  background: linear-gradient(180deg, #ffffff 0%, #f7faff 100%);
}

:root[data-skin="premium"] .show-panel {
  background:
    radial-gradient(circle at 80% 0%, rgb(var(--accent-rgb) / 0.09), transparent 22rem),
    linear-gradient(180deg, rgba(255, 255, 255, 0.015), transparent);
}

:root[data-theme="light"][data-skin="premium"] .show-panel {
  background:
    radial-gradient(circle at 84% 0%, rgb(var(--accent-rgb) / 0.12), transparent 23rem),
    linear-gradient(180deg, #ffffff 0%, var(--accent-bg-light) 100%);
}

:root[data-skin="playful"] .show-panel {
  background:
    radial-gradient(circle at 86% 4%, rgb(var(--accent-rgb) / 0.14), transparent 24rem),
    radial-gradient(circle at 18% 96%, rgb(var(--accent-secondary-rgb) / 0.09), transparent 20rem);
}

:root[data-theme="light"][data-skin="playful"] .show-panel {
  background:
    radial-gradient(circle at 86% 4%, rgb(var(--accent-rgb) / 0.13), transparent 24rem),
    linear-gradient(180deg, #ffffff 0%, var(--accent-bg-light) 100%);
}

.bank-panel {
  position: relative;
  grid-column: 1;
  grid-row: 1;
  display: flex;
  flex-direction: column;
  min-width: 0;
  border-right: 0;
  background: rgba(16, 20, 22, 0.78);
}

.bank-panel {
  padding-inline: 22px;
}

.app-shell.bank-collapsed .show-panel {
  grid-column: 1;
}

:root[data-theme="light"] .bank-panel {
  border-right-color: #bdcad9;
  background: linear-gradient(180deg, #eef4fa 0%, #e7eef6 100%);
}

:root[data-skin="premium"] .bank-panel {
  background:
    linear-gradient(180deg, rgb(var(--accent-rgb) / 0.1), transparent 16rem),
    color-mix(in srgb, var(--accent-bg-dark) 32%, rgba(18, 17, 15, 0.88));
}

:root[data-theme="light"][data-skin="premium"] .bank-panel {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--accent-bg-light) 56%, #f4ead8) 0%, color-mix(in srgb, var(--accent-bg-light-2) 54%, #efe3cf) 100%);
}

:root[data-skin="playful"] .bank-panel {
  background:
    linear-gradient(180deg, rgb(var(--accent-rgb) / 0.14), rgb(var(--accent-secondary-rgb) / 0.065)),
    color-mix(in srgb, var(--accent-bg-dark) 54%, rgba(12, 21, 42, 0.88));
}

:root[data-theme="light"][data-skin="playful"] .bank-panel {
  background:
    linear-gradient(180deg, var(--accent-bg-light) 0%, var(--accent-bg-light-2) 100%);
}

.show-header,
.bank-header,
.dialog-header {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 4px;
}

.show-header {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  column-gap: 20px;
  margin-bottom: 12px;
  padding-bottom: 12px;
}

.show-header::after {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  height: 1px;
  border-radius: 999px;
  background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--green) 44%, transparent), color-mix(in srgb, var(--amber) 22%, transparent), transparent);
  box-shadow: 0 0 14px color-mix(in srgb, var(--green) 26%, transparent);
  content: "";
  pointer-events: none;
}

.bank-header {
  justify-content: flex-start;
}

.lineup-overview {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  align-items: stretch;
  gap: 12px;
  margin-bottom: 12px;
}

.lineup-health-bar {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  min-width: 0;
}

.health-chip {
  display: grid;
  align-content: center;
  min-width: 0;
  min-height: 52px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 8px 10px;
  background: rgba(255, 255, 255, 0.035);
}

.health-chip.primary {
  border-color: color-mix(in srgb, var(--green) 42%, var(--line));
  background: color-mix(in srgb, var(--green) 12%, transparent);
}

.health-chip.good {
  border-color: rgba(57, 196, 132, 0.32);
  background: rgba(57, 196, 132, 0.09);
}

.health-chip.warning {
  border-color: rgba(243, 174, 34, 0.34);
  background: rgba(243, 174, 34, 0.1);
}

.health-chip strong {
  font-size: 0.95rem;
  font-weight: 900;
  line-height: 1.08;
}

.health-chip span {
  overflow: hidden;
  color: var(--muted);
  font-size: 0.66rem;
  font-weight: 850;
  line-height: 1.2;
  text-overflow: ellipsis;
  text-transform: uppercase;
  white-space: nowrap;
}

.lineup-mode-switch {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 5px;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 4px;
  background: color-mix(in srgb, var(--panel-2) 72%, transparent);
}

.lineup-mode-button {
  display: grid;
  align-content: center;
  min-width: 0;
  min-height: 46px;
  border: 0;
  border-radius: 8px;
  padding: 7px 10px;
  color: var(--muted);
  background: transparent;
  text-align: left;
}

.lineup-mode-button.active {
  color: var(--text);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--green) 20%, transparent), color-mix(in srgb, var(--green) 9%, transparent));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--green) 36%, transparent);
}

.lineup-mode-button span {
  overflow: hidden;
  font-size: 0.88rem;
  font-weight: 900;
  line-height: 1.15;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.lineup-mode-button small {
  overflow: hidden;
  color: var(--soft);
  font-size: 0.66rem;
  font-weight: 760;
  line-height: 1.2;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.lineup-mode-button.active small {
  color: color-mix(in srgb, var(--text) 74%, var(--muted));
}

.bank-title-actions {
  position: relative;
  display: flex;
  align-items: center;
  flex: 0 0 auto;
  gap: 8px;
  margin-left: auto;
}

.bank-title-actions .icon-button {
  width: 36px;
  height: 36px;
  min-height: 36px;
  border-radius: 10px;
}

.bank-title-actions .icon-button svg {
  width: 18px;
  height: 18px;
}

.quick-add-menu-popover {
  position: absolute;
  top: calc(100% + 8px);
  right: 104px;
  z-index: 54;
  display: grid;
  gap: 6px;
  width: min(210px, calc(100vw - 28px));
  border: 1px solid color-mix(in srgb, var(--line-strong) 82%, transparent);
  border-radius: 12px;
  padding: 7px;
  background: color-mix(in srgb, var(--panel) 96%, transparent);
  box-shadow: 0 18px 48px rgba(0, 0, 0, 0.36);
}

.quick-add-menu-popover.is-floating {
  position: fixed;
  right: auto;
  z-index: 10050;
  max-height: min(260px, calc(100dvh - 24px));
  overflow: auto;
  overscroll-behavior: contain;
}

.quick-add-menu-popover[hidden] {
  display: none;
}

:root[data-theme="light"] .quick-add-menu-popover {
  background: #ffffff;
  box-shadow: 0 18px 42px rgba(40, 58, 82, 0.16);
}

.quick-add-menu-item {
  display: grid;
  grid-template-columns: 24px minmax(0, 1fr);
  align-items: center;
  gap: 9px;
  min-height: 38px;
  border: 0;
  border-radius: 9px;
  padding: 0 10px;
  background: transparent;
  color: var(--text);
  font-size: 0.84rem;
  font-weight: 850;
  text-align: left;
}

.quick-add-menu-item:hover,
.quick-add-menu-item:focus-visible {
  background: color-mix(in srgb, var(--green) 12%, transparent);
  outline: none;
}

.quick-add-menu-item svg {
  width: 18px;
  height: 18px;
  fill: none;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 2;
}

.manage-songs-button {
  position: relative;
}

.manage-songs-button.active {
  border-color: color-mix(in srgb, var(--green) 48%, var(--line));
  color: var(--green);
  background: color-mix(in srgb, var(--green) 12%, transparent);
}

.manage-songs-button .manage-close-icon,
.manage-songs-button.active .manage-open-icon {
  display: none;
}

.manage-songs-button.active .manage-close-icon {
  display: block;
}

.library-add-note-button {
  position: relative;
  flex: 0 0 auto;
  width: 40px;
  height: 40px;
  min-width: 40px;
  min-height: 40px;
  border-color: color-mix(in srgb, var(--amber) 52%, var(--line));
  color: var(--amber);
  background: color-mix(in srgb, var(--amber) 12%, transparent);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--amber) 10%, transparent);
}

.library-add-note-button > svg:first-child {
  width: 21px;
  height: 21px;
  fill: none;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 2;
}

.library-add-note-button .note-plus-icon {
  position: absolute;
  right: 4px;
  bottom: 4px;
  width: 17px;
  height: 17px;
  border: 1px solid color-mix(in srgb, var(--green) 68%, var(--panel));
  border-radius: 999px;
  padding: 1px;
  background: var(--panel);
  color: var(--green);
}

.side-panel-view {
  display: flex;
  flex: 1;
  flex-direction: column;
  min-height: 0;
  padding-bottom: 0;
}

.side-panel-view[hidden] {
  display: none;
}

.shows-view {
  gap: 12px;
}

.bank-panel.shows-mode .shows-view {
  padding-top: 2px;
}

.eyebrow {
  margin: 0 0 4px;
  color: var(--green);
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0;
  text-transform: uppercase;
}

h1,
h2 {
  margin: 0;
  line-height: 1.1;
}

h1 {
  font-size: clamp(2rem, 4vw, 3.1rem);
}

h2 {
  font-size: 1.45rem;
}

.show-title-input {
  width: auto;
  max-width: 100%;
  height: auto;
  min-height: 48px;
  flex: 1 1 0;
  min-width: 0;
  border-color: transparent;
  background: transparent;
  padding: 0;
  color: var(--text);
  font-size: clamp(2rem, 4vw, 3.1rem);
  font-weight: 900;
  line-height: 1.1;
}

.show-title-input:hover,
.show-title-input:focus {
  border-color: var(--line-strong);
  background: rgba(255, 255, 255, 0.035);
  padding: 0 12px;
  box-shadow: none;
}

:root[data-theme="light"] .show-title-input:hover,
:root[data-theme="light"] .show-title-input:focus {
  background: #f2f6fb;
}

.setlist-title-menu {
  position: relative;
  flex: 0 0 auto;
  align-self: center;
  margin-left: -6px;
}

.setlist-title-menu summary {
  list-style: none;
}

.setlist-title-menu summary::-webkit-details-marker {
  display: none;
}

.setlist-title-menu-button {
  position: relative;
  display: inline-grid;
  place-items: center;
  width: 34px;
  min-width: 34px;
  height: 34px;
  min-height: 34px;
  border-color: color-mix(in srgb, var(--line-strong) 78%, transparent);
  border-radius: 10px;
  padding: 0;
  color: color-mix(in srgb, var(--text) 82%, var(--muted));
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.014)),
    color-mix(in srgb, var(--panel-2) 74%, transparent);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.07),
    0 8px 18px rgba(0, 0, 0, 0.16);
}

.setlist-title-menu-button svg {
  display: none;
}

.setlist-title-menu-button::before {
  content: "";
  width: 0;
  height: 0;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-top: 6px solid currentColor;
  color: currentColor;
  transform: translateY(1px);
  transition: transform 0.16s ease;
}

.setlist-title-menu[open] .setlist-title-menu-button {
  border-color: color-mix(in srgb, var(--green) 42%, var(--line));
  color: var(--green);
  background: color-mix(in srgb, var(--green) 12%, transparent);
}

.setlist-title-menu[open] .setlist-title-menu-button::before {
  transform: translateY(0) rotate(180deg);
}

.setlist-title-menu-popover {
  position: absolute;
  top: calc(100% + 8px);
  left: -10px;
  z-index: 72;
  display: grid;
  gap: 6px;
  width: 204px;
  border: 1px solid var(--line-strong);
  border-radius: var(--radius);
  padding: 8px;
  background: rgba(16, 20, 22, 0.98);
  box-shadow: var(--shadow);
}

:root[data-theme="light"] .setlist-title-menu-popover {
  border-color: #b9c7d8;
  background: rgba(248, 251, 255, 0.98);
}

.setlist-title-menu-item {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  width: 100%;
  min-height: 40px;
  border: 1px solid transparent;
  border-radius: 10px;
  padding: 0 10px;
  color: var(--text);
  background: transparent;
  font-size: 0.9rem;
  font-weight: 760;
  text-align: left;
}

.setlist-title-menu-item:hover,
.setlist-title-menu-item:focus-visible {
  border-color: var(--line);
  background: rgba(255, 255, 255, 0.055);
}

:root[data-theme="light"] .setlist-title-menu-item:hover,
:root[data-theme="light"] .setlist-title-menu-item:focus-visible {
  background: #edf4fb;
}

.setlist-title-menu-item svg {
  width: 18px;
  height: 18px;
  flex: 0 0 auto;
}

.setlist-title-menu-item.danger {
  color: var(--danger);
}

.setlist-title-menu-item.delete-armed {
  border-color: color-mix(in srgb, var(--danger) 46%, var(--line));
  color: #ffd6d2;
  background: color-mix(in srgb, var(--danger) 18%, transparent);
}

.show-title-block {
  min-width: 0;
  flex: 1;
  display: grid;
  align-content: start;
}

.show-title-row {
  display: flex;
  align-items: center;
  flex-wrap: nowrap;
  min-width: 0;
  gap: 12px;
}

.show-date-inline {
  width: 152px;
  height: 44px;
  margin-top: 0;
  flex: 0 0 auto;
}

.show-tools {
  display: flex;
  flex: 0 0 auto;
  flex-direction: column;
  align-items: flex-end;
  align-self: center;
  gap: 8px;
  padding-top: 0;
}

.header-actions,
.dialog-actions,
.row-actions {
  display: flex;
  align-items: center;
  gap: 10px;
}

.history-button.limited {
  border-color: color-mix(in srgb, var(--amber) 46%, var(--line));
  color: var(--amber);
}

.header-menu {
  position: relative;
}

.header-menu summary {
  list-style: none;
}

.header-menu summary::-webkit-details-marker {
  display: none;
}

.header-menu-popover {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  z-index: 4;
  display: grid;
  gap: 6px;
  width: 172px;
  border: 1px solid var(--line-strong);
  border-radius: var(--radius);
  padding: 8px;
  background: rgba(16, 20, 22, 0.98);
  box-shadow: var(--shadow);
}

:root[data-theme="light"] .header-menu-popover {
  border-color: #b9c7d8;
  background: rgba(248, 251, 255, 0.98);
}

.header-menu-popover .top-icon-button {
  width: 100%;
  justify-content: flex-start;
  min-height: 40px;
  padding: 0 10px;
}

.header-menu-popover .top-icon-button span {
  display: inline;
  color: var(--text);
  font-size: 0.9rem;
  font-weight: 760;
}

.header-menu-popover .mobile-theme-menu-button {
  display: none;
}

.header-menu-popover #slidePreviewMenuButton {
  display: none;
}

@media (min-width: 761px) {
  .header-menu-popover #presentationMenuButton {
    min-height: 48px;
    border-color: color-mix(in srgb, var(--green) 48%, var(--line));
    color: var(--text);
    background: color-mix(in srgb, var(--green) 14%, var(--panel-2));
  }

  .header-menu-popover #presentationMenuButton svg {
    width: 24px;
    height: 24px;
    color: var(--green);
    stroke-width: 2.35;
  }

  .header-menu-popover #presentationMenuButton span {
    font-size: 0.96rem;
    font-weight: 950;
  }
}

@media (min-width: 761px) and (max-width: 1420px) {
  .show-header {
    grid-template-columns: minmax(0, 1fr);
    align-items: start;
    row-gap: 10px;
  }

  .show-tools {
    justify-self: end;
    align-items: flex-end;
  }
}

@container show-panel (max-width: 1220px) {
  .show-header {
    grid-template-columns: minmax(0, 1fr);
    align-items: start;
    row-gap: 10px;
  }

  .show-tools {
    justify-self: end;
    align-items: flex-end;
  }
}

body:not(.installed-app-shell) .app-home-menu-item {
  display: none;
}

body.installed-app-shell .app-home-menu-item {
  display: flex;
}

body.installed-app-shell .home-link-bottom {
  display: none !important;
}

.mobile-show-symbol,
.mobile-menu-action {
  display: none;
}

.primary-button,
.ghost-button,
.outline-button,
.danger-button,
.mini-button,
.add-slot-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 44px;
  border-radius: var(--radius);
  border: 1px solid var(--line-strong);
  padding: 0 18px;
  color: var(--text);
  background: var(--panel-2);
  text-decoration: none;
}

.primary-button {
  border-color: rgba(91, 146, 255, 0.38);
  background: linear-gradient(180deg, #50d99a, #2dae78);
  color: #06120d;
  font-weight: 800;
}

:root[data-theme="light"] .primary-button {
  border-color: rgba(60, 120, 230, 0.35);
  background: linear-gradient(180deg, #6fa0ff, #3c78e6);
  color: #071428;
}

:root[data-skin="premium"] .primary-button {
  border-color: color-mix(in srgb, var(--green) 56%, transparent);
  background: linear-gradient(180deg, #e8c679, #b98730);
  box-shadow: 0 12px 30px rgba(185, 135, 48, 0.22);
}

:root[data-skin="playful"] .primary-button {
  border-color: color-mix(in srgb, var(--green) 56%, transparent);
  background: linear-gradient(135deg, var(--green), var(--green-2));
  box-shadow: 0 12px 30px rgba(64, 184, 255, 0.24);
}

.top-icon-button,
.export-file-button {
  width: 48px;
  min-width: 48px;
  min-height: 44px;
  padding: 0;
}

.shows-tab-button {
  width: 48px;
  min-width: 48px;
  justify-content: center;
  padding: 0;
}

.shows-tab-button.active {
  border-color: var(--green);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--green) 28%, transparent);
}

.top-icon-button.is-active {
  border-color: var(--green);
  color: var(--text);
  background: color-mix(in srgb, var(--green) 18%, var(--panel-2));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--green) 30%, transparent);
}

.home-link-bottom {
  position: absolute;
  bottom: 22px;
  left: 26px;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 0 14px;
  color: var(--muted);
  background: color-mix(in srgb, var(--panel) 88%, transparent);
  font-size: 0.82rem;
  font-weight: 850;
  text-decoration: none;
  gap: 6px;
}

.home-link-bottom svg {
  width: 15px;
  height: 15px;
  stroke: currentColor;
  stroke-width: 2.2;
  fill: none;
}

.home-link-bottom:hover {
  border-color: var(--green);
  color: var(--text);
}

.home-link-bottom.manage-back-link {
  color: var(--text);
}

.home-link-bottom.manage-back-link span {
  white-space: nowrap;
}

.export-file-button {
  width: auto;
  min-width: 62px;
  min-height: 36px;
  padding: 0 9px;
  gap: 6px;
  border-radius: 10px;
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0;
}

.export-print-button {
  width: auto;
  min-width: 74px;
}

.top-icon-button svg,
.export-file-button svg {
  width: 18px;
  height: 18px;
}

#slidePreviewToggle svg,
#slidesEditorPreviewButton svg {
  width: 22px;
  height: 22px;
  stroke-width: 2.35;
}

.ghost-button:hover,
.outline-button:hover,
.mini-button:hover {
  border-color: var(--green);
}

:root[data-theme="light"] .ghost-button,
:root[data-theme="light"] .outline-button,
:root[data-theme="light"] .mini-button,
:root[data-theme="light"] .add-slot-button {
  border-color: #b9c7d8;
  background: #f5f8fc;
}

:root[data-theme="light"] .ghost-button:hover,
:root[data-theme="light"] .outline-button:hover,
:root[data-theme="light"] .mini-button:hover {
  background: #ffffff;
}

.danger-button {
  border-color: rgba(219, 89, 79, 0.45);
  color: #ffd6d2;
  background: rgba(219, 89, 79, 0.12);
}

.outline-button {
  width: 100%;
  margin-top: 12px;
  border-color: var(--green-2);
  color: var(--green);
  background: transparent;
  font-weight: 750;
}

.saved-shows-menu {
  position: relative;
}

.saved-shows-menu summary {
  list-style: none;
}

.saved-shows-menu summary::-webkit-details-marker {
  display: none;
}

.shows-menu-button {
  width: auto;
  max-width: 230px;
  min-height: 44px;
  padding: 0 12px;
}

.shows-menu-button span {
  color: var(--text);
  font-weight: 800;
}

.shows-menu-button small {
  overflow: hidden;
  max-width: 110px;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 760;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.rail .shows-menu-button {
  width: 48px;
  max-width: 48px;
  min-height: 48px;
  padding: 0;
}

.rail .shows-menu-button span,
.rail .shows-menu-button small {
  display: none;
}

.saved-shows-popover {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  z-index: 5;
  width: min(360px, calc(100vw - 40px));
  border: 1px solid var(--line-strong);
  border-radius: var(--radius);
  padding: 10px;
  background: rgba(16, 20, 22, 0.98);
  box-shadow: var(--shadow);
}

.rail .saved-shows-popover {
  top: 0;
  right: auto;
  left: calc(100% + 14px);
  z-index: 30;
}

:root[data-theme="light"] .saved-shows-popover {
  border-color: #b9c7d8;
  background: rgba(248, 251, 255, 0.98);
}

.saved-shows-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 8px;
}

.saved-shows-header h2 {
  font-size: 0.95rem;
}

.saved-show-actions {
  display: flex;
  gap: 6px;
}

.setlist-action-bar {
  flex-wrap: wrap;
  justify-content: flex-end;
  margin-bottom: 4px;
}

.setlist-selection-bar {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
  border: 1px solid color-mix(in srgb, var(--green) 38%, var(--line));
  border-radius: calc(var(--radius) + 2px);
  padding: 8px;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--green) 10%, transparent), transparent 70%),
    var(--panel-soft);
}

.setlist-selection-bar[hidden] {
  display: none;
}

.setlist-selection-bar span {
  color: var(--text);
  font-size: 0.78rem;
  font-weight: 900;
  white-space: nowrap;
}

.setlist-selection-hint {
  min-width: 0;
  overflow: hidden;
  color: var(--muted) !important;
  font-weight: 760 !important;
  text-overflow: ellipsis;
}

.saved-shows-list {
  display: grid;
  flex: 1;
  align-content: start;
  gap: 6px;
  min-height: 0;
  max-width: 100%;
  max-height: none;
  overflow: auto;
}

.setlist-folder-section {
  display: grid;
  gap: 5px;
  border: 1px solid color-mix(in srgb, var(--line) 80%, transparent);
  border-radius: var(--radius);
  padding: 6px;
  background: rgba(255, 255, 255, 0.022);
  transition: border-color 140ms ease, background 140ms ease, box-shadow 140ms ease;
}

.setlist-folder-section.active,
.setlist-folder-section.drag-over,
.setlist-folder-header.drag-over {
  border-color: color-mix(in srgb, var(--green) 70%, var(--line));
  background: color-mix(in srgb, var(--green) 11%, transparent);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--green) 18%, transparent);
}

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

.setlist-folder-header-actions {
  display: flex;
  align-items: center;
  gap: 6px;
  min-width: 0;
}

.setlist-folder-toggle {
  display: grid;
  grid-template-columns: 18px 22px minmax(0, 1fr) auto;
  align-items: center;
  gap: 7px;
  min-width: 0;
  min-height: 36px;
  border: 0;
  padding: 0 4px;
  color: var(--text);
  background: transparent;
  text-align: left;
}

.setlist-folder-toggle span {
  overflow: hidden;
  margin: 0;
  color: inherit;
  font-size: 0.84rem;
  font-weight: 950;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.setlist-folder-toggle small {
  color: var(--muted);
  font-size: 0.68rem;
  font-weight: 820;
  white-space: nowrap;
}

.setlist-folder-toggle svg {
  width: 18px;
  height: 18px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
}

.setlist-folder-icon {
  color: var(--green);
}

.setlist-folder-child-button,
.setlist-folder-move-selected {
  min-height: 30px;
  border: 1px solid color-mix(in srgb, var(--green) 48%, var(--line));
  border-radius: 9px;
  color: var(--text);
  background: color-mix(in srgb, var(--green) 13%, transparent);
  font-size: 0.72rem;
  font-weight: 880;
  white-space: nowrap;
}

.setlist-folder-child-button {
  display: grid;
  place-items: center;
  width: 32px;
  min-width: 32px;
  padding: 0;
}

.setlist-folder-child-button svg {
  width: 17px;
  height: 17px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
}

.setlist-folder-move-selected {
  padding: 0 9px;
}

.setlist-folder-items {
  display: grid;
  gap: 5px;
  padding-left: 20px;
}

.setlist-folder-section.nested {
  background: color-mix(in srgb, var(--panel) 88%, transparent);
}

.setlist-folder-empty {
  border: 1px dashed color-mix(in srgb, var(--line) 80%, transparent);
  border-radius: 10px;
  padding: 8px 10px;
  color: var(--muted);
  font-size: 0.74rem;
  font-weight: 760;
}

.saved-show-chip {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 8px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 8px 10px;
  color: var(--text);
  background: rgba(255, 255, 255, 0.035);
  text-align: left;
  transition: border-color 150ms ease, background 150ms ease, box-shadow 150ms ease;
}

.saved-show-chip.dragging {
  opacity: 0.58;
}

.saved-show-open {
  display: grid;
  min-width: 0;
  border: 0;
  padding: 0;
  color: inherit;
  background: transparent;
  text-align: left;
}

.setlist-select {
  display: inline-grid;
  place-items: center;
  width: 18px;
  opacity: 1;
  overflow: hidden;
  transition: width 150ms ease, opacity 150ms ease;
}

.setlist-select input {
  width: 18px;
  height: 18px;
  margin: 0;
}

.saved-show-chip span {
  overflow: hidden;
  font-weight: 850;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.saved-show-chip small {
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 700;
}

.saved-show-chip.active {
  border-color: var(--green);
  box-shadow: inset 0 0 0 1px rgba(91, 146, 255, 0.2);
}

.saved-show-chip.selected {
  border-color: color-mix(in srgb, var(--green) 70%, var(--line));
  background: color-mix(in srgb, var(--green) 13%, transparent);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--green) 22%, transparent);
}

label span {
  display: block;
  margin-bottom: 7px;
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 700;
}

input,
select,
textarea {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.035);
  color: var(--text);
  outline: none;
}

:root[data-theme="light"] input,
:root[data-theme="light"] select,
:root[data-theme="light"] textarea {
  border-color: #bfccd9;
  background: #ffffff;
}

input,
select {
  height: 44px;
  padding: 0 12px;
}

textarea {
  resize: vertical;
  padding: 12px;
}

input:focus,
select:focus,
textarea:focus {
  border-color: var(--green);
  box-shadow: 0 0 0 3px rgba(91, 146, 255, 0.12);
}

.lineup-table {
  display: flex;
  flex: 1 1 auto;
  flex-direction: column;
  min-width: 0;
  min-height: 0;
  overflow: hidden;
  transition: margin-right 180ms ease;
}

.show-panel.slide-preview-open .lineup-table {
  margin-right: calc(min(300px, 28vw) + 18px);
}

.lineup-next-steps {
  display: grid;
  gap: 8px;
  flex: 0 0 auto;
  margin-top: 10px;
  margin-bottom: 42px;
}

.lineup-add-actions {
  display: flex;
  flex: 0 0 auto;
  justify-content: flex-end;
  align-items: center;
  gap: 8px;
  padding: 10px 4px 0;
}

.lineup-add-actions .icon-button {
  width: auto;
  min-width: 82px;
  height: 40px;
  min-height: 40px;
  border-radius: 10px;
  gap: 6px;
  padding: 0 10px;
  font-size: 0.68rem;
  line-height: 1;
}

.lineup-add-actions .icon-button span {
  display: inline-flex;
  align-items: center;
  white-space: nowrap;
  font-size: 0.68rem;
  font-weight: 850;
  letter-spacing: 0;
}

.lineup-add-actions .icon-button .add-action-icon-stack {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 19px;
  width: 19px;
  height: 19px;
  margin-right: 1px;
  font-size: 0;
  line-height: 0;
}

.lineup-add-actions .lineup-add-slide-button .add-action-main-icon,
.lineup-add-actions .library-add-note-button .add-action-main-icon {
  width: 16px;
  height: 16px;
}

.lineup-add-actions .add-action-plus-icon,
.lineup-add-actions .library-add-note-button .note-plus-icon {
  position: absolute;
  top: -3px;
  right: -4px;
  display: block;
  width: 11px;
  height: 11px;
  margin: 0;
  border: 1.35px solid currentColor;
  border-radius: 999px;
  padding: 0;
  background: color-mix(in srgb, var(--panel) 86%, currentColor);
  color: var(--green);
  stroke-width: 2.8;
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--panel) 82%, transparent);
}

.lineup-add-slide-button {
  border-color: color-mix(in srgb, var(--green) 48%, var(--line));
  color: var(--green);
  background: color-mix(in srgb, var(--green) 11%, transparent);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--green) 9%, transparent);
}

@media (pointer: coarse) {
  .bank-panel.is-dragging,
  .app-shell.bank-collapsed .bank-panel {
    touch-action: none;
    user-select: none;
  }
}

.lineup-summary-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 14px;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 12px 14px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.025));
}

:root[data-theme="light"] .lineup-summary-card {
  border-color: #c9d5e2;
  background: linear-gradient(180deg, #ffffff, #f5f8fc);
}

.lineup-summary-card .eyebrow {
  margin: 0 0 4px;
}

.lineup-summary-card h2 {
  margin: 0;
  overflow: hidden;
  font-size: 1rem;
  line-height: 1.15;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.lineup-summary-card p {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 0.82rem;
  line-height: 1.35;
}

.lineup-summary-stats {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 6px;
  max-width: 340px;
}

.lineup-summary-stats span {
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 5px 8px;
  color: var(--muted);
  background: rgba(255, 255, 255, 0.035);
  font-size: 0.7rem;
  font-weight: 820;
  white-space: nowrap;
}

.lineup-summary-stats span.good {
  border-color: rgba(57, 196, 132, 0.32);
  color: color-mix(in srgb, #39c484 82%, var(--text));
  background: rgba(57, 196, 132, 0.09);
}

.lineup-summary-stats span.warning {
  border-color: rgba(243, 174, 34, 0.34);
  color: color-mix(in srgb, var(--amber) 88%, var(--text));
  background: rgba(243, 174, 34, 0.1);
}

.lineup-step-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.lineup-step {
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 9px 10px;
  background: rgba(255, 255, 255, 0.028);
}

.lineup-step.primary {
  border-color: color-mix(in srgb, var(--green) 34%, var(--line));
}

.lineup-step.warning {
  border-color: rgba(243, 174, 34, 0.34);
}

.lineup-step.good {
  border-color: rgba(57, 196, 132, 0.32);
}

.lineup-step strong,
.lineup-step span {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.lineup-step strong {
  color: var(--text);
  font-size: 0.78rem;
  font-weight: 900;
}

.lineup-step span {
  margin-top: 3px;
  color: var(--muted);
  font-size: 0.7rem;
}

.slide-preview-panel {
  position: absolute;
  top: 124px;
  right: 22px;
  bottom: 72px;
  z-index: 4;
  display: flex;
  width: min(300px, 28vw);
  min-width: 240px;
  flex-direction: column;
  gap: 12px;
  border: 1px solid var(--line-strong);
  border-radius: 18px;
  padding: 14px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--panel-2) 95%, transparent), color-mix(in srgb, var(--panel) 94%, transparent));
  box-shadow: 0 22px 70px rgba(0, 0, 0, 0.36);
  backdrop-filter: blur(18px);
}

.slide-preview-panel[hidden] {
  display: none;
}

.slide-preview-header,
.slide-preview-controls {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.slide-preview-header h2 {
  margin: 0;
  font-size: 1.05rem;
}

.slide-preview-header .eyebrow {
  margin: 0 0 2px;
}

.slide-preview-stage {
  display: grid;
  flex: 0 0 auto;
  min-height: 150px;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  place-items: center;
  border: 1px solid color-mix(in srgb, var(--green) 26%, var(--line));
  border-radius: 14px;
  padding: 10px;
  background: #05070b;
}

.mini-slide {
  position: relative;
  display: flex;
  width: 100%;
  height: 100%;
  flex-direction: column;
  justify-content: center;
  gap: 7px;
  overflow: hidden;
  border-radius: 10px;
  padding: 14px;
  color: #f8fafc;
  background:
    radial-gradient(circle at 22% 12%, rgba(91, 146, 255, 0.22), transparent 34%),
    linear-gradient(145deg, #07111f, #020407);
  text-align: center;
}

.mini-slide.has-title .mini-slide-lines {
  padding-top: 10px;
}

.mini-slide.note {
  background:
    radial-gradient(circle at 20% 15%, rgba(243, 174, 34, 0.2), transparent 34%),
    linear-gradient(145deg, #1b1205, #050403);
}

.mini-slide.theme-warm {
  background:
    radial-gradient(circle at 20% 14%, rgba(245, 181, 43, 0.24), transparent 35%),
    radial-gradient(circle at 85% 80%, rgba(61, 132, 105, 0.2), transparent 34%),
    linear-gradient(145deg, #211007, #05070b 70%);
}

.mini-slide.theme-bright {
  color: #0f172a;
  background:
    radial-gradient(circle at 20% 18%, rgba(91, 146, 255, 0.14), transparent 34%),
    linear-gradient(145deg, #fffaf2, #eef6f3);
}

.mini-slide.theme-bright .mini-slide-meta,
.mini-slide.theme-bright small,
.mini-slide.theme-bright strong {
  color: rgba(15, 23, 42, 0.56);
}

.mini-slide.theme-bright .mini-slide-lines {
  color: rgba(15, 23, 42, 0.9);
}

.mini-slide.missing {
  background:
    radial-gradient(circle at 50% 20%, rgba(155, 165, 170, 0.16), transparent 36%),
    linear-gradient(145deg, #111820, #050607);
}

.mini-slide.image {
  padding: 0;
  background: #05070b;
}

.mini-slide-image {
  position: absolute;
  inset: 0;
  background-position: center;
  background-size: cover;
}

.mini-slide.empty {
  color: var(--text);
  background: color-mix(in srgb, var(--panel-3) 80%, var(--panel));
}

.mini-slide-meta {
  position: absolute;
  top: 9px;
  left: 10px;
  max-width: calc(100% - 20px);
  overflow: hidden;
  color: rgba(248, 250, 252, 0.58);
  font-size: 0.58rem;
  font-weight: 850;
  text-overflow: ellipsis;
  text-transform: uppercase;
  white-space: nowrap;
}

.mini-slide strong {
  position: absolute;
  top: 10px;
  left: 42px;
  right: 42px;
  display: block;
  overflow: hidden;
  color: rgba(248, 250, 252, 0.66);
  font-size: 0.62rem;
  font-weight: 900;
  letter-spacing: 0.06em;
  line-height: 1;
  text-overflow: ellipsis;
  text-transform: uppercase;
  white-space: nowrap;
}

.mini-slide-lines {
  display: grid;
  gap: 3px;
  color: rgba(248, 250, 252, 0.9);
  font-size: clamp(0.72rem, var(--mini-slide-font-size, 1vw), 1.05rem);
  font-weight: 700;
  line-height: 1.1;
}

.mini-slide-lines span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.mini-slide small {
  position: absolute;
  right: 10px;
  bottom: 7px;
  color: rgba(248, 250, 252, 0.45);
  font-size: 0.42rem;
  font-weight: 700;
  text-align: right;
}

.slide-preview-controls {
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 5px;
  background: color-mix(in srgb, var(--panel) 84%, transparent);
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 850;
}

.slide-preview-controls .icon-button {
  width: 34px;
  min-width: 34px;
  height: 30px;
  min-height: 30px;
  border: 0;
  background: transparent;
}

.slide-preview-controls .icon-button:disabled {
  cursor: default;
  opacity: 0.35;
}

.slides-editor-dialog {
  width: min(1180px, calc(100vw - 32px));
  max-width: none;
  max-height: calc(var(--lineup-viewport-height, 100dvh) - 32px);
  border: 1px solid var(--line-strong);
  border-radius: 24px;
  padding: 0;
  overflow: hidden;
  color: var(--text);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--panel-2) 94%, transparent), color-mix(in srgb, var(--panel) 98%, transparent));
  box-shadow: 0 30px 90px rgba(0, 0, 0, 0.48);
}

.slides-editor-dialog::backdrop {
  background: rgba(2, 6, 23, 0.72);
  backdrop-filter: blur(8px);
}

.slides-editor-shell {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  max-height: calc(var(--lineup-viewport-height, 100dvh) - 32px);
  min-height: min(720px, calc(var(--lineup-viewport-height, 100dvh) - 32px));
}

.slides-editor-header {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto auto auto auto;
  grid-template-areas: "back title status preview delete ready";
  align-items: center;
  gap: 12px;
  border-bottom: 1px solid var(--line);
  padding: 14px 16px;
  background: color-mix(in srgb, var(--panel-3) 54%, transparent);
}

#slidesEditorBackButton {
  grid-area: back;
}

.slides-editor-title-block {
  grid-area: title;
  min-width: 0;
}

.slides-editor-title-block .eyebrow {
  margin: 0 0 3px;
}

.slides-editor-title-block h2 {
  margin: 0;
  overflow: hidden;
  font-size: clamp(1.15rem, 2vw, 1.55rem);
  line-height: 1.05;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.slides-save-scope {
  grid-area: scope;
  display: grid;
  gap: 4px;
  min-width: 128px;
  justify-self: start;
}

.slides-save-scope span {
  color: var(--muted);
  font-size: 0.58rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.slides-save-scope select {
  height: 34px;
  min-height: 34px;
  border-radius: 9px;
  padding: 0 9px;
  font-size: 0.78rem;
  font-weight: 850;
}

.slides-editor-status {
  grid-area: status;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  justify-self: end;
  min-height: 30px;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 0 11px;
  color: var(--muted);
  background: rgba(255, 255, 255, 0.04);
  font-size: 0.72rem;
  font-weight: 850;
  text-transform: uppercase;
  white-space: nowrap;
}

.slides-editor-status.ready {
  border-color: color-mix(in srgb, var(--green) 72%, white);
  color: #dfffe8;
  background: color-mix(in srgb, var(--green) 18%, transparent);
}

.slides-editor-status.review {
  border-color: color-mix(in srgb, var(--amber) 64%, white);
  color: #ffe5a6;
  background: color-mix(in srgb, var(--amber) 17%, transparent);
}

.slides-editor-status.empty {
  border-color: color-mix(in srgb, var(--line) 80%, white);
}

.slides-editor-header .ghost-button,
.slides-editor-header .primary-button {
  min-height: 38px;
  padding: 0 13px;
}

.slides-editor-header .slides-editor-export {
  grid-area: preview;
}

.slides-editor-header .slides-editor-present {
  grid-area: present;
}

.slides-editor-header .slides-editor-delete-all {
  grid-area: delete;
  justify-self: end;
}

.slides-editor-header .slides-editor-ready {
  grid-area: ready;
  justify-self: end;
}

.slides-editor-header .slides-editor-delete-all {
  border-color: color-mix(in srgb, var(--danger) 52%, var(--line));
  color: color-mix(in srgb, var(--danger) 86%, white);
}

.slides-editor-header .slides-editor-delete-all:hover,
.slides-editor-header .slides-editor-delete-all:focus-visible {
  background: color-mix(in srgb, var(--danger) 14%, transparent);
}

.slides-decision-dialog {
  width: min(420px, calc(100vw - 28px));
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 0;
  color: var(--text);
  background: color-mix(in srgb, var(--panel) 96%, black);
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.46);
}

.slides-decision-dialog::backdrop {
  background: rgba(2, 6, 23, 0.56);
  backdrop-filter: blur(6px);
}

.slides-decision-card {
  display: grid;
  gap: 11px;
  padding: 18px;
}

.slides-decision-card h3 {
  margin: 0;
  font-size: 1.2rem;
  line-height: 1.1;
}

.slides-decision-card p:not(.eyebrow) {
  margin: 0;
  color: var(--muted);
  font-weight: 650;
  line-height: 1.4;
}

.slides-decision-actions {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
  margin-top: 4px;
}

.slides-decision-actions[data-layout="choice"] {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.slides-decision-actions button {
  width: 100%;
  justify-content: center;
}

.slides-decision-remember {
  grid-column: 1 / -1;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 2px;
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 750;
}

.slides-decision-remember input {
  width: 16px;
  height: 16px;
  accent-color: var(--accent, var(--blue));
}

@media (max-width: 420px) {
  .slides-decision-actions[data-layout="choice"] {
    grid-template-columns: 1fr;
  }
}

.slides-setup-view {
  display: grid;
  grid-template-columns: minmax(250px, 0.72fr) minmax(0, 1.28fr);
  grid-template-areas:
    "copy paste"
    "actions actions";
  gap: 16px;
  min-height: 0;
  padding: 18px;
}

.slides-setup-view[hidden],
.slides-workspace-view[hidden] {
  display: none;
}

.slides-setup-copy {
  grid-area: copy;
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 18px;
  background:
    radial-gradient(circle at 12% 8%, color-mix(in srgb, var(--green) 22%, transparent), transparent 30%),
    color-mix(in srgb, var(--panel-3) 60%, transparent);
}

.slides-setup-copy h3 {
  margin: 0 0 10px;
  font-size: clamp(1.65rem, 4vw, 2.4rem);
  line-height: 0.98;
}

.slides-setup-copy p:not(.eyebrow) {
  margin: 0;
  color: var(--muted);
  font-weight: 650;
  line-height: 1.45;
}

.slides-paste-label {
  display: grid;
  grid-area: paste;
  min-height: 0;
}

.slides-paste-label textarea {
  min-height: 360px;
  resize: none;
  font-size: 1.05rem;
  line-height: 1.5;
}

.slides-setup-actions {
  display: flex;
  grid-area: actions;
  justify-content: flex-end;
  gap: 10px;
}

.slides-workspace-view {
  display: grid;
  grid-template-columns: 220px minmax(360px, 1fr) 320px;
  gap: 14px;
  min-height: 0;
  padding: 14px;
}

.slides-strip,
.slides-live-area,
.slides-edit-panel {
  min-width: 0;
  min-height: 0;
}

.slides-strip,
.slides-edit-panel {
  display: flex;
  flex-direction: column;
  gap: 12px;
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 12px;
  background: color-mix(in srgb, var(--panel-3) 48%, transparent);
}

.slides-strip-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 900;
  text-transform: uppercase;
}

.slides-strip-head-actions {
  display: flex;
  align-items: center;
  gap: 6px;
}

.slides-strip-head-actions .icon-button {
  width: 34px;
  height: 34px;
}

.slides-selection-bar {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 6px;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 6px;
  background: color-mix(in srgb, var(--panel) 58%, transparent);
}

.slides-selection-bar[hidden] {
  display: none;
}

.slides-selection-bar span {
  overflow: hidden;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 900;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.slides-selection-bar .ghost-button {
  min-height: 30px;
  padding: 0 9px;
  border-radius: 9px;
  font-size: 0.7rem;
}

.slides-editor-list {
  display: grid;
  gap: 8px;
  overflow-y: auto;
  padding-right: 2px;
}

.slides-editor-list.is-reordering,
.slides-editor-list.is-reordering *,
body.reordering-slides-editor,
body.reordering-slides-editor .slides-editor-list,
body.reordering-slides-editor .slides-editor-list * {
  user-select: none !important;
  -webkit-user-select: none !important;
}

.slides-list-item {
  position: relative;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  grid-template-areas:
    "select title grip"
    "num meta grip";
  align-items: center;
  gap: 3px 10px;
  min-height: 64px;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 9px 10px;
  color: var(--text);
  background: rgba(255, 255, 255, 0.035);
  text-align: left;
}

.slides-list-select {
  display: grid;
  grid-area: select;
  place-items: center;
  width: 30px;
  height: 30px;
  cursor: pointer;
}

.slides-list-select input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.slides-list-select span {
  display: grid;
  width: 18px;
  height: 18px;
  place-items: center;
  border: 1px solid color-mix(in srgb, var(--line) 80%, white);
  border-radius: 6px;
  background: color-mix(in srgb, var(--panel) 74%, transparent);
}

.slides-list-select input:checked + span {
  border-color: var(--green);
  background: var(--green);
}

.slides-list-select input:checked + span::after {
  content: "";
  width: 7px;
  height: 4px;
  border-bottom: 2px solid #ffffff;
  border-left: 2px solid #ffffff;
  transform: rotate(-45deg) translate(1px, -1px);
}

.slides-list-number {
  display: grid;
  grid-area: num;
  width: 30px;
  height: 30px;
  place-items: center;
  border-radius: 999px;
  color: var(--muted);
  background: color-mix(in srgb, var(--panel) 70%, transparent);
  font-size: 0.72rem;
  font-weight: 900;
}

.slides-list-thumb {
  display: none;
}

.slides-list-grip {
  display: grid;
  grid-area: grip;
  align-self: stretch;
  width: 20px;
  place-content: center;
  gap: 3px;
  color: var(--muted);
  cursor: grab;
  touch-action: none;
}

.slides-list-grip i {
  display: block;
  width: 3px;
  height: 3px;
  border-radius: 999px;
  background: currentColor;
}

.slides-list-item strong {
  grid-area: title;
  overflow: hidden;
  font-size: 0.88rem;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.slides-list-item small {
  grid-area: meta;
  color: var(--muted);
  font-size: 0.7rem;
  font-weight: 760;
}

.slides-list-item.active {
  border-color: color-mix(in srgb, var(--green) 76%, white);
  background: color-mix(in srgb, var(--green) 16%, transparent);
}

.slides-list-item.selected {
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--green) 72%, transparent);
}

.slides-list-item.dragging {
  border-color: var(--green);
  opacity: 0.68;
}

.slides-list-item.drop-before::before,
.slides-list-item.drop-after::after {
  content: "";
  position: absolute;
  right: 10px;
  left: 10px;
  z-index: 4;
  height: 4px;
  border-radius: 999px;
  background: var(--green);
  box-shadow: 0 0 14px rgba(91, 146, 255, 0.5);
  pointer-events: none;
  animation: dropPulse 900ms ease-in-out infinite;
}

.slides-list-item.drop-before::before {
  top: -6px;
}

.slides-list-item.drop-after::after {
  bottom: -6px;
}

.slides-live-area {
  display: grid;
  grid-template-rows: minmax(0, 1fr) auto;
  gap: 12px;
}

.slides-live-preview-wrap {
  display: grid;
  min-height: 0;
  place-items: center;
  border: 1px solid var(--line);
  border-radius: 20px;
  padding: 18px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.02)),
    color-mix(in srgb, var(--panel-3) 46%, transparent);
}

.slides-live-preview {
  position: relative;
  display: grid;
  width: min(100%, 720px);
  max-height: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  place-items: center;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 18px;
  padding: clamp(26px, 4vw, 56px);
  padding-bottom: clamp(44px, 5vw, 70px);
  color: #f8fafc;
  background:
    radial-gradient(circle at 18% 12%, rgba(91, 146, 255, 0.22), transparent 34%),
    linear-gradient(145deg, #07111f, #020407);
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.34);
  text-align: center;
}

.slides-live-preview.theme-warm {
  background:
    radial-gradient(circle at 20% 14%, rgba(245, 181, 43, 0.24), transparent 35%),
    radial-gradient(circle at 85% 80%, rgba(61, 132, 105, 0.2), transparent 34%),
    linear-gradient(145deg, #211007, #05070b 70%);
}

.slides-live-preview.theme-bright {
  color: #0f172a;
  border-color: rgba(15, 23, 42, 0.12);
  background:
    radial-gradient(circle at 20% 18%, rgba(91, 146, 255, 0.14), transparent 34%),
    linear-gradient(145deg, #fffaf2, #eef6f3);
}

.slides-live-preview.rendered-slide-editor-preview {
  padding: 0;
  background: #020617;
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.34);
}

.slides-live-preview.rendered-slide-editor-preview.is-rendering {
  padding: clamp(26px, 4vw, 56px);
}

.slides-live-rendered-image {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.slides-live-lines {
  display: grid;
  gap: 0.08em;
  width: 100%;
  max-height: 100%;
  font-size: var(--slide-editor-display-font-size, var(--slide-editor-font-size, 56px));
  font-weight: 700;
  line-height: 1;
}

.slides-live-lines span {
  overflow: visible;
  overflow-wrap: normal;
  white-space: nowrap;
  word-break: keep-all;
}

.slides-live-meta,
.slides-live-preview small {
  position: absolute;
  color: rgba(248, 250, 252, 0.54);
  font-size: 0.7rem;
  font-weight: 850;
  text-transform: uppercase;
}

.slides-live-preview.theme-bright .slides-live-meta,
.slides-live-preview.theme-bright small {
  color: rgba(15, 23, 42, 0.52);
}

.slides-live-meta {
  top: 16px;
  left: 18px;
}

.slides-live-preview small {
  right: 14px;
  bottom: 10px;
  font-size: 0.56rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-align: right;
}

.slides-quick-actions {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(132px, 1fr));
  align-items: stretch;
  gap: 8px;
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 10px;
  background: color-mix(in srgb, var(--panel-3) 48%, transparent);
}

.slides-action-group {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  align-content: center;
  gap: 6px;
  min-width: 0;
  border: 1px solid color-mix(in srgb, var(--line) 76%, transparent);
  border-radius: 12px;
  padding: 7px;
  background: rgba(255, 255, 255, 0.025);
}

.slides-action-group > span:first-child {
  flex: 0 0 100%;
  color: var(--muted);
  font-size: 0.62rem;
  font-weight: 900;
  text-transform: uppercase;
}

.slides-quick-actions .ghost-button,
.slides-quick-actions .danger-button {
  min-height: 36px;
  padding: 0 10px;
  font-size: 0.76rem;
  font-weight: 850;
}

.slides-mobile-action-label {
  display: none;
}

.slides-current-text {
  display: grid;
  min-height: 0;
}

.slides-current-text textarea {
  min-height: 220px;
  resize: none;
  font-size: 1.03rem;
  line-height: 1.45;
}

.slides-design-panel {
  display: grid;
  gap: 14px;
  border-top: 1px solid var(--line);
  padding-top: 12px;
}

.slides-control-label {
  display: block;
  margin-bottom: 7px;
  color: var(--muted);
  font-size: 0.74rem;
  font-weight: 900;
  text-transform: uppercase;
}

.slides-size-control {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr) 42px;
  align-items: center;
  gap: 8px;
}

.slides-fit-button {
  grid-column: 1 / -1;
  justify-content: center;
  min-height: 36px;
}

.slides-size-control output {
  display: grid;
  height: 38px;
  place-items: center;
  border: 1px solid var(--line);
  border-radius: 12px;
  color: var(--text);
  background: rgba(255, 255, 255, 0.035);
  font-weight: 900;
}

.slides-theme-buttons {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.slides-background-menu {
  position: relative;
  display: grid;
  gap: 8px;
}

.slides-background-trigger {
  display: none;
}

.slides-theme-swatch {
  display: grid;
  gap: 7px;
  min-height: 64px;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 8px;
  color: var(--muted);
  background: rgba(255, 255, 255, 0.035);
  font-size: 0.72rem;
  font-weight: 850;
}

.slides-theme-swatch span {
  display: block;
  height: 22px;
  border-radius: 8px;
  background: linear-gradient(135deg, #07111f, #020407);
}

.slides-theme-swatch.theme-warm span {
  background: linear-gradient(135deg, #211007, #3d8469);
}

.slides-theme-swatch.theme-bright span {
  background: linear-gradient(135deg, #fffaf2, #dfeeea);
}

.slides-theme-swatch.active {
  border-color: color-mix(in srgb, var(--green) 72%, white);
  color: var(--text);
  background: color-mix(in srgb, var(--green) 15%, transparent);
}

.lineup-heading,
.lineup-row {
  display: grid;
  grid-template-columns: 24px 32px minmax(180px, 1fr) minmax(148px, 0.38fr) 92px 62px 42px 42px 42px 68px;
  align-items: center;
  gap: 8px;
}

.lineup-heading {
  padding: 0 14px 6px;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
}

.lineup-rows {
  display: grid;
  gap: 6px;
  align-content: start;
  flex: 1 1 auto;
  min-height: 84px;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  padding-right: 4px;
  border-radius: var(--radius);
  transition: background 160ms ease, outline-color 160ms ease;
}

.lineup-rows.drop-ready {
  outline: 2px dashed rgba(91, 146, 255, 0.5);
  outline-offset: 6px;
  background: rgba(91, 146, 255, 0.035);
}

.lineup-rows.drop-at-end::after {
  content: "";
  display: block;
  height: 5px;
  border-radius: 999px;
  background: var(--green);
  box-shadow: 0 0 16px rgba(91, 146, 255, 0.5);
  animation: dropPulse 900ms ease-in-out infinite;
}

.lineup-row,
.bank-song {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.025));
}

:root[data-theme="light"] .lineup-row,
:root[data-theme="light"] .bank-song {
  border-color: #cad5e2;
  background: linear-gradient(180deg, #ffffff, #f4f7fb);
  box-shadow: 0 1px 0 rgba(21, 34, 54, 0.04);
}

:root[data-theme="light"] .lineup-row:hover,
:root[data-theme="light"] .bank-song:hover {
  border-color: #9fb2c8;
  background: #ffffff;
}

.lineup-row.note-row {
  grid-template-columns: 24px 32px minmax(160px, 1fr);
  border-color: rgba(243, 174, 34, 0.32);
  background: linear-gradient(180deg, rgba(243, 174, 34, 0.11), rgba(255, 255, 255, 0.025));
}

:root[data-theme="light"] .lineup-row.note-row {
  border-color: rgba(200, 135, 5, 0.34);
  background: linear-gradient(180deg, #fff7e4, #fffaf0);
}

.lineup-row {
  position: relative;
  min-height: 54px;
  padding: 6px 8px;
}

.lineup-row.song-row::before,
.bank-song::before {
  content: "";
  position: absolute;
  top: 10px;
  bottom: 10px;
  left: 0;
  width: 3px;
  border-radius: 0 999px 999px 0;
  background: var(--category-color, var(--green));
  opacity: 0.85;
}

.lineup-row.drop-before::before,
.lineup-row.drop-after::after {
  content: "";
  position: absolute;
  right: 10px;
  left: 10px;
  z-index: 3;
  height: 5px;
  border-radius: 999px;
  background: var(--green);
  box-shadow: 0 0 16px rgba(91, 146, 255, 0.55);
  pointer-events: none;
  animation: dropPulse 900ms ease-in-out infinite;
}

.lineup-row.drop-before::before {
  top: -7px;
}

.lineup-row.drop-after::after {
  bottom: -7px;
}

.lineup-row {
  cursor: grab;
}

.lineup-row:active {
  cursor: grabbing;
}

body.is-pointer-dragging,
body.is-pointer-dragging * {
  user-select: none;
  cursor: grabbing !important;
}

.lineup-drag-ghost {
  position: fixed !important;
  top: 0;
  left: 0;
  z-index: 9999;
  max-width: calc(100vw - 24px);
  opacity: 0.68;
  pointer-events: none !important;
  cursor: grabbing;
  filter: drop-shadow(0 18px 36px rgba(0, 0, 0, 0.32));
  transform-origin: top left;
  transition: none !important;
  will-change: transform;
}

.lineup-drag-ghost,
.lineup-drag-ghost * {
  pointer-events: none !important;
}

.lineup-drag-preview-row {
  opacity: 0.58;
  border-style: dashed;
  border-color: color-mix(in srgb, var(--green) 52%, var(--line));
  background: color-mix(in srgb, var(--green) 15%, var(--panel-2));
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--green) 26%, transparent),
    0 12px 28px rgba(0, 0, 0, 0.16);
  pointer-events: none !important;
  animation: dropPulse 900ms ease-in-out infinite;
}

.lineup-drag-preview-row,
.lineup-drag-preview-row * {
  cursor: grabbing !important;
  pointer-events: none !important;
}

:root[data-theme="light"] .lineup-drag-preview-row {
  background: color-mix(in srgb, var(--green) 12%, #ffffff);
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--green) 24%, transparent),
    0 10px 24px rgba(21, 34, 54, 0.12);
}

.lineup-row.dragging {
  border-color: var(--green);
  opacity: 0.58;
}

body.is-pointer-dragging .lineup-row.dragging:not(.drag-origin-visible) {
  display: none !important;
}

.lineup-row.song-row:has(.key-picker-trigger[aria-expanded="true"]) {
  border-color: color-mix(in srgb, var(--green) 72%, var(--line));
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--green) 18%, transparent) 0%, color-mix(in srgb, var(--green) 8%, transparent) 38%, transparent 82%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.072), rgba(255, 255, 255, 0.032));
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--green) 22%, transparent),
    0 0 0 3px color-mix(in srgb, var(--green) 12%, transparent),
    0 12px 28px rgba(0, 0, 0, 0.18);
}

.lineup-row.song-row:has(.key-picker-trigger[aria-expanded="true"])::before {
  opacity: 1;
  box-shadow: 0 0 18px color-mix(in srgb, var(--category-color, var(--green)) 48%, transparent);
}

:root[data-theme="light"] .lineup-row.song-row:has(.key-picker-trigger[aria-expanded="true"]) {
  border-color: color-mix(in srgb, var(--green) 54%, #9fb2c8);
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--green) 20%, transparent) 0%, color-mix(in srgb, var(--green) 8%, transparent) 42%, transparent 82%),
    linear-gradient(180deg, #ffffff, #f3f8ff);
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--green) 18%, transparent),
    0 0 0 3px color-mix(in srgb, var(--green) 10%, transparent),
    0 10px 22px rgba(40, 76, 120, 0.12);
}

.bank-song {
  cursor: pointer;
  -webkit-touch-callout: none;
  -webkit-user-drag: none;
  -webkit-user-select: none;
  user-select: none;
}

.bank-song.dragging {
  border-color: var(--green);
  opacity: 0.68;
}

.bank-song.just-added-to-bank {
  border-color: color-mix(in srgb, var(--green) 58%, var(--line));
  box-shadow:
    0 0 0 3px color-mix(in srgb, var(--green) 18%, transparent),
    0 0 26px color-mix(in srgb, var(--green) 34%, transparent);
}

.bank-song.long-press-ready {
  border-color: color-mix(in srgb, var(--green) 68%, var(--line));
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--green) 16%, transparent);
}

.bank-song.is-in-lineup {
  border-color: color-mix(in srgb, var(--green) 50%, var(--line));
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--green) 28%, transparent) 0%, color-mix(in srgb, var(--green) 14%, transparent) 38%, transparent 78%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.025));
}

:root[data-theme="light"] .bank-song.is-in-lineup {
  border-color: color-mix(in srgb, var(--green) 42%, #cad5e2);
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--green) 24%, transparent) 0%, color-mix(in srgb, var(--green) 10%, transparent) 40%, transparent 78%),
    linear-gradient(180deg, #ffffff, #f6f9fc);
}

:root[data-skin="premium"] .lineup-row,
:root[data-skin="premium"] .bank-song,
:root[data-skin="premium"] .saved-shows-menu,
:root[data-skin="premium"] .search-box {
  box-shadow: inset 0 1px 0 rgba(255, 244, 214, 0.05);
}

:root[data-skin="playful"] .lineup-row,
:root[data-skin="playful"] .bank-song {
  border-radius: 12px;
}

:root[data-skin="playful"] .rail-button.active {
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--green) 28%, transparent),
    0 0 22px color-mix(in srgb, var(--green) 22%, transparent);
}

.drag-handle {
  color: var(--muted);
  cursor: grab;
}

.lineup-mobile-controls {
  display: contents;
}

.song-title-wrap {
  display: flex;
  align-items: center;
  min-width: 0;
  gap: 10px;
}

.mobile-row-status {
  display: none;
}

.mobile-status-chip {
  display: inline-grid;
  place-items: center;
  width: 24px;
  height: 24px;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 0;
  color: var(--muted);
  background: rgba(255, 255, 255, 0.035);
  font-size: 0.68rem;
  font-weight: 850;
  white-space: nowrap;
}

.mobile-status-chip svg {
  width: 14px;
  height: 14px;
  fill: none;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 2;
}

.mobile-status-chip.ready,
.mobile-status-chip.slides-ready {
  border-color: rgba(57, 196, 132, 0.34);
  color: color-mix(in srgb, #39c484 80%, var(--text));
  background: rgba(57, 196, 132, 0.09);
}

.mobile-status-chip.review,
.mobile-status-chip.pending {
  border-color: rgba(243, 174, 34, 0.34);
  color: color-mix(in srgb, var(--amber) 85%, var(--text));
  background: rgba(243, 174, 34, 0.1);
}

.mobile-status-chip.empty {
  border-color: color-mix(in srgb, var(--muted) 42%, var(--line));
  color: var(--muted);
}

.song-name {
  overflow: hidden;
  color: var(--text);
  font-weight: 720;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.song-name-line {
  display: flex;
  align-items: center;
  min-width: 0;
  gap: 6px;
}

.lineup-banger-toggle {
  display: none;
}

.lineup-title-banger {
  display: inline-flex;
  align-items: center;
  flex: 0 0 auto;
  color: var(--amber);
}

.lineup-title-banger svg {
  width: 15px;
  height: 15px;
}

.demo-badge {
  display: inline-flex;
  align-items: center;
  flex: 0 0 auto;
  min-height: 18px;
  padding: 0 6px;
  border: 1px solid color-mix(in srgb, var(--amber) 42%, transparent);
  border-radius: 999px;
  color: color-mix(in srgb, var(--amber) 88%, #ffffff);
  background: color-mix(in srgb, var(--amber) 14%, transparent);
  font-size: 0.58rem;
  font-weight: 950;
  line-height: 1;
  text-transform: uppercase;
}

.subline {
  margin-top: 0;
  overflow: hidden;
  color: var(--soft);
  font-size: 0.76rem;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.slides-status-button {
  position: relative;
  display: inline-grid;
  place-items: center;
  overflow: visible;
  width: 30px;
  height: 30px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.04);
  color: var(--muted);
}

.slides-status-button svg {
  width: 17px;
  height: 17px;
}

.slides-status-button span {
  display: none;
}

.slides-status-button .slides-count-badge {
  position: absolute;
  top: -6px;
  right: -6px;
  z-index: 2;
  display: inline-grid;
  place-items: center;
  min-width: 16px;
  height: 16px;
  padding: 0 4px;
  border: 1px solid color-mix(in srgb, var(--green) 64%, var(--line));
  border-radius: 999px;
  background: var(--green);
  color: #05110b;
  box-shadow:
    0 0 0 2px color-mix(in srgb, var(--panel) 86%, transparent),
    0 5px 12px rgba(0, 0, 0, 0.24);
  font-size: 0.56rem;
  font-weight: 950;
  line-height: 1;
  pointer-events: none;
}

:root[data-theme="light"] .slides-status-button .slides-count-badge {
  box-shadow:
    0 0 0 2px rgba(255, 255, 255, 0.94),
    0 5px 12px rgba(8, 16, 28, 0.16);
}

.slides-status-button.ready {
  border-color: rgba(91, 146, 255, 0.5);
  background: rgba(91, 146, 255, 0.16);
  color: var(--green);
}

.slides-status-button.review {
  border-color: rgba(243, 174, 34, 0.55);
  background: rgba(243, 174, 34, 0.13);
  color: var(--amber);
}

.slides-status-button.empty {
  opacity: 0.48;
}

.slides-status-button:hover {
  opacity: 1;
  border-color: rgba(91, 146, 255, 0.58);
  color: var(--green);
  background: rgba(91, 146, 255, 0.12);
}

.sheets-status-button {
  display: inline-grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.04);
  color: var(--muted);
}

.sheets-status-button svg {
  width: 17px;
  height: 17px;
  fill: none;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 2;
}

.sheets-status-button span {
  display: none;
}

.sheets-status-button.has-sheets {
  border-color: rgba(91, 146, 255, 0.52);
  background: rgba(91, 146, 255, 0.14);
  color: var(--green);
}

.sheets-status-button:hover {
  border-color: rgba(91, 146, 255, 0.58);
  color: var(--green);
  background: rgba(91, 146, 255, 0.12);
}

.mobile-note-button {
  display: none;
}

.line-song-note {
  min-width: 0;
}

.line-song-note input {
  width: 100%;
  height: 32px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.04);
  color: var(--text);
  padding: 0 10px;
}

:root[data-theme="light"] .line-song-note input {
  border-color: #c7d2df;
  background: #eef3f8;
}

.line-song-note input:focus {
  border-color: var(--green);
  outline: none;
}

.note-title {
  color: var(--amber);
  font-size: 0.78rem;
  font-weight: 900;
  text-transform: uppercase;
}

.note-text {
  overflow: hidden;
  color: var(--text);
  font-weight: 760;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.capo-select,
.key-select {
  height: 32px;
  padding: 0 8px;
}

.capo-cell,
.key-cell {
  min-width: 0;
}

.capo-select {
  width: 88px;
}

.key-select {
  min-width: 58px;
}

.key-cell .key-picker-trigger {
  height: 32px;
  min-height: 32px;
  padding: 0 8px;
  font-size: 0.86rem;
}

.key-preview-button {
  display: inline-grid;
  width: 32px;
  min-width: 32px;
  height: 32px;
  min-height: 32px;
  place-items: center;
  border: 1px solid var(--line);
  border-radius: 9px;
  padding: 0;
  color: var(--muted);
  background: rgba(255, 255, 255, 0.035);
  cursor: pointer;
}

.key-preview-button:hover,
.key-preview-button:focus-visible,
.key-preview-button.playing {
  border-color: rgba(91, 146, 255, 0.56);
  color: var(--green);
  background: rgba(91, 146, 255, 0.12);
  outline: none;
}

.key-preview-button.playing {
  box-shadow: 0 0 0 3px rgba(91, 146, 255, 0.1);
}

.key-preview-button svg {
  width: 16px;
  height: 16px;
  fill: none;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 2;
}

.ready-toggle {
  display: none;
  place-items: center;
  width: 26px;
  height: 26px;
  border: 2px solid #7e898f;
  border-radius: 5px;
  color: #06120d;
  background: transparent;
}

.ready-toggle.ready {
  border-color: var(--green);
  background: var(--green);
}

.ready-toggle svg {
  width: 16px;
  height: 16px;
}

.ready-toggle span {
  display: none;
}

.slide-only-row {
  border-color: color-mix(in srgb, var(--amber) 34%, var(--line));
}

.slide-only-subline {
  color: color-mix(in srgb, var(--amber) 82%, var(--soft));
  font-weight: 820;
}

.slide-only-note {
  display: grid;
  align-items: center;
  height: 32px;
  color: var(--amber);
  font-size: 0.72rem;
  font-weight: 850;
  white-space: nowrap;
}

.slide-only-inline-image-button {
  display: inline-grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border: 1px solid var(--line);
  border-radius: 8px;
  color: var(--muted);
  background: rgba(255, 255, 255, 0.04);
}

.slide-only-inline-image-button.has-image {
  border-color: rgba(91, 146, 255, 0.5);
  color: var(--green);
  background: rgba(91, 146, 255, 0.16);
}

.slide-only-inline-image-button svg {
  width: 17px;
  height: 17px;
  fill: none;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 2;
}

.slide-only-control-spacer,
.ready-toggle-placeholder {
  display: block;
  min-width: 0;
  height: 1px;
}

.icon-action.is-active {
  color: var(--green);
  background: rgba(91, 146, 255, 0.12);
}

.show-panel[data-lineup-mode="build"] .drag-handle {
  color: color-mix(in srgb, var(--green) 58%, var(--muted));
}

.show-panel[data-lineup-mode="rehearse"] .line-song-note input,
.show-panel[data-lineup-mode="rehearse"] .capo-select,
.show-panel[data-lineup-mode="rehearse"] .key-select,
.show-panel[data-lineup-mode="rehearse"] .ready-toggle {
  border-color: color-mix(in srgb, var(--amber) 36%, var(--line));
}

.show-panel[data-lineup-mode="present"] .slides-status-button {
  border-color: color-mix(in srgb, var(--green) 44%, var(--line));
  opacity: 1;
}

.show-panel[data-lineup-mode="present"] .line-song-note,
.show-panel[data-lineup-mode="present"] .capo-cell,
.show-panel[data-lineup-mode="present"] .key-cell {
  opacity: 0.72;
}

.more-button,
.icon-action {
  width: 30px;
  height: 30px;
  border: 0;
  border-radius: var(--radius);
  background: transparent;
  color: var(--muted);
}

.more-button:hover,
.icon-action:hover {
  color: var(--text);
  background: rgba(255, 255, 255, 0.05);
}

.icon-action {
  display: inline-grid;
  place-items: center;
  border: 1px solid transparent;
}

.icon-action svg {
  width: 16px;
  height: 16px;
}

.icon-action.danger {
  color: #ff9a92;
}

.icon-action.danger:hover {
  border-color: rgba(219, 89, 79, 0.35);
  color: #ffd6d2;
  background: rgba(219, 89, 79, 0.16);
}

.icon-action.danger.delete-armed {
  border-color: rgba(219, 89, 79, 0.68);
  color: #fff0ed;
  background: rgba(219, 89, 79, 0.34);
  box-shadow: 0 0 0 1px rgba(219, 89, 79, 0.22);
}

.row-icon-actions,
.note-inline-actions {
  display: flex;
  gap: 4px;
  justify-content: flex-end;
  opacity: 0;
  pointer-events: none;
  transition: opacity 140ms ease;
}

.row-icon-actions,
.note-row .note-inline-actions {
  z-index: 4;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 2px;
  background: color-mix(in srgb, var(--panel) 94%, transparent);
  box-shadow: 0 10px 26px rgba(0, 0, 0, 0.24);
}

.row-icon-actions {
  position: static;
  grid-column: -2 / -1;
  justify-self: end;
  align-self: center;
}

.note-row .note-inline-actions {
  position: absolute;
  top: 50%;
  right: 8px;
  transform: translateY(-50%);
}

:root[data-theme="light"] .row-icon-actions,
:root[data-theme="light"] .note-row .note-inline-actions {
  background: rgba(255, 255, 255, 0.96);
}

@keyframes dropPulse {
  0%,
  100% {
    opacity: 0.72;
    transform: scaleX(0.985);
  }

  50% {
    opacity: 1;
    transform: scaleX(1);
  }
}

.lineup-row:hover .row-icon-actions,
.lineup-row:focus-within .row-icon-actions,
.lineup-row:hover .note-inline-actions,
.lineup-row:focus-within .note-inline-actions {
  opacity: 1;
  pointer-events: auto;
}

.note-inline-actions {
  align-items: center;
}

.mini-button {
  min-height: 38px;
  padding: 0 12px;
  font-size: 0.82rem;
}

.mini-button.remove {
  border-color: rgba(219, 89, 79, 0.35);
  color: #ffd6d2;
  background: rgba(219, 89, 79, 0.18);
}

.lineup-add-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 0;
  padding: 10px 4px 0;
}

.mobile-first-song-button {
  display: none;
}

.lineup-theme-toggle {
  width: 46px;
  height: 46px;
  min-width: 46px;
  color: var(--text);
}

.coach-overlay {
  position: fixed;
  inset: 0;
  z-index: 92;
  background: transparent;
  backdrop-filter: none;
  animation: coach-fade 220ms ease both;
  pointer-events: auto;
  touch-action: manipulation;
}

.coach-overlay.in-dialog {
  position: absolute;
  z-index: 80;
  border-radius: inherit;
  overflow: hidden;
}

.coach-spotlight {
  position: fixed;
  z-index: 1;
  border: 2px solid color-mix(in srgb, var(--green) 76%, #ffffff);
  border-radius: 16px;
  box-shadow:
    0 0 0 3px color-mix(in srgb, var(--green) 18%, transparent),
    0 0 22px color-mix(in srgb, var(--green) 30%, transparent),
    inset 0 0 0 1px rgba(255, 255, 255, 0.14);
  pointer-events: none;
  transition: left 260ms ease, top 260ms ease, width 260ms ease, height 260ms ease;
}

.coach-overlay.in-dialog .coach-spotlight,
.coach-overlay.in-dialog .coach-tip {
  position: absolute;
}

.coach-tip {
  position: fixed;
  z-index: 3;
  display: grid;
  gap: 10px;
  border: 1px solid color-mix(in srgb, var(--green) 42%, var(--line));
  border-radius: 20px;
  padding: 18px;
  color: var(--text);
  background: var(--panel);
  box-shadow:
    0 24px 80px rgba(0, 0, 0, 0.42),
    0 0 0 1px rgba(255, 255, 255, 0.06) inset;
  transition: left 260ms ease, top 260ms ease;
  pointer-events: auto;
  touch-action: manipulation;
}

.coach-tip::before {
  position: absolute;
  top: 22px;
  left: -9px;
  width: 16px;
  height: 16px;
  border-left: 1px solid color-mix(in srgb, var(--green) 35%, var(--line));
  border-bottom: 1px solid color-mix(in srgb, var(--green) 35%, var(--line));
  background: inherit;
  content: "";
  transform: rotate(45deg);
}

.coach-tip[data-placement="left"]::before {
  right: -9px;
  left: auto;
  transform: rotate(225deg);
}

.coach-tip[data-placement="top"]::before {
  top: auto;
  bottom: -9px;
  left: 50%;
  transform: translateX(-50%) rotate(-45deg);
}

.coach-tip[data-placement="bottom"]::before {
  top: -9px;
  left: 50%;
  transform: translateX(-50%) rotate(135deg);
}

.coach-step {
  margin: 0;
  color: var(--green);
  font-size: 0.72rem;
  font-weight: 950;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.coach-tip h2 {
  margin: 0;
  font-size: 1.26rem;
  font-weight: 950;
  letter-spacing: -0.02em;
}

.coach-tip p:not(.coach-step) {
  margin: 0;
  color: var(--muted);
  font-size: 0.9rem;
  font-weight: 760;
  line-height: 1.45;
}

.coach-actions {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  margin-top: 8px;
}

.coach-actions .ghost-button,
.coach-actions .primary-button {
  position: relative;
  z-index: 1;
  min-height: 40px;
  padding: 0 12px;
  font-size: 0.82rem;
  pointer-events: auto;
}

.coach-actions .ghost-button:disabled {
  opacity: 0.45;
}

.onboarding-tour-button .settings-action-icon {
  color: var(--amber);
}

body.auth-required .app-shell {
  filter: blur(1px);
}

body.auth-required #accountDialog [data-close-dialog],
body.auth-required #accountDialog::backdrop {
  cursor: default;
}

body.auth-required #accountDialog .dialog-header [data-close-dialog] {
  display: none;
}

@keyframes coach-fade {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@media (prefers-reduced-motion: reduce) {
  .lineup-intro-card,
  .intro-mark,
  .lineup-intro.is-leaving,
  body.intro-complete .app-shell,
  .start-dialog.from-intro[open],
  .start-dialog.from-intro::backdrop,
  .coach-overlay,
  .coach-spotlight,
  .coach-tip,
  .song-manager-view,
  .key-picker-menu {
    animation: none;
    transition: none;
  }
}

@media (max-width: 760px) {
  .coach-overlay {
    background: transparent;
  }

  .coach-spotlight {
    border-radius: 12px;
  }

  .coach-tip {
    max-width: calc(100vw - 16px);
    gap: 6px;
    padding: 10px;
    border-radius: 12px;
    box-shadow:
      0 12px 34px rgba(0, 0, 0, 0.34),
      0 0 0 1px rgba(255, 255, 255, 0.06) inset;
  }

  .coach-tip::before {
    display: none;
  }

  .coach-step {
    font-size: 0.58rem;
    letter-spacing: 0.08em;
  }

  .coach-tip h2 {
    font-size: 0.9rem;
    line-height: 1.1;
  }

  .coach-tip p:not(.coach-step) {
    font-size: 0.72rem;
    line-height: 1.25;
  }

  .coach-actions {
    align-items: center;
    flex-direction: row;
    gap: 6px;
    margin-top: 2px;
  }

  .coach-actions .ghost-button,
  .coach-actions .primary-button {
    min-height: 30px;
    width: auto;
    padding: 0 9px;
    font-size: 0.68rem;
  }
}

.add-slot-button {
  width: min(420px, 100%);
  min-height: 70px;
  border-style: dashed;
  color: var(--green);
  background: rgba(91, 146, 255, 0.035);
  font-weight: 780;
}

.add-slot-button.note {
  border-color: rgba(243, 174, 34, 0.5);
  color: var(--amber);
  background: rgba(243, 174, 34, 0.035);
}

.search-row {
  display: grid;
  grid-template-columns: 1fr 44px 44px;
  gap: 8px;
  margin-bottom: 10px;
}

.search-box {
  position: relative;
  min-width: 0;
}

.search-box svg {
  position: absolute;
  left: 14px;
  top: 50%;
  color: var(--muted);
  transform: translateY(-50%);
}

.search-box input {
  padding-left: 46px;
}

.category-filters {
  display: grid;
  gap: 8px;
  margin-bottom: 12px;
}

.category-filters[hidden] {
  display: none !important;
}

.filter-toggle-button {
  position: relative;
}

.filter-toggle-button.active {
  border-color: color-mix(in srgb, var(--green) 44%, var(--line));
  color: var(--green);
  background: color-mix(in srgb, var(--green) 12%, var(--panel-2));
}

.filter-toggle-button.active[data-count]:not([data-count=""])::after {
  content: attr(data-count);
  position: absolute;
  top: -5px;
  right: -5px;
  display: grid;
  place-items: center;
  min-width: 16px;
  height: 16px;
  border-radius: 999px;
  padding: 0 4px;
  color: #06120d;
  background: var(--green);
  font-size: 0.62rem;
  font-weight: 950;
}

.filter-group {
  display: grid;
  gap: 6px;
}

.filter-heading-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.filter-label {
  color: var(--soft);
  font-size: 0.68rem;
  font-weight: 900;
  text-transform: uppercase;
}

.filter-options {
  display: flex;
  flex-wrap: nowrap;
  gap: 3px;
  width: 100%;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.035);
  padding: 4px;
}

:root[data-theme="light"] .filter-options {
  border-color: #bfccd9;
  background: #dde7f2;
}

.filter-chip {
  flex: 1 1 auto;
  min-height: 28px;
  border: 0;
  border-radius: 6px;
  padding: 0 8px;
  color: var(--muted);
  background: transparent;
  font-size: 0.88rem;
  font-weight: 720;
  white-space: nowrap;
}

.filter-chip.active {
  color: #ffffff;
  background: var(--chip-color);
}

.filter-select {
  width: 100%;
  height: 42px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.04);
  color: var(--text);
  padding: 0 38px 0 12px;
  font-size: 0.88rem;
  font-weight: 760;
}

.banger-filter,
.hebrew-filter {
  display: inline-grid;
  flex: 0 0 32px;
  place-items: center;
  width: 32px;
  min-height: 28px;
  border: 0;
  border-radius: 6px;
  background: transparent;
  color: var(--amber);
}

.hebrew-filter {
  color: var(--accent);
  font-size: 0.74rem;
  font-weight: 900;
}

.banger-filter.active {
  background: rgba(243, 174, 34, 0.18);
}

.hebrew-filter.active {
  color: #ffffff;
  background: var(--accent);
}

.banger-filter svg,
.banger-toggle svg,
.banger-mark svg {
  width: 17px;
  height: 17px;
  stroke-width: 2.2;
}

.song-bank-list {
  display: grid;
  flex: 1;
  align-content: start;
  min-height: 0;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  gap: 7px;
  padding-right: 4px;
}

.bank-song {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto auto auto;
  align-items: center;
  gap: 8px;
  min-height: 44px;
  padding: 7px 9px;
  cursor: pointer;
}

.bank-song:hover {
  border-color: var(--line-strong);
  background: rgba(255, 255, 255, 0.065);
}

:root[data-theme="light"] .bank-song:hover {
  border-color: #9fb2c8;
  background: #ffffff;
}

.bank-song:focus-visible {
  outline: 3px solid rgba(91, 146, 255, 0.3);
  outline-offset: 2px;
}

.bank-add-button {
  display: flex;
  align-items: center;
  width: 100%;
  height: auto;
  min-width: 0;
  gap: 8px;
  border: 0;
  padding: 0;
  color: inherit;
  background: transparent;
  text-align: left;
  cursor: pointer;
}

.bank-add-icon {
  display: inline-grid;
  flex: 0 0 auto;
  place-items: center;
  width: 26px;
  height: 26px;
  border: 1px solid color-mix(in srgb, var(--green) 38%, var(--line));
  border-radius: 8px;
  color: var(--green);
  background: color-mix(in srgb, var(--green) 10%, transparent);
  font-size: 1rem;
  font-weight: 900;
  line-height: 1;
}

.bank-add-button:hover .bank-add-icon {
  border-color: color-mix(in srgb, var(--green) 68%, var(--line));
  background: color-mix(in srgb, var(--green) 18%, transparent);
}

.bank-song-main {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  min-width: 0;
  gap: 10px;
}

.bank-song-main .song-name {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.bank-song .more-button {
  display: none;
}

.bank-song .banger-toggle,
.bank-slides-button,
.bank-sheets-button,
.bank-edit-button {
  width: 30px;
  height: 30px;
  min-height: 30px;
}

.bank-edit-button {
  color: var(--muted);
}

.bank-edit-button:hover {
  color: var(--green);
}

.bank-tags {
  display: none;
  flex-basis: 100%;
  overflow: hidden;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 800;
  line-height: 1.1;
  opacity: 0.78;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.hebrew-badge {
  display: inline-grid;
  flex: 0 0 auto;
  place-items: center;
  min-width: 24px;
  height: 22px;
  border: 1px solid color-mix(in srgb, var(--green) 54%, transparent);
  border-radius: 999px;
  padding: 0 6px;
  color: var(--green);
  font-size: 0.68rem;
  font-weight: 900;
}

.banger-mark {
  display: inline-flex;
  flex: 0 0 auto;
  align-items: center;
  justify-content: center;
  color: var(--amber);
}

.banger-mark.inline {
  margin-right: 4px;
  vertical-align: -3px;
}

.banger-toggle {
  display: inline-grid;
  place-items: center;
  width: 32px;
  height: 32px;
  border: 1px solid transparent;
  border-radius: var(--radius);
  background: transparent;
  color: var(--muted);
}

.banger-toggle:hover,
.banger-toggle.active {
  border-color: rgba(243, 174, 34, 0.36);
  color: var(--amber);
  background: rgba(243, 174, 34, 0.12);
}

.empty-state {
  display: grid;
  place-items: center;
  min-height: 160px;
  border: 1px dashed var(--line-strong);
  border-radius: var(--radius);
  color: var(--muted);
  text-align: center;
}

.empty-state strong {
  display: block;
  margin-bottom: 4px;
  color: var(--text);
}

.library-empty-action-zone {
  cursor: pointer;
  transition: border-color 160ms ease, background 160ms ease, transform 160ms ease;
}

.library-empty-action-zone:hover,
.library-empty-action-zone:focus-visible {
  border-color: color-mix(in srgb, var(--green) 48%, var(--line-strong));
  background: color-mix(in srgb, var(--green) 8%, transparent);
  transform: translateY(-1px);
  outline: none;
}

.lineup-start-empty {
  align-content: center;
  gap: 8px;
  padding: 28px 18px;
}

.lineup-start-empty .lineup-start-mark {
  width: 68px;
  height: 68px;
  margin-bottom: 2px;
}

.lineup-start-empty .lineup-start-mark svg {
  width: 62px;
  height: 62px;
}

.lineup-start-empty p {
  max-width: 320px;
  margin: 0;
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.35;
}

.lineup-start-empty small {
  max-width: 330px;
  color: var(--soft);
  font-size: 0.74rem;
  font-weight: 750;
  line-height: 1.35;
}

.song-dialog,
.export-dialog {
  position: fixed;
  inset-block-start: 50%;
  inset-inline-start: 50%;
  z-index: 10000;
  isolation: isolate;
  transform: translate(-50%, -50%);
  width: min(560px, calc(100vw - 28px));
  margin: 0;
  border: 1px solid var(--line-strong);
  border-radius: 16px;
  padding: 0;
  color: var(--text);
  background: #101416;
  box-shadow: var(--shadow);
}

.song-dialog {
  max-height: calc(var(--lineup-viewport-height, 100dvh) - 28px);
  overflow: hidden;
}

:root[data-theme="light"] .song-dialog,
:root[data-theme="light"] .export-dialog {
  border-color: #b9c7d8;
  background: #f8fbff;
}

.export-dialog {
  inset-block-start: max(16px, env(safe-area-inset-top));
  inset-inline-start: 50%;
  transform: translateX(-50%);
  width: min(1280px, calc(100vw - 24px));
  height: min(920px, calc(var(--lineup-viewport-height, 100dvh) - 32px));
  max-height: calc(var(--lineup-viewport-height, 100dvh) - 32px);
  overflow: hidden;
}

.song-dialog::backdrop,
.export-dialog::backdrop {
  background: rgba(2, 6, 23, 0.68);
  backdrop-filter: blur(10px);
}

.presentation-dialog {
  position: fixed;
  inset: 0;
  width: 100vw;
  height: var(--lineup-viewport-height, 100dvh);
  max-width: none;
  max-height: none;
  border: 0;
  padding: 0;
  background: #020617;
}

.presentation-dialog::backdrop {
  background: #020617;
}

.presentation-stage {
  position: relative;
  display: grid;
  place-items: center;
  width: 100%;
  height: 100%;
  background: #020617;
}

.presentation-stage img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.presentation-controls {
  position: absolute;
  left: 50%;
  bottom: max(18px, env(safe-area-inset-bottom));
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 999px;
  background: rgba(2, 6, 23, 0.72);
  color: #fff;
  transform: translateX(-50%);
  backdrop-filter: blur(14px);
}

.presentation-control {
  display: inline-grid;
  place-items: center;
  width: 40px;
  height: 40px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 999px;
  color: #fff;
  background: rgba(255, 255, 255, 0.08);
}

.presentation-control svg {
  width: 20px;
  height: 20px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.presentation-control:disabled {
  opacity: 0.38;
}

.presentation-count {
  min-width: 62px;
  text-align: center;
  font-size: 0.82rem;
  font-weight: 900;
}

.song-dialog form {
  display: grid;
  gap: 16px;
  max-height: calc(var(--lineup-viewport-height, 100dvh) - 28px);
  padding: 24px;
  overflow: auto;
  overscroll-behavior: contain;
}

.start-dialog {
  width: min(460px, calc(100vw - 28px));
}

.start-dialog.from-intro[open] {
  animation: start-dialog-arrive 620ms cubic-bezier(0.16, 1, 0.3, 1) both;
}

.start-dialog.from-intro::backdrop {
  animation: start-backdrop-arrive 620ms ease both;
}

.start-choice-grid {
  display: grid;
  gap: 10px;
}

.start-choice-button {
  justify-content: flex-start;
  min-height: 58px;
  font-size: 1rem;
  font-weight: 880;
}

.start-choice-button svg {
  width: 20px;
  height: 20px;
}

@keyframes start-dialog-arrive {
  from {
    opacity: 0;
    transform: translateY(22px) scale(0.94);
    filter: blur(6px);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
    filter: blur(0);
  }
}

@keyframes start-backdrop-arrive {
  from {
    background: rgba(0, 0, 0, 0);
    backdrop-filter: blur(0);
  }
  to {
    background: rgba(0, 0, 0, 0.58);
    backdrop-filter: blur(8px);
  }
}

.share-file-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.share-file-actions .ghost-button {
  min-height: 48px;
  padding: 0 14px;
}

.sync-note {
  margin: 0;
  color: var(--muted);
  font-size: 0.86rem;
  line-height: 1.35;
}

.account-sync-panel {
  display: grid;
  gap: 12px;
}

.account-sync-panel[hidden] {
  display: none;
}

.account-choice-view,
.account-credential-view {
  display: grid;
  gap: 12px;
}

.account-choice-view[hidden],
.account-credential-view[hidden] {
  display: none;
}

.account-choice-button {
  display: grid;
  min-height: 74px;
  gap: 4px;
  border: 1px solid var(--line);
  border-radius: calc(var(--radius) + 4px);
  padding: 14px;
  color: var(--text);
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--green) 8%, transparent), transparent 70%),
    var(--panel-soft);
  text-align: left;
  transition: border-color 160ms ease, background 160ms ease, transform 160ms ease;
}

.account-choice-button:hover,
.account-choice-button:focus-visible {
  border-color: var(--green);
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--green) 14%, transparent), transparent 70%),
    var(--panel-soft);
}

.account-choice-button:active {
  transform: scale(0.99);
}

.account-choice-button strong,
.account-choice-button small {
  display: block;
}

.account-choice-button strong {
  font-size: 1rem;
  font-weight: 930;
}

.account-choice-button small {
  color: var(--muted);
  font-size: 0.8rem;
  line-height: 1.35;
}

.account-choice-button.guest {
  border-color: color-mix(in srgb, var(--blue) 32%, var(--line));
}

.account-back-button {
  justify-self: start;
  min-height: 34px;
  padding-inline: 0;
}

.account-signup-fields {
  display: grid;
  gap: 12px;
}

.account-signup-fields[hidden],
.account-conditional-field[hidden] {
  display: none;
}

.link-button {
  justify-self: start;
  min-height: 0;
  border: 0;
  padding: 0;
  color: var(--green);
  background: transparent;
  font-size: 0.9rem;
  font-weight: 900;
}

.link-button:hover {
  color: color-mix(in srgb, var(--green) 70%, white);
}

.sync-status-card {
  display: grid;
  gap: 4px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 12px 14px;
  background: rgba(91, 146, 255, 0.12);
}

.sync-status-card strong {
  color: var(--text);
  font-size: 1rem;
}

.sync-status-card small {
  color: var(--muted);
  font-weight: 800;
}

.account-profile-card {
  display: grid;
  gap: 12px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: calc(var(--radius) + 4px);
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--blue) 8%, transparent), transparent 62%),
    var(--panel-soft);
}

.account-profile-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.account-profile-title strong {
  color: var(--text);
  font-size: 0.95rem;
}

.account-profile-card .primary-button {
  justify-self: end;
  min-height: 40px;
  padding-inline: 18px;
}

.utility-dialog {
  width: min(620px, calc(100vw - 28px));
}

#slidesExportDialog {
  inset-block-start: max(14px, env(safe-area-inset-top, 0px));
  transform: translateX(-50%);
  width: min(840px, calc(100vw - 28px));
  max-height: calc(var(--lineup-viewport-height, 100dvh) - 28px);
  overflow: hidden;
}

#slidesExportDialog form {
  max-height: calc(var(--lineup-viewport-height, 100dvh) - 28px);
  overflow: auto;
  overscroll-behavior: contain;
}

.sheets-dialog {
  inset-block-start: 50%;
  inset-inline-start: 50%;
  transform: translate(-50%, -50%);
  width: min(1120px, calc(100vw - 28px));
  height: min(820px, calc(var(--lineup-viewport-height, 100dvh) - 28px));
  max-height: calc(var(--lineup-viewport-height, 100dvh) - 28px);
}

.sheets-shell {
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr);
  gap: 10px;
  height: 100%;
  padding: 14px;
  overflow: hidden;
}

.sheets-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.sheets-toolbar .icon-button {
  width: 40px;
  height: 40px;
}

.sheets-sync-hint {
  flex: 1 1 240px;
  min-width: min(100%, 220px);
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 800;
  line-height: 1.35;
}

.sheets-layout {
  display: grid;
  grid-template-columns: minmax(180px, 250px) minmax(0, 1fr);
  gap: 12px;
  min-height: 0;
}

.sheets-list-panel,
.sheets-preview-panel {
  min-height: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.035);
}

.sheets-list-panel {
  overflow: auto;
}

.sheets-list {
  display: grid;
  gap: 8px;
  padding: 10px;
}

.sheet-item {
  display: grid;
  gap: 3px;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 10px;
  color: var(--text);
  background: rgba(255, 255, 255, 0.035);
  text-align: left;
}

.sheet-item.active {
  border-color: var(--green);
  background: color-mix(in srgb, var(--green) 12%, transparent);
}

.sheet-item-name {
  overflow: hidden;
  font-weight: 850;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.sheet-item-meta {
  color: var(--muted);
  font-size: 0.74rem;
  font-weight: 750;
}

.sheets-preview-panel {
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr);
  gap: 9px;
  padding: 10px;
  overflow: hidden;
}

.sheets-preview-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.sheets-preview-meta {
  min-width: 0;
  overflow: hidden;
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 800;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.sheets-page-controls {
  display: flex;
  align-items: center;
  gap: 6px;
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 850;
  white-space: nowrap;
}

.sheets-page-controls .icon-button {
  width: 34px;
  height: 34px;
}

.sheets-markup-tools {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  align-items: center;
}

.sheets-markup-tools .icon-action.active {
  border-color: var(--green);
  color: var(--green);
  background: rgba(91, 146, 255, 0.14);
}

.sheets-preview-stage {
  position: relative;
  display: grid;
  place-items: center;
  min-height: 0;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--line-strong) 70%, transparent);
  border-radius: var(--radius);
  background:
    linear-gradient(45deg, rgba(255, 255, 255, 0.04) 25%, transparent 25% 75%, rgba(255, 255, 255, 0.04) 75%),
    #080b0c;
  background-size: 22px 22px;
}

.sheets-preview-stage.is-drop-target {
  border-color: color-mix(in srgb, var(--green) 78%, white);
  background:
    linear-gradient(45deg, color-mix(in srgb, var(--green) 13%, transparent) 25%, transparent 25% 75%, color-mix(in srgb, var(--green) 13%, transparent) 75%),
    #080b0c;
  box-shadow:
    inset 0 0 0 2px color-mix(in srgb, var(--green) 58%, transparent),
    0 0 0 4px color-mix(in srgb, var(--green) 14%, transparent);
}

.sheets-drop-overlay {
  position: absolute;
  inset: 16px;
  z-index: 4;
  display: grid;
  place-items: center;
  border: 2px dashed color-mix(in srgb, var(--green) 72%, white);
  border-radius: calc(var(--radius) - 2px);
  color: #071428;
  background: color-mix(in srgb, var(--green) 88%, white);
  font-size: 1rem;
  font-weight: 950;
  pointer-events: none;
  box-shadow: 0 18px 42px rgba(0, 0, 0, 0.28);
}

.sheets-drop-overlay[hidden] {
  display: none;
}

.sheets-preview-stage img,
.sheets-preview-stage iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
  object-fit: contain;
  background: #ffffff;
}

.sheets-preview-stage iframe {
  object-fit: fill;
}

.sheets-preview-stage canvas {
  position: absolute;
  inset: 0;
  z-index: 2;
  width: 100%;
  height: 100%;
  cursor: crosshair;
  touch-action: none;
}

.sheets-preview-stage .empty-state {
  position: relative;
  z-index: 1;
}

:root[data-theme="light"] .sheets-list-panel,
:root[data-theme="light"] .sheets-preview-panel,
:root[data-theme="light"] .sheet-item {
  border-color: #c4d0df;
  background: #ffffff;
}

.account-dialog {
  width: min(640px, calc(100vw - 28px));
  inset-block-start: max(14px, env(safe-area-inset-top, 0px));
  transform: translateX(-50%);
}

.account-dialog form {
  max-height: min(760px, calc(var(--lineup-viewport-height, 100dvh) - 28px));
  overflow: auto;
  overscroll-behavior: contain;
}

.account-dialog .form-grid {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 220px), 1fr));
  align-items: start;
}

.account-dialog label {
  min-width: 0;
}

.account-dialog input,
.account-dialog select {
  width: 100%;
  min-width: 0;
}

.password-entry-label {
  gap: 6px;
}

.password-entry-field {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.04);
}

.password-entry-field:focus-within {
  border-color: color-mix(in srgb, var(--green) 62%, var(--line-strong));
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--green) 16%, transparent);
}

.account-dialog .password-entry-field input {
  border: 0;
  background: transparent;
  box-shadow: none;
}

.password-visibility-toggle {
  display: grid;
  width: 44px;
  height: 44px;
  place-items: center;
  border: 0;
  color: var(--muted);
  background: transparent;
}

.password-visibility-toggle:hover {
  color: var(--text);
}

.password-visibility-toggle .password-eye-off-icon {
  display: none;
}

.password-visibility-toggle[aria-pressed="true"] .password-eye-icon {
  display: none;
}

.password-visibility-toggle[aria-pressed="true"] .password-eye-off-icon {
  display: block;
}

.utility-copy {
  margin: -4px 0 0;
  color: var(--muted);
  font-size: 0.92rem;
  line-height: 1.42;
}

.settings-action-list {
  display: grid;
  gap: 8px;
}

.settings-action-button {
  display: grid;
  grid-template-columns: 36px minmax(0, 1fr);
  align-items: center;
  gap: 10px;
  min-height: 52px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 8px 10px;
  color: var(--text);
  background: rgba(255, 255, 255, 0.035);
  text-align: left;
}

:root[data-theme="light"] .settings-action-button {
  border-color: #c2cedb;
  background: #ffffff;
}

.settings-section-label {
  margin: 0 0 6px;
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 900;
  text-transform: uppercase;
}

.settings-select-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(150px, 0.78fr);
  align-items: center;
  gap: 12px;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 10px;
  background: color-mix(in srgb, var(--panel-2) 76%, transparent);
}

.settings-select-row > span {
  display: grid;
  gap: 2px;
}

.settings-select-row strong {
  font-size: 0.88rem;
}

.settings-select-row small {
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 700;
}

.settings-select-row select {
  width: 100%;
  min-height: 38px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 0 10px;
  color: var(--text);
  background: var(--panel);
  font: inherit;
  font-size: 0.82rem;
  font-weight: 800;
}

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

.skin-choice {
  display: grid;
  gap: 6px;
  min-height: 74px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 8px;
  color: var(--text);
  background: rgba(255, 255, 255, 0.035);
  text-align: left;
}

:root[data-theme="light"] .skin-choice {
  border-color: #c2cedb;
  background: #ffffff;
}

.skin-choice:hover,
.skin-choice.active {
  border-color: var(--green);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--green) 24%, transparent);
}

.skin-choice.active {
  background: color-mix(in srgb, var(--green) 14%, transparent);
}

.skin-choice strong,
.skin-choice small {
  display: block;
}

.skin-choice strong {
  font-size: 0.92rem;
  line-height: 1.05;
}

.skin-choice small {
  color: var(--muted);
  font-size: 0.72rem;
  line-height: 1.15;
}

.skin-swatch {
  display: block;
  height: 28px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 7px;
}

.skin-swatch.simple {
  background: linear-gradient(135deg, #0f1830 0 48%, #5b92ff 49% 64%, #f3ae22 65%);
}

.skin-swatch.premium {
  background: linear-gradient(135deg, #090908 0 48%, #d6aa51 49% 64%, #fff4d6 65%);
}

.skin-swatch.playful {
  background: linear-gradient(135deg, #40b8ff 0 36%, #5e7cff 37% 68%, #ffba2e 69%);
}

.accent-choice-grid {
  display: flex;
  flex-wrap: nowrap;
  gap: 8px;
  overflow-x: auto;
  padding-bottom: 2px;
  scrollbar-width: thin;
}

.accent-choice {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 42px;
  width: 42px;
  min-width: 42px;
  min-height: 38px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 0;
  color: var(--text);
  background: rgba(255, 255, 255, 0.035);
  font-size: 0.82rem;
  font-weight: 900;
}

.accent-choice > span:not(.accent-swatch) {
  display: none;
}

:root[data-theme="light"] .accent-choice {
  border-color: #c2cedb;
  background: #ffffff;
}

.accent-choice:hover,
.accent-choice.active {
  border-color: var(--green);
  background: color-mix(in srgb, var(--green) 13%, transparent);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--green) 22%, transparent);
}

.accent-swatch {
  width: 22px;
  height: 22px;
  border-radius: 999px;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.34);
}

.accent-swatch.blue { background: #5b92ff; }
.accent-swatch.green { background: #31c46b; }
.accent-swatch.yellow { background: #f2b632; }
.accent-swatch.teal { background: #22c7b8; }
.accent-swatch.rose { background: #f06a8c; }
.accent-swatch.purple { background: #a678ff; }

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

.notation-choice {
  display: grid;
  gap: 4px;
  min-height: 64px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 10px 12px;
  color: var(--text);
  background: rgba(255, 255, 255, 0.035);
  text-align: left;
}

:root[data-theme="light"] .notation-choice {
  border-color: #c2cedb;
  background: #ffffff;
}

.notation-choice.active,
.notation-choice:hover {
  border-color: var(--green);
  background: color-mix(in srgb, var(--green) 13%, transparent);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--green) 22%, transparent);
}

.notation-choice strong,
.notation-choice small {
  display: block;
}

.notation-choice small {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 760;
}

.settings-action-button:hover {
  border-color: var(--green);
  background: color-mix(in srgb, var(--green) 12%, transparent);
  transform: translateY(-1px);
}

.settings-action-icon {
  display: inline-grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border: 1px solid var(--line-strong);
  border-radius: var(--radius);
  color: var(--green);
  background: rgba(91, 146, 255, 0.1);
}

.settings-action-icon svg {
  width: 18px;
  height: 18px;
}

.settings-action-button strong,
.settings-action-button small {
  display: block;
}

.settings-action-button strong {
  font-size: 0.95rem;
  line-height: 1.1;
}

.settings-action-button small {
  margin-top: 4px;
  color: var(--muted);
  font-size: 0.82rem;
  line-height: 1.2;
}

.quick-add-dialog {
  width: min(760px, calc(100vw - 28px));
}

.quick-add-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.quick-paste-panel {
  display: grid;
  gap: 10px;
}

.quick-paste-panel .ghost-button {
  justify-self: start;
}

.quick-add-head,
.quick-add-row {
  display: grid;
  grid-template-columns: 34px minmax(160px, 1fr) 148px minmax(150px, 0.85fr) 42px;
  gap: 10px;
  align-items: center;
}

.quick-add-head {
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 900;
  text-transform: uppercase;
}

.quick-add-rows {
  display: grid;
  max-height: min(42vh, 360px);
  overflow: auto;
  gap: 8px;
  padding-right: 4px;
}

.quick-add-row {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.035);
  padding: 8px;
}

.quick-add-row input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: var(--green);
  justify-self: center;
}

.quick-add-row input,
.quick-add-row select {
  height: 38px;
}

.quick-banger-toggle {
  display: inline-grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: transparent;
  color: var(--muted);
}

.quick-banger-toggle:hover,
.quick-banger-toggle.active {
  border-color: rgba(243, 174, 34, 0.7);
  color: var(--amber);
  background: rgba(243, 174, 34, 0.12);
}

.quick-banger-toggle svg {
  width: 18px;
  height: 18px;
}

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

.slides-theme-export-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
  gap: 14px;
  align-items: start;
}

.slides-theme-controls {
  display: grid;
  gap: 12px;
}

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

.theme-preset-row label {
  min-width: 0;
}

.theme-preset-row .icon-only-button {
  width: 44px;
  height: 44px;
  padding: 0;
}

.slides-more-background-button {
  justify-content: flex-start;
  width: 100%;
  min-height: 44px;
  gap: 8px;
}

.slides-background-dialog {
  width: min(560px, calc(100vw - 28px));
}

.slides-background-settings {
  display: grid;
  gap: 12px;
}

.text-color-control {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
}

.text-color-control span {
  margin-bottom: 0;
}

.text-color-control input[type="color"] {
  width: 52px;
  height: 42px;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 4px;
  background: var(--panel-2);
}

.color-toggle-control > span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.color-toggle-control.is-disabled > input[type="color"] {
  opacity: 0.42;
  cursor: not-allowed;
}

.theme-crop-controls {
  display: grid;
  gap: 8px;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 10px;
  background: rgba(255, 255, 255, 0.035);
}

.theme-crop-controls label {
  display: grid;
  gap: 4px;
}

.theme-crop-controls label.is-disabled {
  opacity: 0.42;
}

.theme-crop-controls label.is-disabled input {
  cursor: not-allowed;
}

.theme-crop-controls span {
  color: var(--muted);
  font-size: 0.68rem;
  font-weight: 850;
  text-transform: uppercase;
}

.theme-crop-controls input[type="range"] {
  height: 24px;
  padding: 0;
}

.theme-image-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

.slide-export-options {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(118px, 0.9fr) repeat(2, minmax(82px, 0.72fr));
  gap: 8px;
  align-items: end;
}

.slide-title-mode-control,
.slide-title-numbers-control {
  display: grid;
  gap: 5px;
  min-width: 0;
}

.slide-title-mode-control span,
.slide-title-numbers-control span {
  color: var(--muted);
  font-size: 0.68rem;
  font-weight: 850;
  text-transform: uppercase;
}

.slide-title-mode-control select,
.slide-title-numbers-control input {
  min-height: 38px;
  border-radius: 10px;
}

.slide-title-numbers-control.is-disabled {
  opacity: 0.48;
}

.slides-theme-preview {
  position: relative;
  align-self: start;
  width: 100%;
  min-height: 0;
  aspect-ratio: 16 / 9;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
  display: grid;
  place-items: center;
  background-position: center;
  background-size: cover;
  color: #ffffff;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.04);
}

.slides-export-preview-image {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  background: #020617;
}

.slides-theme-preview.theme-shabbat {
  background-image:
    radial-gradient(ellipse at 42% 68%, rgba(255, 210, 118, 0.54), transparent 16%),
    radial-gradient(ellipse at 58% 68%, rgba(255, 232, 168, 0.44), transparent 15%),
    linear-gradient(180deg, rgba(2, 5, 12, 0.12), rgba(2, 5, 12, 0.58)),
    linear-gradient(145deg, #211005, #05070b 72%);
}

.slides-theme-preview.theme-shabbat::before,
.slides-theme-preview.theme-shabbat::after {
  content: "";
  position: absolute;
  bottom: 14%;
  width: 5%;
  height: 28%;
  border-radius: 999px 999px 12px 12px;
  background: linear-gradient(90deg, #b98743, #fff4d8 34%, #e0bd75 70%, #8d5728);
  box-shadow: 0 0 36px rgba(255, 192, 90, 0.24);
}

.slides-theme-preview.theme-shabbat::before {
  left: 42%;
}

.slides-theme-preview.theme-shabbat::after {
  right: 42%;
}

.slides-theme-preview.theme-campfire {
  background-image:
    radial-gradient(ellipse at 50% 79%, rgba(255, 214, 106, 0.72), transparent 13%),
    radial-gradient(ellipse at 50% 100%, rgba(255, 100, 24, 0.54), transparent 34%),
    linear-gradient(180deg, #061328 0%, #12111a 58%, #090403 100%);
}

.slides-theme-preview.theme-campfire::before {
  content: "";
  position: absolute;
  left: 35%;
  right: 35%;
  bottom: 10%;
  height: 22%;
  background:
    radial-gradient(ellipse at 38% 100%, #ff6b1d 0 30%, transparent 31%),
    radial-gradient(ellipse at 50% 82%, #ffe07b 0 24%, transparent 25%),
    radial-gradient(ellipse at 62% 100%, #ff8e31 0 28%, transparent 29%);
  filter: drop-shadow(0 0 30px rgba(255, 118, 33, 0.58));
}

.slides-theme-preview.theme-bright {
  color: #101827;
}

.slides-theme-preview.has-custom-image {
  background: #05070b;
}

.slides-theme-preview.has-custom-image::before,
.slides-theme-preview.has-custom-image::after {
  content: "";
  position: absolute;
  inset: 0;
}

.slides-theme-preview.has-custom-image::before {
  inset: -2%;
  background-image: var(--theme-image);
  background-position: var(--theme-x, 50%) var(--theme-y, 50%);
  background-size: cover;
  transform: scale(var(--theme-scale, 1));
  transform-origin: var(--theme-x, 50%) var(--theme-y, 50%);
}

.slides-theme-preview.has-custom-image::after {
  background: linear-gradient(rgba(3, 7, 18, 0.42), rgba(3, 7, 18, 0.58));
}

.slides-theme-preview.is-full-image-slide::before,
.slides-theme-preview.is-full-image-slide::after {
  display: none;
}

.slides-theme-preview-content {
  position: relative;
  z-index: 1;
  min-height: 100%;
  width: 100%;
  display: grid;
  grid-template-rows: 1fr auto;
  align-items: center;
  gap: 10px;
  padding: clamp(20px, 5vw, 56px);
  padding-bottom: clamp(38px, 5vw, 64px);
  text-align: center;
  text-shadow: 0 2px 18px rgba(0, 0, 0, 0.55);
}

.slides-theme-preview .preview-slide-title {
  position: absolute;
  top: 14px;
  left: 18px;
  right: 88px;
  overflow: hidden;
  opacity: 0.72;
  font-size: clamp(0.58rem, 1.3vw, 0.82rem);
  letter-spacing: 0.08em;
  text-overflow: ellipsis;
  text-transform: uppercase;
  white-space: nowrap;
}

.preview-slide-count-overlay {
  position: absolute;
  top: 14px;
  right: 18px;
  max-width: 68px;
  overflow: hidden;
  opacity: 0.74;
  font-size: clamp(0.54rem, 1.1vw, 0.72rem);
  font-weight: 900;
  line-height: 1.05;
  text-align: right;
  text-transform: none;
}

.slides-theme-preview-content span,
.slides-theme-preview-content small {
  font-weight: 800;
  color: currentColor;
  opacity: 0.78;
}

.preview-slide-lines {
  display: grid;
  gap: 0.18em;
  place-items: center;
}

.slides-theme-preview-content strong {
  display: block;
  font-size: clamp(1.15rem, 2.6vw, 2.05rem);
  font-weight: 700;
  line-height: 0.98;
  color: currentColor;
}

.preview-slide-credits {
  position: absolute;
  bottom: 18px;
  left: 20px;
  z-index: 2;
  max-width: 42%;
  overflow: hidden;
  color: currentColor;
  font-size: 0.72rem;
  font-weight: 800;
  opacity: 0.78;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.preview-slide-brand {
  position: absolute;
  right: 14px;
  bottom: 10px;
  display: grid;
  justify-items: end;
  min-width: 72px;
  color: currentColor;
  opacity: 0.58;
  line-height: 1;
  text-align: right;
}

.preview-slide-brand span {
  font-size: clamp(0.34rem, 0.82vw, 0.46rem);
  opacity: 0.78;
}

.preview-slide-brand b {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: clamp(0.42rem, 0.96vw, 0.56rem);
  font-weight: 700;
}

.preview-slide-brand i {
  display: inline-grid;
  place-items: center;
  width: 11px;
  height: 11px;
  border: 1px solid currentColor;
  border-radius: 4px;
  font-style: normal;
  font-size: 0.7em;
}

.preview-slide-brand em {
  margin-top: 2px;
  font-size: clamp(0.24rem, 0.62vw, 0.34rem);
  font-style: normal;
  font-weight: 700;
  letter-spacing: 0.08em;
}

.slides-export-preview-count {
  position: absolute;
  bottom: 12px;
  left: 50%;
  z-index: 3;
  display: inline-grid;
  place-items: center;
  min-width: 48px;
  height: 28px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 999px;
  padding: 0 10px;
  color: #ffffff;
  background: rgba(3, 7, 18, 0.48);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
  font-size: 0.72rem;
  font-weight: 900;
  line-height: 1;
  backdrop-filter: blur(10px);
  transform: translateX(-50%);
}

.slides-export-preview-nav {
  position: absolute;
  top: 50%;
  right: 10px;
  left: 10px;
  z-index: 3;
  display: flex;
  justify-content: space-between;
  pointer-events: none;
  transform: translateY(-50%);
}

.slides-export-preview-nav button {
  display: inline-grid;
  place-items: center;
  width: 36px;
  height: 36px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 999px;
  color: #ffffff;
  background: rgba(3, 7, 18, 0.54);
  box-shadow: 0 12px 34px rgba(0, 0, 0, 0.24);
  pointer-events: auto;
  backdrop-filter: blur(10px);
}

.slides-export-preview-nav button:disabled {
  opacity: 0.36;
  cursor: not-allowed;
}

.slides-export-preview-nav svg {
  width: 20px;
  height: 20px;
  fill: none;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 2.5;
}

.slide-title-option {
  display: flex;
  align-items: center;
  gap: 9px;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 11px 12px;
  color: var(--text);
  background: rgba(255, 255, 255, 0.035);
  font-size: 0.86rem;
  font-weight: 850;
}

.slide-title-option input {
  width: 18px;
  height: 18px;
  accent-color: var(--green);
}

.theme-export-card {
  position: relative;
  display: grid;
  gap: 5px;
  min-height: 74px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 10px 12px;
  color: var(--text);
  background: rgba(255, 255, 255, 0.035);
}

:root[data-theme="light"] .theme-export-card {
  background: #ffffff;
}

.theme-export-card input {
  position: absolute;
  opacity: 0;
}

.theme-export-card strong,
.theme-export-card small {
  display: block;
}

.theme-export-card strong {
  font-size: 0.95rem;
}

.theme-export-card small {
  color: var(--muted);
  font-size: 0.78rem;
  line-height: 1.25;
}

.theme-export-card:has(input:checked) {
  border-color: var(--green);
  background: color-mix(in srgb, var(--green) 14%, transparent);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--green) 22%, transparent);
}

.export-dialog-inner {
  display: grid;
  grid-template-columns: minmax(230px, 286px) minmax(0, 1fr);
  grid-template-rows: auto auto minmax(0, 1fr) auto auto;
  gap: 8px 12px;
  height: 100%;
  min-height: 0;
  overflow: hidden;
  padding: 12px;
}

.export-dialog .dialog-header {
  grid-column: 1 / -1;
  grid-row: 1;
  min-height: 0;
  margin-bottom: 0;
}

.export-dialog .dialog-header [data-close-dialog] {
  position: relative;
  z-index: 90;
}

.export-dialog .dialog-header h2 {
  font-size: clamp(1.45rem, 2.2vw, 2rem);
  line-height: 1;
}

.export-dialog .dialog-header .eyebrow {
  margin-bottom: 4px;
}

.export-tabs {
  grid-column: 1 / -1;
  grid-row: 2;
  display: flex;
  gap: 6px;
  min-width: 0;
  overflow-x: auto;
  padding-bottom: 1px;
  scrollbar-width: thin;
}

.export-tab {
  flex: 0 0 auto;
  min-height: 34px;
  border: 1px solid var(--line);
  border-radius: 9px;
  padding: 0 12px;
  color: var(--muted);
  background: rgba(255, 255, 255, 0.035);
  font-size: 0.78rem;
  font-weight: 900;
}

.export-tab.active {
  border-color: var(--green);
  color: #071428;
  background: var(--green);
}

.export-settings {
  grid-column: 1;
  grid-row: 3;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-content: start;
  gap: 7px;
  min-height: 0;
  max-height: 100%;
  overflow: auto;
  border: 1px solid color-mix(in srgb, var(--line-strong) 70%, transparent);
  border-radius: var(--radius);
  padding: 8px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.04), transparent),
    rgba(255, 255, 255, 0.025);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

:root[data-theme="light"] .export-settings {
  border-color: #c1cedd;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.76), transparent),
    #edf3fa;
}

.export-option {
  position: relative;
  display: grid;
  align-content: start;
  gap: 5px;
  min-height: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 7px;
  width: 100%;
  min-width: 0;
  color: var(--text);
  font-weight: 750;
  background: color-mix(in srgb, var(--panel-2) 82%, transparent);
}

:root[data-theme="light"] .export-option {
  border-color: #c7d3e2;
  background: #ffffff;
}

.export-option::before {
  content: "Option";
  color: var(--muted);
  font-size: 0.62rem;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.export-toggle-row {
  display: grid;
  grid-column: 1 / -1;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 7px;
}

.export-toggle-row .export-option {
  min-height: 42px;
  padding: 0;
}

.credit-toggle::before {
  content: "Credits";
}

.real-key-toggle::before {
  content: "Real key";
}

.fit-toggle::before {
  content: "Scale";
}

.export-toggle-row .credit-toggle::before,
.export-toggle-row .real-key-toggle::before {
  content: none;
}

.export-option input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.export-option span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  border: 1px solid var(--line-strong);
  border-radius: var(--radius);
  margin: 0;
  padding: 0 8px;
  color: var(--muted);
  background: rgba(255, 255, 255, 0.03);
  font-size: 0.78rem;
  font-weight: 800;
}

.export-toggle-row .export-option span {
  min-height: 42px;
  width: 100%;
  border-radius: var(--radius);
  font-weight: 900;
}

.credit-toggle,
.fit-toggle,
.real-key-toggle {
  width: 100%;
}

.export-option input:checked + span {
  border-color: var(--green);
  color: #06120d;
  background: var(--green);
}

.orientation-control {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  align-items: end;
  align-content: space-between;
  gap: 0;
  min-height: 0;
  min-inline-size: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  margin: 0;
  padding: 7px;
  background: color-mix(in srgb, var(--panel-2) 82%, transparent);
}

.font-control {
  min-width: 0;
}

:root[data-theme="light"] .orientation-control {
  border-color: #c7d3e2;
  background: #ffffff;
}

.orientation-control legend {
  position: static;
  width: 100%;
  padding: 0;
  margin: 0 0 5px;
  color: var(--muted);
  font-size: 0.62rem;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.orientation-control label {
  position: relative;
  display: inline-flex;
}

.orientation-control input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.orientation-control span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  border: 1px solid var(--line-strong);
  padding: 0 8px;
  color: var(--muted);
  background: rgba(255, 255, 255, 0.03);
  font-size: 0.78rem;
  font-weight: 800;
}

.orientation-control label + label span {
  border-left: 0;
}

.orientation-control:not(.font-control) span {
  width: 34px;
  padding: 0;
}

.orientation-icon::before {
  content: "";
  display: block;
  border: 2px solid currentColor;
  border-radius: 3px;
}

.portrait-icon::before {
  width: 12px;
  height: 20px;
}

.landscape-icon::before {
  width: 22px;
  height: 12px;
}

.orientation-control label:first-of-type span {
  border-radius: var(--radius) 0 0 var(--radius);
}

.orientation-control label:last-of-type span {
  border-left: 0;
  border-radius: 0 var(--radius) var(--radius) 0;
}

.orientation-control input:checked + span {
  border-color: var(--green);
  color: #06120d;
  background: var(--green);
}

.font-control label:not(:first-of-type) span {
  border-left: 0;
  border-radius: 0;
}

.font-control label:last-of-type span {
  border-radius: 0 var(--radius) var(--radius) 0;
}

.spacing-control label span {
  min-width: 54px;
}

.columns-control label span {
  min-width: 40px;
}

.pages-control label span {
  min-width: 38px;
}

.font-control,
.spacing-control {
  grid-column: 1 / -1;
}

.form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.song-meta-grid {
  grid-template-columns: minmax(0, 1fr) auto auto;
  align-items: end;
}

.song-credit-key-grid {
  grid-template-columns: minmax(0, 1fr) 96px 136px 42px;
  align-items: end;
}

.song-credit-key-grid label,
.song-credit-key-grid .key-picker-field {
  min-width: 0;
}

.song-preview-key-button {
  width: 42px;
  min-width: 42px;
  height: 42px;
  min-height: 42px;
  align-self: end;
  border-radius: var(--radius);
}

.song-small-grid {
  grid-template-columns: 96px 136px minmax(130px, 1fr) 112px;
  justify-content: start;
  align-items: end;
}

.key-picker-field {
  display: grid;
  gap: 7px;
}

.key-picker-trigger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-height: 42px;
  border: 1px solid var(--line-strong);
  border-radius: var(--radius);
  padding: 0 12px;
  color: var(--text);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.015)),
    rgba(255, 255, 255, 0.035);
  font-size: 0.95rem;
  font-weight: 900;
}

.key-picker-trigger:hover,
.key-picker-trigger[aria-expanded="true"] {
  border-color: var(--green);
  background: color-mix(in srgb, var(--green) 12%, transparent);
}

.key-picker-trigger svg {
  width: 15px;
  height: 15px;
}

.key-picker-menu {
  position: fixed;
  z-index: 9999;
  display: grid;
  gap: 10px;
  border: 1px solid color-mix(in srgb, var(--line-strong) 82%, transparent);
  border-radius: 14px;
  padding: 10px;
  color: var(--text);
  background: color-mix(in srgb, var(--panel) 97%, transparent);
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.42);
  animation: key-picker-in 140ms ease both;
}

.key-picker-close-button {
  position: absolute;
  top: -9px;
  right: -9px;
  display: grid;
  place-items: center;
  width: 28px;
  min-width: 28px;
  height: 28px;
  min-height: 28px;
  border: 1px solid color-mix(in srgb, var(--line-strong) 82%, transparent);
  border-radius: 999px;
  padding: 0;
  color: var(--text);
  background: color-mix(in srgb, var(--panel-2) 96%, transparent);
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.24);
}

.key-picker-close-button svg {
  width: 15px;
  height: 15px;
  stroke: currentColor;
  stroke-width: 2.3;
  fill: none;
}

:root[data-theme="light"] .key-picker-menu {
  background: #ffffff;
  box-shadow: 0 18px 46px rgba(40, 58, 82, 0.18);
}

.key-picker-menu[hidden] {
  display: none !important;
}

.key-picker-quality-row {
  display: grid;
  grid-template-columns: 1fr 1fr auto;
  gap: 6px;
}

.key-picker-quality-row button {
  min-height: 30px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 0 8px;
  color: var(--muted);
  background: rgba(255, 255, 255, 0.035);
  font-size: 0.76rem;
  font-weight: 900;
}

.key-picker-quality-row button.active {
  border-color: var(--green);
  color: #071428;
  background: var(--green);
}

.key-picker-quality-row .key-notation-switch {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  width: 54px;
  padding: 2px;
  color: var(--muted);
  background: color-mix(in srgb, var(--panel-2) 86%, transparent);
}

.key-notation-switch::before {
  position: absolute;
  top: 3px;
  bottom: 3px;
  left: 3px;
  width: calc(50% - 3px);
  border-radius: 6px;
  background: var(--green);
  content: "";
  transition: transform 140ms ease;
}

.key-notation-switch.sharp::before {
  transform: translateX(100%);
}

.key-notation-switch span {
  position: relative;
  z-index: 1;
  display: grid;
  place-items: center;
  min-height: 24px;
}

.key-notation-switch.flat span:first-child,
.key-notation-switch.sharp span:last-child {
  color: #071428;
}

.key-piano {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  grid-template-rows: 32px 44px;
  gap: 5px;
}

.key-piano button {
  display: grid;
  place-items: center;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 8px;
  font-weight: 950;
}

.key-black {
  grid-row: 1;
  align-self: end;
  justify-self: center;
  width: min(52px, 82%);
  height: 28px;
  color: #f4f7f5;
  background: #151a1d;
  font-size: 0.72rem;
}

:root[data-theme="light"] .key-black {
  color: #ffffff;
  background: #1b2635;
}

.key-white {
  grid-row: 2;
  min-height: 42px;
  color: var(--text);
  background: color-mix(in srgb, var(--panel-2) 78%, transparent);
  font-size: 0.88rem;
}

.key-piano button.active {
  border-color: var(--green);
  color: #071428;
  background: var(--green);
}

@keyframes key-picker-in {
  from {
    opacity: 0;
    transform: translateY(-4px) scale(0.98);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.category-choice > span {
  display: block;
  margin-bottom: 7px;
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 700;
}

.category-choice-buttons {
  display: flex;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.025);
}

:root[data-theme="light"] .category-choice-buttons {
  border-color: #bfccd9;
  background: #ffffff;
}

.category-choice-button {
  flex: 1 1 0;
  min-height: 44px;
  border: 0;
  border-left: 1px solid var(--line);
  padding: 0 10px;
  color: var(--muted);
  background: transparent;
  font-weight: 800;
}

.category-choice-button:first-child {
  border-left: 0;
}

.category-choice-button.active {
  color: #071428;
  background: var(--green);
}

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

.tag-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  min-height: 0;
}

.tag-chip-list[hidden] {
  display: none;
}

.tag-chip {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  min-height: 28px;
  border: 1px solid color-mix(in srgb, var(--green) 58%, var(--line));
  border-radius: 999px;
  padding: 0 8px 0 10px;
  color: var(--text);
  background: color-mix(in srgb, var(--green) 14%, transparent);
  font-size: 0.76rem;
  font-weight: 850;
}

.tag-chip strong {
  display: grid;
  place-items: center;
  width: 17px;
  min-width: 17px;
  height: 17px;
  border-radius: 999px;
  color: var(--panel);
  background: var(--green);
  font-size: 0.72rem;
  line-height: 1;
}

.tag-suggestions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.tag-suggestion {
  min-height: 26px;
  border: 1px solid color-mix(in srgb, var(--green) 42%, var(--line));
  border-radius: 999px;
  padding: 0 9px;
  color: var(--muted);
  background: color-mix(in srgb, var(--green) 8%, transparent);
  font-size: 0.74rem;
  font-weight: 800;
}

.tag-suggestion:hover {
  color: var(--text);
  border-color: var(--green);
  background: color-mix(in srgb, var(--green) 16%, transparent);
}

.song-title-matches {
  display: grid;
  gap: 7px;
  border: 1px solid color-mix(in srgb, var(--amber) 52%, var(--line));
  border-radius: 10px;
  padding: 9px;
  background: color-mix(in srgb, var(--amber) 10%, transparent);
}

.song-title-matches[hidden] {
  display: none;
}

.song-title-matches > strong {
  color: color-mix(in srgb, var(--amber) 86%, white);
  font-size: 0.74rem;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.song-title-matches button {
  display: grid;
  gap: 2px;
  min-height: 42px;
  border: 1px solid color-mix(in srgb, var(--amber) 44%, var(--line));
  border-radius: 8px;
  padding: 7px 9px;
  color: var(--text);
  background: color-mix(in srgb, var(--panel-2) 78%, transparent);
  text-align: left;
}

.song-title-matches button:hover {
  border-color: var(--amber);
  background: color-mix(in srgb, var(--amber) 14%, var(--panel-2));
}

.song-title-matches button span {
  font-weight: 900;
}

.song-title-matches button small {
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 750;
}

.duplicate-song-dialog {
  max-width: min(94vw, 560px);
}

.duplicate-song-matches {
  display: grid;
  gap: 8px;
  margin: 14px 0 4px;
}

.duplicate-song-match {
  display: grid;
  gap: 4px;
  width: 100%;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 11px 12px;
  color: var(--text);
  background: rgba(255, 255, 255, 0.035);
  text-align: left;
}

.duplicate-song-match:hover {
  border-color: var(--green);
  background: color-mix(in srgb, var(--green) 10%, transparent);
}

.duplicate-song-match span {
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 760;
}

.duplicate-actions {
  grid-template-columns: repeat(4, minmax(0, auto));
}

.song-manager-view {
  gap: 12px;
  padding-bottom: 0;
  border-radius: 14px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.025), transparent 220px);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.045),
    0 22px 50px rgba(0, 0, 0, 0.16);
  animation: manage-expand-in 240ms cubic-bezier(0.2, 0.8, 0.2, 1) both;
}

:root[data-theme="light"] .song-manager-view {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.48), transparent 220px);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.8),
    0 18px 44px rgba(40, 58, 82, 0.11);
}

.song-manager-toolbar {
  display: grid;
  grid-template-columns: minmax(130px, 0.5fr) minmax(220px, 1fr) minmax(130px, auto) minmax(130px, auto) repeat(4, 40px);
  align-items: end;
  gap: 10px;
}

.song-manager-title {
  display: grid;
  min-width: 0;
  gap: 1px;
}

.song-manager-title strong {
  overflow: hidden;
  color: var(--text);
  font-size: 1.06rem;
  font-weight: 900;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.song-manager-search {
  min-width: 0;
}

.song-manager-search input,
.song-manager-toolbar select {
  height: 42px;
  font-size: 0.9rem;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.055),
    0 9px 18px rgba(0, 0, 0, 0.13);
}

.song-manager-columns-menu {
  position: relative;
}

.song-manager-columns-menu summary {
  display: grid;
  align-self: end;
  place-items: center;
  width: 40px;
  height: 40px;
  min-height: 40px;
  list-style: none;
  line-height: 0;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.075),
    0 8px 17px rgba(0, 0, 0, 0.16);
}

#songManagerNewSongButton,
#songBankExportButton,
#songBankImportButton {
  display: grid;
  align-self: end;
  place-items: center;
  line-height: 0;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 8px 17px rgba(0, 0, 0, 0.16);
}

#songManagerNewSongButton svg,
#songBankExportButton svg,
#songBankImportButton svg {
  display: block;
  width: 18px;
  height: 18px;
}

.song-manager-columns-menu summary::-webkit-details-marker {
  display: none;
}

.song-manager-columns-menu[open] summary {
  border-color: color-mix(in srgb, var(--green) 44%, var(--line));
  color: var(--green);
  background: color-mix(in srgb, var(--green) 12%, transparent);
  box-shadow:
    inset 0 1px 0 color-mix(in srgb, var(--green) 22%, transparent),
    0 10px 20px color-mix(in srgb, var(--green) 18%, rgba(0, 0, 0, 0.22));
}

.song-manager-columns-list {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  z-index: 40;
  display: grid;
  width: 220px;
  max-height: min(420px, 70vh);
  overflow: auto;
  border: 1px solid color-mix(in srgb, var(--line-strong) 78%, transparent);
  border-radius: 12px;
  padding: 7px;
  background: color-mix(in srgb, var(--panel) 96%, transparent);
  box-shadow: 0 18px 52px rgba(0, 0, 0, 0.36);
}

:root[data-theme="light"] .song-manager-columns-list {
  background: #ffffff;
  box-shadow: 0 18px 48px rgba(40, 58, 82, 0.16);
}

.song-manager-column-choice {
  display: grid;
  grid-template-columns: 18px minmax(0, 1fr);
  align-items: center;
  gap: 9px;
  min-height: 34px;
  border-radius: 8px;
  padding: 0 8px;
  color: var(--text);
  font-size: 0.8rem;
  font-weight: 820;
}

.song-manager-column-choice:hover {
  background: color-mix(in srgb, var(--green) 10%, transparent);
}

.song-bank-transfer-dialog {
  width: min(720px, calc(100vw - 24px));
}

.song-bank-transfer-form {
  gap: 14px;
}

.song-transfer-search {
  width: 100%;
}

.export-file-name-field {
  display: grid;
  gap: 6px;
  margin: 2px 0 4px;
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 900;
}

.export-file-name-field input {
  width: 100%;
  min-height: 42px;
  border-radius: 12px;
  padding: 0 12px;
  font-size: 0.94rem;
  font-weight: 850;
}

.song-transfer-tools {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 38px;
}

.song-transfer-tools .ghost-button {
  min-height: 34px;
  padding: 0 14px;
}

.song-transfer-tools span {
  margin-left: auto;
  color: var(--muted);
  font-size: 0.86rem;
  font-weight: 850;
}

.song-transfer-list {
  display: grid;
  gap: 8px;
  max-height: min(430px, 48vh);
  overflow: auto;
  border: 1px solid color-mix(in srgb, var(--line) 84%, transparent);
  border-radius: 14px;
  padding: 8px;
  background: color-mix(in srgb, var(--panel-strong) 72%, transparent);
}

.song-transfer-row {
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr);
  align-items: start;
  gap: 10px;
  min-height: 58px;
  border: 1px solid color-mix(in srgb, var(--line) 82%, transparent);
  border-radius: 11px;
  padding: 10px 12px;
  background: color-mix(in srgb, var(--panel) 82%, transparent);
}

.song-transfer-row input {
  width: 18px;
  height: 18px;
  align-self: start;
  margin: 4px 0 0;
  accent-color: var(--green);
}

.song-transfer-main {
  display: grid;
  gap: 6px;
  min-width: 0;
}

.song-transfer-main strong {
  overflow: hidden;
  color: var(--text);
  font-size: 0.94rem;
  font-weight: 900;
  line-height: 1.1;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.song-transfer-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  color: var(--muted);
  font-size: 0.75rem;
  font-weight: 800;
}

.song-transfer-meta span {
  border: 1px solid color-mix(in srgb, var(--line) 72%, transparent);
  border-radius: 999px;
  padding: 1px 7px;
  background: color-mix(in srgb, var(--panel-strong) 76%, transparent);
  line-height: 1.2;
}

.setlist-import-targets {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.setlist-import-targets label {
  display: flex;
  align-items: center;
  min-height: 42px;
  gap: 8px;
  border: 1px solid var(--line);
  border-radius: 11px;
  padding: 0 10px;
  color: var(--text);
  background: color-mix(in srgb, var(--panel) 78%, transparent);
  font-size: 0.82rem;
  font-weight: 850;
}

.setlist-import-targets input {
  width: 17px;
  height: 17px;
  accent-color: var(--green);
}

.setlist-bank-capture-button {
  min-height: 34px;
  border: 1px solid color-mix(in srgb, var(--green) 42%, var(--line));
  border-radius: 10px;
  padding: 0 11px;
  color: var(--green);
  background: color-mix(in srgb, var(--green) 10%, transparent);
  font-size: 0.78rem;
  font-weight: 900;
  text-align: left;
}

.bank-panel.drop-ready {
  box-shadow:
    inset 0 0 0 2px color-mix(in srgb, var(--green) 64%, transparent),
    0 0 30px color-mix(in srgb, var(--green) 18%, transparent),
    var(--shadow);
}

.guest-mode-notice {
  position: fixed;
  right: max(14px, env(safe-area-inset-right, 0px));
  bottom: max(14px, env(safe-area-inset-bottom, 0px));
  left: max(14px, env(safe-area-inset-left, 0px));
  z-index: 80;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  border: 1px solid color-mix(in srgb, var(--amber) 42%, var(--line));
  border-radius: 14px;
  padding: 9px 12px;
  color: var(--text);
  background: color-mix(in srgb, var(--panel-strong) 96%, transparent);
  box-shadow: 0 16px 42px rgba(0, 0, 0, 0.28);
  font-size: 0.78rem;
  font-weight: 800;
}

.guest-mode-notice[hidden] {
  display: none;
}

.guest-mode-notice span {
  min-width: 0;
}

.guest-mode-notice button {
  flex: 0 0 auto;
  min-height: 30px;
  border: 1px solid color-mix(in srgb, var(--green) 54%, var(--line));
  border-radius: 999px;
  padding: 0 12px;
  color: #06120c;
  background: var(--green);
  font-weight: 950;
}

body.guest-mode .toast {
  bottom: calc(78px + env(safe-area-inset-bottom, 0px));
}

body.guest-mode .app-shell {
  padding-bottom: 58px;
}

.song-manager-column-choice input {
  width: 16px;
  height: 16px;
  margin: 0;
  accent-color: var(--green);
}

.song-manager-column-choice span {
  margin: 0;
  overflow: hidden;
  color: inherit;
  font: inherit;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.song-manager-bulk-bar {
  display: grid;
  grid-template-columns: minmax(86px, auto) auto auto minmax(140px, 1fr) minmax(118px, auto) minmax(96px, auto) minmax(104px, auto) auto auto;
  align-items: center;
  gap: 7px;
  border: 1px solid color-mix(in srgb, var(--green) 32%, var(--line));
  border-radius: 12px;
  padding: 7px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--green) 10%, transparent), transparent),
    color-mix(in srgb, var(--panel-strong) 78%, transparent);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.06),
    0 12px 28px rgba(0, 0, 0, 0.16);
}

.song-manager-bulk-bar[hidden] {
  display: none;
}

.song-manager-bulk-bar strong {
  color: var(--green);
  font-size: 0.82rem;
  font-weight: 950;
  white-space: nowrap;
}

.song-manager-bulk-bar input,
.song-manager-bulk-bar select {
  min-width: 0;
  height: 34px;
  border: 1px solid color-mix(in srgb, var(--line) 84%, transparent);
  border-radius: 9px;
  padding: 0 9px;
  color: var(--text);
  background: color-mix(in srgb, var(--panel) 82%, transparent);
  font-size: 0.78rem;
  font-weight: 820;
}

.song-manager-bulk-bar .ghost-button,
.song-manager-bulk-bar .primary-button,
.song-manager-bulk-bar .danger-button {
  min-height: 34px;
  padding: 0 11px;
  border-radius: 9px;
  font-size: 0.76rem;
  white-space: nowrap;
}

.song-manager-bulk-bar #songManagerBulkDeleteButton {
  min-width: 92px;
  border-color: rgba(255, 119, 111, 0.8);
  color: #fff5f3;
  background: linear-gradient(180deg, rgba(244, 85, 77, 0.94), rgba(168, 34, 29, 0.94));
  font-weight: 920;
  text-shadow: 0 1px 1px rgba(0, 0, 0, 0.38);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.1),
    0 8px 18px rgba(0, 0, 0, 0.22);
}

.song-manager-bulk-bar .danger-button.confirm-delete,
.song-manager-delete-button.confirm-delete {
  border-color: #ffb4ae;
  color: #ffffff;
  background:
    linear-gradient(180deg, #ff7b73, #dc2f27);
  box-shadow:
    0 0 0 1px color-mix(in srgb, #ffffff 12%, transparent) inset,
    0 0 22px color-mix(in srgb, var(--danger) 38%, transparent),
    0 10px 22px rgba(0, 0, 0, 0.24);
  text-shadow: 0 1px 1px rgba(0, 0, 0, 0.34);
}

#songManagerBulkDeleteButton.confirm-delete {
  min-width: 142px;
  color: #ffffff !important;
  border-color: #ffc1bc !important;
  background: linear-gradient(180deg, #ff8a82 0%, #e03228 100%) !important;
  opacity: 1 !important;
  font-weight: 950;
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.18) inset,
    0 0 24px rgba(255, 93, 85, 0.42),
    0 10px 24px rgba(0, 0, 0, 0.28);
}

.song-manager-grid {
  display: grid;
  align-content: start;
  gap: 6px;
  flex: 1 1 auto;
  min-height: 0;
  overflow: auto;
  border: 1px solid color-mix(in srgb, var(--line) 86%, transparent);
  border-radius: 12px;
  padding: 7px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.045), transparent 180px),
    rgba(255, 255, 255, 0.018);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.045),
    inset 0 -18px 34px rgba(0, 0, 0, 0.075),
    0 18px 42px rgba(0, 0, 0, 0.14);
  scrollbar-width: thin;
}

:root[data-theme="light"] .song-manager-grid {
  border-color: #c4cfdb;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.86), transparent 180px),
    #edf3f9;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.88),
    inset 0 -18px 34px rgba(97, 119, 144, 0.06),
    0 18px 40px rgba(40, 58, 82, 0.12);
}

.song-manager-row {
  display: grid;
  grid-template-columns: var(--song-manager-grid-template);
  align-items: center;
  width: max-content;
  min-width: 100%;
  min-height: 44px;
  border: 1px solid color-mix(in srgb, var(--line) 88%, transparent);
  border-radius: 10px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.064), rgba(255, 255, 255, 0.026)),
    color-mix(in srgb, var(--panel-2) 54%, transparent);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.05),
    0 2px 0 rgba(255, 255, 255, 0.022),
    0 10px 22px rgba(0, 0, 0, 0.18);
  overflow: clip;
  transition:
    border-color 90ms ease,
    transform 90ms ease;
}

.song-manager-row:nth-child(even):not(.song-manager-head-row) {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.07), rgba(255, 255, 255, 0.03)),
    color-mix(in srgb, var(--panel-2) 62%, transparent);
}

:root[data-theme="light"] .song-manager-row:nth-child(even):not(.song-manager-head-row) {
  background: linear-gradient(180deg, #ffffff, #f5f8fc);
}

.song-manager-row:hover:not(.song-manager-head-row) {
  border-color: color-mix(in srgb, var(--green) 34%, var(--line-strong));
  background: color-mix(in srgb, var(--green) 8%, transparent);
  transform: translateY(-1px);
}

.song-manager-row.is-selected:not(.song-manager-head-row) {
  border-color: color-mix(in srgb, var(--green) 54%, var(--line-strong));
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--green) 14%, transparent), color-mix(in srgb, var(--green) 8%, transparent)),
    color-mix(in srgb, var(--panel-2) 62%, transparent);
}

.song-manager-head-row {
  position: sticky;
  top: 0;
  z-index: 8;
  min-height: 36px;
  border-bottom-color: color-mix(in srgb, var(--line-strong) 92%, transparent);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--panel-2) 98%, #000000) 0%, color-mix(in srgb, var(--panel-2) 94%, #000000) 100%);
  box-shadow:
    0 8px 18px rgba(0, 0, 0, 0.18),
    0 0 0 1px color-mix(in srgb, var(--line) 72%, transparent);
  backdrop-filter: blur(14px);
}

:root[data-theme="light"] .song-manager-head-row {
  background: #e9f0f8;
  box-shadow: 0 8px 18px rgba(40, 58, 82, 0.08);
}

:root[data-theme="light"] .song-manager-row:not(.song-manager-head-row) {
  border-color: #cad5e2;
  background: linear-gradient(180deg, #ffffff, #f4f7fb);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.75),
    0 1px 0 rgba(21, 34, 54, 0.04),
    0 10px 22px rgba(40, 58, 82, 0.1);
}

:root[data-theme="light"] .song-manager-row:nth-child(even):not(.song-manager-head-row) {
  background: linear-gradient(180deg, #f8fbff, #eef4fb);
}

:root[data-theme="light"] .song-manager-row:hover:not(.song-manager-head-row) {
  border-color: #9fb2c8;
  background: #ffffff;
}

.song-manager-cell {
  position: relative;
  display: flex;
  align-items: center;
  min-width: 0;
  height: 100%;
  padding: 5px 8px;
  border-right: 1px solid color-mix(in srgb, var(--line) 68%, transparent);
}

.song-manager-cell.compact {
  justify-content: center;
  padding-inline: 4px;
}

.song-manager-select-cell {
  justify-content: center;
  padding-inline: 5px;
}

.song-manager-select-cell input {
  width: 18px;
  height: 18px;
  margin: 0;
  accent-color: var(--green);
}

.song-manager-head-select {
  background: color-mix(in srgb, var(--green) 6%, transparent);
}

.song-manager-head-cell {
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 950;
  line-height: 1;
  text-transform: uppercase;
  white-space: nowrap;
}

.song-manager-head-cell.is-sorted {
  color: var(--green);
}

.song-manager-head-cell.is-dragging {
  border-color: var(--green);
  color: var(--green);
  background: color-mix(in srgb, var(--green) 10%, transparent);
}

.song-manager-head-cell svg {
  width: 16px;
  height: 16px;
}

.song-manager-header-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  width: 100%;
  min-width: 0;
  height: 100%;
  min-height: 28px;
  border: 0;
  padding: 0 6px;
  color: inherit;
  background: transparent;
  font: inherit;
  line-height: 1;
  text-transform: inherit;
  cursor: grab;
}

.song-manager-header-button:active {
  cursor: grabbing;
}

.song-manager-header-button:focus-visible {
  border-radius: 7px;
  outline: 2px solid color-mix(in srgb, var(--green) 46%, transparent);
  outline-offset: -2px;
}

.song-manager-header-label {
  display: inline-flex;
  min-width: 0;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  text-overflow: ellipsis;
}

.song-manager-sort-mark {
  display: inline-grid;
  place-items: center;
  width: 10px;
  min-width: 10px;
  color: var(--green);
  font-size: 0.76rem;
  line-height: 1;
}

.song-manager-column-resizer {
  position: absolute;
  top: 0;
  right: -4px;
  z-index: 5;
  width: 8px;
  height: 100%;
  cursor: col-resize;
}

.song-manager-column-resizer::after {
  position: absolute;
  top: 8px;
  right: 3px;
  bottom: 8px;
  width: 2px;
  border-radius: 999px;
  background: transparent;
  content: "";
}

.song-manager-column-resizer:hover::after,
body.resizing-song-manager-column .song-manager-column-resizer::after {
  background: var(--green);
}

body.resizing-song-manager-column {
  cursor: col-resize;
  user-select: none;
}

body.reordering-song-manager-column {
  cursor: grabbing;
  user-select: none;
}

.song-manager-input,
.song-manager-select,
.manager-key-button {
  height: 34px;
  min-height: 34px;
  border: 1px solid transparent;
  border-radius: 7px;
  background: transparent;
  color: var(--text);
  font-size: 0.9rem;
  font-weight: 760;
}

.song-manager-input,
.song-manager-select {
  width: 100%;
  min-width: 0;
  padding: 0 8px;
}

.song-manager-input {
  overflow: hidden;
  text-overflow: ellipsis;
}

.song-manager-input:focus,
.song-manager-select:focus,
.manager-key-button:focus-visible {
  border-color: color-mix(in srgb, var(--green) 60%, var(--line));
  outline: none;
  background: color-mix(in srgb, var(--green) 8%, transparent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--green) 12%, transparent);
}

.song-manager-select {
  padding-right: 20px;
}

.manager-key-button {
  display: inline-grid;
  place-items: center;
  width: 100%;
  max-width: 62px;
  padding: 0 8px;
  border-color: color-mix(in srgb, var(--line) 80%, transparent);
  color: var(--green);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.018)),
    color-mix(in srgb, var(--panel-2) 74%, transparent);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.09),
    0 6px 14px rgba(0, 0, 0, 0.16);
  font-weight: 900;
  transition:
    border-color 90ms ease,
    color 90ms ease,
    transform 90ms ease;
}

.manager-category-toggles {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  width: 100%;
  gap: 4px;
}

.manager-category-toggles button,
.manager-hebrew-button,
.manager-banger-button {
  display: inline-grid;
  place-items: center;
  min-width: 0;
  height: 33px;
  border: 1px solid color-mix(in srgb, var(--line) 80%, transparent);
  border-radius: 7px;
  padding: 0 7px;
  color: var(--muted);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.012)),
    color-mix(in srgb, var(--panel-2) 66%, transparent);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.07),
    0 1px 0 rgba(255, 255, 255, 0.025),
    0 7px 15px rgba(0, 0, 0, 0.17);
  font-size: 0.8rem;
  font-weight: 900;
  transition:
    border-color 90ms ease,
    color 90ms ease,
    transform 90ms ease;
}

.manager-category-toggles button.active {
  border-color: color-mix(in srgb, var(--chip-color) 72%, transparent);
  color: #ffffff;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--chip-color) 86%, #ffffff), var(--chip-color));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.22),
    0 2px 0 color-mix(in srgb, var(--chip-color) 28%, transparent),
    0 9px 18px color-mix(in srgb, var(--chip-color) 38%, transparent);
}

.manager-hebrew-button {
  width: 38px;
  color: var(--green);
}

.manager-hebrew-button.active {
  border-color: var(--green);
  color: #071428;
  background: var(--green);
}

.manager-banger-button {
  width: 38px;
  color: var(--amber);
}

.manager-banger-button svg {
  width: 16px;
  height: 16px;
}

.manager-banger-button.active {
  border-color: color-mix(in srgb, var(--amber) 64%, transparent);
  background: color-mix(in srgb, var(--amber) 16%, transparent);
}

.song-manager-row-actions {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  width: 100%;
  min-width: 0;
}

.song-manager-row-actions .icon-action {
  width: 32px;
  min-width: 32px;
  height: 32px;
  min-height: 32px;
  border-radius: 7px;
}

.song-manager-delete-button {
  color: var(--danger);
}

.song-manager-delete-button.confirm-delete {
  width: auto;
  min-width: 76px;
  padding-inline: 10px;
  font-size: 0.72rem;
  font-weight: 950;
  line-height: 1;
  letter-spacing: 0.01em;
}

.song-manager-row:has(.song-manager-delete-button.confirm-delete) .song-manager-row-actions .icon-action:not(.song-manager-delete-button) {
  display: none;
}

.song-manager-cell .slides-status-button,
.song-manager-cell .sheets-status-button {
  width: 32px;
  height: 32px;
  min-height: 32px;
  border-radius: 7px;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.09),
    0 1px 0 rgba(255, 255, 255, 0.022),
    0 7px 15px rgba(0, 0, 0, 0.17);
  transition: transform 90ms ease;
}

.manager-key-button:hover,
.manager-category-toggles button:hover,
.manager-hebrew-button:hover,
.manager-banger-button:hover,
.song-manager-cell .slides-status-button:hover,
.song-manager-cell .sheets-status-button:hover {
  transform: translateY(-1px);
}

.song-manager-cell .slides-status-button svg,
.song-manager-cell .sheets-status-button svg {
  width: 18px;
  height: 18px;
}

.song-manager-cell .slides-status-button svg {
  stroke-width: 2.35;
}

.song-manager-empty {
  width: 100%;
  min-height: 160px;
  border: 0;
  border-radius: 0;
}

@keyframes manage-expand-in {
  from {
    opacity: 0;
    transform: translateX(-8px) scale(0.995);
  }
  to {
    opacity: 1;
    transform: translateX(0) scale(1);
  }
}

.hebrew-toggle {
  display: grid;
  align-content: end;
  gap: 7px;
}

.hebrew-toggle input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.hebrew-toggle span {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-width: 72px;
  height: 42px;
  padding: 0 12px;
  margin: 0;
  border: 1px solid var(--line-strong);
  border-radius: var(--radius);
  color: color-mix(in srgb, var(--text) 70%, var(--muted));
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.015)),
    rgba(255, 255, 255, 0.035);
  font-size: 0.9rem;
  font-weight: 900;
  box-shadow: inset 0 0 0 1px transparent;
  transition:
    border-color 140ms ease,
    background 140ms ease,
    box-shadow 140ms ease,
    color 140ms ease,
  transform 140ms ease;
}

.hebrew-toggle span svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  stroke-width: 2;
  fill: none;
  opacity: 0.78;
}

.hebrew-toggle span strong {
  line-height: 1;
}

.hebrew-toggle input:checked + span {
  border-color: var(--green);
  color: #071428;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--green) 92%, white), var(--green));
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--green) 50%, white),
    0 0 0 3px color-mix(in srgb, var(--green) 18%, transparent);
}

.banger-dialog-toggle span {
  min-width: 50px;
  color: var(--amber);
}

.banger-dialog-toggle span svg {
  fill: none;
}

.banger-dialog-toggle input:checked + span {
  border-color: color-mix(in srgb, var(--amber) 78%, white);
  color: #160f02;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--amber) 82%, white), var(--amber));
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--amber) 48%, white),
    0 0 0 3px color-mix(in srgb, var(--amber) 18%, transparent);
}

.hebrew-toggle input:focus-visible + span {
  outline: 2px solid var(--green);
  outline-offset: 2px;
}

.hebrew-toggle:hover span {
  transform: translateY(-1px);
}

:root[data-theme="light"] .hebrew-toggle span {
  border-color: #bfccd9;
  background:
    linear-gradient(180deg, #ffffff, #f3f7fc);
  color: #4f6072;
}

:root[data-theme="light"] .hebrew-toggle input:checked + span {
  border-color: var(--green);
  color: #071428;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--green) 86%, white), var(--green));
}

.song-meta-grid select,
.song-credit-key-grid select,
.song-credit-key-grid input,
.song-credit-key-grid .key-picker-trigger,
.song-credit-key-grid .key-preview-button,
.song-small-grid select,
.song-small-grid input,
.song-small-grid .key-picker-trigger {
  height: 42px;
}

.dialog-actions {
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  margin-top: 4px;
}

.dialog-actions.compact {
  grid-template-columns: auto 1fr auto auto;
}

.dialog-actions.export-actions {
  grid-column: 1;
  grid-row: 4;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: center;
  gap: 6px;
  min-width: 0;
  margin-top: 0;
}

.song-dialog-actions {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  width: 100%;
}

.song-dialog-actions .one-time-dialog-action {
  grid-column: 1;
  justify-self: start;
}

.song-dialog-actions .dialog-primary-actions {
  display: contents;
}

.song-dialog-actions #deleteSongButton {
  grid-column: 1;
  justify-self: start;
  width: 44px;
  min-width: 44px;
  margin-left: 0;
  padding: 0;
  overflow: hidden;
}

.song-dialog-actions #deleteSongButton:not(.confirm-delete) span {
  display: none;
}

.song-dialog-actions #deleteSongButton.confirm-delete {
  width: auto;
  min-width: 96px;
  padding: 0 14px;
  color: #ffe5e2;
  background: rgba(219, 89, 79, 0.24);
}

.song-dialog-actions #saveSongButton {
  grid-column: 3;
  justify-self: end;
}

.export-download-ready {
  grid-column: 1;
  grid-row: 5;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  min-height: 34px;
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 750;
}

.export-ready-icon {
  display: grid;
  flex: 0 0 32px;
  width: 32px;
  height: 32px;
  place-items: center;
  border-radius: 10px;
  color: #ffffff;
  background: color-mix(in srgb, var(--blue) 78%, var(--green));
}

.export-ready-icon svg {
  width: 18px;
  height: 18px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.export-download-ready[hidden] {
  display: none;
}

.export-download-ready a {
  color: var(--green);
  font-weight: 900;
  text-decoration: none;
}

.export-preview {
  grid-column: 2;
  grid-row: 3 / 6;
  align-self: stretch;
  justify-self: stretch;
  display: grid;
  place-items: center;
  min-width: 0;
  min-height: 0;
  width: 100%;
  height: 100%;
  max-height: calc(var(--lineup-viewport-height, 100dvh) - 32px);
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.64), rgba(255, 255, 255, 0.22)),
    #d8dee7;
  padding: clamp(14px, 2vw, 24px);
}

.export-tab-panel {
  grid-column: 1 / -1;
  grid-row: 3 / 6;
  min-width: 0;
  min-height: 0;
  overflow: auto;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 12px;
  background: rgba(255, 255, 255, 0.035);
  overscroll-behavior: contain;
}

.export-tab-panel[hidden] {
  display: none;
}

#exportSlidesPanel {
  display: grid;
  align-content: start;
  overflow: hidden;
}

#exportSlidesPanel[hidden] {
  display: none;
}

#exportSlidesPanel #slidesExportForm {
  display: grid;
  grid-template-rows: minmax(0, 1fr) auto;
  gap: 14px;
  height: 100%;
  max-height: none;
  padding: 0;
  overflow: hidden;
}

#exportSlidesPanel .dialog-header {
  display: none;
}

#exportSlidesPanel .slides-theme-export-layout {
  grid-template-columns: minmax(260px, 390px) minmax(520px, 1fr);
  min-height: 0;
  overflow: hidden;
}

#exportSlidesPanel .slides-theme-controls {
  min-height: 0;
  overflow: auto;
  padding-right: 4px;
}

#exportSlidesPanel .slides-more-background-button {
  min-height: 40px;
}

#exportSlidesPanel .slides-theme-preview {
  align-self: stretch;
  width: 100%;
  min-height: min(62dvh, 620px);
}

#exportSheetsPanel {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 10px;
}

#exportSheetsPanel[hidden] {
  display: none;
}

.sheet-pack-export-layout {
  display: grid;
  grid-template-columns: minmax(240px, 0.82fr) minmax(320px, 1fr);
  gap: 12px;
  min-height: 0;
}

.sheet-pack-selection {
  display: grid;
  align-content: start;
  gap: 10px;
  min-height: 0;
  overflow: auto;
}

.sheet-pack-song {
  display: grid;
  gap: 8px;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 10px;
  background: rgba(255, 255, 255, 0.035);
}

.sheet-pack-song-title,
.sheet-pack-file {
  display: flex;
  align-items: center;
  gap: 10px;
}

.sheet-pack-song-title {
  font-weight: 900;
}

.sheet-pack-song-title input,
.sheet-pack-file input {
  width: 18px;
  height: 18px;
  accent-color: var(--green);
}

.sheet-pack-files {
  display: grid;
  gap: 7px;
  padding-left: 28px;
}

.sheet-pack-file {
  min-height: 42px;
  border: 1px solid color-mix(in srgb, var(--line) 80%, transparent);
  border-radius: 9px;
  padding: 8px 10px;
  background: rgba(255, 255, 255, 0.025);
}

.sheet-pack-file span {
  display: grid;
  gap: 2px;
}

.sheet-pack-file strong {
  font-size: 0.9rem;
}

.sheet-pack-file small {
  color: var(--muted);
  font-size: 0.74rem;
  font-weight: 750;
}

.sheet-pack-export-preview {
  display: grid;
  align-content: start;
  justify-items: center;
  gap: 12px;
  min-width: 0;
  min-height: 0;
  overflow: auto;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 12px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.58), rgba(255, 255, 255, 0.2)),
    #d8dee7;
}

.sheet-pack-export-preview .empty-state {
  align-self: center;
  width: 100%;
}

.sheet-pack-preview-page {
  display: grid;
  grid-template-columns: repeat(var(--preview-columns, 1), minmax(0, 1fr));
  grid-template-rows: repeat(var(--preview-rows, 1), minmax(0, 1fr));
  gap: 8px;
  width: min(100%, 320px);
  aspect-ratio: 8.5 / 11;
  padding: 10px;
  border: 1px solid rgba(15, 23, 42, 0.16);
  border-radius: 3px;
  background: #ffffff;
  color: #111827;
  box-shadow: 0 18px 44px rgba(15, 23, 42, 0.26);
}

.sheet-pack-preview-cell {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: 5px;
  min-width: 0;
  min-height: 0;
  overflow: hidden;
  border: 1px solid rgba(15, 23, 42, 0.13);
  border-radius: 3px;
  padding: 5px;
  background: #ffffff;
}

.sheet-pack-preview-cell strong {
  overflow: hidden;
  color: #1f2937;
  font-size: 0.54rem;
  line-height: 1.15;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.sheet-pack-preview-cell img {
  width: 100%;
  height: 100%;
  min-height: 0;
  object-fit: contain;
  background: #ffffff;
}

.sheet-pack-preview-placeholder {
  display: grid;
  place-items: center;
  min-height: 0;
  border-radius: 2px;
  color: #334155;
  background: linear-gradient(135deg, #f8fafc, #e2e8f0);
  font-size: 0.64rem;
  font-weight: 900;
  text-align: center;
}

.sheet-pack-preview-meta {
  color: var(--muted);
  font-size: 0.74rem;
  font-weight: 850;
}

.export-sheet-preview {
  --export-row-height: 47px;
  --export-note-row-height: 43px;
  --export-credit-gap: 9px;
  width: min(100%, 620px);
  min-height: 760px;
  margin: 0 auto;
  border-radius: 4px;
  background: #ffffff;
  color: #111;
  box-shadow: 0 18px 52px rgba(0, 0, 0, 0.34);
  padding: 30px 28px;
  font-family: Arial, Helvetica, sans-serif;
}

.export-sheet-preview.landscape {
  width: min(100%, 920px);
  min-height: 520px;
}

.export-sheet-preview-stack {
  display: grid;
  justify-items: center;
  align-content: start;
  gap: 14px;
  width: 100%;
  height: 100%;
  min-height: 0;
  max-height: 100%;
  overflow: auto;
  padding: 4px;
  scrollbar-gutter: stable;
}

.export-sheet-preview-stack.portrait.multi-page {
  display: flex;
  flex-wrap: nowrap;
  align-items: flex-start;
  justify-content: center;
}

.export-sheet-preview.image-preview {
  --page-preview-ratio: 210 / 297;
  display: grid;
  place-items: center;
  position: relative;
  width: min(100%, calc(72dvh * 210 / 297), 510px);
  height: auto;
  aspect-ratio: var(--page-preview-ratio);
  min-width: 0;
  min-height: 0;
  max-width: 100%;
  max-height: 100%;
  padding: 0;
  overflow: hidden;
  background: #ffffff;
  border: 1px solid rgba(15, 23, 42, 0.18);
  border-radius: 2px;
  box-shadow:
    0 24px 58px rgba(15, 23, 42, 0.28),
    0 2px 0 rgba(255, 255, 255, 0.96) inset;
}

.export-sheet-preview.image-preview.landscape {
  --page-preview-ratio: 297 / 210;
  width: min(100%, 82dvh, 920px);
  height: auto;
  aspect-ratio: var(--page-preview-ratio);
  min-height: 0;
  max-height: none;
}

.export-sheet-preview-stack.portrait.multi-page > .export-sheet-preview.image-preview {
  flex: 0 0 auto;
  width: clamp(220px, calc((100% - 18px) / 2), 360px) !important;
  height: auto !important;
}

.export-sheet-preview.image-preview img {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
  border-radius: 0;
  box-shadow: none;
  object-fit: contain;
  background: #ffffff;
}

.export-sheet-preview-page-label {
  position: absolute;
  right: 8px;
  bottom: 8px;
  z-index: 1;
  border-radius: 999px;
  padding: 4px 7px;
  color: #ffffff;
  background: rgba(15, 23, 42, 0.7);
  font-size: 0.66rem;
  font-weight: 900;
  line-height: 1;
}

@media (max-width: 860px) {
  .sheet-pack-export-layout {
    grid-template-columns: 1fr;
  }

  .sheet-pack-export-preview {
    min-height: 300px;
  }

  .sheet-pack-preview-page {
    width: min(100%, 270px);
  }
}

@media (max-height: 760px) {
  .export-dialog-inner {
    gap: 8px 12px;
    padding: 14px;
  }

  .export-dialog .dialog-header h2 {
    font-size: 1.35rem;
  }

  .export-dialog .dialog-header .eyebrow {
    margin-bottom: 2px;
  }

  .export-settings {
    gap: 6px;
    padding: 8px;
  }
}

.export-sheet-preview.font-small .export-sheet-line {
  font-size: clamp(18px, 1.9vw, 24px);
}

.export-sheet-preview.font-large .export-sheet-line {
  font-size: clamp(22px, 2.4vw, 32px);
}

.export-sheet-preview.font-xl .export-sheet-line {
  font-size: clamp(26px, 2.8vw, 38px);
}

.export-sheet-preview header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 18px;
  border-bottom: 2px solid #111;
  padding-bottom: 9px;
}

.export-sheet-preview h3 {
  margin: 0;
  color: #111;
  font-size: 34px;
  line-height: 1;
}

.export-sheet-preview.portrait h3 {
  font-size: 30px;
}

.export-sheet-preview .date {
  color: #222;
  font-size: 18px;
  font-weight: 800;
}

.export-sheet-grid {
  column-gap: 22px;
  margin-top: 0;
}

.export-chart-labels {
  display: grid;
  grid-template-columns: 36px minmax(0, 1fr) 42px 38px;
  align-items: center;
  margin-top: 3px;
  border-bottom: 1.5px solid #111;
  color: #444;
  font-size: 9px;
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.export-chart-labels span {
  padding: 0 5px 5px;
  text-align: center;
}

.export-chart-labels span:nth-child(2) {
  text-align: left;
}

.export-sheet-line {
  display: grid;
  grid-template-columns: 36px minmax(0, 1fr) 42px 38px;
  align-items: center;
  min-height: var(--export-row-height);
  break-inside: avoid;
  border-bottom: 1.5px solid #222;
  color: #111;
  font-size: clamp(18px, 2.1vw, 28px);
  font-weight: 900;
}

.export-sheet-line > span {
  overflow: hidden;
  padding: 1px 5px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.export-sheet-line .title {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 0;
  overflow: visible;
  line-height: 1.02;
}

.export-sheet-line .title-main {
  display: flex;
  align-items: baseline;
  gap: 10px;
  min-width: 0;
  line-height: 1.04;
}

.export-sheet-line .song-title-export {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.export-sheet-line .title-main,
.export-sheet-line .credits,
.export-sheet-line .line-note-export {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.export-sheet-line .credits {
  margin-top: var(--export-credit-gap);
  color: #555;
  font-size: 0.42em;
  font-weight: 750;
  line-height: 1;
}

.export-sheet-line .line-note-export {
  flex: 0 1 auto;
  color: #6a4a00;
  font-style: italic;
  font-weight: 750;
}

.export-sheet-line .note-size-short {
  font-size: 0.55em;
}

.export-sheet-line .note-size-medium {
  font-size: 0.48em;
}

.export-sheet-line .note-size-long {
  font-size: 0.42em;
}

.export-sheet-line .note-size-xlong {
  font-size: 0.35em;
}

.export-sheet-line .number,
.export-sheet-line .capo,
.export-sheet-line .key {
  color: #333;
  text-align: center;
}

.export-sheet-line .number {
  overflow: visible;
  padding-left: 2px;
  padding-right: 2px;
  font-size: 0.82em;
  letter-spacing: 0;
  text-overflow: clip;
}

.export-sheet-line.note {
  grid-template-columns: 42px minmax(0, 1fr);
  background: #f3f0e8;
  font-size: clamp(16px, 1.8vw, 24px);
  min-height: var(--export-note-row-height);
}

.export-sheet-line.note .title {
  color: #222;
  font-style: italic;
}

.export-sheet-line.note .note-symbol {
  color: #6a4a00;
  font-style: normal;
}

.toast {
  position: fixed;
  left: 50%;
  bottom: 24px;
  z-index: 5;
  max-width: min(440px, calc(100vw - 32px));
  padding: 13px 16px;
  border: 1px solid rgba(91, 146, 255, 0.3);
  border-radius: var(--radius);
  color: var(--text);
  background: rgba(16, 20, 22, 0.94);
  box-shadow: var(--shadow);
  opacity: 0;
  pointer-events: none;
  transform: translate(-50%, 16px);
  transition: 160ms ease;
}

.toast.has-action {
  display: flex;
  align-items: center;
  gap: 14px;
  pointer-events: auto;
}

.toast [data-toast-action] {
  min-height: 32px;
  border: 1px solid color-mix(in srgb, var(--green) 48%, var(--line));
  border-radius: 999px;
  padding: 0 13px;
  color: var(--green);
  background: color-mix(in srgb, var(--green) 12%, transparent);
  font-size: 0.78rem;
  font-weight: 950;
}

:root[data-theme="light"] .toast {
  background: rgba(255, 255, 255, 0.96);
}

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

@media (max-width: 1100px) {
  .app-shell {
    grid-template-columns: 1fr;
  }

  .app-shell.bank-collapsed {
    grid-template-columns: 1fr;
  }

  .app-shell.manage-songs-open {
    grid-template-columns: minmax(0, 1fr);
  }

  .app-shell.manage-songs-open .show-panel,
  .app-shell.manage-songs-open .panel-resizer {
    display: none;
  }

  .app-shell.manage-songs-open .bank-panel {
    grid-column: 1;
    display: flex;
  }

  .song-manager-toolbar {
    grid-template-columns: minmax(0, 1fr) minmax(120px, auto) minmax(120px, auto) repeat(4, 40px);
  }

  .song-manager-title {
    grid-column: 1 / -1;
  }

  .bank-panel {
    grid-column: 1;
    grid-row: auto;
    border-top: 1px solid var(--line);
    border-right: 0;
  }

  .panel-resizer {
    display: none;
  }

  .show-panel {
    grid-column: 1;
  }

  .lineup-overview {
    grid-template-columns: minmax(0, 1fr);
  }

  .show-panel.slide-preview-open .lineup-table {
    margin-right: 0;
  }

  .slide-preview-panel {
    position: relative;
    top: auto;
    right: auto;
    bottom: auto;
    width: 100%;
    min-width: 0;
    margin: 0 0 14px;
  }

  .slides-workspace-view {
    grid-template-columns: minmax(152px, 188px) minmax(0, 1fr);
    grid-template-rows: minmax(220px, 0.9fr) minmax(0, 1fr) auto;
    grid-template-areas:
      "strip live"
      "strip edit"
      "strip actions";
    overflow-y: auto;
  }

  .slides-workspace-view .slides-strip {
    grid-area: strip;
  }

  .slides-workspace-view .slides-live-area {
    display: contents;
  }

  .slides-workspace-view .slides-live-preview-wrap {
    grid-area: live;
    min-height: 220px;
    padding: 10px;
  }

  .slides-workspace-view .slides-quick-actions {
    grid-area: actions;
  }

  .slides-workspace-view .slides-edit-panel {
    grid-area: edit;
    overflow: visible;
  }

  .slides-editor-dialog {
    width: calc(100vw - 18px);
  }

  .saved-shows-list {
    max-width: calc(100vw - 150px);
  }

  .export-dialog {
    width: min(980px, calc(100vw - 12px));
  }

  .export-dialog-inner {
    grid-template-columns: minmax(205px, 246px) minmax(0, 1fr);
    gap: 8px;
    padding: 8px;
  }

  .export-settings {
    grid-template-columns: 1fr;
  }
}

@media (min-width: 761px) and (max-width: 1200px) and (orientation: landscape) {
  .app-shell {
    grid-template-columns: clamp(260px, var(--bank-width, 320px), min(460px, 42vw)) 10px minmax(0, 1fr);
    grid-template-rows: minmax(0, 1fr);
  }

  .app-shell.bank-collapsed {
    grid-template-columns: minmax(0, 1fr);
  }

  .bank-panel {
    position: relative;
    grid-column: 1;
    grid-row: 1;
    height: auto;
    border-top: 0;
    border-right: 1px solid var(--line);
  }

  .panel-resizer {
    display: block;
    grid-column: 2;
    grid-row: 1;
  }

  .show-panel {
    grid-column: 3;
    grid-row: 1;
  }

  .app-shell.bank-collapsed .show-panel {
    grid-column: 1;
  }
}

@media (min-width: 761px) and (max-width: 1100px) and (orientation: portrait),
  (min-width: 1101px) and (max-width: 1366px) and (orientation: portrait) and (pointer: coarse) {
  .app-shell {
    position: relative;
    grid-template-rows: minmax(0, 1fr);
  }

  .show-panel {
    grid-row: 1;
    height: 100%;
    min-height: 0;
    overflow: hidden;
    padding-bottom: calc(var(--lineup-add-bar-bank-height, min(42dvh, 440px)) + 26px + env(safe-area-inset-bottom, 0px));
  }

  .app-shell.bank-collapsed .show-panel {
    padding-bottom: calc(var(--lineup-add-bar-min-height, 62px) + env(safe-area-inset-bottom, 0px));
  }

  .bank-panel {
    position: fixed;
    right: 18px;
    bottom: 0;
    left: 18px;
    z-index: 20;
    display: flex;
    height: var(--mobile-library-height, var(--lineup-add-bar-bank-height, min(42dvh, 440px)));
    min-height: min(300px, var(--lineup-add-bar-bank-height, 300px));
    padding: 20px 18px calc(14px + env(safe-area-inset-bottom, 0px));
    border-top: 1px solid color-mix(in srgb, var(--green) 34%, var(--line-strong));
    border-right: 1px solid color-mix(in srgb, var(--green) 20%, var(--line));
    border-left: 1px solid color-mix(in srgb, var(--green) 20%, var(--line));
    border-radius: 20px 20px 0 0;
    background:
      linear-gradient(180deg, rgb(var(--accent-rgb) / 0.12), rgb(var(--accent-secondary-rgb) / 0.05)),
      color-mix(in srgb, var(--accent-bg-dark) 56%, rgba(6, 17, 24, 0.99));
    box-shadow:
      0 -22px 70px rgba(0, 0, 0, 0.36),
      inset 0 1px 0 color-mix(in srgb, var(--green) 16%, transparent);
    transition: height 240ms ease, min-height 240ms ease, transform 240ms ease;
    touch-action: pan-y;
    overscroll-behavior: contain;
    will-change: height, transform;
  }

  :root[data-theme="light"] .bank-panel {
    border-top-color: #a9d8de;
    background: linear-gradient(180deg, var(--accent-bg-light) 0%, var(--accent-bg-light-2) 100%);
  }

  .bank-panel.mobile-expanded {
    height: var(--mobile-library-height, var(--lineup-add-bar-full-height, calc(var(--lineup-viewport-height, 100dvh) - 18px)));
    min-height: var(--mobile-library-height, var(--lineup-add-bar-full-height, calc(var(--lineup-viewport-height, 100dvh) - 18px)));
  }

  .bank-panel.is-dragging {
    transition: none;
    touch-action: none;
    user-select: none;
  }

  .bank-header {
    cursor: ns-resize;
    touch-action: pan-y;
  }

  .bank-panel::before {
    content: "";
    position: absolute;
    top: 8px;
    left: 50%;
    width: 52px;
    height: 4px;
    border-radius: 999px;
    background: var(--line-strong);
    transform: translateX(-50%);
  }

  .app-shell.bank-collapsed .bank-panel {
    display: flex;
    height: var(--lineup-add-bar-min-height, calc(52px + env(safe-area-inset-bottom, 0px))) !important;
    max-height: var(--lineup-add-bar-min-height, calc(52px + env(safe-area-inset-bottom, 0px)));
    min-height: 0;
    overflow: hidden;
    padding: 16px 18px calc(8px + env(safe-area-inset-bottom, 0px));
    touch-action: none;
  }

  .app-shell.bank-collapsed .bank-panel .side-panel-view,
  .app-shell.bank-collapsed .bank-panel .home-link-bottom {
    display: none;
  }

  .app-shell.bank-collapsed .bank-panel .bank-header {
    width: 100%;
  }

  .slides-editor-dialog {
    width: calc(100vw - 22px);
    max-height: calc(var(--lineup-viewport-height, 100dvh) - 22px);
  }

  .slides-workspace-view {
    display: flex;
    flex-direction: column;
    gap: 10px;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    padding: 10px 10px calc(18px + env(safe-area-inset-bottom, 0px));
  }

  .slides-strip {
    order: 2;
    flex: 0 0 auto;
  }

  .slides-editor-list {
    display: flex;
    gap: 8px;
    overflow-x: auto;
    overflow-y: hidden;
  }

  .slides-list-item {
    flex: 0 0 160px;
  }

  .slides-live-area {
    display: contents;
  }

  .slides-live-preview-wrap {
    order: 1;
    min-height: 250px;
    padding: 10px;
  }

  .slides-live-preview {
    width: 100%;
    max-height: 36dvh;
  }

  .slides-edit-panel {
    order: 3;
    overflow: visible;
  }

  .slides-quick-actions {
    order: 4;
  }
}

@media (min-width: 761px) and (max-width: 1200px) and (orientation: landscape) {
  .slides-live-preview {
    padding: 22px 24px 50px;
  }

}

@media (min-width: 761px) and (max-width: 1200px) and (orientation: landscape) and (pointer: coarse) {
  .app-shell {
    grid-template-columns: clamp(280px, var(--bank-width, 34vw), min(560px, 58vw)) 16px minmax(0, 1fr);
  }

  .panel-resizer {
    width: 16px;
    min-width: 16px;
    background:
      linear-gradient(90deg, transparent 0 4px, color-mix(in srgb, var(--green) 18%, transparent) 4px 12px, transparent 12px 100%);
  }

  .panel-resizer::before {
    width: 3px;
    background: color-mix(in srgb, var(--green) 54%, var(--line));
    box-shadow: 0 0 14px color-mix(in srgb, var(--green) 20%, transparent);
  }

  .panel-resizer::after {
    width: 6px;
    height: 58px;
    opacity: 0.78;
    background:
      radial-gradient(circle at 50% 9px, currentColor 0 1.5px, transparent 2px),
      radial-gradient(circle at 50% 19px, currentColor 0 1.5px, transparent 2px),
      radial-gradient(circle at 50% 29px, currentColor 0 1.5px, transparent 2px),
      radial-gradient(circle at 50% 39px, currentColor 0 1.5px, transparent 2px),
      radial-gradient(circle at 50% 49px, currentColor 0 1.5px, transparent 2px);
    color: color-mix(in srgb, var(--green) 72%, var(--text));
  }

  .category-filters {
    gap: 5px;
    max-height: 118px;
    margin-bottom: 8px;
    overflow-y: auto;
    overflow-x: hidden;
    scrollbar-width: thin;
  }

  .filter-group {
    gap: 4px;
  }

  .filter-options {
    min-width: 0;
    flex-wrap: wrap;
    gap: 3px;
    padding: 3px;
  }

  .filter-chip {
    flex: 0 1 auto;
    min-width: 0;
    min-height: 24px;
    max-width: 104px;
    padding: 0 7px;
    overflow: hidden;
    font-size: 0.76rem;
    text-overflow: ellipsis;
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (min-height: 521px) and (orientation: landscape) and (pointer: coarse) {
  .app-shell,
  .app-shell.bank-collapsed {
    position: relative;
    grid-template-columns: 1fr;
    grid-template-rows: minmax(0, 1fr);
  }

  .show-panel {
    grid-column: 1;
    grid-row: 1;
    height: 100%;
    min-height: 0;
    overflow: hidden;
    padding-bottom: calc(var(--lineup-add-bar-bank-height, min(38dvh, 390px)) + 26px + env(safe-area-inset-bottom, 0px));
  }

  .app-shell.bank-collapsed .show-panel {
    grid-column: 1;
    padding-bottom: calc(var(--lineup-add-bar-min-height, 62px) + env(safe-area-inset-bottom, 0px));
  }

  .bank-panel {
    position: fixed;
    right: 18px;
    bottom: 0;
    left: 18px;
    z-index: 20;
    display: flex;
    grid-column: 1;
    grid-row: auto;
    width: auto;
    max-width: none;
    height: var(--mobile-library-height, var(--lineup-add-bar-bank-height, min(38dvh, 390px)));
    min-height: min(250px, var(--lineup-add-bar-bank-height, 250px));
    margin-inline: 0;
    padding: 20px 18px calc(14px + env(safe-area-inset-bottom, 0px));
    border-top: 1px solid color-mix(in srgb, var(--green) 34%, var(--line-strong));
    border-right: 1px solid color-mix(in srgb, var(--green) 20%, var(--line));
    border-left: 1px solid color-mix(in srgb, var(--green) 20%, var(--line));
    border-radius: 20px 20px 0 0;
    background:
      linear-gradient(180deg, rgb(var(--accent-rgb) / 0.12), rgb(var(--accent-secondary-rgb) / 0.05)),
      color-mix(in srgb, var(--accent-bg-dark) 56%, rgba(6, 17, 24, 0.99));
    box-shadow:
      0 -22px 70px rgba(0, 0, 0, 0.36),
      inset 0 1px 0 color-mix(in srgb, var(--green) 16%, transparent);
    transition: height 240ms ease, min-height 240ms ease, transform 240ms ease;
    touch-action: pan-y;
    overscroll-behavior: contain;
    will-change: height, transform;
  }

  :root[data-theme="light"] .bank-panel {
    border-top-color: #a9d8de;
    background: linear-gradient(180deg, var(--accent-bg-light) 0%, var(--accent-bg-light-2) 100%);
  }

  .bank-panel.mobile-expanded {
    height: var(--mobile-library-height, var(--lineup-add-bar-full-height, calc(var(--lineup-viewport-height, 100dvh) - 18px)));
    min-height: var(--mobile-library-height, var(--lineup-add-bar-full-height, calc(var(--lineup-viewport-height, 100dvh) - 18px)));
  }

  .bank-panel.is-dragging {
    transition: none;
  }

  .bank-header {
    cursor: ns-resize;
    touch-action: pan-y;
  }

  .bank-panel::before {
    content: "";
    position: absolute;
    top: 8px;
    left: 50%;
    width: 52px;
    height: 4px;
    border-radius: 999px;
    background: var(--line-strong);
    transform: translateX(-50%);
  }

  .app-shell.bank-collapsed .bank-panel {
    display: flex;
    height: var(--lineup-add-bar-min-height, calc(52px + env(safe-area-inset-bottom, 0px))) !important;
    max-height: var(--lineup-add-bar-min-height, calc(52px + env(safe-area-inset-bottom, 0px)));
    min-height: 0;
    overflow: hidden;
    padding: 16px 18px calc(8px + env(safe-area-inset-bottom, 0px));
  }

  .app-shell.bank-collapsed .bank-panel .side-panel-view,
  .app-shell.bank-collapsed .bank-panel .home-link-bottom {
    display: none;
  }

  .app-shell.bank-collapsed .bank-panel .bank-header {
    width: 100%;
  }

  .panel-resizer {
    display: none;
  }

  .lineup-rows.is-empty + .lineup-next-steps {
    display: none;
  }
}

@media (max-height: 520px) and (orientation: landscape) and (pointer: coarse) {
  html,
  body {
    position: fixed;
    inset: 0;
    width: 100%;
    height: var(--lineup-viewport-height, 100dvh);
    max-height: var(--lineup-viewport-height, 100dvh);
    min-height: var(--lineup-viewport-height, 100dvh);
    overflow: hidden;
    overscroll-behavior: none;
  }

  body {
    padding: 0;
  }

  .app-shell {
    position: relative;
    grid-template-columns: clamp(248px, var(--bank-width, 42vw), min(560px, 72vw)) 16px minmax(0, 1fr);
    grid-template-rows: minmax(0, 1fr);
    width: 100vw;
    height: var(--lineup-viewport-height, 100dvh);
    max-height: var(--lineup-viewport-height, 100dvh);
    min-height: var(--lineup-viewport-height, 100dvh);
    margin: 0;
    border: 0;
    border-radius: 0;
  }

  .app-shell.bank-collapsed {
    grid-template-columns: clamp(248px, var(--bank-width, 42vw), min(560px, 72vw)) 16px minmax(0, 1fr);
  }

  .bank-panel {
    position: relative;
    right: auto;
    bottom: auto;
    left: auto;
    z-index: 1;
    display: flex;
    grid-column: 1;
    grid-row: 1;
    width: auto;
    max-width: none;
    height: auto;
    max-height: none;
    min-width: 0;
    min-height: 0;
    margin-inline: 0;
    padding: 10px 8px 8px calc(10px + env(safe-area-inset-left, 0px));
    border-top: 0;
    border-right: 1px solid color-mix(in srgb, var(--green) 26%, var(--line));
    border-radius: 0;
    background:
      linear-gradient(180deg, rgb(var(--accent-rgb) / 0.12), rgb(var(--accent-secondary-rgb) / 0.05)),
      color-mix(in srgb, var(--accent-bg-dark) 56%, rgba(6, 17, 24, 0.99));
    box-shadow:
      18px 0 48px rgba(0, 0, 0, 0.24),
      inset 0 1px 0 color-mix(in srgb, var(--green) 16%, transparent);
    transform: none;
    transition: none;
    touch-action: auto;
    overscroll-behavior: contain;
    will-change: auto;
  }

  :root[data-theme="light"] .bank-panel {
    border-top-color: transparent;
    border-right-color: #a9d8de;
    background: linear-gradient(180deg, var(--accent-bg-light) 0%, var(--accent-bg-light-2) 100%);
  }

  .bank-panel.mobile-expanded {
    height: auto;
    min-height: 0;
  }

  .bank-panel.is-dragging {
    transition: none;
  }

  .bank-header {
    margin-bottom: 6px;
    cursor: default;
    touch-action: auto;
  }

  .bank-panel::before {
    content: none;
    display: none;
  }

  .setlist-selection-bar {
    grid-template-columns: auto minmax(0, 1fr) auto;
  }

  .setlist-selection-bar span {
    grid-column: auto;
  }

  .panel-resizer {
    display: block;
    grid-column: 2;
    grid-row: 1;
    width: 16px;
    min-width: 16px;
    background:
      linear-gradient(90deg, transparent 0 4px, color-mix(in srgb, var(--green) 18%, transparent) 4px 12px, transparent 12px 100%);
    touch-action: pan-y;
  }

  .panel-resizer::before {
    width: 3px;
    background: color-mix(in srgb, var(--green) 54%, var(--line));
    box-shadow: 0 0 14px color-mix(in srgb, var(--green) 20%, transparent);
  }

  .panel-resizer::after {
    width: 6px;
    height: 58px;
    opacity: 0.78;
    background:
      radial-gradient(circle at 50% 9px, currentColor 0 1.5px, transparent 2px),
      radial-gradient(circle at 50% 19px, currentColor 0 1.5px, transparent 2px),
      radial-gradient(circle at 50% 29px, currentColor 0 1.5px, transparent 2px),
      radial-gradient(circle at 50% 39px, currentColor 0 1.5px, transparent 2px),
      radial-gradient(circle at 50% 49px, currentColor 0 1.5px, transparent 2px);
    color: color-mix(in srgb, var(--green) 72%, var(--text));
  }

  .show-panel {
    grid-column: 3;
    grid-row: 1;
    height: 100%;
    min-width: 0;
    min-height: 0;
    overflow: hidden;
    padding: 10px calc(10px + env(safe-area-inset-right, 0px)) 10px 10px;
  }

  .app-shell.bank-collapsed .show-panel {
    grid-column: 3;
    padding-bottom: 10px;
  }

  .lineup-start-empty.mobile-start {
    min-height: clamp(112px, 34dvh, 148px);
    gap: 4px;
    border: 0;
    background: transparent;
    padding: 8px 8px 4px;
  }

  .lineup-start-empty.mobile-start .lineup-start-mark {
    width: 50px;
    height: 50px;
  }

  .lineup-start-empty.mobile-start .lineup-start-mark svg {
    width: 46px;
    height: 46px;
  }

  .lineup-start-empty.mobile-start strong {
    font-size: 0.96rem;
    line-height: 1.08;
  }

  .lineup-start-empty.mobile-start p {
    display: none;
  }

  .lineup-rows.is-empty + .lineup-next-steps {
    display: none;
  }

  .lineup-summary-stats {
    display: none;
  }

  .lineup-add-actions {
    align-self: flex-end;
    justify-content: flex-start;
    width: max-content;
    max-width: calc(100% - 8px);
    margin-top: 5px;
    padding: 5px;
    gap: 5px;
    border: 1px solid color-mix(in srgb, var(--green) 26%, var(--line));
    border-radius: 13px;
    background:
      linear-gradient(180deg, color-mix(in srgb, var(--green) 8%, transparent), transparent 78%),
      color-mix(in srgb, var(--panel-2) 82%, #050707);
    box-shadow: inset 0 1px 0 color-mix(in srgb, white 7%, transparent);
  }

  .lineup-add-actions::after {
    content: none;
  }

  .lineup-add-actions .icon-button,
  .lineup-add-actions #addNoteButton {
    width: auto;
    min-width: 66px;
    height: 36px;
    min-height: 36px;
    padding: 0 8px;
    gap: 3px;
    border-radius: 10px;
    font-size: 0.64rem;
  }

  .lineup-add-actions .icon-button span {
    font-size: 0.64rem;
    font-weight: 900;
  }

  .lineup-add-actions .lineup-add-slide-button .add-action-main-icon,
  .lineup-add-actions .library-add-note-button .add-action-main-icon,
  .lineup-add-actions #addNoteButton .add-action-main-icon {
    width: 16px;
    height: 16px;
  }

  .app-shell.bank-collapsed .bank-panel {
    display: flex;
    height: auto !important;
    max-height: none;
    min-height: 0;
    overflow: hidden;
    padding: 10px 8px 8px calc(10px + env(safe-area-inset-left, 0px));
  }

  .app-shell.bank-collapsed .bank-panel .side-panel-view {
    display: flex;
  }

  .app-shell.bank-collapsed .bank-panel .home-link-bottom {
    display: none;
  }

  .app-shell.bank-collapsed .bank-panel .bank-header {
    margin-bottom: 6px;
  }

  .side-panel-view {
    min-height: 0;
    padding-bottom: 0;
    overflow: hidden;
  }

  .library-view {
    gap: 3px;
  }

  .search-row {
    grid-template-columns: minmax(0, 1fr) 30px 30px;
    gap: 4px;
    margin-bottom: 5px;
  }

  .search-row > .icon-button {
    width: 30px;
    min-width: 30px;
    height: 32px;
    min-height: 32px;
    border-radius: 8px;
  }

  .search-box input {
    height: 32px;
    padding-left: 36px;
    font-size: 0.82rem;
  }

  .category-filters {
    gap: 4px;
    max-height: 70px;
    margin-bottom: 5px;
    padding-right: 2px;
    overflow-y: auto;
    overflow-x: hidden;
    scrollbar-width: none;
  }

  .category-filters::-webkit-scrollbar {
    display: none;
  }

  .filter-group {
    gap: 3px;
    min-width: 0;
  }

  .filter-heading-row {
    gap: 4px;
    min-height: 0;
  }

  .filter-label {
    font-size: 0.56rem;
  }

  .filter-options {
    min-width: 0;
    flex-wrap: wrap;
    gap: 2px;
    padding: 2px;
    border-radius: 8px;
  }

  .filter-chip {
    flex: 0 1 auto;
    min-width: 0;
    min-height: 21px;
    max-width: 82px;
    padding: 0 5px;
    overflow: hidden;
    font-size: 0.66rem;
    text-overflow: ellipsis;
  }

  .filter-select {
    height: 30px;
    min-height: 30px;
    padding: 0 24px 0 8px;
    font-size: 0.72rem;
  }

  .song-bank-list {
    gap: 4px;
    padding-right: 0;
    padding-bottom: 3px;
    overflow-y: auto;
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
    touch-action: pan-y;
  }

  .bank-song {
    min-height: 30px;
    grid-template-columns: minmax(0, 1fr) 22px 22px 22px 22px;
    gap: 3px;
    padding: 4px 6px;
    touch-action: pan-y;
  }

  .bank-song-main {
    gap: 4px;
    min-width: 0;
  }

  .bank-song .song-name {
    font-size: 0.86rem;
    line-height: 1.05;
  }

  .bank-tags {
    display: none;
  }

  .hebrew-badge {
    min-width: 18px;
    height: 17px;
    padding: 0 3px;
    font-size: 0.55rem;
  }

  .bank-song .banger-toggle,
  .bank-slides-button,
  .bank-sheets-button,
  .bank-edit-button {
    width: 22px;
    height: 22px;
    min-height: 22px;
    border-radius: 7px;
  }

  .lineup-add-actions {
    margin-top: 4px;
    gap: 5px;
  }

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

  .show-title-row {
    display: grid;
    grid-template-columns: 34px minmax(0, 1fr) 34px 94px;
    align-items: center;
    gap: 7px;
    min-width: 0;
  }

  .show-title-input {
    min-width: 0;
    height: 38px;
    border: 0;
    padding: 0;
    background: transparent;
    font-size: 1.08rem;
    box-shadow: none;
  }

  .mobile-show-symbol {
    display: grid;
    width: 32px;
    min-width: 32px;
    height: 32px;
    min-height: 32px;
  }

  .show-date-inline {
    width: 94px;
    height: 30px;
    border-radius: 10px;
    padding: 0 3px;
    font-size: 0.66rem;
  }

  .show-tools {
    align-items: center;
    width: auto;
  }

  .header-actions > button {
    display: none;
  }

  .header-actions > .history-button,
  .header-actions > #exportButton {
    display: inline-flex;
    width: 38px;
    min-width: 38px;
    height: 38px;
    min-height: 38px;
  }

  .header-menu,
  .header-menu summary {
    display: inline-grid;
  }

  .header-menu summary {
    width: 38px;
    min-width: 38px;
    height: 38px;
    min-height: 38px;
  }

  .header-menu-popover {
    z-index: 70;
    min-width: 176px;
    width: max-content;
    padding: 7px;
  }

  .header-menu-popover .top-icon-button,
  .mobile-menu-action {
    display: flex;
    justify-content: flex-start;
    width: 100%;
    height: 40px;
    min-height: 40px;
    padding: 0 10px;
  }

  .header-menu-popover .top-icon-button svg {
    width: 18px;
    height: 18px;
  }

  .header-menu-popover .top-icon-button span {
    display: inline;
  }

  .header-menu-popover .mobile-theme-menu-button {
    display: flex;
  }

  .bank-header {
    margin-bottom: 6px;
  }

  #closeBankButton {
    display: none;
  }

  .home-link-bottom {
    bottom: calc(8px + env(safe-area-inset-bottom, 0px));
    left: calc(10px + env(safe-area-inset-left, 0px));
  }
}

@media (max-width: 760px) {
  .setlist-title-menu-button {
    width: 32px;
    min-width: 32px;
    height: 32px;
    min-height: 32px;
    border-radius: 9px;
  }

  .setlist-title-menu-popover {
    right: 0;
    left: auto;
  }

  html,
  body {
    position: fixed;
    inset: 0;
    width: 100%;
    height: var(--lineup-viewport-height, 100dvh);
    max-height: var(--lineup-viewport-height, 100dvh);
    min-height: var(--lineup-viewport-height, 100dvh);
    overflow: hidden;
    overscroll-behavior: none;
  }

  body {
    padding: 0;
  }

  body.intro-active {
    overflow: hidden;
  }

  body.intro-active .app-shell {
    visibility: visible;
    opacity: 1;
    pointer-events: auto;
  }

  .lineup-intro {
    display: none;
    pointer-events: none;
  }

  .coach-overlay {
    pointer-events: none;
  }

  .coach-overlay .coach-tip {
    pointer-events: auto;
  }

  button,
  summary,
  a {
    touch-action: manipulation;
  }

  .app-shell {
    position: relative;
    grid-template-columns: 1fr;
    grid-template-rows: auto minmax(0, 1fr);
    margin: 0;
    width: 100vw;
    height: var(--lineup-viewport-height, 100dvh);
    min-height: var(--lineup-viewport-height, 100dvh);
    max-height: var(--lineup-viewport-height, 100dvh);
    border: 0;
    border-radius: 0;
  }

  .rail {
    position: sticky;
    top: 0;
    z-index: 3;
    flex-direction: row;
    justify-content: space-between;
    padding: calc(10px + env(safe-area-inset-top, 0px)) 14px 10px;
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }

  .brand-mark {
    width: 36px;
  }

  .rail-nav {
    flex: 0 1 auto;
    flex-direction: row;
    gap: 6px;
  }

  .rail-button {
    width: 42px;
    height: 42px;
  }

  .logout {
    display: none;
  }

  .show-panel,
  .bank-panel {
    grid-column: 1;
    padding: 22px 16px;
    width: 100%;
    max-width: 100vw;
  }

  .show-panel {
    grid-row: 2;
    height: 100%;
    min-height: 0;
    overflow: hidden;
    overflow-x: hidden;
    padding: 12px 12px calc(44dvh + 28px + env(safe-area-inset-bottom, 0px));
  }

  .slide-preview-panel {
    gap: 10px;
    padding: 12px;
  }

  .slide-preview-stage {
    min-height: 122px;
  }

  .app-shell.bank-collapsed .show-panel {
    padding-bottom: calc(58px + env(safe-area-inset-bottom, 0px));
  }

  .bank-panel {
    position: fixed;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 20;
    display: flex;
    height: var(--mobile-library-height, min(44dvh, 430px));
    min-height: 265px;
    padding: 18px 14px calc(4px + env(safe-area-inset-bottom, 0px));
    border-top: 1px solid color-mix(in srgb, var(--green) 34%, var(--line-strong));
    border-radius: 18px 18px 0 0;
    background:
      linear-gradient(180deg, rgb(var(--accent-rgb) / 0.12), rgb(var(--accent-secondary-rgb) / 0.05)),
      color-mix(in srgb, var(--accent-bg-dark) 56%, rgba(6, 17, 24, 0.99));
    box-shadow:
      0 -22px 70px rgba(0, 0, 0, 0.42),
      inset 0 1px 0 color-mix(in srgb, var(--green) 16%, transparent);
    transform: translateY(0);
    transition: height 240ms ease, min-height 240ms ease, transform 240ms ease;
    touch-action: pan-y;
    overscroll-behavior: contain;
    will-change: height, transform;
  }

  :root[data-theme="light"] .bank-panel {
    border-top-color: #a9d8de;
    background: linear-gradient(180deg, var(--accent-bg-light) 0%, var(--accent-bg-light-2) 100%);
  }

  .bank-panel.mobile-expanded {
    height: var(--mobile-library-height, calc(var(--lineup-viewport-height, 100dvh) - 12px));
    min-height: var(--mobile-library-height, calc(var(--lineup-viewport-height, 100dvh) - 12px));
  }

  .bank-panel.is-dragging {
    transition: none;
  }

  body.song-bank-search-editing .bank-panel:not(.is-dragging),
  body.song-bank-search-editing .lineup-add-actions:not([hidden]) {
    transition: none !important;
  }

  .bank-header {
    cursor: ns-resize;
    touch-action: none;
  }

  .side-panel-view,
  .show-panel,
  .bank-panel {
    min-height: 0;
  }

  .bank-panel::before {
    content: "";
    position: absolute;
    top: 7px;
    left: 50%;
    width: 44px;
    height: 4px;
    border-radius: 999px;
    background: var(--line-strong);
    transform: translateX(-50%);
  }

  .app-shell.bank-collapsed .bank-panel {
    display: flex;
    height: calc(52px + env(safe-area-inset-bottom, 0px)) !important;
    max-height: calc(52px + env(safe-area-inset-bottom, 0px));
    min-height: 0;
    overflow: hidden;
    padding: 14px 14px calc(8px + env(safe-area-inset-bottom, 0px));
    cursor: ns-resize;
    touch-action: none;
  }

  .app-shell.bank-collapsed .bank-panel .side-panel-view {
    display: none;
  }

  .app-shell.bank-collapsed .bank-panel .home-link-bottom {
    display: none;
  }

  .app-shell.bank-collapsed .bank-panel .bank-header {
    margin-bottom: 0;
    cursor: ns-resize;
    touch-action: none;
  }

  .app-shell.bank-collapsed .bank-title-actions {
    display: none;
  }

  .show-header,
  .bank-header {
    align-items: flex-start;
  }

  .show-header {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 8px;
    margin-bottom: 10px;
  }

  .show-title-block,
  .show-title-input {
    width: 100%;
  }

  .show-title-row {
    display: grid;
    grid-template-columns: 34px minmax(0, 1fr) 34px 94px;
    align-items: center;
    gap: 7px;
    min-width: 0;
  }

  .show-title-input {
    min-width: 0;
    height: 38px;
    border: 0;
    padding: 0;
    background: transparent;
    font-size: 1.08rem;
    box-shadow: none;
  }

  .mobile-show-symbol {
    display: grid;
    width: 32px;
    height: 32px;
    min-width: 32px;
  }

  .bank-header {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto;
    align-items: center;
    column-gap: 5px;
    margin-bottom: 12px;
    padding-right: 0;
    padding-top: 4px;
  }

  .bank-heading {
    display: none;
  }

  .bank-header::after {
    content: attr(data-panel-title);
    grid-column: 1;
    order: 1;
    min-width: 0;
    color: var(--green);
    font-size: 0.78rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
  }

  .bank-title-actions {
    grid-column: 2;
    position: relative;
    order: 2;
    z-index: 2;
    display: flex;
    flex: 0 0 auto;
    gap: 5px;
    margin-left: 0;
  }

  .quick-add-menu-popover {
    right: 0;
    width: min(190px, calc(100vw - 22px));
  }

  .bank-header .library-add-note-button {
    grid-column: 3;
    order: 3;
    position: relative;
    top: auto;
    right: auto;
    z-index: 2;
    width: 36px;
    min-width: 36px;
    height: 36px;
    min-height: 36px;
    margin-left: 0;
    border-color: color-mix(in srgb, var(--amber) 52%, var(--line));
    color: var(--amber);
    background: color-mix(in srgb, var(--amber) 12%, transparent);
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--amber) 10%, transparent);
    transform: none;
  }

  .bank-title-actions .icon-button {
    width: 32px;
    min-width: 32px;
    height: 32px;
    min-height: 32px;
    border-color: color-mix(in srgb, var(--line) 70%, transparent);
    color: var(--muted);
    background: transparent;
    box-shadow: none;
  }

  .bank-title-actions .icon-button svg,
  .bank-header .library-add-note-button > svg:first-child {
    width: 19px;
    height: 19px;
  }

  #closeBankButton {
    display: none;
  }

  .show-date-inline {
    grid-column: 4;
    grid-row: 1;
    justify-self: start;
    width: 94px;
    height: 30px;
    border-radius: 10px;
    padding: 0 3px;
    font-size: 0.66rem;
  }

  .show-tools {
    align-items: center;
    width: auto;
  }

  .header-actions {
    overflow: visible;
    width: auto;
    padding-bottom: 0;
  }

  .header-actions > button {
    display: none;
  }

  .header-actions > .history-button,
  .header-actions > #exportButton {
    display: inline-flex;
    width: 38px;
    min-width: 38px;
    height: 38px;
    min-height: 38px;
  }

  .header-menu,
  .header-menu summary {
    display: inline-grid;
  }

  .header-menu summary {
    width: 38px;
    min-width: 38px;
    height: 38px;
    min-height: 38px;
  }

  .header-menu-popover {
    top: calc(100% + 8px);
    right: 0;
    left: auto;
    display: grid;
    grid-template-columns: 1fr;
    z-index: 70;
    min-width: 176px;
    width: max-content;
    padding: 7px;
  }

  .header-menu-popover .top-icon-button,
  .mobile-menu-action {
    display: flex;
    justify-content: flex-start;
    width: 100%;
    height: 40px;
    min-height: 40px;
    padding: 0 10px;
  }

  .header-menu-popover .top-icon-button svg {
    width: 18px;
    height: 18px;
  }

  .header-menu-popover .top-icon-button span {
    display: inline;
  }

  .header-menu-popover .mobile-theme-menu-button {
    display: flex;
  }

  .top-icon-button {
    flex: 0 0 auto;
  }

  .side-panel-heading {
    display: none;
  }

  .bank-panel .side-panel-view {
    overflow: hidden;
    padding-bottom: 0;
  }

  .bank-panel .library-view,
  .bank-panel .song-bank-list {
    min-height: 0;
  }

  .bank-panel .song-bank-list {
    flex: 1 1 auto;
    padding-bottom: max(3px, env(safe-area-inset-bottom, 0px));
  }

  .home-link-bottom {
    position: absolute;
    bottom: calc(8px + env(safe-area-inset-bottom, 0px));
    left: 12px;
    z-index: 46;
    width: 34px;
    min-width: 0;
    height: 34px;
    min-height: 34px;
    padding: 0;
    border-radius: 999px;
  }

  .home-link-bottom span {
    display: none;
  }

  .home-link-bottom svg {
    width: 18px;
    height: 18px;
  }

  .home-link-bottom.address-revealed {
    width: auto;
    padding: 0 10px;
  }

  .home-link-bottom.address-revealed span {
    display: inline;
    max-width: 126px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .home-link-bottom.manage-back-link {
    width: auto;
    max-width: min(178px, calc(100vw - 24px));
    padding: 0 10px;
  }

  .home-link-bottom.manage-back-link span {
    display: inline;
    max-width: 124px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .rail .saved-shows-popover {
    top: calc(100% + 8px);
    left: 0;
  }

  .form-grid,
  .lineup-add-actions,
  .share-file-actions,
  .quick-add-head,
  .quick-add-row {
    grid-template-columns: 1fr;
  }

  .song-dialog:not(.export-dialog) {
    inset-block-start: max(8px, env(safe-area-inset-top));
    inset-inline-start: 8px;
    transform: none;
    width: calc(100vw - 16px);
    max-width: none;
    max-height: calc(var(--lineup-viewport-height, 100dvh) - 16px);
    overflow: hidden;
    border-radius: 18px;
  }

  .song-dialog:not(.export-dialog) form {
    gap: 9px;
    max-height: calc(var(--lineup-viewport-height, 100dvh) - 16px);
    padding: 12px;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }

  .sheets-dialog {
    inset-block-start: 0;
    inset-inline-start: 0;
    transform: none;
    width: 100vw;
    height: var(--lineup-viewport-height, 100dvh);
    max-height: var(--lineup-viewport-height, 100dvh);
    border: 0;
    border-radius: 0;
  }

  .sheets-shell {
    gap: 8px;
    padding: calc(10px + env(safe-area-inset-top, 0px)) 10px calc(10px + env(safe-area-inset-bottom, 0px));
  }

  .sheets-toolbar {
    flex-wrap: nowrap;
    overflow-x: auto;
    padding-bottom: 2px;
  }

  .sheets-layout {
    grid-template-columns: 1fr;
    grid-template-rows: auto minmax(0, 1fr);
  }

  .sheets-list-panel {
    max-height: 112px;
  }

  .sheets-list {
    display: flex;
    overflow-x: auto;
  }

  .sheet-item {
    flex: 0 0 min(220px, 70vw);
  }

  .sheets-preview-panel {
    min-height: 0;
  }

  .sheets-preview-head {
    align-items: stretch;
    flex-direction: column;
    gap: 6px;
  }

  .sheets-page-controls {
    justify-content: space-between;
  }

  .song-dialog .dialog-header {
    gap: 10px;
  }

  .song-dialog .dialog-header h2 {
    font-size: clamp(1.35rem, 7vw, 1.85rem);
    line-height: 1;
  }

  .song-meta-grid {
    grid-template-columns: minmax(0, 1fr) 50px 50px;
    gap: 8px;
    align-items: end;
  }

  .song-credit-key-grid {
    grid-template-columns: minmax(0, 1fr) 74px 94px 40px;
    gap: 8px;
  }

  .song-preview-key-button {
    width: 40px;
    min-width: 40px;
    height: 40px;
    min-height: 40px;
  }

  .song-small-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }

  .hebrew-toggle {
    align-content: stretch;
  }

  .hebrew-toggle span {
    width: 100%;
    min-width: 0;
    height: 40px;
    padding: 0 8px;
  }

  .hebrew-toggle span svg {
    width: 16px;
    height: 16px;
  }

  .category-choice-buttons {
    min-width: 0;
  }

  .category-choice-button {
    min-height: 40px;
    padding: 0 6px;
    font-size: 0.84rem;
  }

  .song-meta-grid select,
  .song-credit-key-grid select,
  .song-credit-key-grid input,
  .song-credit-key-grid .key-picker-trigger,
  .song-credit-key-grid .key-preview-button,
  .song-small-grid select,
  .song-small-grid input,
  .song-small-grid .key-picker-trigger {
    height: 40px;
  }

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

  .song-manager-toolbar {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) repeat(4, 40px);
    gap: 8px;
  }

  .app-shell.manage-songs-open {
    display: block;
    min-height: var(--lineup-viewport-height, 100dvh);
    overflow: hidden;
  }

  .app-shell.manage-songs-open .show-panel,
  .app-shell.manage-songs-open .panel-resizer {
    display: none !important;
  }

  .app-shell.manage-songs-open .bank-panel.manage-mode {
    position: fixed;
    inset: 0;
    z-index: 70;
    width: 100vw;
    height: var(--lineup-viewport-height, 100dvh);
    min-height: var(--lineup-viewport-height, 100dvh);
    border: 0;
    border-radius: 0;
    padding: calc(12px + env(safe-area-inset-top, 0px)) 10px calc(12px + env(safe-area-inset-bottom, 0px));
    transform: none;
  }

  .app-shell.manage-songs-open .bank-panel.manage-mode::before {
    content: none;
  }

  .app-shell.manage-songs-open .song-manager-view {
    min-height: 0;
    flex: 1 1 auto;
    border-radius: 12px;
  }

  .song-manager-title,
  .song-manager-search {
    grid-column: 1 / -1;
  }

  .song-bank-transfer-dialog {
    width: min(640px, calc(100vw - 14px));
  }

  .song-transfer-list {
    max-height: min(430px, 46vh);
  }

  .song-manager-toolbar select {
    min-width: 0;
  }

  .song-manager-bulk-bar {
    grid-template-columns: minmax(0, 1fr) auto auto;
    gap: 5px;
    padding: 6px;
  }

  .song-manager-bulk-bar strong {
    grid-column: 1;
    font-size: 0.74rem;
  }

  .song-manager-bulk-bar .ghost-button {
    min-width: 0;
    padding-inline: 8px;
    font-size: 0.68rem;
  }

  .song-manager-bulk-bar input,
  .song-manager-bulk-bar select {
    height: 31px;
    padding-inline: 7px;
    font-size: 0.7rem;
  }

  .song-manager-bulk-bar input {
    grid-column: 1 / -1;
  }

  .song-manager-bulk-bar select {
    min-width: 0;
  }

  .song-manager-bulk-bar .primary-button,
  .song-manager-bulk-bar .danger-button {
    min-height: 32px;
    padding-inline: 10px;
    font-size: 0.7rem;
  }

  .song-manager-grid {
    gap: 5px;
    padding: 5px;
    border-radius: 11px;
  }

  .song-manager-row {
    min-height: 40px;
    border-radius: 9px;
  }

  .song-manager-head-row {
    min-height: 34px;
    top: 0;
  }

  .song-manager-cell {
    padding: 4px 5px;
  }

  .song-manager-cell.compact {
    padding-inline: 3px;
  }

  .song-manager-select-cell {
    padding-inline: 3px;
  }

  .song-manager-select-cell input {
    width: 16px;
    height: 16px;
  }

  .song-manager-head-cell {
    font-size: 0.62rem;
  }

  .song-manager-input,
  .song-manager-select,
  .manager-key-button {
    height: 30px;
    min-height: 30px;
    border-radius: 7px;
    font-size: 0.78rem;
  }

  .manager-key-button {
    max-width: 56px;
    padding-inline: 5px;
  }

  .manager-category-toggles {
    gap: 3px;
  }

  .manager-category-toggles button,
  .manager-hebrew-button,
  .manager-banger-button {
    height: 30px;
    padding-inline: 3px;
    overflow: hidden;
    font-size: 0.68rem;
    line-height: 1;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .manager-hebrew-button,
  .manager-banger-button {
    width: 34px;
  }

  .song-manager-cell .slides-status-button,
  .song-manager-cell .sheets-status-button {
    width: 30px;
    height: 30px;
    min-height: 30px;
  }

  .song-manager-row-actions {
    gap: 3px;
  }

  .song-manager-row-actions .icon-action {
    width: 30px;
    min-width: 30px;
    height: 30px;
    min-height: 30px;
  }

  .song-manager-delete-button.confirm-delete {
    min-width: 68px;
    padding-inline: 8px;
    font-size: 0.68rem;
  }

  .song-dialog label > span,
  .category-choice > span {
    margin-bottom: 4px;
    font-size: 0.72rem;
  }

  .song-dialog textarea {
    min-height: 82px;
  }

  .quick-add-head {
    display: none;
  }

  .quick-add-dialog form {
    gap: 7px;
  }

  .quick-add-dialog .dialog-header h2 {
    font-size: clamp(1.18rem, 5.6vw, 1.5rem);
  }

  .quick-add-toolbar {
    gap: 6px;
  }

  .quick-add-toolbar .ghost-button {
    min-height: 34px;
    padding: 0 10px;
    font-size: 0.82rem;
  }

  .quick-paste-panel textarea {
    min-height: 74px;
  }

  .quick-add-rows {
    gap: 5px;
    max-height: min(46vh, 360px);
  }

  .quick-add-row {
    grid-template-columns: 22px minmax(0, 1fr) 82px 34px;
    grid-template-areas:
      "check title category banger"
      ". credits credits credits";
    gap: 5px;
    padding: 5px;
    border-radius: 11px;
  }

  .quick-add-row input[type="checkbox"] {
    grid-area: check;
    width: 16px;
    height: 16px;
  }

  .quick-add-row [data-quick-title] {
    grid-area: title;
  }

  .quick-add-row [data-quick-category] {
    grid-area: category;
  }

  .quick-add-row [data-quick-credits] {
    grid-area: credits;
  }

  .quick-add-row .quick-banger-toggle {
    grid-area: banger;
  }

  .quick-add-row input,
  .quick-add-row select,
  .quick-banger-toggle {
    height: 32px;
    min-height: 32px;
    border-radius: 9px;
    font-size: 0.8rem;
  }

  .quick-banger-toggle {
    width: 32px;
  }

  .saved-shows-header {
    align-items: flex-start;
  }

  .saved-show-chip {
    grid-template-columns: auto minmax(0, 1fr);
    min-width: 132px;
  }

  .setlist-action-bar {
    justify-content: flex-end;
    gap: 5px;
  }

  .setlist-selection-bar {
    grid-template-columns: minmax(0, 1fr) auto;
  }

  .setlist-selection-bar span {
    grid-column: 1 / -1;
  }

  .setlist-selection-hint {
    white-space: normal !important;
  }

  .setlist-folder-header {
    grid-template-columns: minmax(0, 1fr);
  }

  .setlist-folder-move-selected {
    justify-self: start;
  }

  .setlist-folder-items {
    padding-left: 12px;
  }

  .lineup-overview {
    grid-template-columns: minmax(0, 1fr);
    gap: 8px;
    margin-bottom: 8px;
    width: 100%;
    max-width: calc(100vw - 24px);
    min-width: 0;
  }

  .lineup-health-bar {
    display: flex;
    gap: 7px;
    overflow-x: auto;
    padding-bottom: 2px;
    scrollbar-width: none;
  }

  .lineup-health-bar::-webkit-scrollbar {
    display: none;
  }

  .health-chip {
    flex: 0 0 auto;
    min-width: 92px;
    min-height: 44px;
    padding: 7px 9px;
  }

  .health-chip strong {
    font-size: 0.86rem;
  }

  .health-chip span {
    font-size: 0.6rem;
  }

  .lineup-mode-switch {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    gap: 4px;
    border-radius: 9px;
    padding: 3px;
  }

  .lineup-mode-button {
    min-height: 38px;
    min-width: 0;
    padding: 6px 7px;
    text-align: center;
  }

  .lineup-mode-button span {
    font-size: 0.78rem;
  }

  .lineup-mode-button small {
    display: none;
  }

  .lineup-heading {
    display: none;
  }

  .lineup-table {
    width: 100%;
    max-width: calc(100vw - 24px);
    flex: 0 0 auto;
    min-height: 0;
    overflow: hidden;
  }

  .app-shell.bank-collapsed .lineup-table {
    flex: 0 1 auto;
  }

  .lineup-next-steps {
    display: none;
    margin-bottom: 8px;
  }

  .lineup-rows {
    flex: 0 1 auto;
    gap: 8px;
    padding-right: 0;
    padding-bottom: 6px;
    max-height: min(46dvh, 430px);
    overflow-y: auto;
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
    touch-action: pan-y;
  }

  .app-shell.bank-collapsed .lineup-rows {
    flex: 0 1 auto;
    max-height: calc(var(--lineup-viewport-height, 100dvh) - 210px - env(safe-area-inset-bottom, 0px));
  }

  .lineup-row {
    grid-template-columns: 28px minmax(0, 1fr) 30px;
    grid-template-areas:
      "num song actions"
      "drag controls controls";
    align-items: start;
    column-gap: 7px;
    row-gap: 6px;
    min-height: 78px;
    padding: 8px 8px 10px;
    border-radius: 12px;
    overflow: hidden;
    touch-action: pan-y;
    box-shadow: 0 8px 22px rgba(0, 0, 0, 0.12);
  }

  .lineup-row.long-press-ready,
  .lineup-row.dragging {
    touch-action: none;
  }

  .lineup-row,
  .lineup-row .song-title-wrap,
  .lineup-row .song-text,
  .lineup-row .song-name-line,
  .lineup-row .song-name,
  .lineup-row .subline,
  .lineup-row .song-number,
  .lineup-row .drag-handle {
    -webkit-touch-callout: none;
    -webkit-user-drag: none;
    -webkit-user-select: none;
    user-select: none;
  }

  .lineup-row.note-row {
    grid-template-columns: 30px minmax(0, 1fr) auto;
    grid-template-areas:
      "num song actions"
      "drag song actions";
    min-height: 64px;
  }

  .lineup-row.note-row .song-text {
    grid-area: song;
  }

  .note-inline-actions {
    position: static;
    grid-area: actions;
    flex-wrap: nowrap;
    justify-content: flex-end;
    gap: 4px;
    border: 0;
    padding: 0;
    background: transparent;
    box-shadow: none;
    transform: none;
  }

  .lineup-row .drag-handle { grid-area: drag; }
  .lineup-row .song-number { grid-area: num; }
  .lineup-row .song-title-wrap { grid-area: song; }
  .lineup-row .lineup-mobile-controls { grid-area: controls; }
  .lineup-row .line-song-note { display: none; }
  .lineup-row .row-icon-actions {
    position: static;
    grid-area: actions;
    align-self: start;
    justify-self: end;
    border: 0;
    padding: 0;
    background: transparent;
    box-shadow: none;
    transform: none;
  }

  .lineup-row:has(.delete-armed) {
    grid-template-columns: 28px minmax(0, 1fr) 64px;
  }

  .lineup-row .row-icon-actions [data-action="info"] {
    display: none;
  }

  .lineup-row .row-icon-actions [data-action="sheets"] {
    display: none;
  }

  .lineup-row .row-icon-actions [data-action="remove"].delete-armed {
    width: 64px;
    padding: 0 8px;
    font-size: 0.72rem;
    font-weight: 950;
    letter-spacing: 0;
    text-transform: none;
  }

  .lineup-row .row-icon-actions [data-action="remove"].delete-armed svg {
    display: none;
  }

  .lineup-row .row-icon-actions [data-action="remove"].delete-armed::after {
    content: "Delete";
  }

  .lineup-row.song-row::before {
    top: 9px;
    bottom: 9px;
    width: 4px;
  }

  .lineup-row .song-number {
    display: grid;
    place-items: center;
    align-self: start;
    width: 26px;
    height: 26px;
    border: 1px solid var(--line);
    border-radius: 9px;
    color: var(--text);
    background: rgba(255, 255, 255, 0.04);
    font-size: 0.78rem;
    font-weight: 900;
  }

  .lineup-row .drag-handle {
    display: grid;
    place-items: center;
    align-self: center;
    width: 26px;
    height: 28px;
    border-radius: 9px;
    background: rgba(255, 255, 255, 0.03);
    touch-action: none;
  }

  .lineup-mobile-controls {
    display: grid;
    grid-template-columns: 28px 48px 42px 30px 32px 32px;
    align-items: center;
    align-self: start;
    justify-content: end;
    justify-self: end;
    gap: 4px;
    min-width: 0;
  }

  .lineup-row .song-title-wrap {
    display: flex;
    align-items: center;
    gap: 6px;
    min-width: 0;
  }

  .lineup-row .song-text {
    min-width: 0;
  }

  .lineup-row .song-name-line {
    min-width: 0;
  }

  .lineup-row .song-name {
    overflow: hidden;
    font-size: 0.96rem;
    line-height: 1.08;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .lineup-row .lineup-title-banger {
    display: inline-flex;
    align-items: center;
  }

  .lineup-row .subline {
    display: none;
  }

  .lineup-row.slide-only-row .subline {
    display: block;
    margin-top: 2px;
    font-size: 0.68rem;
    line-height: 1.1;
  }

  .mobile-row-status {
    display: inline-flex;
    flex: 0 0 auto;
    gap: 4px;
  }

  .mobile-row-status .mobile-status-chip:first-child {
    display: none;
  }

  .lineup-row .key-preview-button,
  .lineup-row .slides-status-button,
  .lineup-row .sheets-status-button {
    display: grid;
    justify-content: center;
    width: 34px;
    height: 28px;
    min-height: 28px;
    gap: 7px;
    padding: 0;
    font-size: 0.76rem;
    font-weight: 850;
  }

  .lineup-row .slides-status-button span,
  .lineup-row .sheets-status-button span {
    display: none;
  }

  .lineup-row .key-preview-button {
    width: 30px;
    min-width: 30px;
  }

  .lineup-row .slides-status-button .slides-count-badge {
    top: -5px;
    right: -5px;
    display: inline-grid;
    min-width: 14px;
    height: 14px;
    padding: 0 3px;
    font-size: 0.5rem;
  }

  .slide-only-inline-image-button {
    width: 100%;
    height: 28px;
    min-height: 28px;
    border-radius: 9px;
  }

  .lineup-row .ready-toggle {
    display: none;
  }

  .lineup-row .ready-toggle span {
    display: none;
  }

  .lineup-row.drop-before::before,
  .lineup-row.drop-after::after {
    content: "";
    position: absolute;
    right: 18px;
    left: 18px;
    z-index: 30;
    width: auto;
    height: 3px;
    border-radius: 999px;
    background: rgba(96, 165, 250, 0.82);
    box-shadow: 0 1px 4px rgba(37, 99, 235, 0.24);
    pointer-events: none;
  }

  .lineup-row.drop-before::before {
    top: 1px;
    bottom: auto;
  }

  .lineup-row.drop-after::after {
    top: auto;
    bottom: 1px;
  }

  .lineup-rows.drop-at-end::after {
    height: 4px;
    margin: 2px 18px 0;
    background: rgba(96, 165, 250, 0.82);
    box-shadow: 0 1px 4px rgba(37, 99, 235, 0.24);
  }

  .mobile-note-button {
    display: grid;
    width: 100%;
    height: 28px;
    min-height: 28px;
    place-items: center;
    border: 1px solid var(--line);
    border-radius: 9px;
    color: var(--muted);
    background: rgba(255, 255, 255, 0.035);
  }

  .mobile-note-button.has-note {
    border-color: color-mix(in srgb, var(--amber) 50%, var(--line));
    color: var(--amber);
    background: rgba(243, 174, 34, 0.1);
  }

  .mobile-note-button svg {
    width: 16px;
    height: 16px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
  }

  .row-icon-actions,
  .note-inline-actions {
    opacity: 1;
    pointer-events: auto;
  }

  .capo-select,
  .key-select {
    width: 100%;
    height: 28px;
    min-height: 28px;
    border-radius: 9px;
    padding: 0 4px;
    font-size: 0.76rem;
  }

  .capo-cell,
  .key-cell {
    min-width: 0;
  }

  .capo-select {
    max-width: 48px;
  }

  .key-select {
    min-width: 0;
    max-width: 48px;
  }

  .key-cell .key-picker-trigger {
    height: 28px;
    min-height: 28px;
    padding: 0 4px;
    font-size: 0.76rem;
  }

  .search-row {
    grid-template-columns: minmax(0, 1fr) 36px 36px;
    gap: 6px;
    margin-bottom: 8px;
  }

  .search-row > .icon-button {
    width: 36px;
    min-width: 36px;
    height: 40px;
    min-height: 40px;
    border-radius: 10px;
  }

  .search-box input {
    height: 42px;
  }

  .category-filters {
    margin-bottom: 10px;
    overflow-x: auto;
    scrollbar-width: none;
  }

  .category-filters::-webkit-scrollbar {
    display: none;
  }

  .filter-options {
    min-width: max-content;
  }

  .filter-chip {
    flex: 0 0 auto;
    min-width: 76px;
  }

  .song-bank-list {
    gap: 8px;
    padding-right: 0;
    overflow-y: auto;
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
    touch-action: pan-y;
  }

  .bank-song {
    min-height: 38px;
    grid-template-columns: minmax(0, 1fr) 26px 26px 26px 26px;
    gap: 5px;
    padding: 5px 8px;
    touch-action: pan-y;
  }

  .bank-add-icon {
    width: 28px;
    height: 28px;
  }

  .bank-song-main {
    flex-wrap: nowrap;
    gap: 6px;
  }

  .bank-song .song-name {
    font-size: 0.9rem;
    line-height: 1;
  }

  .bank-song .banger-toggle,
  .bank-slides-button,
  .bank-sheets-button,
  .bank-edit-button {
    width: 26px;
    height: 26px;
    min-height: 26px;
    border-radius: 9px;
  }

  .lineup-add-actions {
    display: flex;
    justify-content: flex-start;
    position: relative;
    margin-top: 8px;
    gap: 7px;
    width: 100%;
    padding: 8px 10px 10px;
    border: 1px solid color-mix(in srgb, var(--green) 24%, var(--line));
    border-bottom: 0;
    border-radius: 15px 15px 0 0;
    background:
      linear-gradient(180deg, color-mix(in srgb, var(--green) 8%, transparent), transparent 76%),
      color-mix(in srgb, var(--panel-2) 72%, transparent);
    box-shadow: inset 0 1px 0 color-mix(in srgb, white 6%, transparent);
  }

  .lineup-add-actions::after {
    position: absolute;
    right: 10px;
    bottom: -1px;
    left: calc(10px + 166px);
    height: 1px;
    background: color-mix(in srgb, var(--green) 24%, var(--line));
    content: "";
    pointer-events: none;
  }

  .lineup-add-actions .icon-button {
    width: auto;
    min-width: 78px;
    height: 36px;
    min-height: 36px;
    padding: 0 10px;
    gap: 6px;
    font-size: 0.72rem;
  }

  .lineup-add-actions .icon-button span {
    display: inline-flex;
    align-items: center;
    font-size: 0.72rem;
    font-weight: 900;
    letter-spacing: 0;
    white-space: nowrap;
  }

  #addNoteButton {
    width: auto;
    min-width: 72px;
    height: 36px;
    min-height: 36px;
    border-color: color-mix(in srgb, var(--amber) 52%, var(--line));
    padding: 0 10px;
    font-size: 0.72rem;
    color: var(--amber);
    background: color-mix(in srgb, var(--amber) 12%, transparent);
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--amber) 10%, transparent);
  }

  #addNoteButton .add-action-main-icon {
    width: 18px;
    height: 18px;
    margin: 0;
  }

  #addNoteButton .note-plus-icon {
    width: 15px;
    height: 15px;
    margin-left: 0;
    color: var(--green);
  }

  .mobile-first-song-button {
    display: inline-flex;
    width: 100%;
    margin-top: 14px;
  }

  .lineup-start-empty.mobile-start {
    min-height: min(48dvh, 360px);
    border: 0;
    background: transparent;
    padding: 30px 12px 18px;
  }

  .lineup-start-empty.mobile-start .lineup-start-mark {
    width: 76px;
    height: 76px;
  }

  .lineup-start-empty.mobile-start .lineup-start-mark svg {
    width: 70px;
    height: 70px;
  }

  .lineup-start-empty.mobile-start strong {
    margin-bottom: 0;
    font-size: 1.06rem;
  }

  .lineup-start-empty.mobile-start p {
    max-width: 260px;
    font-size: 0.82rem;
  }

  .lineup-start-empty.mobile-start small {
    max-width: 270px;
    font-size: 0.68rem;
  }

  .lineup-rows.is-empty + .lineup-next-steps {
    display: none;
  }

  .lineup-next-steps {
    display: none !important;
  }

  .lineup-summary-card {
    grid-template-columns: minmax(0, 1fr);
    gap: 6px;
    padding: 10px 11px;
    border-top-left-radius: 0;
    border-top-right-radius: 0;
  }

  .lineup-summary-card h2 {
    font-size: 0.88rem;
  }

  .lineup-summary-card p {
    font-size: 0.74rem;
    line-height: 1.25;
  }

  .lineup-step-list {
    display: none;
  }

  .lineup-summary-stats {
    display: none;
  }

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

  .dialog-actions span {
    display: none;
  }

  .song-dialog-actions span {
    display: inline;
  }

  .song-dialog-actions {
    grid-template-columns: auto minmax(0, 1fr) auto;
  }

  .song-dialog-actions .dialog-primary-actions {
    display: contents;
  }

  .account-dialog {
    width: calc(100vw - 18px);
    max-width: none;
  }

.account-dialog form {
    gap: 12px;
    padding: 18px;
    max-height: calc(var(--lineup-viewport-height, 100dvh) - 18px);
    overflow-y: auto;
  }

  .account-dialog .form-grid {
    grid-template-columns: 1fr;
  }

  .account-dialog .dialog-header {
    align-items: flex-start;
    gap: 12px;
  }

  .account-dialog .dialog-header h2 {
    font-size: clamp(1.5rem, 8vw, 2.2rem);
    line-height: 1;
  }

  .account-dialog .utility-copy {
    font-size: 0.88rem;
  }

  .account-dialog .account-choice-button {
    min-height: 68px;
  }

  .account-dialog .dialog-actions.compact {
    grid-template-columns: 1fr;
  }

  .account-dialog .dialog-actions.compact .primary-button,
  .account-dialog .dialog-actions.compact .ghost-button {
    width: 100%;
  }

  .theme-export-grid {
    grid-template-columns: 1fr;
  }

  .slides-theme-export-layout {
    grid-template-columns: 1fr;
  }

  #slidesExportDialog {
    inset-block-start: 0;
    inset-inline-start: 0;
    transform: none;
    width: 100vw;
    height: var(--lineup-viewport-height, 100dvh);
    max-width: none;
    max-height: var(--lineup-viewport-height, 100dvh);
    overflow: hidden;
    border: 0;
    border-radius: 0;
  }

  #slidesExportDialog form {
    display: grid;
    grid-template-rows: auto auto minmax(0, 1fr) auto;
    gap: 9px;
    width: 100%;
    height: 100%;
    max-height: var(--lineup-viewport-height, 100dvh);
    padding: 10px;
    overflow: hidden;
  }

  #slidesExportDialog .slides-theme-export-layout {
    min-height: 0;
    overflow: auto;
    overscroll-behavior: contain;
    padding-right: 2px;
  }

  .slides-theme-preview {
    min-height: 0;
  }

  #slidesExportDialog .slides-theme-preview {
    width: min(100%, 560px);
    margin: 0 auto;
  }

  #slidesExportDialog .dialog-actions.compact {
    grid-template-columns: 1fr 1fr;
    margin-top: 0;
  }

  #slidesExportDialog .dialog-actions.compact span {
    display: none;
  }

  #slidesExportDialog .dialog-actions.compact .ghost-button,
  #slidesExportDialog .dialog-actions.compact .primary-button {
    width: 100%;
  }

  .slides-editor-dialog {
    inset-block-start: 0;
    inset-inline-start: 0;
    margin: 0;
    transform: none;
    width: 100vw;
    height: var(--lineup-viewport-height, 100dvh);
    max-height: var(--lineup-viewport-height, 100dvh);
    border: 0;
    border-radius: 0;
  }

  .slides-editor-shell {
    height: var(--lineup-viewport-height, 100dvh);
    max-height: var(--lineup-viewport-height, 100dvh);
    min-height: 0;
  }

  .slides-editor-header {
    grid-template-columns: 44px minmax(0, 1fr) auto auto;
    grid-template-areas:
      "back title title ready"
      "status preview delete delete";
    gap: 8px;
    padding: max(9px, env(safe-area-inset-top)) 10px 10px;
  }

  #slidesEditorBackButton {
    grid-area: back;
  }

  .slides-editor-title-block {
    grid-area: title;
  }

  .slides-editor-status {
    grid-area: status;
    justify-self: start;
  }

  .slides-editor-header .slides-editor-export {
    grid-area: preview;
  }

  .slides-editor-header .slides-editor-delete-all {
    grid-area: delete;
  }

  .slides-editor-header .slides-editor-ready {
    grid-area: ready;
    justify-self: end;
  }

  .slides-editor-title-block .eyebrow {
    display: none;
  }

  .slides-editor-title-block h2 {
    font-size: 1.05rem;
  }

  .slides-editor-status {
    min-height: 30px;
    padding: 0 10px;
    font-size: 0.62rem;
  }

  .slides-editor-header .slides-editor-export,
  .slides-editor-header .slides-editor-delete-all,
  .slides-editor-header .slides-editor-ready {
    grid-column: span 1;
    min-height: 34px;
    padding: 0 9px;
    font-size: 0.68rem;
  }

  .slides-editor-header .slides-editor-export span,
  .slides-editor-header .slides-editor-delete-all span {
    display: inline;
  }

  .slides-editor-header .slides-editor-export:disabled,
  .slides-editor-header .slides-editor-delete-all:disabled,
  .slides-editor-header .slides-editor-ready:disabled {
    display: none;
  }

  .slides-setup-view {
    grid-template-columns: 1fr;
    grid-template-areas:
      "copy"
      "paste"
      "actions";
    gap: 10px;
    overflow-y: auto;
    padding: 12px;
  }

  .slides-setup-copy {
    padding: 14px;
  }

  .slides-setup-copy h3 {
    font-size: 1.65rem;
  }

  .slides-paste-label textarea {
    min-height: 46dvh;
    color: #0f172a;
    background: #ffffff;
    font-size: 16px;
    caret-color: #2563eb;
    -webkit-text-fill-color: #0f172a;
  }

  .slides-setup-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }

  .slides-workspace-view {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 96px;
    grid-template-rows: minmax(0, 1fr) 116px 108px;
    grid-template-areas:
      "preview strip"
      "edit edit"
      "tools tools";
    gap: 6px;
    height: 100%;
    min-height: 0;
    overflow: hidden;
    padding: 7px 8px calc(8px + env(safe-area-inset-bottom, 0px));
  }

  .slides-strip {
    grid-area: strip;
    min-height: 0;
    gap: 8px;
    border-radius: 16px;
    padding: 8px;
    overflow: hidden;
  }

  .slides-strip-head {
    display: none;
  }

  .slides-editor-list {
    display: grid;
    gap: 7px;
    min-height: 0;
    overflow-x: hidden;
    overflow-y: auto;
    padding-right: 2px;
  }

  .slides-list-item {
    min-height: 52px;
    padding: 7px;
  }

  .slides-live-area {
    display: contents;
  }

  .slides-workspace-view .slides-live-preview-wrap {
    grid-area: preview;
    min-height: 0;
    padding: 7px;
    border-radius: 16px;
  }

  .slides-live-preview {
    width: 100%;
    max-height: 100%;
    border-radius: 14px;
    padding: 20px 16px 34px;
  }

  .slides-live-lines {
    font-size: var(--slide-editor-display-font-size, var(--slide-editor-font-size, 56px));
  }

  .slides-live-meta {
    top: 10px;
    left: 12px;
    font-size: 0.56rem;
  }

  .slides-live-preview small {
    right: 12px;
    bottom: 7px;
    font-size: 0.44rem;
  }

  .slides-workspace-view .slides-quick-actions {
    grid-area: tools;
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 4px;
    height: 108px;
    max-height: 108px;
    min-height: 0;
    overflow: hidden;
    padding: 5px;
    border-radius: 15px;
  }

  .slides-action-group {
    display: grid;
    grid-template-columns: 1fr;
    align-content: start;
    gap: 2px;
    padding: 4px;
  }

  .slides-action-group > span:first-child {
    grid-column: 1 / -1;
    font-size: 0.5rem;
    line-height: 1;
  }

  .slides-quick-actions .ghost-button,
  .slides-quick-actions .danger-button {
    flex-direction: column;
    min-width: 0;
    min-height: 22px;
    height: 22px;
    padding: 2px;
    gap: 1px;
    border-radius: 9px;
    font-size: 0.45rem;
    line-height: 1;
    white-space: normal;
    text-align: center;
  }

  .slides-quick-actions .ghost-button svg,
  .slides-quick-actions .danger-button svg {
    width: 12px;
    height: 12px;
    flex: 0 0 auto;
  }

  .slides-mobile-action-label,
  #slidesDuplicateButton span {
    display: block;
    font-size: 0.45rem;
    font-weight: 800;
    line-height: 1;
  }

  #slidesSplitButton,
  #slidesSentencePreviousButton,
  #slidesSentenceNextButton,
  #slidesJoinPreviousButton,
  #slidesJoinNextButton {
    grid-column: span 1;
    min-height: 22px;
  }

  #slidesDeleteButton {
    grid-column: span 1;
  }

  .slides-workspace-view .slides-edit-panel {
    grid-area: edit;
    display: grid;
    grid-template-columns: minmax(0, 0.72fr) minmax(150px, 1fr);
    gap: 6px;
    height: 116px;
    max-height: 116px;
    overflow: visible;
    border-radius: 16px;
    padding: 6px;
  }

  .slides-current-text {
    gap: 4px;
    min-height: auto;
  }

  .slides-current-text span {
    font-size: 0.54rem;
  }

  .slides-current-text textarea {
    min-height: 38px;
    max-height: 42px;
    font-size: 0.74rem;
    line-height: 1.2;
    transition: min-height 160ms ease, max-height 160ms ease;
  }

  .slides-current-text:focus-within {
    position: fixed;
    z-index: 25;
    left: 10px;
    right: 10px;
    bottom: calc(10px + env(safe-area-inset-bottom, 0px));
    display: grid;
    gap: 8px;
    padding: 10px;
    border: 1px solid var(--line);
    border-radius: 16px;
    background: color-mix(in srgb, var(--card) 98%, white);
    box-shadow: var(--shadow-lg);
  }

  .slides-current-text:focus-within textarea {
    min-height: min(34dvh, 240px);
    max-height: min(34dvh, 240px);
  }

  .slides-design-panel {
    grid-template-columns: 1fr;
    gap: 4px;
    padding-top: 0;
    border-top: 0;
    align-items: start;
    position: relative;
    z-index: 6;
    overflow: visible;
  }

  .slides-control-label {
    margin-bottom: 2px;
    font-size: 0.52rem;
  }

  .slides-size-control {
    grid-template-columns: 28px minmax(38px, 48px) 28px minmax(76px, 1fr);
    gap: 4px;
  }

  .slides-size-control output {
    height: 26px;
    font-size: 0.64rem;
  }

  .slides-fit-button {
    grid-column: auto;
    min-height: 26px;
    padding: 0 6px;
    font-size: 0.68rem;
  }

  .slides-theme-buttons {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 5px;
  }

  .slides-theme-swatch {
    min-height: 28px;
    padding: 3px;
    font-size: 0.5rem;
  }

  .slides-theme-swatch span {
    height: 9px;
  }

  .slides-editor-dialog {
    color: #0f172a;
    background: #f8fafc;
  }

  .slides-editor-shell {
    grid-template-rows: auto minmax(0, 1fr);
    background: #f8fafc;
  }

  .slides-editor-header {
    grid-template-columns: 40px minmax(0, 1fr) auto auto;
    grid-template-areas: "back title delete ready";
    column-gap: 7px;
    row-gap: 0;
    border-bottom: 1px solid #e2e8f0;
    min-height: 54px;
    padding: max(7px, env(safe-area-inset-top)) 8px 7px;
    background: rgba(248, 250, 252, 0.96);
  }

  #slidesEditorBackButton {
    width: 40px;
    height: 40px;
    border-radius: 12px;
  }

  .slides-editor-status,
  .slides-editor-header .slides-editor-export {
    display: none;
  }

  .slides-editor-title-block h2 {
    overflow: visible;
    font-size: clamp(0.92rem, 4.4vw, 1.08rem);
    letter-spacing: 0;
    white-space: nowrap;
  }

  .slides-editor-header .slides-editor-delete-all,
  .slides-editor-header .slides-editor-ready {
    min-height: 38px;
    border-radius: 11px;
    padding: 0 8px;
    font-size: 0.7rem;
    white-space: nowrap;
  }

  .slides-editor-header .slides-editor-delete-all {
    border-color: #fecaca;
    color: #dc2626;
    background: #ffffff;
    box-shadow: 0 6px 16px rgba(15, 23, 42, 0.06);
  }

  .slides-editor-header .slides-editor-delete-all:hover,
  .slides-editor-header .slides-editor-delete-all:focus-visible {
    border-color: #fca5a5;
    color: #b91c1c;
    background: #fff5f5;
  }

  .slides-editor-header .slides-editor-delete-all svg {
    color: currentColor;
  }

  .slides-editor-header .slides-editor-delete-all:disabled {
    display: inline-flex;
    border-color: #dbe4f0;
    color: #94a3b8;
    background: #f1f5f9;
    box-shadow: none;
    cursor: not-allowed;
    opacity: 1;
  }

  .slides-editor-header .slides-editor-delete-all:disabled svg {
    color: #94a3b8;
    opacity: 0.72;
  }

  .slides-editor-header .slides-editor-ready {
    min-width: 66px;
    padding-inline: 9px;
  }

  .slides-workspace-view {
    grid-template-columns: minmax(0, 1fr);
    grid-template-rows:
      clamp(104px, 14dvh, 122px)
      clamp(142px, 22dvh, 188px)
      minmax(210px, 1fr)
      clamp(72px, 10dvh, 82px);
    grid-template-areas:
      "strip"
      "preview"
      "edit"
      "tools";
    gap: 7px;
    padding: 7px 10px calc(8px + env(safe-area-inset-bottom, 0px));
    background: #f8fafc;
  }

  .slides-strip {
    position: relative;
    border: 0;
    border-radius: 0;
    padding: 0;
    background: transparent;
    overflow: hidden;
  }

  .slides-strip::before,
  .slides-strip::after {
    position: absolute;
    z-index: 2;
    top: 0;
    bottom: 10px;
    width: 24px;
    pointer-events: none;
    content: "";
  }

  .slides-strip::before {
    left: 0;
    background: linear-gradient(90deg, #f8fafc, rgba(248, 250, 252, 0));
  }

  .slides-strip::after {
    right: 0;
    background: linear-gradient(270deg, #f8fafc, rgba(248, 250, 252, 0));
  }

  .slides-editor-list {
    display: flex;
    align-items: stretch;
    gap: 7px;
    height: 100%;
    min-height: 0;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 0 26px 10px 2px;
    scrollbar-color: #2563eb #dbeafe;
    scrollbar-width: thin;
    scroll-snap-type: x proximity;
    -webkit-overflow-scrolling: touch;
  }

  .slides-editor-list.is-reordering {
    cursor: grabbing;
    scroll-snap-type: none;
  }

  .slides-list-item {
    position: relative;
    display: grid;
    flex: 0 0 122px;
    grid-template-columns: 24px 30px minmax(0, 1fr) 15px;
    grid-template-rows: 25px minmax(0, 1fr);
    grid-template-areas:
      "select num spacer grip"
      "thumb thumb thumb thumb";
    gap: 4px;
    min-height: 0;
    height: 100%;
    border: 1px solid #dbe4f0;
    border-radius: 13px;
    padding: 6px;
    color: #0f172a;
    background: #ffffff;
    box-shadow: 0 6px 16px rgba(15, 23, 42, 0.06);
    scroll-snap-align: start;
    touch-action: pan-x;
  }

  .slides-editor-list.is-reordering .slides-list-item {
    touch-action: none;
  }

  .slides-list-item.active {
    border-color: #2563eb;
    background: #eff6ff;
    box-shadow: 0 0 0 1px rgba(37, 99, 235, 0.18), 0 10px 22px rgba(37, 99, 235, 0.12);
  }

  .slides-list-item.drop-before::before,
  .slides-list-item.drop-after::after {
    top: 8px;
    bottom: 8px;
    width: 4px;
    height: auto;
    right: auto;
    left: auto;
  }

  .slides-list-item.drop-before::before {
    left: -5px;
  }

  .slides-list-item.drop-after::after {
    right: -5px;
  }

  .slides-list-number {
    width: 30px;
    height: 30px;
    color: #ffffff;
    background: #2563eb;
    font-size: 0.96rem;
  }

  .slides-list-select {
    width: 22px;
    height: 26px;
  }

  .slides-list-select span {
    width: 17px;
    height: 17px;
    border-color: #bfdbfe;
    background: #ffffff;
  }

  .slides-list-grip {
    display: grid;
    grid-area: grip;
    align-content: center;
    justify-items: center;
    gap: 3px;
    width: 18px;
    height: 26px;
    cursor: grab;
    touch-action: none;
  }

  .slides-list-grip i {
    width: 4px;
    height: 4px;
    border-radius: 999px;
    background: #94a3b8;
  }

  .slides-list-thumb {
    display: grid;
    grid-area: thumb;
    align-content: center;
    gap: 2px;
    min-height: 0;
    overflow: hidden;
    border-radius: 9px;
    padding: 6px;
    color: #f8fafc;
    background: linear-gradient(145deg, #07111f, #020407);
    text-align: left;
  }

  .slides-list-thumb.theme-warm {
    background: linear-gradient(145deg, #211007, #3d8469);
  }

  .slides-list-thumb.theme-bright {
    color: #0f172a;
    background: linear-gradient(145deg, #fffaf2, #dfeeea);
  }

  .slides-list-thumb em {
    overflow: hidden;
    font-size: 0.48rem;
    font-style: normal;
    font-weight: 850;
    line-height: 1.12;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .slides-list-item strong,
  .slides-list-item small {
    display: none;
  }

  .slides-workspace-view .slides-live-preview-wrap {
    min-height: 0;
    border-color: #e2e8f0;
    overflow: hidden;
    padding: 6px;
    background: #ffffff;
    box-shadow: 0 8px 22px rgba(15, 23, 42, 0.06);
  }

  .slides-live-preview {
    width: auto;
    height: 100%;
    max-width: 100%;
    max-height: 100%;
    border-radius: 12px;
    padding: clamp(13px, 3.2vw, 18px) clamp(12px, 3vw, 16px) clamp(25px, 5vw, 30px);
    box-shadow: none;
  }

  .slides-workspace-view .slides-edit-panel {
    grid-template-columns: minmax(0, 1fr) minmax(146px, 38vw);
    gap: 7px;
    height: auto;
    max-height: none;
    min-height: 0;
    overflow: visible;
    border: 1px solid #e2e8f0;
    border-radius: 16px;
    padding: 7px;
    background: #ffffff;
    box-shadow: 0 8px 22px rgba(15, 23, 42, 0.06);
  }

  .slides-current-text {
    display: grid;
    grid-template-rows: auto minmax(0, 1fr);
    gap: 6px;
    min-height: 0;
  }

  .slides-current-text span {
    color: #64748b;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0;
    text-transform: none;
  }

  .slides-current-text textarea {
    width: 100%;
    height: 100%;
    min-height: 0;
    max-height: none;
    border-color: #e2e8f0;
    border-radius: 13px;
    padding: 10px;
    color: #0f172a;
    background: #f8fafc;
    font-size: 16px;
    line-height: 1.28;
    caret-color: #2563eb;
    -webkit-text-fill-color: #0f172a;
  }

  .slides-current-text:focus-within {
    position: static;
    z-index: auto;
    display: grid;
    gap: 8px;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
  }

  .slides-current-text:focus-within textarea {
    min-height: 0;
    max-height: none;
  }

  .slides-design-panel {
    display: grid;
    align-content: start;
    gap: 5px;
    min-width: 0;
    position: relative;
    z-index: 6;
    overflow: visible;
  }

  .slides-control-label {
    margin: 0;
    color: #64748b;
    font-size: 0.68rem;
    letter-spacing: 0;
    text-transform: none;
  }

  .slides-size-control {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 4px;
  }

  .slides-size-control .icon-button,
  .slides-size-control output {
    width: auto;
    min-width: 0;
    height: 30px;
    min-height: 30px;
    border-color: #dbe4f0;
    border-radius: 10px;
    color: #0f172a;
    background: #ffffff;
    font-size: 0.75rem;
  }

  .slides-fit-button {
    grid-column: 1 / -1;
    min-height: 30px;
    border-color: #dbe4f0;
    border-radius: 10px;
    padding: 0 8px;
    color: #0f172a;
    background: #ffffff;
    font-size: 0.73rem;
    white-space: nowrap;
  }

  .slides-line-control-panel {
    display: grid;
    gap: 5px;
  }

  .slides-line-control-panel .ghost-button {
    justify-content: flex-start;
    min-height: 30px;
    border-color: #dbe4f0;
    border-radius: 10px;
    padding: 0 7px;
    color: #0f172a;
    background: #ffffff;
    font-size: 0.62rem;
    white-space: nowrap;
  }

  .slides-line-control-panel svg {
    width: 15px;
    height: 15px;
    color: #0f172a;
  }

  .slides-background-menu {
    position: relative;
  }

  .slides-background-trigger {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 5px;
    min-height: 34px;
    border: 1px solid #0f172a;
    border-radius: 10px;
    padding: 0 7px;
    color: #f8fafc;
    background: linear-gradient(145deg, #07111f, #020407);
    font-size: 0.68rem;
    font-weight: 850;
    list-style: none;
    cursor: pointer;
  }

  .slides-background-trigger::-webkit-details-marker {
    display: none;
  }

  .slides-background-trigger.theme-warm {
    background: linear-gradient(145deg, #211007, #3d8469);
  }

  .slides-background-trigger.theme-bright {
    border-color: #dbe4f0;
    color: #0f172a;
    background: linear-gradient(145deg, #fffaf2, #dfeeea);
  }

  .slides-background-trigger svg {
    width: 14px;
    height: 14px;
    flex: 0 0 auto;
  }

  .slides-background-chevron {
    width: 12px;
    height: 12px;
  }

  .slides-background-menu:not([open]) .slides-theme-buttons {
    display: none;
  }

  .slides-background-menu[open] .slides-theme-buttons {
    position: absolute;
    right: 0;
    top: calc(100% + 6px);
    bottom: auto;
    z-index: 80;
    display: grid;
    width: min(180px, calc(100vw - 28px));
    max-width: calc(100vw - 28px);
    grid-template-columns: 1fr;
    gap: 6px;
    border: 1px solid #dbe4f0;
    border-radius: 14px;
    padding: 7px;
    background: #ffffff;
    box-shadow: 0 18px 42px rgba(15, 23, 42, 0.18);
  }

  .slides-theme-swatch {
    grid-template-columns: 38px minmax(0, 1fr);
    align-items: center;
    min-height: 36px;
    border-color: #dbe4f0;
    border-radius: 10px;
    color: #0f172a;
    background: #ffffff;
    font-size: 0.72rem;
  }

  .slides-theme-swatch span {
    height: 20px;
  }

  .slides-workspace-view .slides-quick-actions {
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 5px;
    height: 100%;
    max-height: 100%;
    border: 1px solid #e2e8f0;
    border-radius: 16px;
    padding: 6px;
    background: #ffffff;
    box-shadow: 0 8px 22px rgba(15, 23, 42, 0.06);
  }

  .slides-action-group {
    display: contents;
  }

  .slides-action-group > span:first-child {
    display: none;
  }

  .slides-quick-actions .ghost-button,
  .slides-quick-actions .danger-button {
    display: flex;
    flex-direction: column;
    min-height: 0;
    height: 100%;
    border-color: #e2e8f0;
    border-radius: 13px;
    padding: 4px 2px;
    gap: 4px;
    color: #0f172a;
    background: #ffffff;
    font-size: 0.58rem;
    font-weight: 760;
    line-height: 1.08;
  }

  .slides-quick-actions .danger-button {
    border-color: color-mix(in srgb, var(--danger) 34%, #e2e8f0);
    color: #dc2626;
    background: color-mix(in srgb, var(--danger) 5%, white);
  }

  .slides-quick-actions .ghost-button svg,
  .slides-quick-actions .danger-button svg {
    width: 19px;
    height: 19px;
  }

  .slides-mobile-action-label,
  #slidesDuplicateButton span {
    font-size: 0.58rem;
    line-height: 1.08;
  }

  #slidesJoinNextButton span,
  #slidesDuplicateButton span,
  #slidesDeleteButton span {
    max-width: 62px;
  }

  body.slides-keyboard-editing .slides-editor-dialog {
    position: fixed !important;
    inset-block-start: var(--lineup-visual-offset-top, 0px) !important;
    inset-inline-start: var(--lineup-visual-offset-left, 0px) !important;
    width: var(--lineup-visual-width, 100vw) !important;
    height: var(--lineup-visual-height, var(--lineup-viewport-height, 100dvh)) !important;
    max-height: var(--lineup-visual-height, var(--lineup-viewport-height, 100dvh)) !important;
    margin: 0 !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    overscroll-behavior: contain;
    transform: none !important;
    -webkit-overflow-scrolling: touch;
  }

  body.slides-keyboard-editing .slides-editor-shell {
    height: var(--lineup-viewport-height, 100dvh) !important;
    min-height: var(--lineup-viewport-height, 100dvh) !important;
    max-height: none !important;
  }

  .export-dialog {
    inset-block-start: 0;
    inset-inline-start: 0;
    transform: none;
    width: 100vw;
    height: var(--lineup-viewport-height, 100dvh);
    max-width: none;
    max-height: var(--lineup-viewport-height, 100dvh);
    overflow: hidden;
    border: 0;
    border-radius: 0;
  }

  .export-dialog-inner {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto minmax(0, 1fr) auto auto;
    gap: 6px;
    padding: 8px;
    width: 100%;
    height: 100%;
    overflow: hidden;
  }

  .export-dialog .dialog-header {
    grid-column: 1;
    grid-row: 1;
  }

  .export-tabs {
    grid-column: 1;
    grid-row: 2;
    gap: 4px;
    overflow: visible;
  }

  .export-tab {
    flex: 1 1 0;
    min-width: 0;
    min-height: 30px;
    padding: 0 5px;
    font-size: clamp(0.58rem, 2.2vw, 0.7rem);
  }

  .export-settings {
    grid-column: 1;
    grid-row: 3;
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    align-items: stretch;
    gap: 4px;
    min-height: 0;
    max-height: none;
    overflow: visible;
    padding: 5px;
  }

  .export-settings > * {
    flex: initial;
    min-width: 0;
  }

  .export-settings .orientation-control {
    display: flex;
    grid-auto-flow: initial;
    grid-auto-columns: initial;
    grid-template-rows: none;
    flex-wrap: nowrap;
    align-content: center;
    align-items: stretch;
    gap: 0;
    min-height: 0;
    min-width: 0;
    padding: 4px;
  }

  .export-settings .orientation-control legend {
    display: none;
  }

  .export-settings .orientation-control label {
    grid-row: auto;
    flex: 1 1 0;
    min-width: 0;
  }

  .export-settings .orientation-control span,
  .export-settings .export-option span {
    width: 100%;
    min-width: 0;
    min-height: 28px;
    padding: 0 4px;
    font-size: 0.66rem;
    line-height: 1;
    white-space: nowrap;
  }

  .export-settings .font-control span,
  .export-settings .page-control span,
  .export-settings .spacing-control label span,
  .export-settings .columns-control label span {
    min-width: 0;
  }

  .export-settings .export-option {
    width: auto;
    min-width: 0;
    min-height: 0;
    padding: 4px;
  }

  .export-settings .export-option::before {
    content: none;
  }

  .export-settings .page-control {
    order: 1;
    grid-column: span 2;
  }

  .export-settings .export-toggle-row {
    order: 2;
    grid-column: span 3;
    gap: 4px;
  }

  .export-settings .fit-toggle {
    order: 3;
    grid-column: span 2;
  }

  .export-settings .orientation-control.font-control:not(.columns-control):not(.spacing-control) {
    order: 4;
    grid-column: 1 / -1;
  }

  .export-settings .orientation-control.columns-control {
    order: 5;
    grid-column: span 3;
  }

  .export-settings .orientation-control.spacing-control {
    order: 6;
    grid-column: span 4;
  }

  .export-settings .export-toggle-row .export-option {
    padding: 0;
  }

  .export-settings .export-toggle-row .export-option span {
    min-height: 28px;
    padding: 0 3px;
    font-size: 0;
  }

  .export-settings .credit-toggle span::before,
  .export-settings .real-key-toggle span::before {
    font-size: 0.62rem;
    line-height: 1;
  }

  .export-settings .credit-toggle span::before {
    content: "Credits";
  }

  .export-settings .real-key-toggle span::before {
    content: "Real key";
  }

  .export-preview {
    grid-column: 1;
    grid-row: 4;
    min-height: 0;
    max-height: none;
    overflow: hidden;
    padding: 6px;
  }

  .export-sheet-preview.image-preview {
    width: min(100%, 34dvh);
    height: auto;
    aspect-ratio: 210 / 297;
    max-width: calc(100vw - 20px);
    max-height: 100%;
  }

  .export-sheet-preview.image-preview.landscape {
    width: min(100%, 56dvh);
    height: auto;
    aspect-ratio: 297 / 210;
  }

  .dialog-actions.export-actions {
    grid-column: 1;
    grid-row: 5;
    justify-content: flex-start;
    gap: 5px;
  }

  .export-download-ready {
    grid-column: 1;
    grid-row: 6;
    justify-content: flex-start;
  }

  .export-tab-panel {
    grid-column: 1;
    grid-row: 3 / 7;
  }

  #exportSlidesPanel {
    padding: 8px;
  }

  #exportSlidesPanel #slidesExportForm {
    grid-template-rows: minmax(0, 1fr) auto;
    gap: 8px;
  }

  #exportSlidesPanel .slides-theme-export-layout {
    display: flex;
    flex-direction: column;
    grid-template-columns: 1fr;
    gap: 8px;
    overflow: hidden;
  }

  #exportSlidesPanel .slides-theme-preview {
    order: 1;
    flex: 0 0 auto;
    min-height: clamp(178px, 30dvh, 250px);
    max-height: 32dvh;
  }

  #exportSlidesPanel .slides-theme-controls {
    order: 2;
    flex: 1 1 auto;
    min-height: 0;
    overflow: auto;
    padding-right: 0;
  }

  #exportSlidesPanel .theme-export-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 6px;
  }

  #exportSlidesPanel .theme-export-card {
    min-height: 52px;
    padding: 7px;
  }

  #exportSlidesPanel .theme-export-card small {
    display: none;
  }

  #exportSlidesPanel .slide-export-options,
  #exportSlidesPanel .theme-image-actions {
    gap: 6px;
  }

  #exportSlidesPanel .slide-export-options {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  #exportSlidesPanel .slide-title-option {
    min-height: 34px;
    padding: 6px 8px;
    font-size: 0.78rem;
  }

  #exportSlidesPanel .theme-crop-controls {
    gap: 5px;
    padding: 7px;
  }

  #exportSlidesPanel .ghost-button,
  #exportSlidesPanel .primary-button {
    min-height: 36px;
    padding: 0 10px;
    font-size: 0.78rem;
  }
}

@media (max-height: 520px) and (orientation: landscape) and (pointer: coarse) {
  .export-dialog {
    inset-block-start: 0;
    inset-inline-start: 0;
    transform: none;
    width: 100vw;
    height: var(--lineup-viewport-height, 100dvh);
    max-width: none;
    max-height: var(--lineup-viewport-height, 100dvh);
    overflow: hidden;
    border: 0;
    border-radius: 0;
  }

  .export-dialog-inner {
    grid-template-columns: minmax(286px, 0.95fr) minmax(0, 1fr);
    grid-template-rows: auto auto minmax(0, 1fr) auto auto;
    gap: 6px 8px;
    padding: 8px;
    width: 100%;
    height: 100%;
    overflow: hidden;
  }

  .export-dialog .dialog-header {
    grid-column: 1 / -1;
    grid-row: 1;
  }

  .export-tabs {
    grid-column: 1 / -1;
    grid-row: 2;
    gap: 4px;
    overflow: visible;
  }

  .export-tab {
    flex: 1 1 0;
    min-width: 0;
    min-height: 30px;
    padding: 0 6px;
    font-size: clamp(0.58rem, 1.35vw, 0.7rem);
  }

  .export-settings {
    grid-column: 1;
    grid-row: 3;
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    align-self: start;
    align-items: stretch;
    gap: 4px;
    min-height: 0;
    max-height: 100%;
    overflow: auto;
    padding: 5px;
  }

  .export-settings > * {
    flex: initial;
    min-width: 0;
  }

  .export-settings .orientation-control {
    display: flex;
    flex-wrap: nowrap;
    align-content: center;
    align-items: stretch;
    gap: 0;
    min-height: 0;
    min-width: 0;
    padding: 4px;
  }

  .export-settings .orientation-control legend,
  .export-settings .export-option::before {
    display: none;
    content: none;
  }

  .export-settings .orientation-control label {
    flex: 1 1 0;
    min-width: 0;
  }

  .export-settings .orientation-control span,
  .export-settings .export-option span {
    width: 100%;
    min-width: 0;
    min-height: 28px;
    padding: 0 4px;
    font-size: 0.66rem;
    line-height: 1;
    white-space: nowrap;
  }

  .export-settings .font-control span,
  .export-settings .page-control span,
  .export-settings .spacing-control label span,
  .export-settings .columns-control label span {
    min-width: 0;
  }

  .export-settings .export-option {
    width: auto;
    min-width: 0;
    min-height: 0;
    padding: 4px;
  }

  .export-settings .page-control {
    order: 1;
    grid-column: span 2;
  }

  .export-settings .export-toggle-row {
    order: 2;
    grid-column: span 3;
    gap: 4px;
  }

  .export-settings .fit-toggle {
    order: 3;
    grid-column: span 2;
  }

  .export-settings .orientation-control.font-control:not(.columns-control):not(.spacing-control) {
    order: 4;
    grid-column: 1 / -1;
  }

  .export-settings .orientation-control.columns-control {
    order: 5;
    grid-column: span 3;
  }

  .export-settings .orientation-control.spacing-control {
    order: 6;
    grid-column: span 4;
  }

  .export-settings .export-toggle-row .export-option {
    padding: 0;
  }

  .export-settings .export-toggle-row .export-option span {
    min-height: 28px;
    padding: 0 3px;
    font-size: 0;
  }

  .export-settings .credit-toggle span::before,
  .export-settings .real-key-toggle span::before {
    font-size: 0.62rem;
    line-height: 1;
  }

  .export-settings .credit-toggle span::before {
    content: "Credits";
  }

  .export-settings .real-key-toggle span::before {
    content: "Real key";
  }

  .export-preview {
    grid-column: 2;
    grid-row: 3;
    min-height: 0;
    max-height: none;
    overflow: hidden;
    padding: 6px;
  }

  .export-sheet-preview.image-preview {
    width: min(100%, 40dvh);
    height: auto;
    aspect-ratio: 210 / 297;
    max-height: 100%;
  }

  .export-sheet-preview.image-preview.landscape {
    width: min(100%, 76dvh);
    height: auto;
    aspect-ratio: 297 / 210;
  }

  .dialog-actions.export-actions {
    grid-column: 1 / -1;
    grid-row: 4;
    justify-content: flex-start;
    gap: 5px;
  }

  .export-download-ready {
    grid-column: 1 / -1;
    grid-row: 5;
    justify-content: flex-start;
  }

  .export-tab-panel {
    grid-column: 1 / -1;
    grid-row: 3 / 6;
  }
}

@media (max-width: 600px) {
  .show-header,
  .lineup-overview,
  .lineup-table {
    max-width: min(366px, calc(100vw - 24px));
  }

  .lineup-health-bar {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 6px;
    overflow: visible;
    padding-bottom: 0;
  }

  .health-chip {
    min-width: 0;
    min-height: 42px;
    padding: 7px 6px;
  }

  .health-chip strong {
    white-space: normal;
    font-size: 0.78rem;
    line-height: 1.06;
  }

  .health-chip span {
    font-size: 0.55rem;
  }

  .lineup-mode-button {
    padding-inline: 4px;
  }

  .bank-panel {
    right: 12px;
    left: 12px;
    width: auto;
    max-width: none;
    margin-inline: 0;
  }
}

@media (max-height: 520px) and (orientation: landscape) and (pointer: coarse) {
  .app-shell {
    position: relative;
    grid-template-columns: clamp(248px, var(--bank-width, 42vw), min(560px, 72vw)) 16px minmax(0, 1fr);
    grid-template-rows: minmax(0, 1fr);
  }

  .app-shell.bank-collapsed {
    grid-template-columns: clamp(248px, var(--bank-width, 42vw), min(560px, 72vw)) 16px minmax(0, 1fr);
  }

  .show-panel {
    grid-column: 3;
    grid-row: 1;
    height: 100%;
    min-height: 0;
    overflow: hidden;
    padding: 10px calc(10px + env(safe-area-inset-right, 0px)) 10px 10px;
  }

  .app-shell.bank-collapsed .show-panel {
    grid-column: 3;
    padding-bottom: 10px;
  }

  .lineup-start-empty.mobile-start {
    min-height: clamp(112px, 34dvh, 148px);
    gap: 4px;
    border: 0;
    background: transparent;
    padding: 8px 8px 4px;
  }

  .lineup-start-empty.mobile-start .lineup-start-mark {
    width: 50px;
    height: 50px;
  }

  .lineup-start-empty.mobile-start .lineup-start-mark svg {
    width: 46px;
    height: 46px;
  }

  .lineup-start-empty.mobile-start strong {
    font-size: 0.96rem;
    line-height: 1.08;
  }

  .lineup-start-empty.mobile-start p {
    display: none;
  }

  .lineup-rows.is-empty + .lineup-next-steps {
    display: none;
  }

  .lineup-summary-stats {
    display: none;
  }

  .bank-panel {
    position: relative;
    right: auto;
    bottom: auto;
    left: auto;
    z-index: 1;
    display: flex;
    grid-column: 1;
    grid-row: 1;
    width: auto;
    max-width: none;
    height: auto;
    max-height: none;
    min-width: 0;
    min-height: 0;
    margin-inline: 0;
    padding: 10px 8px 8px calc(10px + env(safe-area-inset-left, 0px));
    border-top: 0;
    border-right: 1px solid color-mix(in srgb, var(--green) 26%, var(--line));
    border-radius: 0;
    touch-action: auto;
    overscroll-behavior: contain;
  }

  .bank-panel.mobile-expanded {
    height: auto;
    min-height: 0;
  }

  .app-shell.bank-collapsed .bank-panel {
    display: flex;
    height: auto !important;
    max-height: none;
    min-height: 0;
    overflow: hidden;
    padding: 10px 8px 8px calc(10px + env(safe-area-inset-left, 0px));
  }

  .app-shell.bank-collapsed .bank-panel .side-panel-view {
    display: flex;
  }

  .app-shell.bank-collapsed .bank-panel .home-link-bottom {
    display: none;
  }

  .app-shell.bank-collapsed .bank-title-actions {
    display: flex;
  }

  .bank-panel::before {
    content: none;
    display: none;
  }

  .panel-resizer {
    display: block;
    grid-column: 2;
    grid-row: 1;
    width: 16px;
    min-width: 16px;
    background:
      linear-gradient(90deg, transparent 0 4px, color-mix(in srgb, var(--green) 18%, transparent) 4px 12px, transparent 12px 100%);
    touch-action: none;
  }

  .panel-resizer::before {
    width: 3px;
    background: color-mix(in srgb, var(--green) 54%, var(--line));
    box-shadow: 0 0 14px color-mix(in srgb, var(--green) 20%, transparent);
  }

  .panel-resizer::after {
    width: 6px;
    height: 58px;
    opacity: 0.78;
    background:
      radial-gradient(circle at 50% 9px, currentColor 0 1.5px, transparent 2px),
      radial-gradient(circle at 50% 19px, currentColor 0 1.5px, transparent 2px),
      radial-gradient(circle at 50% 29px, currentColor 0 1.5px, transparent 2px),
      radial-gradient(circle at 50% 39px, currentColor 0 1.5px, transparent 2px),
      radial-gradient(circle at 50% 49px, currentColor 0 1.5px, transparent 2px);
    color: color-mix(in srgb, var(--green) 72%, var(--text));
  }

  .bank-header {
    margin-bottom: 6px;
    cursor: default;
    touch-action: auto;
  }

  .bank-panel .side-panel-view {
    overflow: hidden;
    padding-bottom: 0;
  }

  .library-view {
    gap: 3px;
  }

  .search-row {
    grid-template-columns: minmax(0, 1fr) 30px 30px;
    gap: 4px;
    margin-bottom: 5px;
  }

  .search-row > .icon-button {
    width: 30px;
    min-width: 30px;
    height: 32px;
    min-height: 32px;
    border-radius: 8px;
  }

  .search-box input {
    height: 32px;
    padding-left: 36px;
    font-size: 0.82rem;
  }

  .category-filters {
    gap: 4px;
    max-height: 70px;
    margin-bottom: 5px;
    padding-right: 2px;
    overflow-y: auto;
    overflow-x: hidden;
    scrollbar-width: none;
  }

  .category-filters::-webkit-scrollbar {
    display: none;
  }

  .filter-group {
    gap: 3px;
    min-width: 0;
  }

  .filter-heading-row {
    gap: 4px;
    min-height: 0;
  }

  .filter-label {
    font-size: 0.56rem;
  }

  .filter-options {
    min-width: 0;
    flex-wrap: wrap;
    gap: 2px;
    padding: 2px;
    border-radius: 8px;
  }

  .filter-chip {
    flex: 0 1 auto;
    min-width: 0;
    min-height: 21px;
    max-width: 82px;
    padding: 0 5px;
    overflow: hidden;
    font-size: 0.66rem;
    text-overflow: ellipsis;
  }

  .filter-select {
    height: 30px;
    min-height: 30px;
    padding: 0 24px 0 8px;
    font-size: 0.72rem;
  }

  .bank-panel .song-bank-list {
    flex: 1 1 auto;
    min-height: 0;
    gap: 4px;
    padding-bottom: 3px;
  }

  .bank-song {
    min-height: 30px;
    grid-template-columns: minmax(0, 1fr) 22px 22px 22px 22px;
    gap: 3px;
    padding: 4px 6px;
    touch-action: pan-y;
  }

  .bank-song-main {
    gap: 4px;
    min-width: 0;
  }

  .bank-song .song-name {
    font-size: 0.86rem;
    line-height: 1.05;
  }

  .bank-tags {
    display: none;
  }

  .hebrew-badge {
    min-width: 18px;
    height: 17px;
    padding: 0 3px;
    font-size: 0.55rem;
  }

  .bank-song .banger-toggle,
  .bank-slides-button,
  .bank-sheets-button,
  .bank-edit-button {
    width: 22px;
    height: 22px;
    min-height: 22px;
    border-radius: 7px;
  }
}

@media (pointer: coarse) {
  .app-shell.bank-collapsed .bank-panel.is-dragging {
    height: var(--mobile-library-height, var(--lineup-add-bar-min-height, calc(52px + env(safe-area-inset-bottom, 0px)))) !important;
    max-height: calc(var(--lineup-viewport-height, 100dvh) - 12px);
    touch-action: none;
  }

  .app-shell.bank-collapsed .bank-panel.is-revealing .side-panel-view {
    display: flex;
  }

  .app-shell.bank-collapsed .bank-panel.is-revealing .bank-title-actions {
    display: flex;
  }

  .app-shell.bank-collapsed .bank-panel.is-revealing .bank-header {
    margin-bottom: 8px;
  }

  .app-shell.bank-collapsed .bank-panel .bank-header {
    cursor: ns-resize;
    touch-action: none;
  }
}

@media (max-width: 760px) and (orientation: portrait) {
  .app-shell {
    --lineup-add-bar-bank-height: min(44dvh, 430px);
    --lineup-add-bar-full-height: calc(var(--lineup-viewport-height, 100dvh) - 12px);
    --lineup-add-bar-inset: 12px;
  }
}

/* v405: browser home link moved out of the bank bottom so the list can use the full drawer height. */
.bank-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  grid-template-areas:
    "home home"
    "brand actions"
    "back back";
  align-items: center;
  gap: 7px 10px;
}

.bank-header .bank-home-link {
  grid-area: home;
  position: static;
  z-index: 3;
  justify-self: start;
  display: inline-flex;
  width: 36px;
  min-width: 36px;
  max-width: 36px;
  height: 34px;
  min-height: 34px;
  padding: 0;
  overflow: hidden;
  border-color: color-mix(in srgb, var(--line-strong) 72%, transparent);
  background: color-mix(in srgb, var(--panel) 88%, transparent);
  transition:
    max-width 180ms ease,
    width 180ms ease,
    padding 180ms ease,
    border-color 180ms ease,
    color 180ms ease,
    background-color 180ms ease;
}

.bank-header .bank-home-link svg {
  flex: 0 0 auto;
  width: 17px;
  height: 17px;
}

.bank-header .bank-home-link span {
  display: inline-block;
  max-width: 0;
  overflow: hidden;
  opacity: 0;
  white-space: nowrap;
  transition:
    max-width 180ms ease,
    opacity 160ms ease;
}

.bank-header .bank-home-link:hover,
.bank-header .bank-home-link:focus-visible,
.bank-header .bank-home-link.address-revealed,
.bank-header .bank-home-link.manage-back-link {
  width: auto;
  max-width: min(220px, 100%);
  padding: 0 13px;
  border-color: var(--green);
  color: var(--text);
}

.bank-header .bank-home-link:hover span,
.bank-header .bank-home-link:focus-visible span,
.bank-header .bank-home-link.address-revealed span,
.bank-header .bank-home-link.manage-back-link span {
  max-width: 150px;
  opacity: 1;
}

.bank-header .bank-heading {
  grid-area: brand;
}

.bank-header .bank-title-actions {
  grid-area: actions;
}

.bank-header .setlists-back-top-button {
  grid-area: back;
  justify-self: start;
}

.logo-action-button.brand-mark,
.mobile-show-symbol.logo-action-button,
.bank-logo.logo-action-button {
  color: var(--green) !important;
}

.bank-logo.logo-action-button svg,
.mobile-show-symbol.logo-action-button svg {
  filter: drop-shadow(0 0 16px rgba(91, 146, 255, 0.28)) !important;
}

body.installed-app-shell .bank-header .bank-home-link {
  display: none !important;
}

/* v406: keep the browser back affordance out of the bank header flow. */
.bank-header {
  display: flex;
  grid-template-areas: none;
  grid-template-columns: none;
  align-items: center;
  justify-content: flex-start;
  gap: 18px;
  margin-bottom: 4px;
}

.bank-header .bank-heading,
.bank-header .bank-title-actions,
.bank-header .setlists-back-top-button {
  grid-area: auto;
}

.bank-panel > .bank-home-link {
  position: absolute;
  top: 2px;
  left: 22px;
  bottom: auto;
  z-index: 5;
  width: 28px;
  min-width: 28px;
  max-width: 28px;
  height: 28px;
  min-height: 28px;
  padding: 0;
  gap: 5px;
  overflow: hidden;
  border-color: color-mix(in srgb, var(--line-strong) 64%, transparent);
  background: color-mix(in srgb, var(--panel) 84%, transparent);
}

.bank-panel > .bank-home-link svg {
  width: 15px;
  height: 15px;
}

.bank-panel > .bank-home-link span {
  display: inline-block;
  max-width: 0;
  overflow: hidden;
  opacity: 0;
  white-space: nowrap;
  transition:
    max-width 180ms ease,
    opacity 160ms ease;
}

.bank-panel > .bank-home-link:hover,
.bank-panel > .bank-home-link:focus-visible,
.bank-panel > .bank-home-link.address-revealed,
.bank-panel > .bank-home-link.manage-back-link {
  width: auto;
  max-width: min(220px, calc(100% - 44px));
  padding: 0 11px;
  border-color: var(--green);
  color: var(--text);
}

.bank-panel > .bank-home-link:hover span,
.bank-panel > .bank-home-link:focus-visible span,
.bank-panel > .bank-home-link.address-revealed span,
.bank-panel > .bank-home-link.manage-back-link span {
  max-width: 150px;
  opacity: 1;
}

body.installed-app-shell .bank-panel > .bank-home-link {
  display: none !important;
}

/* v407: remove the unfinished adaptive "..." overflow behavior. */
.lineup-row .row-overflow-menu,
.bank-song .bank-row-more,
.lineup-row.overflow-level-1 .row-overflow-menu,
.lineup-row.overflow-level-2 .row-overflow-menu,
.lineup-row.overflow-level-3 .row-overflow-menu,
.lineup-row.overflow-level-4 .row-overflow-menu,
.lineup-row.overflow-level-5 .row-overflow-menu,
.lineup-row.overflow-level-6 .row-overflow-menu,
.lineup-row.overflow-level-7 .row-overflow-menu,
.lineup-row.overflow-level-8 .row-overflow-menu,
.bank-song.overflow-level-1 .bank-row-more,
.bank-song.overflow-level-2 .bank-row-more,
.bank-song.overflow-level-3 .bank-row-more,
.bank-song.overflow-level-4 .bank-row-more,
.bank-song.overflow-level-5 .bank-row-more {
  display: none !important;
}

.bank-song .bank-edit-button,
.bank-song .banger-toggle,
.bank-song .bank-recording-cluster,
.bank-song .bank-sheets-button,
.bank-song .bank-slides-button {
  display: inline-grid !important;
}

.bank-song .bank-recording-cluster {
  display: inline-flex !important;
}

.lineup-row .row-icon-actions {
  display: flex !important;
}

.lineup-row .row-icon-actions .icon-action,
.lineup-row.note-row .note-inline-actions .icon-action,
.lineup-row.slide-only-row .row-icon-actions [data-action="edit-slide-title"],
.lineup-row .lineup-note-button,
.lineup-row .key-preview-button,
.lineup-row .sheets-status-button,
.lineup-row .slides-status-button {
  display: inline-grid !important;
}

.lineup-row .lineup-recording-cluster {
  display: inline-flex !important;
}

.lineup-row .lineup-asset-controls,
.lineup-row .lineup-key-controls {
  display: grid !important;
}

.lineup-row .capo-cell {
  display: block !important;
}

.bank-panel > .bank-home-link:not(:hover):not(:focus-visible) {
  width: 28px !important;
  min-width: 28px !important;
  max-width: 28px !important;
  height: 28px !important;
  min-height: 28px !important;
  padding: 0 !important;
  border-radius: 999px !important;
}

.bank-panel > .bank-home-link:not(:hover):not(:focus-visible) span {
  max-width: 0 !important;
  opacity: 0 !important;
}

@media (min-width: 761px) and (max-width: 1100px) and (orientation: portrait),
  (min-width: 1101px) and (max-width: 1366px) and (orientation: portrait) and (pointer: coarse) {
  .app-shell {
    --lineup-add-bar-min-height: clamp(94px, 10.5dvh, 136px);
    --lineup-add-bar-bank-height: clamp(260px, 34dvh, 420px);
    --lineup-add-bar-full-height: clamp(348px, 56dvh, 660px);
    --lineup-add-bar-inset: 18px;
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (min-height: 521px) and (orientation: landscape) and (pointer: coarse) {
  .app-shell {
    --lineup-add-bar-min-height: clamp(94px, 13.5dvh, 132px);
    --lineup-add-bar-bank-height: clamp(260px, 31dvh, 360px);
    --lineup-add-bar-full-height: clamp(348px, 54dvh, 520px);
    --lineup-add-bar-inset: 18px;
  }
}

@media (max-width: 760px) and (orientation: portrait),
  (min-width: 761px) and (max-width: 1100px) and (orientation: portrait),
  (min-width: 1101px) and (max-width: 1366px) and (orientation: portrait) and (pointer: coarse),
  (min-width: 761px) and (max-width: 1366px) and (min-height: 521px) and (orientation: landscape) and (pointer: coarse) {
  .app-shell {
    --lineup-add-bar-overlap: 1px;
    --lineup-add-bar-border: color-mix(in srgb, var(--green) 34%, var(--line-strong));
    --lineup-add-bar-bg:
      linear-gradient(180deg, rgb(var(--accent-rgb) / 0.12), rgb(var(--accent-secondary-rgb) / 0.1)),
      color-mix(in srgb, var(--accent-bg-dark) 56%, rgba(6, 17, 24, 0.99));
  }

  :root[data-theme="light"] .app-shell {
    --lineup-add-bar-bg: var(--accent-bg-light);
    --lineup-add-bar-border: #a9d8de;
  }

  .app-shell.mobile-library-full {
    --lineup-add-bar-bank-height: var(--lineup-add-bar-full-height);
  }

  .app-shell.bank-collapsed,
  .app-shell.mobile-library-minimized {
    --lineup-add-bar-bank-height: var(--lineup-add-bar-min-height, calc(52px + env(safe-area-inset-bottom, 0px)));
  }

  .app-shell.bank-collapsed .show-panel,
  .app-shell.mobile-library-minimized .show-panel {
    padding-bottom: calc(var(--lineup-add-bar-min-height, 52px) + env(safe-area-inset-bottom, 0px));
  }

  .app-shell.mobile-library-middle .show-panel {
    padding-bottom: calc(var(--mobile-library-height, var(--lineup-add-bar-bank-height)) + env(safe-area-inset-bottom, 0px));
  }

  .app-shell.bank-collapsed .lineup-table,
  .app-shell.mobile-library-minimized .lineup-table {
    flex: 1 1 auto;
  }

  .app-shell.mobile-library-middle .lineup-table,
  .app-shell.mobile-library-full .lineup-table {
    flex: 1 1 auto;
  }

  .app-shell.bank-collapsed .lineup-rows,
  .app-shell.mobile-library-minimized .lineup-rows {
    flex: 1 1 auto;
    max-height: none;
    padding-bottom: calc(6px + env(safe-area-inset-bottom, 0px));
  }

  .app-shell.mobile-library-middle .lineup-rows,
  .app-shell.mobile-library-full .lineup-rows {
    flex: 1 1 auto;
    max-height: none;
    gap: 8px;
    padding-bottom: calc(6px + env(safe-area-inset-bottom, 0px));
  }

  .app-shell.mobile-library-middle .lineup-row,
  .app-shell.mobile-library-full .lineup-row {
    min-height: 84px;
    padding: 8px 8px 10px;
    row-gap: 6px;
  }

  .app-shell.bank-collapsed .lineup-row:not(.note-row),
  .app-shell.mobile-library-minimized .lineup-row:not(.note-row),
  .app-shell.mobile-library-middle .lineup-row:not(.note-row),
  .app-shell.mobile-library-full .lineup-row:not(.note-row) {
    height: 84px;
    min-height: 84px;
  }

  .app-shell.mobile-library-middle .lineup-row.song-row::before,
  .app-shell.mobile-library-full .lineup-row.song-row::before {
    top: 9px;
    bottom: 9px;
  }

  .app-shell:has(.lineup-add-actions:not([hidden])) .bank-panel {
    border-top-right-radius: 0;
  }

  .lineup-add-actions:not([hidden]) {
    position: fixed;
    right: var(--lineup-add-bar-inset, 12px);
    bottom: max(0px, calc(var(--lineup-add-actions-bottom, var(--mobile-library-height, var(--lineup-add-bar-bank-height))) - var(--lineup-add-bar-overlap, 5px)));
    left: auto;
    z-index: 24;
    display: inline-flex;
    align-items: flex-end;
    justify-content: flex-start;
    width: fit-content;
    inline-size: fit-content;
    min-width: 0;
    max-width: calc(100vw - (var(--lineup-add-bar-inset, 12px) * 2));
    margin: 0;
    padding: 5px;
    gap: 5px;
    overflow: hidden;
    border: 1px solid var(--lineup-add-bar-border);
    border-bottom-color: transparent;
    border-radius: 13px 13px 0 0;
    background: var(--lineup-add-bar-bg);
    box-shadow: inset 0 1px 0 color-mix(in srgb, white 8%, transparent);
    transition: bottom 240ms ease;
    transform: translateZ(0);
    will-change: bottom;
  }

  .app-shell.mobile-library-dragging .lineup-add-actions:not([hidden]),
  .app-shell.mobile-library-settling .lineup-add-actions:not([hidden]) {
    transition: none;
  }

  .lineup-add-actions::after {
    content: none;
  }

  .lineup-add-actions .icon-button,
  .lineup-add-actions #addNoteButton {
    position: relative;
    z-index: 1;
    width: auto;
    min-width: 66px;
    height: 36px;
    min-height: 36px;
    padding: 0 8px;
    gap: 4px;
    border-radius: 10px;
    font-size: 0.64rem;
  }

  .lineup-add-actions .icon-button span {
    font-size: 0.64rem;
    font-weight: 900;
  }

  .lineup-add-actions .lineup-add-slide-button .add-action-main-icon,
  .lineup-add-actions .library-add-note-button .add-action-main-icon,
  .lineup-add-actions #addNoteButton .add-action-main-icon {
    width: 16px;
    height: 16px;
  }

  .lineup-add-actions .add-action-plus-icon,
  .lineup-add-actions #addNoteButton .note-plus-icon {
    width: 11px;
    height: 11px;
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (pointer: coarse) {
  .header-actions > #slidePreviewToggle,
  .header-actions > .visible-theme-toggle {
    display: none !important;
  }

  .header-menu,
  .header-menu summary {
    display: inline-grid;
  }

  .header-menu-popover #slidePreviewMenuButton,
  .header-menu-popover .mobile-theme-menu-button {
    display: flex;
  }

  .header-menu-popover {
    min-width: 184px;
  }

  .lineup-heading,
  .lineup-row {
    grid-template-columns: 24px 34px minmax(168px, 1fr) minmax(156px, 0.36fr) 116px 76px 42px 46px 46px 48px;
    gap: 8px;
  }

  .lineup-rows {
    overflow-x: hidden;
    padding-right: 10px;
  }

  .lineup-row {
    padding-right: 12px;
    overflow: visible;
  }

  .row-icon-actions,
  .note-inline-actions {
    opacity: 1;
    pointer-events: auto;
  }

  .row-icon-actions {
    border-color: color-mix(in srgb, var(--line) 70%, transparent);
    background: color-mix(in srgb, var(--panel) 84%, transparent);
  }

  .bank-song,
  .bank-song *,
  .lineup-row,
  .lineup-row .song-title-wrap,
  .lineup-row .song-text,
  .lineup-row .song-name {
    -webkit-touch-callout: none;
    -webkit-user-drag: none;
    -webkit-user-select: none;
    user-select: none;
  }

  .line-song-note input,
  .capo-cell select,
  .key-cell .key-picker-trigger {
    min-height: 38px;
  }

  .show-panel.slide-preview-open .lineup-table {
    margin-right: min(194px, 21vw);
  }

  .show-panel.slide-preview-open .lineup-heading,
  .show-panel.slide-preview-open .lineup-row {
    grid-template-columns: 20px 28px minmax(120px, 1fr) minmax(88px, 0.3fr) 76px 54px 34px 34px 34px 38px;
    gap: 6px;
  }

  .slide-preview-panel {
    position: absolute;
    top: clamp(128px, 13dvh, 174px);
    right: 18px;
    left: auto;
    bottom: auto;
    width: min(188px, 21vw);
    min-width: 168px;
    margin: 0;
    max-height: min(300px, 34dvh);
    gap: 7px;
    border-radius: 13px;
    padding: 8px;
  }

  .slide-preview-header h2 {
    font-size: 0.82rem;
  }

  .slide-preview-header .eyebrow {
    font-size: 0.58rem;
  }

  .slide-preview-stage {
    min-height: 84px;
    border-radius: 10px;
    padding: 5px;
  }

  .slide-preview-controls .ghost-button {
    min-height: 30px;
    padding: 0 8px;
  }

  .slide-preview-controls svg {
    width: 15px;
    height: 15px;
  }

  .slide-preview-count {
    font-size: 0.68rem;
  }

  .app-shell.manage-songs-open {
    display: block;
    min-height: var(--lineup-viewport-height, 100dvh);
    overflow: hidden;
  }

  .app-shell.manage-songs-open .show-panel,
  .app-shell.manage-songs-open .panel-resizer {
    display: none !important;
  }

  .app-shell.manage-songs-open .bank-panel.manage-mode {
    position: fixed;
    inset: calc(22px + env(safe-area-inset-top, 0px)) 22px calc(22px + env(safe-area-inset-bottom, 0px));
    z-index: 70;
    width: auto;
    height: auto;
    min-height: 0;
    max-height: none;
    border: 1px solid color-mix(in srgb, var(--green) 24%, var(--line-strong));
    border-radius: 22px;
    padding: 18px;
    transform: none;
  }

  .app-shell.manage-songs-open .bank-panel.manage-mode::before {
    content: none;
  }

  .app-shell.manage-songs-open .song-manager-view {
    min-height: 0;
    flex: 1 1 auto;
    border-radius: 16px;
  }

  body.guest-mode .bank-panel .song-bank-list {
    padding-bottom: max(6px, env(safe-area-inset-bottom, 0px));
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (min-height: 521px) and (orientation: landscape) and (pointer: coarse) {
  .app-shell {
    grid-template-columns: clamp(280px, var(--bank-width, 34vw), min(560px, 58vw)) 16px minmax(0, 1fr);
    grid-template-rows: minmax(0, 1fr);
  }

  .app-shell.bank-collapsed {
    grid-template-columns: minmax(520px, 1fr);
  }

  .show-panel {
    grid-column: 3;
    grid-row: 1;
    height: 100%;
    min-height: 0;
    overflow: hidden;
    padding-bottom: 30px;
  }

  .app-shell.bank-collapsed .show-panel {
    grid-column: 1;
    padding-bottom: 30px;
  }

  .bank-panel {
    position: relative;
    right: auto;
    bottom: auto;
    left: auto;
    z-index: 1;
    grid-column: 1;
    grid-row: 1;
    width: auto;
    max-width: none;
    height: auto;
    max-height: none;
    min-height: 0;
    margin-inline: 0;
    padding: 20px 18px;
    border-top: 0;
    border-right: 1px solid color-mix(in srgb, var(--green) 26%, var(--line));
    border-left: 0;
    border-radius: 0;
    box-shadow:
      18px 0 48px rgba(0, 0, 0, 0.24),
      inset 0 1px 0 color-mix(in srgb, var(--green) 16%, transparent);
    transform: none;
    transition: none;
    touch-action: auto;
    will-change: auto;
  }

  :root[data-theme="light"] .bank-panel {
    border-top-color: transparent;
    border-right-color: #a9d8de;
    border-left-color: transparent;
    background: linear-gradient(180deg, var(--accent-bg-light) 0%, var(--accent-bg-light-2) 100%);
  }

  .bank-panel.mobile-expanded {
    height: auto;
    min-height: 0;
  }

  .bank-header {
    cursor: default;
    touch-action: auto;
  }

  .bank-panel::before {
    content: none;
    display: none;
  }

  .app-shell.bank-collapsed .bank-panel {
    display: none;
  }

  .panel-resizer {
    display: block;
    grid-column: 2;
    grid-row: 1;
    width: 16px;
    min-width: 16px;
    background:
      linear-gradient(90deg, transparent 0 4px, color-mix(in srgb, var(--green) 18%, transparent) 4px 12px, transparent 12px 100%);
    touch-action: pan-y;
  }

  .panel-resizer::before {
    width: 3px;
    background: color-mix(in srgb, var(--green) 54%, var(--line));
    box-shadow: 0 0 14px color-mix(in srgb, var(--green) 20%, transparent);
  }

  .panel-resizer::after {
    width: 6px;
    height: 58px;
    opacity: 0.78;
    color: color-mix(in srgb, var(--green) 72%, var(--text));
    background:
      radial-gradient(circle at 50% 9px, currentColor 0 1.5px, transparent 2px),
      radial-gradient(circle at 50% 19px, currentColor 0 1.5px, transparent 2px),
      radial-gradient(circle at 50% 29px, currentColor 0 1.5px, transparent 2px),
      radial-gradient(circle at 50% 39px, currentColor 0 1.5px, transparent 2px),
      radial-gradient(circle at 50% 49px, currentColor 0 1.5px, transparent 2px);
  }

  .lineup-add-actions:not([hidden]) {
    position: static;
    right: auto;
    bottom: auto;
    left: auto;
    z-index: auto;
    width: auto;
    inline-size: auto;
    max-width: none;
    height: auto;
    min-height: 0;
    margin: 0;
    padding: 10px 4px 0;
    gap: 8px;
    overflow: visible;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    contain: none;
    isolation: auto;
    pointer-events: auto;
    transform: none;
    transition: none;
    will-change: auto;
  }

  :root[data-theme="light"] .lineup-add-actions:not([hidden]) {
    background: transparent;
  }

  .lineup-add-actions:not([hidden])::before,
  .lineup-add-actions::after {
    content: none;
  }

  .lineup-add-actions .icon-button,
  .lineup-add-actions #addNoteButton {
    width: auto;
    min-width: 82px;
    height: 40px;
    min-height: 40px;
    padding: 0 10px;
    gap: 6px;
    border-radius: 10px;
    font-size: 0.68rem;
    pointer-events: auto;
  }

  .lineup-add-actions .icon-button span {
    font-size: 0.68rem;
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (orientation: portrait) and (pointer: coarse) {
  .show-panel.slide-preview-open .lineup-table {
    margin-top: clamp(470px, 58vw, 620px);
    margin-right: 0;
  }

  .show-panel.slide-preview-open .lineup-heading,
  .show-panel.slide-preview-open .lineup-row {
    grid-template-columns: 24px 34px minmax(168px, 1fr) minmax(156px, 0.36fr) 116px 76px 42px 46px 46px 48px;
    gap: 8px;
  }

  .show-panel.slide-preview-open .lineup-add-actions {
    display: none;
  }

  .show-panel.slide-preview-open .slide-preview-panel {
    top: clamp(92px, 9dvh, 128px);
    right: 22px;
    bottom: auto;
    left: 22px;
    width: auto;
    min-width: 0;
    max-height: none;
    gap: 10px;
    padding: 12px;
  }

  .show-panel.slide-preview-open .slide-preview-stage {
    min-height: 0;
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (min-height: 521px) and (orientation: landscape) and (pointer: coarse) {
  .show-panel.slide-preview-open .lineup-table {
    margin-right: min(506px, 44vw);
  }

  .show-panel.slide-preview-open .lineup-add-actions {
    display: none;
  }

  .show-panel.slide-preview-open .slide-preview-panel {
    top: clamp(112px, 14dvh, 134px);
    right: 22px;
    bottom: auto;
    left: auto;
    width: min(486px, 42vw);
    min-width: 420px;
    max-height: none;
    gap: 10px;
    padding: 12px;
  }

  .show-panel.slide-preview-open .slide-preview-stage {
    min-height: 0;
  }
}

@media (min-width: 761px) and (max-width: 1366px) {
  :root.tablet-touch-layout .header-actions > #slidePreviewToggle,
  :root.tablet-touch-layout .header-actions > .visible-theme-toggle {
    display: none !important;
  }

  :root.tablet-touch-layout .header-menu,
  :root.tablet-touch-layout .header-menu summary {
    display: inline-grid;
  }

  :root.tablet-touch-layout .header-menu-popover #slidePreviewMenuButton,
  :root.tablet-touch-layout .header-menu-popover .mobile-theme-menu-button {
    display: flex;
  }

  :root.tablet-touch-layout .header-menu-popover {
    min-width: 184px;
  }

  :root.tablet-touch-layout .lineup-heading,
  :root.tablet-touch-layout .lineup-row {
    grid-template-columns: 24px 34px minmax(168px, 1fr) minmax(156px, 0.36fr) 116px 76px 42px 46px 46px 48px;
    gap: 8px;
  }

  :root.tablet-touch-layout .lineup-rows {
    overflow-x: hidden;
    padding-right: 10px;
  }

  :root.tablet-touch-layout .lineup-row {
    padding-right: 12px;
    overflow: visible;
  }

  :root.tablet-touch-layout .row-icon-actions,
  :root.tablet-touch-layout .note-inline-actions {
    opacity: 1;
    pointer-events: auto;
  }

  :root.tablet-touch-layout .row-icon-actions {
    border-color: color-mix(in srgb, var(--line) 70%, transparent);
    background: color-mix(in srgb, var(--panel) 84%, transparent);
  }

  :root.tablet-touch-layout .bank-song,
  :root.tablet-touch-layout .bank-song *,
  :root.tablet-touch-layout .lineup-row,
  :root.tablet-touch-layout .lineup-row .song-title-wrap,
  :root.tablet-touch-layout .lineup-row .song-text,
  :root.tablet-touch-layout .lineup-row .song-name {
    -webkit-touch-callout: none;
    -webkit-user-drag: none;
    -webkit-user-select: none;
    user-select: none;
  }

  :root.tablet-touch-layout .line-song-note input,
  :root.tablet-touch-layout .capo-cell select,
  :root.tablet-touch-layout .key-cell .key-picker-trigger {
    min-height: 38px;
  }

  :root.tablet-touch-layout .app-shell.manage-songs-open {
    display: block;
    min-height: var(--lineup-viewport-height, 100dvh);
    overflow: hidden;
  }

  :root.tablet-touch-layout .app-shell.manage-songs-open .show-panel,
  :root.tablet-touch-layout .app-shell.manage-songs-open .panel-resizer {
    display: none !important;
  }

  :root.tablet-touch-layout .app-shell.manage-songs-open .bank-panel.manage-mode {
    position: fixed;
    inset: calc(22px + env(safe-area-inset-top, 0px)) 22px calc(22px + env(safe-area-inset-bottom, 0px));
    z-index: 70;
    width: auto;
    height: auto;
    min-height: 0;
    max-height: none;
    border: 1px solid color-mix(in srgb, var(--green) 24%, var(--line-strong));
    border-radius: 22px;
    padding: 18px;
    transform: none;
  }

  :root.tablet-touch-layout .app-shell.manage-songs-open .bank-panel.manage-mode::before {
    content: none;
  }

  :root.tablet-touch-layout .app-shell.manage-songs-open .song-manager-view {
    min-height: 0;
    flex: 1 1 auto;
    border-radius: 16px;
  }

  :root.tablet-touch-layout body.guest-mode .bank-panel .song-bank-list {
    padding-bottom: max(6px, env(safe-area-inset-bottom, 0px));
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (min-height: 521px) and (orientation: landscape) {
  :root.tablet-touch-layout .app-shell {
    grid-template-columns: clamp(280px, var(--bank-width, 34vw), min(560px, 58vw)) 16px minmax(0, 1fr);
    grid-template-rows: minmax(0, 1fr);
  }

  :root.tablet-touch-layout .app-shell.bank-collapsed {
    grid-template-columns: minmax(520px, 1fr);
  }

  :root.tablet-touch-layout .show-panel {
    grid-column: 3;
    grid-row: 1;
    height: 100%;
    min-height: 0;
    overflow: hidden;
    padding-bottom: 30px;
  }

  :root.tablet-touch-layout .app-shell.bank-collapsed .show-panel {
    grid-column: 1;
    padding-bottom: 30px;
  }

  :root.tablet-touch-layout .bank-panel {
    position: relative;
    right: auto;
    bottom: auto;
    left: auto;
    z-index: 1;
    grid-column: 1;
    grid-row: 1;
    width: auto;
    max-width: none;
    height: auto;
    max-height: none;
    min-height: 0;
    margin-inline: 0;
    padding: 20px 18px;
    border-top: 0;
    border-right: 1px solid color-mix(in srgb, var(--green) 26%, var(--line));
    border-left: 0;
    border-radius: 0;
    box-shadow:
      18px 0 48px rgba(0, 0, 0, 0.24),
      inset 0 1px 0 color-mix(in srgb, var(--green) 16%, transparent);
    transform: none;
    transition: none;
    touch-action: auto;
    will-change: auto;
  }

  :root[data-theme="light"].tablet-touch-layout .bank-panel {
    border-top-color: transparent;
    border-right-color: #a9d8de;
    border-left-color: transparent;
    background: linear-gradient(180deg, var(--accent-bg-light) 0%, var(--accent-bg-light-2) 100%);
  }

  :root.tablet-touch-layout .bank-panel.mobile-expanded {
    height: auto;
    min-height: 0;
  }

  :root.tablet-touch-layout .bank-header {
    cursor: default;
    touch-action: auto;
  }

  :root.tablet-touch-layout .bank-panel::before {
    content: none;
    display: none;
  }

  :root.tablet-touch-layout .app-shell.bank-collapsed .bank-panel {
    display: none;
  }

  :root.tablet-touch-layout .panel-resizer {
    display: block;
    grid-column: 2;
    grid-row: 1;
    width: 16px;
    min-width: 16px;
    background:
      linear-gradient(90deg, transparent 0 4px, color-mix(in srgb, var(--green) 18%, transparent) 4px 12px, transparent 12px 100%);
    touch-action: pan-y;
  }

  :root.tablet-touch-layout .panel-resizer::before {
    width: 3px;
    background: color-mix(in srgb, var(--green) 54%, var(--line));
    box-shadow: 0 0 14px color-mix(in srgb, var(--green) 20%, transparent);
  }

  :root.tablet-touch-layout .panel-resizer::after {
    width: 6px;
    height: 58px;
    opacity: 0.78;
    color: color-mix(in srgb, var(--green) 72%, var(--text));
    background:
      radial-gradient(circle at 50% 9px, currentColor 0 1.5px, transparent 2px),
      radial-gradient(circle at 50% 19px, currentColor 0 1.5px, transparent 2px),
      radial-gradient(circle at 50% 29px, currentColor 0 1.5px, transparent 2px),
      radial-gradient(circle at 50% 39px, currentColor 0 1.5px, transparent 2px),
      radial-gradient(circle at 50% 49px, currentColor 0 1.5px, transparent 2px);
  }

  :root.tablet-touch-layout .lineup-add-actions:not([hidden]) {
    position: static;
    right: auto;
    bottom: auto;
    left: auto;
    z-index: auto;
    width: auto;
    inline-size: auto;
    max-width: none;
    height: auto;
    min-height: 0;
    margin: 0;
    padding: 10px 4px 0;
    gap: 8px;
    overflow: visible;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    contain: none;
    isolation: auto;
    pointer-events: auto;
    transform: none;
    transition: none;
    will-change: auto;
  }

  :root[data-theme="light"].tablet-touch-layout .lineup-add-actions:not([hidden]) {
    background: transparent;
  }

  :root.tablet-touch-layout .lineup-add-actions:not([hidden])::before,
  :root.tablet-touch-layout .lineup-add-actions::after {
    content: none;
  }

  :root.tablet-touch-layout .lineup-add-actions .icon-button,
  :root.tablet-touch-layout .lineup-add-actions #addNoteButton {
    width: auto;
    min-width: 82px;
    height: 40px;
    min-height: 40px;
    padding: 0 10px;
    gap: 6px;
    border-radius: 10px;
    font-size: 0.68rem;
    pointer-events: auto;
  }

  :root.tablet-touch-layout .lineup-add-actions .icon-button span {
    font-size: 0.68rem;
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (orientation: portrait) {
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-table {
    margin-top: clamp(470px, 58vw, 620px);
    margin-right: 0;
  }

  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-heading,
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-row {
    grid-template-columns: 24px 34px minmax(168px, 1fr) minmax(156px, 0.36fr) 116px 76px 42px 46px 46px 48px;
    gap: 8px;
  }

  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-add-actions {
    display: none;
  }

  :root.tablet-touch-layout .show-panel.slide-preview-open .slide-preview-panel {
    top: clamp(92px, 9dvh, 128px);
    right: 22px;
    bottom: auto;
    left: 22px;
    width: auto;
    min-width: 0;
    max-height: none;
    gap: 10px;
    padding: 12px;
  }

  :root.tablet-touch-layout .show-panel.slide-preview-open .slide-preview-stage {
    min-height: 0;
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (min-height: 521px) and (orientation: landscape) {
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-table {
    margin-right: min(506px, 44vw);
  }

  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-add-actions {
    display: none;
  }

  :root.tablet-touch-layout .show-panel.slide-preview-open .slide-preview-panel {
    top: clamp(112px, 14dvh, 134px);
    right: 22px;
    bottom: auto;
    left: auto;
    width: min(486px, 42vw);
    min-width: 420px;
    max-height: none;
    gap: 10px;
    padding: 12px;
  }

  :root.tablet-touch-layout .show-panel.slide-preview-open .slide-preview-stage {
    min-height: 0;
  }
}

@media (max-width: 760px), (max-height: 520px) and (orientation: landscape) and (pointer: coarse) {
  .guest-mode-notice {
    right: max(8px, env(safe-area-inset-right, 0px));
    bottom: max(8px, env(safe-area-inset-bottom, 0px));
    left: max(8px, env(safe-area-inset-left, 0px));
    justify-content: space-between;
    padding: 7px 8px;
    font-size: 0.66rem;
    line-height: 1.15;
  }

  .guest-mode-notice button {
    min-height: 28px;
    padding: 0 9px;
    font-size: 0.66rem;
  }

  body.guest-mode .app-shell {
    padding-bottom: 48px;
  }

  .setlist-import-targets {
    grid-template-columns: minmax(0, 1fr);
    gap: 6px;
  }

  .show-header {
    align-items: start;
    gap: 6px;
  }

  .show-tools {
    align-self: start;
    align-items: flex-start;
    padding-top: 0;
  }

  .header-actions {
    align-items: flex-start;
    gap: 6px;
  }

  .show-title-row {
    grid-template-columns: 34px minmax(0, 1fr) 30px;
    grid-template-rows: 34px 28px;
    align-items: flex-end;
    column-gap: 5px;
    row-gap: 2px;
    min-width: 0;
  }

  .mobile-show-symbol {
    grid-column: 1;
    grid-row: 1;
    width: 32px;
    min-width: 32px;
    height: 32px;
    min-height: 32px;
  }

  .show-title-input {
    grid-column: 2;
    grid-row: 1;
    min-width: 0;
    width: 100%;
    height: 34px;
    min-height: 34px;
    overflow: hidden;
    border: 0;
    padding: 0;
    background: transparent;
    font-size: 1.12rem;
    line-height: 1;
    text-overflow: ellipsis;
    box-shadow: none;
  }

  .setlist-title-menu {
    grid-column: 3;
    grid-row: 1;
    justify-self: start;
    margin-left: -10px;
  }

  .setlist-title-menu-button {
    width: 30px;
    min-width: 30px;
    height: 30px;
    min-height: 30px;
    border-color: color-mix(in srgb, var(--line-strong) 78%, transparent);
    border-radius: 10px;
    background:
      linear-gradient(180deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.012)),
      color-mix(in srgb, var(--panel-2) 82%, transparent);
    color: color-mix(in srgb, var(--text) 86%, var(--muted));
  }

  .setlist-title-menu-button::before {
    border-left-width: 4.5px;
    border-right-width: 4.5px;
    border-top-width: 5.5px;
  }

  .setlist-title-menu[open] .setlist-title-menu-button {
    border-color: color-mix(in srgb, var(--green) 34%, transparent);
    color: var(--green);
  }

  .show-date-inline {
    grid-column: 2 / 4;
    grid-row: 2;
    justify-self: start;
    width: min(128px, 100%);
    height: 28px;
    border-radius: 10px;
    padding: 0 5px;
    font-size: 0.68rem;
  }
}

@media (max-height: 520px) and (orientation: landscape) and (pointer: coarse) {
  .lineup-add-actions:not([hidden]) {
    position: fixed;
    right: calc(10px + env(safe-area-inset-right, 0px));
    bottom: 0;
    left: auto;
    z-index: 24;
    display: inline-flex;
    align-items: flex-end;
    justify-content: flex-end;
    width: min(152px, calc(100vw - 20px - env(safe-area-inset-right, 0px) - env(safe-area-inset-left, 0px)));
    inline-size: min(152px, calc(100vw - 20px - env(safe-area-inset-right, 0px) - env(safe-area-inset-left, 0px)));
    height: 45px;
    min-height: 45px;
    min-width: 0;
    max-width: calc(100vw - 20px - env(safe-area-inset-right, 0px) - env(safe-area-inset-left, 0px));
    margin: 0;
    padding: 5px 5px 0;
    gap: 4px;
    overflow: visible;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    contain: layout style;
    isolation: isolate;
    pointer-events: none;
    transform: translateZ(0);
  }

  :root[data-theme="light"] .lineup-add-actions:not([hidden]) {
    background: transparent;
  }

  .lineup-add-actions:not([hidden])::before {
    position: absolute;
    inset: 0;
    right: 0;
    z-index: 0;
    width: auto;
    border: 1px solid color-mix(in srgb, var(--green) 34%, var(--line-strong));
    border-bottom-color: transparent;
    border-radius: 13px 13px 0 0;
    background:
      linear-gradient(180deg, rgb(var(--accent-rgb) / 0.12), rgb(var(--accent-secondary-rgb) / 0.1)),
      color-mix(in srgb, var(--accent-bg-dark) 56%, rgba(6, 17, 24, 0.99));
    box-shadow:
      0 -8px 22px rgba(0, 0, 0, 0.2),
      inset 0 1px 0 color-mix(in srgb, white 8%, transparent);
    content: "";
    pointer-events: none;
  }

  :root[data-theme="light"] .lineup-add-actions:not([hidden])::before {
    border-color: #a9d8de;
    background: var(--accent-bg-light);
  }

  .lineup-add-actions::after {
    content: none;
  }

  .lineup-add-actions .icon-button,
  .lineup-add-actions #addNoteButton {
    position: relative;
    z-index: 1;
    display: inline-grid;
    grid-template-rows: 17px 12px;
    align-content: center;
    justify-items: center;
    width: 68px;
    min-width: 68px;
    height: 40px;
    min-height: 40px;
    padding: 3px 7px 2px;
    gap: 2px;
    overflow: visible;
    border-radius: 10px;
    font-size: 0.6rem;
    line-height: 1;
    pointer-events: auto;
  }

  .lineup-add-actions #addSlideOnlyButton {
    border-color: color-mix(in srgb, var(--green) 48%, var(--line));
    color: var(--green);
    background: color-mix(in srgb, var(--green) 11%, transparent);
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--green) 9%, transparent);
  }

  .lineup-add-actions #addNoteButton {
    border-color: color-mix(in srgb, var(--amber) 52%, var(--line));
    color: var(--amber);
    background: color-mix(in srgb, var(--amber) 12%, transparent);
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--amber) 10%, transparent);
  }

  .lineup-add-actions .icon-button span {
    display: block;
    font-size: 0.6rem;
    font-weight: 900;
    line-height: 1;
    white-space: nowrap;
  }

  .lineup-add-actions .icon-button .add-action-icon-stack {
    flex-basis: 17px;
    width: 17px;
    height: 17px;
    margin-right: 0;
  }

  .lineup-add-actions .lineup-add-slide-button .add-action-main-icon,
  .lineup-add-actions .library-add-note-button .add-action-main-icon,
  .lineup-add-actions #addNoteButton .add-action-main-icon {
    width: 15px;
    height: 15px;
  }

  .lineup-add-actions .add-action-plus-icon,
  .lineup-add-actions #addNoteButton .note-plus-icon {
    top: -3px;
    right: -4px;
    width: 10px;
    height: 10px;
  }

  .show-title-row {
    grid-template-columns: 30px minmax(0, 1fr) 26px;
    grid-template-rows: 30px 24px;
    column-gap: 5px;
    row-gap: 1px;
  }

  .mobile-show-symbol {
    width: 28px;
    min-width: 28px;
    height: 28px;
    min-height: 28px;
  }

  .show-title-input {
    height: 30px;
    min-height: 30px;
    font-size: 1rem;
  }

  .setlist-title-menu-button {
    width: 26px;
    min-width: 26px;
    height: 28px;
    min-height: 28px;
  }

  .show-date-inline {
    width: min(112px, 100%);
    height: 24px;
    font-size: 0.62rem;
  }
}

@media (orientation: landscape) and (max-width: 960px) and (max-height: 620px) and (pointer: coarse) {
  .show-panel,
  .app-shell.bank-collapsed .show-panel,
  .app-shell.mobile-library-minimized .show-panel,
  .app-shell.mobile-library-middle .show-panel,
  .app-shell.mobile-library-full .show-panel {
    padding-bottom: 0;
  }

  .lineup-table,
  .app-shell.bank-collapsed .lineup-table,
  .app-shell.mobile-library-minimized .lineup-table,
  .app-shell.mobile-library-middle .lineup-table,
  .app-shell.mobile-library-full .lineup-table {
    flex: 1 1 auto;
    min-height: 0;
  }

  .lineup-rows,
  .app-shell.bank-collapsed .lineup-rows,
  .app-shell.mobile-library-minimized .lineup-rows,
  .app-shell.mobile-library-middle .lineup-rows,
  .app-shell.mobile-library-full .lineup-rows {
    flex: 1 1 auto;
    max-height: none;
    padding-bottom: 4px;
  }

  .lineup-add-actions:not([hidden]) {
    position: fixed;
    right: calc(8px + env(safe-area-inset-right, 0px));
    bottom: 0;
    left: auto;
    z-index: 24;
    display: inline-flex;
    align-items: flex-end;
    justify-content: center;
    width: min(176px, calc(100vw - 18px - env(safe-area-inset-right, 0px) - env(safe-area-inset-left, 0px)));
    inline-size: min(176px, calc(100vw - 18px - env(safe-area-inset-right, 0px) - env(safe-area-inset-left, 0px)));
    height: 49px;
    min-height: 49px;
    max-width: calc(100vw - 18px - env(safe-area-inset-right, 0px) - env(safe-area-inset-left, 0px));
    margin: 0;
    padding: 6px 6px 0;
    gap: 6px;
    overflow: visible;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    pointer-events: none;
    transform: none;
  }

  .lineup-add-actions:not([hidden])::before {
    position: absolute;
    inset: 0;
    z-index: 0;
    border: 1px solid color-mix(in srgb, var(--green) 34%, var(--line-strong));
    border-bottom-color: transparent;
    border-radius: 14px 14px 0 0;
    background:
      linear-gradient(180deg, rgb(var(--accent-rgb) / 0.12), rgb(var(--accent-secondary-rgb) / 0.1)),
      color-mix(in srgb, var(--accent-bg-dark) 58%, rgba(6, 17, 24, 0.99));
    box-shadow:
      0 -8px 22px rgba(0, 0, 0, 0.2),
      inset 0 1px 0 color-mix(in srgb, white 8%, transparent);
    content: "";
    pointer-events: none;
  }

  :root[data-theme="light"] .lineup-add-actions:not([hidden])::before {
    border-color: #a9d8de;
    background: var(--accent-bg-light);
  }

  .lineup-add-actions::after {
    content: none;
  }

  .lineup-add-actions .icon-button,
  .lineup-add-actions #addNoteButton {
    position: relative;
    z-index: 1;
    display: inline-grid;
    grid-template-rows: 18px 13px;
    align-content: center;
    justify-items: center;
    width: 79px;
    min-width: 79px;
    height: 43px;
    min-height: 43px;
    padding: 4px 8px 3px;
    gap: 2px;
    overflow: visible;
    border-radius: 11px;
    font-size: 0.62rem;
    line-height: 1;
    pointer-events: auto;
  }

  .lineup-add-actions #addSlideOnlyButton {
    border-color: color-mix(in srgb, var(--green) 50%, var(--line));
    color: var(--green);
    background: color-mix(in srgb, var(--green) 12%, transparent);
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--green) 10%, transparent);
  }

  .lineup-add-actions #addNoteButton {
    border-color: color-mix(in srgb, var(--amber) 54%, var(--line));
    color: var(--amber);
    background: color-mix(in srgb, var(--amber) 13%, transparent);
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--amber) 11%, transparent);
  }

  .lineup-add-actions .icon-button span {
    display: block;
    margin: 0;
    font-size: 0.62rem;
    font-weight: 900;
    line-height: 1;
    white-space: nowrap;
  }

  .lineup-add-actions .icon-button .add-action-icon-stack {
    flex-basis: 18px;
    width: 18px;
    height: 18px;
    margin-right: 0;
  }

  .lineup-add-actions .lineup-add-slide-button .add-action-main-icon,
  .lineup-add-actions .library-add-note-button .add-action-main-icon,
  .lineup-add-actions #addNoteButton .add-action-main-icon {
    width: 16px;
    height: 16px;
  }

  .lineup-add-actions .add-action-plus-icon,
  .lineup-add-actions #addNoteButton .note-plus-icon {
    top: -3px;
    right: -4px;
    width: 10px;
    height: 10px;
  }

  .export-dialog-inner {
    grid-template-columns: clamp(224px, 31vw, 286px) minmax(0, 1fr);
    grid-template-rows: auto auto minmax(0, 1fr) auto;
    gap: 6px 8px;
    padding: 7px;
  }

  .export-dialog .dialog-header {
    grid-column: 1;
    grid-row: 1;
    align-items: center;
    min-height: 0;
    margin: 0;
  }

  .export-dialog .dialog-header .eyebrow {
    display: none;
  }

  .export-dialog .dialog-header h2 {
    font-size: 0.92rem;
    line-height: 1;
  }

  .export-dialog .dialog-header .icon-button {
    width: 28px;
    min-width: 28px;
    height: 28px;
    min-height: 28px;
    border-radius: 8px;
  }

  .export-tabs {
    grid-column: 1;
    grid-row: 2;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 3px;
    min-width: 0;
    overflow: visible;
    padding-bottom: 0;
  }

  .export-tab {
    min-width: 0;
    min-height: 30px;
    border-radius: 7px;
    padding: 0 4px;
    font-size: 0;
  }

  .export-tab::after {
    font-size: 0.62rem;
    font-weight: 950;
    line-height: 1;
  }

  .export-tab[data-export-tab="setlist"]::after {
    content: "Setlist";
  }

  .export-tab[data-export-tab="slides"]::after {
    content: "Slides";
  }

  .export-tab[data-export-tab="sheets"]::after {
    content: "Sheets";
  }

  .export-settings {
    grid-column: 1;
    grid-row: 3;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-self: stretch;
    align-content: start;
    align-items: stretch;
    gap: 5px;
    min-height: 0;
    max-height: none;
    overflow: auto;
    padding: 5px;
  }

  .export-settings .page-control {
    order: 1;
    grid-column: 1;
    width: 76px;
  }

  .export-settings .orientation-control.font-control:not(.columns-control):not(.spacing-control) {
    order: 2;
    grid-column: 2;
    justify-self: start;
    width: min(100%, 170px);
  }

  .export-settings .orientation-control.columns-control {
    order: 3;
    grid-column: 1;
    width: 76px;
  }

  .export-settings .orientation-control.spacing-control {
    order: 5;
    grid-column: 1 / -1;
  }

  .export-settings .export-toggle-row {
    order: 6;
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 4px;
  }

  .export-settings .fit-toggle {
    order: 4;
    grid-column: 2;
    justify-self: start;
    width: max-content;
    min-width: 88px;
  }

  .export-settings .orientation-control,
  .export-settings .export-option,
  .export-settings .export-toggle-row .export-option {
    align-content: stretch;
    min-width: 0;
    min-height: 40px;
    border-radius: 8px;
    padding: 4px;
  }

  .export-settings .orientation-control {
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    gap: 1px 0;
  }

  .export-settings .export-option,
  .export-settings .export-toggle-row .export-option {
    display: grid;
  }

  .export-settings .orientation-control legend,
  .export-settings .export-option::before {
    flex: 0 0 100%;
    display: block;
    width: 100%;
    height: 10px;
    margin: 0;
    color: var(--muted);
    font-size: 0.48rem;
    font-weight: 950;
    line-height: 1;
    letter-spacing: 0;
    text-transform: uppercase;
  }

  .export-settings .page-control legend,
  .export-settings .export-toggle-row .export-option::before,
  .export-settings .fit-toggle::before {
    display: none;
    content: none;
  }

  .export-settings .orientation-control.font-control:not(.columns-control):not(.spacing-control) legend {
    font-size: 0;
  }

  .export-settings .orientation-control.font-control:not(.columns-control):not(.spacing-control) legend::after {
    content: "Text size";
    font-size: 0.42rem;
  }

  .export-settings .orientation-control label {
    flex: 1 1 0;
    min-width: 0;
  }

  .export-settings .orientation-control span,
  .export-settings .export-option span,
  .export-settings .export-toggle-row .export-option span {
    min-width: 0;
    min-height: 25px;
    margin: 0;
    padding: 0 4px;
    font-size: 0.58rem;
    line-height: 1;
    white-space: nowrap;
  }

  .export-settings .page-control {
    grid-template-rows: minmax(40px, 1fr);
  }

  .export-settings .page-control span {
    min-height: 40px;
    padding: 0;
  }

  .export-settings .orientation-icon::before {
    border-width: 1.7px;
  }

  .export-settings .portrait-icon::before {
    width: 11px;
    height: 19px;
  }

  .export-settings .landscape-icon::before {
    width: 22px;
    height: 11px;
  }

  .export-settings .orientation-control.font-control:not(.columns-control):not(.spacing-control) label:nth-of-type(2) span,
  .export-settings .orientation-control.font-control:not(.columns-control):not(.spacing-control) label:nth-of-type(3) span,
  .export-settings .orientation-control.font-control:not(.columns-control):not(.spacing-control) label:nth-of-type(4) span,
  .export-settings .orientation-control.columns-control label:first-of-type span {
    font-size: 0;
  }

  .export-settings .orientation-control.font-control:not(.columns-control):not(.spacing-control) label:nth-of-type(2) span::after {
    content: "S";
    font-size: 0.58rem;
  }

  .export-settings .orientation-control.font-control:not(.columns-control):not(.spacing-control) label:nth-of-type(3) span::after {
    content: "M";
    font-size: 0.58rem;
  }

  .export-settings .orientation-control.font-control:not(.columns-control):not(.spacing-control) label:nth-of-type(4) span::after {
    content: "L";
    font-size: 0.58rem;
  }

  .export-settings .orientation-control.columns-control label:first-of-type span::after {
    content: "A";
    font-size: 0.58rem;
  }

  .export-settings .spacing-control label span,
  .export-settings .columns-control label span {
    min-width: 0;
  }

  .export-settings .credit-toggle,
  .export-settings .real-key-toggle,
  .export-settings .fit-toggle {
    grid-template-rows: minmax(36px, 1fr);
  }

  .export-settings .credit-toggle span,
  .export-settings .real-key-toggle span,
  .export-settings .fit-toggle span {
    min-height: 36px;
    font-size: 0;
  }

  .export-settings .credit-toggle span::before {
    content: "Credits";
    font-size: 0.58rem;
  }

  .export-settings .real-key-toggle span::before {
    content: "Real key";
    font-size: 0.58rem;
  }

  .export-settings .fit-toggle span::before {
    content: "Fit page";
    font-size: 0.58rem;
  }

  .export-preview {
    grid-column: 2;
    grid-row: 1 / 5;
    align-self: stretch;
    justify-self: stretch;
    min-width: 0;
    min-height: 0;
    max-height: none;
    overflow: hidden;
    height: 100%;
    padding: 6px;
  }

  .export-sheet-preview.image-preview {
    width: auto;
    height: 100%;
    max-width: 100%;
    max-height: 100%;
  }

  .export-sheet-preview.image-preview.landscape {
    width: 100%;
    height: auto;
    max-width: 100%;
    max-height: 100%;
  }

  .dialog-actions.export-actions {
    grid-column: 1;
    grid-row: 4;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    justify-content: stretch;
    gap: 5px;
    min-width: 0;
  }

  .dialog-actions.export-actions .export-file-button {
    min-width: 0;
    min-height: 38px;
    padding: 0 8px;
    font-size: 0.66rem;
  }

  .export-download-ready {
    grid-column: 2;
    grid-row: 4;
    align-self: end;
    justify-content: flex-start;
  }

  .export-tab-panel {
    grid-column: 1 / -1;
    grid-row: 3 / 5;
  }
}

@media (min-width: 761px) and (max-width: 1100px) and (orientation: portrait),
  (min-width: 1101px) and (max-width: 1366px) and (orientation: portrait) and (pointer: coarse) {
  .guest-mode-notice {
    right: auto;
    bottom: max(12px, env(safe-area-inset-bottom, 0px));
    left: max(18px, env(safe-area-inset-left, 0px));
    width: min(500px, calc(100vw - 260px));
    justify-content: space-between;
    padding: 8px 10px;
    font-size: 0.68rem;
    line-height: 1.15;
  }

  .guest-mode-notice button {
    min-height: 28px;
    padding: 0 10px;
    font-size: 0.68rem;
  }

  body.guest-mode .app-shell {
    padding-bottom: 0;
  }

  body.guest-mode .bank-panel .song-bank-list {
    padding-bottom: calc(46px + env(safe-area-inset-bottom, 0px));
  }

  .home-link-bottom,
  body.guest-mode .home-link-bottom {
    display: none;
  }

  body:has(.app-shell.bank-collapsed) .guest-mode-notice,
  body:has(.app-shell.mobile-library-minimized) .guest-mode-notice {
    bottom: calc(62px + env(safe-area-inset-bottom, 0px));
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (min-height: 521px) and (orientation: landscape) and (pointer: coarse) {
  .guest-mode-notice {
    right: auto;
    bottom: max(12px, env(safe-area-inset-bottom, 0px));
    left: max(18px, env(safe-area-inset-left, 0px));
    width: min(500px, calc(100vw - 260px));
    justify-content: space-between;
    padding: 8px 10px;
    font-size: 0.68rem;
    line-height: 1.15;
  }

  .guest-mode-notice button {
    min-height: 28px;
    padding: 0 10px;
    font-size: 0.68rem;
  }

  body.guest-mode .app-shell {
    padding-bottom: 0;
  }

  body.guest-mode .bank-panel .song-bank-list {
    padding-bottom: calc(46px + env(safe-area-inset-bottom, 0px));
  }

  .home-link-bottom,
  body.guest-mode .home-link-bottom {
    display: none;
  }

  body:has(.app-shell.bank-collapsed) .guest-mode-notice,
  body:has(.app-shell.mobile-library-minimized) .guest-mode-notice {
    bottom: calc(62px + env(safe-area-inset-bottom, 0px));
  }
}

@media (max-width: 600px) and (orientation: portrait) {
  .export-settings {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 4px;
    padding: 5px;
    overflow: visible;
  }

  .export-settings .page-control {
    order: 1;
    grid-column: span 2;
  }

  .export-settings .orientation-control.font-control:not(.columns-control):not(.spacing-control) {
    order: 2;
    grid-column: span 3;
  }

  .export-settings .orientation-control.columns-control {
    order: 3;
    grid-column: span 2;
  }

  .export-settings .fit-toggle {
    order: 4;
    grid-column: span 2;
  }

  .export-settings .orientation-control.spacing-control {
    order: 5;
    grid-column: span 3;
  }

  .export-settings .export-toggle-row {
    display: contents;
  }

  .export-settings .credit-toggle {
    order: 6;
    grid-column: span 1;
  }

  .export-settings .real-key-toggle {
    order: 7;
    grid-column: span 1;
  }

  .export-settings .orientation-control,
  .export-settings .export-option,
  .export-settings .export-toggle-row .export-option {
    align-content: stretch;
    min-width: 0;
    min-height: 38px;
    border-radius: 9px;
    padding: 4px;
  }

  .export-settings .orientation-control {
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    gap: 1px 0;
  }

  .export-settings .export-option,
  .export-settings .export-toggle-row .export-option {
    display: grid;
  }

  .export-settings .orientation-control legend {
    flex: 0 0 100%;
    display: block;
    width: 100%;
    height: 10px;
    margin: 0;
    color: var(--muted);
    font-size: 0.48rem;
    font-weight: 950;
    line-height: 1;
    letter-spacing: 0;
    text-transform: uppercase;
  }

  .export-settings .page-control legend {
    display: none;
  }

  .export-settings .orientation-control.font-control:not(.columns-control):not(.spacing-control) legend {
    font-size: 0;
  }

  .export-settings .orientation-control.font-control:not(.columns-control):not(.spacing-control) legend::after {
    content: "Text size";
    font-size: 0.42rem;
  }

  .export-settings .orientation-control label {
    flex: 1 1 0;
    min-width: 0;
  }

  .export-settings .orientation-control span,
  .export-settings .export-option span,
  .export-settings .export-toggle-row .export-option span {
    min-width: 0;
    min-height: 24px;
    margin: 0;
    padding: 0 3px;
    font-size: 0.56rem;
    line-height: 1;
    white-space: nowrap;
  }

  .export-settings .page-control {
    grid-template-rows: minmax(38px, 1fr);
  }

  .export-settings .page-control span {
    min-height: 38px;
    padding: 0;
  }

  .export-settings .orientation-icon::before {
    border-width: 1.8px;
  }

  .export-settings .portrait-icon::before {
    width: 11px;
    height: 20px;
  }

  .export-settings .landscape-icon::before {
    width: 23px;
    height: 12px;
  }

  .export-settings .orientation-control.font-control:not(.columns-control):not(.spacing-control) label:nth-of-type(2) span,
  .export-settings .orientation-control.font-control:not(.columns-control):not(.spacing-control) label:nth-of-type(3) span,
  .export-settings .orientation-control.font-control:not(.columns-control):not(.spacing-control) label:nth-of-type(4) span,
  .export-settings .orientation-control.columns-control label:first-of-type span {
    font-size: 0;
  }

  .export-settings .orientation-control.font-control:not(.columns-control):not(.spacing-control) label:nth-of-type(2) span::after {
    content: "S";
    font-size: 0.58rem;
  }

  .export-settings .orientation-control.font-control:not(.columns-control):not(.spacing-control) label:nth-of-type(3) span::after {
    content: "M";
    font-size: 0.58rem;
  }

  .export-settings .orientation-control.font-control:not(.columns-control):not(.spacing-control) label:nth-of-type(4) span::after {
    content: "L";
    font-size: 0.58rem;
  }

  .export-settings .orientation-control.columns-control label:first-of-type span::after {
    content: "A";
    font-size: 0.58rem;
  }

  .export-settings .spacing-control label span,
  .export-settings .columns-control label span {
    min-width: 0;
  }

  .export-settings .export-option::before,
  .export-settings .export-toggle-row .export-option::before {
    display: none;
    content: none;
  }

  .export-settings .credit-toggle,
  .export-settings .real-key-toggle,
  .export-settings .fit-toggle {
    grid-template-rows: minmax(38px, 1fr);
  }

  .export-settings .credit-toggle span,
  .export-settings .real-key-toggle span,
  .export-settings .fit-toggle span {
    min-height: 38px;
    font-size: 0;
  }

  .export-settings .credit-toggle span::before {
    content: "Credits";
    font-size: 0.52rem;
  }

  .export-settings .real-key-toggle span::before {
    content: "Real key";
    font-size: 0.52rem;
  }

  .export-settings .fit-toggle span::before {
    content: "Fit page";
    font-size: 0.56rem;
  }

  .export-preview {
    padding: 4px;
  }

  .export-sheet-preview.image-preview {
    width: min(100%, 42dvh);
    max-height: 100%;
  }

  .export-sheet-preview.image-preview.landscape {
    width: min(100%, 58dvh);
  }
}

@media (max-width: 600px) and (orientation: portrait),
  (orientation: landscape) and (max-width: 960px) and (max-height: 620px) and (pointer: coarse) {
  .export-settings .credit-toggle::before,
  .export-settings .real-key-toggle::before,
  .export-settings .export-toggle-row .credit-toggle::before,
  .export-settings .export-toggle-row .real-key-toggle::before {
    display: none !important;
    content: none !important;
  }

  .export-settings .credit-toggle span,
  .export-settings .real-key-toggle span {
    font-size: 0.52rem !important;
    line-height: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .export-settings .credit-toggle span::before,
  .export-settings .real-key-toggle span::before {
    display: none !important;
    content: none !important;
  }
}

@media (min-width: 761px) and (max-width: 1366px) {
  :root.tablet-touch-layout .app-shell {
    margin: 16px;
    height: calc(var(--lineup-viewport-height, 100dvh) - 32px);
    border-radius: 28px;
  }

  :root.tablet-touch-layout .show-panel {
    padding: 32px 30px 22px;
  }

  :root.tablet-touch-layout .show-header {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 14px;
    margin-bottom: 26px;
  }

  :root.tablet-touch-layout .show-title-block {
    width: auto;
    min-width: 0;
  }

  :root.tablet-touch-layout .show-title-row {
    display: flex;
    align-items: center;
    flex-wrap: nowrap;
    gap: 12px;
    min-width: 0;
  }

  :root.tablet-touch-layout .mobile-show-symbol {
    display: grid;
    width: 38px;
    min-width: 38px;
    height: 38px;
    min-height: 38px;
    border-radius: 8px;
  }

  :root.tablet-touch-layout .show-title-input {
    flex: 0 1 auto;
    width: auto;
    min-width: 0;
    max-width: min(34vw, 330px);
    height: 42px;
    min-height: 42px;
    border: 0;
    padding: 0;
    background: transparent;
    box-shadow: none;
    font-size: 1.7rem;
    font-weight: 820;
    line-height: 1;
  }

  :root.tablet-touch-layout .show-title-input:hover,
  :root.tablet-touch-layout .show-title-input:focus {
    border-color: transparent;
    background: transparent;
    padding: 0;
    box-shadow: none;
  }

  :root.tablet-touch-layout .setlist-title-menu {
    flex: 0 0 auto;
    align-self: center;
    margin-left: -2px;
    order: 2;
  }

  :root.tablet-touch-layout .setlist-title-menu-button {
    width: 30px;
    min-width: 30px;
    height: 30px;
    min-height: 30px;
    border-radius: 9px;
  }

  :root.tablet-touch-layout .setlist-title-menu-button::before {
    border-left-width: 5px;
    border-right-width: 5px;
    border-top-width: 6px;
  }

  :root.tablet-touch-layout .setlist-title-menu-popover {
    top: calc(100% + 8px);
    left: -300px;
    width: 250px;
    border-radius: 14px;
    padding: 10px;
  }

  :root.tablet-touch-layout .setlist-title-menu-item {
    min-height: 42px;
    border-radius: 10px;
    font-size: 0.86rem;
    font-weight: 860;
  }

  :root.tablet-touch-layout .show-date-inline {
    flex: 0 0 128px;
    width: 128px;
    height: 30px;
    min-height: 30px;
    border-radius: 8px;
    padding: 0 8px;
    font-size: 0.76rem;
    order: 3;
  }

  :root.tablet-touch-layout .show-tools {
    align-self: center;
    align-items: flex-end;
    width: auto;
  }

  :root.tablet-touch-layout .header-actions {
    gap: 8px;
    width: auto;
    overflow: visible;
  }

  :root.tablet-touch-layout .top-icon-button,
  :root.tablet-touch-layout .header-menu summary,
  :root.tablet-touch-layout .header-actions > .history-button,
  :root.tablet-touch-layout .header-actions > #exportButton,
  :root.tablet-touch-layout .header-actions > #saveLineupButton {
    width: 38px;
    min-width: 38px;
    height: 38px;
    min-height: 38px;
    border-radius: 8px;
  }

  :root.tablet-touch-layout .header-actions > #saveLineupButton {
    display: inline-grid;
  }

  :root.tablet-touch-layout .header-actions > #slidePreviewToggle,
  :root.tablet-touch-layout .header-actions > .visible-theme-toggle {
    display: none !important;
  }

  :root.tablet-touch-layout .header-menu,
  :root.tablet-touch-layout .header-menu summary {
    display: inline-grid;
  }

  :root.tablet-touch-layout .header-menu-popover {
    z-index: 80;
    width: 278px;
    min-width: 278px;
    border-radius: 14px;
    padding: 10px;
  }

  :root.tablet-touch-layout .header-menu-popover .top-icon-button,
  :root.tablet-touch-layout .header-menu-popover .app-home-menu-item {
    display: flex;
    width: 100%;
    height: 42px;
    min-height: 42px;
    justify-content: flex-start;
    gap: 12px;
    border-radius: 10px;
    padding: 0 12px;
  }

  :root.tablet-touch-layout .header-menu-popover #slidePreviewMenuButton,
  :root.tablet-touch-layout .header-menu-popover .mobile-theme-menu-button {
    display: flex;
  }

  :root.tablet-touch-layout .header-menu-popover .top-icon-button span {
    display: inline;
    font-size: 0.86rem;
    font-weight: 860;
  }

  :root.tablet-touch-layout .lineup-table {
    min-height: 0;
    border: 1px solid var(--line);
    border-radius: 8px;
    padding: 18px 16px;
    background: color-mix(in srgb, var(--panel) 92%, transparent);
  }

  :root.tablet-touch-layout .lineup-heading,
  :root.tablet-touch-layout .lineup-row {
    grid-template-columns: 24px 32px minmax(200px, 1fr) minmax(126px, 0.42fr) 74px 54px 42px 42px 42px;
    gap: 8px;
  }

  :root.tablet-touch-layout .lineup-heading {
    padding: 0 10px 10px;
    font-size: 0.72rem;
  }

  :root.tablet-touch-layout .lineup-heading span:nth-child(5),
  :root.tablet-touch-layout .lineup-row .capo-cell {
    display: none;
  }

  :root.tablet-touch-layout .lineup-rows {
    gap: 8px;
    min-height: 0;
    padding-right: 0;
    overflow-x: hidden;
  }

  :root.tablet-touch-layout .lineup-row {
    min-height: 64px;
    border-radius: 8px;
    padding: 8px 10px;
  }

  :root.tablet-touch-layout .lineup-row.song-row::before {
    top: 11px;
    bottom: 11px;
    width: 4px;
    border-radius: 999px;
  }

  :root.tablet-touch-layout .song-name {
    font-size: 0.98rem;
    font-weight: 820;
  }

  :root.tablet-touch-layout .subline {
    font-size: 0.76rem;
    font-weight: 720;
  }

  :root.tablet-touch-layout .line-song-note input {
    min-height: 34px;
    border: 0;
    background: transparent;
    box-shadow: none;
    padding: 0;
    font-size: 0.75rem;
    font-weight: 760;
  }

  :root.tablet-touch-layout .key-cell .key-picker-trigger {
    min-width: 46px;
    min-height: 28px;
    border-radius: 999px;
    padding: 0 10px;
    font-size: 0.74rem;
    font-weight: 900;
  }

  :root.tablet-touch-layout .row-icon-actions,
  :root.tablet-touch-layout .note-inline-actions {
    display: none;
  }

  :root.tablet-touch-layout .lineup-row .icon-action,
  :root.tablet-touch-layout .lineup-row .slides-status-button,
  :root.tablet-touch-layout .lineup-row .sheets-status-button {
    width: 30px;
    min-width: 30px;
    height: 30px;
    min-height: 30px;
    border-radius: 8px;
  }

  :root.tablet-touch-layout .lineup-add-actions:not([hidden]) {
    align-self: flex-end;
    width: auto;
    margin-top: 8px;
    padding: 10px 14px;
    gap: 8px;
    border: 1px solid color-mix(in srgb, var(--green) 24%, var(--line));
    border-radius: 12px;
    background: color-mix(in srgb, var(--panel) 88%, transparent);
    box-shadow: 0 16px 34px rgba(0, 0, 0, 0.22);
  }

  :root.tablet-touch-layout .lineup-add-actions .icon-button,
  :root.tablet-touch-layout .lineup-add-actions #addNoteButton {
    width: auto;
    min-width: 104px;
    height: 32px;
    min-height: 32px;
    border-radius: 8px;
    padding: 0 12px;
    gap: 8px;
    font-size: 0.74rem;
  }

  :root.tablet-touch-layout .lineup-add-actions .icon-button span {
    display: inline;
    font-size: 0.74rem;
    font-weight: 860;
  }

  :root.tablet-touch-layout .bank-panel {
    border-color: color-mix(in srgb, var(--green) 20%, var(--line));
    background: linear-gradient(180deg, #16243a 0%, #101922 34%, #0b1115 100%);
  }

  :root.tablet-touch-layout .bank-header {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 12px;
  }

  :root.tablet-touch-layout .bank-heading {
    display: none;
  }

  :root.tablet-touch-layout .bank-header::after {
    content: attr(data-panel-title);
    grid-column: 1;
    grid-row: 1;
    min-width: 0;
    color: var(--text);
    font-size: 1.15rem;
    font-weight: 850;
    letter-spacing: 0;
    text-transform: none;
  }

  :root.tablet-touch-layout .bank-title-actions {
    grid-column: 2;
    grid-row: 1;
  }

  :root.tablet-touch-layout .side-panel-heading {
    display: none;
  }

  :root.tablet-touch-layout .search-row {
    grid-template-columns: minmax(0, 1fr) 34px 34px;
    gap: 8px;
  }

  :root.tablet-touch-layout .search-box input {
    height: 42px;
    font-size: 0.82rem;
  }

  :root.tablet-touch-layout .category-filters {
    gap: 8px;
    margin-bottom: 12px;
  }

  :root.tablet-touch-layout .filter-chip {
    min-height: 28px;
    border-radius: 999px;
    padding: 0 14px;
    font-size: 0.76rem;
  }

  :root.tablet-touch-layout .bank-panel .song-bank-list {
    gap: 8px;
  }

  :root.tablet-touch-layout .bank-song {
    min-height: 66px;
    grid-template-columns: minmax(0, 1fr) 30px 30px 30px;
    gap: 8px;
    border-radius: 8px;
    padding: 10px 10px 10px 16px;
  }

  :root.tablet-touch-layout .bank-song::before {
    top: 12px;
    bottom: 12px;
    width: 3px;
    border-radius: 999px;
  }

  :root.tablet-touch-layout .bank-song .song-name {
    font-size: 0.96rem;
  }

  :root.tablet-touch-layout .bank-tags,
  :root.tablet-touch-layout .hebrew-badge {
    display: inline-flex;
    max-width: 120px;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  :root.tablet-touch-layout .bank-song .banger-toggle {
    display: none;
  }

  :root.tablet-touch-layout .bank-slides-button,
  :root.tablet-touch-layout .bank-sheets-button,
  :root.tablet-touch-layout .bank-edit-button {
    width: 30px;
    min-width: 30px;
    height: 30px;
    min-height: 30px;
    border-radius: 8px;
  }

  :root.tablet-touch-layout .guest-mode-notice {
    left: max(28px, env(safe-area-inset-left, 0px));
    right: auto;
    bottom: max(16px, env(safe-area-inset-bottom, 0px));
    width: min(520px, calc(100vw - 56px));
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (orientation: portrait) {
  :root.tablet-touch-layout .app-shell {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    grid-template-rows: minmax(0, 1fr);
  }

  :root.tablet-touch-layout .show-panel {
    grid-column: 1;
    grid-row: 1;
    padding: 32px 30px 378px;
  }

  :root.tablet-touch-layout .show-header {
    grid-template-columns: minmax(0, 1fr) auto;
    margin-bottom: 26px;
  }

  :root.tablet-touch-layout .show-title-input {
    max-width: min(38vw, 286px);
  }

  :root.tablet-touch-layout .header-actions > #redoLineupButton,
  :root.tablet-touch-layout .header-actions > #exportButton {
    display: none !important;
  }

  :root.tablet-touch-layout .lineup-table {
    flex: 0 1 auto;
    height: min(636px, calc(var(--lineup-viewport-height, 100dvh) - 438px));
  }

  :root.tablet-touch-layout .lineup-heading,
  :root.tablet-touch-layout .lineup-row {
    grid-template-columns: 24px 32px minmax(180px, 1fr) minmax(118px, 0.38fr) 58px 42px 42px 42px;
  }

  :root.tablet-touch-layout .lineup-heading span:nth-child(4),
  :root.tablet-touch-layout .lineup-row .line-song-note {
    display: block;
  }

  :root.tablet-touch-layout .bank-panel {
    position: absolute;
    right: 30px;
    bottom: 26px;
    left: 30px;
    z-index: 40;
    width: auto;
    max-width: none;
    height: 342px;
    max-height: none;
    min-height: 0;
    margin: 0;
    border: 1px solid color-mix(in srgb, var(--green) 22%, var(--line));
    border-radius: 18px;
    padding: 22px 20px 18px;
    box-shadow: 0 24px 52px rgba(0, 0, 0, 0.34);
    transform: none;
  }

  :root.tablet-touch-layout .bank-panel::before {
    content: "";
    position: absolute;
    top: 9px;
    left: 50%;
    display: block;
    width: 64px;
    height: 4px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--muted) 40%, transparent);
    transform: translateX(-50%);
  }

  :root.tablet-touch-layout .bank-header {
    margin-bottom: 12px;
    padding: 0;
  }

  :root.tablet-touch-layout .bank-title-actions {
    gap: 8px;
  }

  :root.tablet-touch-layout .bank-panel .song-bank-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    overflow: auto;
  }

  :root.tablet-touch-layout .app-shell.bank-collapsed .bank-panel {
    display: flex;
    height: 70px;
    overflow: hidden;
    padding: 16px 20px;
  }

  :root.tablet-touch-layout .app-shell.bank-collapsed .bank-panel .side-panel-view {
    display: none;
  }

  :root.tablet-touch-layout .app-shell.bank-collapsed .bank-header {
    margin: 0;
  }

  :root.tablet-touch-layout .panel-resizer {
    display: none;
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (min-height: 521px) and (orientation: landscape) {
  :root.tablet-touch-layout .app-shell {
    grid-template-columns: 330px 12px minmax(0, 1fr);
    grid-template-rows: minmax(0, 1fr);
  }

  :root.tablet-touch-layout .bank-panel {
    grid-column: 1;
    grid-row: 1;
    padding: 30px 20px;
    border-right: 1px solid color-mix(in srgb, var(--green) 24%, var(--line));
    border-radius: 0;
  }

  :root.tablet-touch-layout .panel-resizer {
    display: block;
    grid-column: 2;
    width: 12px;
    min-width: 12px;
  }

  :root.tablet-touch-layout .show-panel {
    grid-column: 3;
    grid-row: 1;
    padding: 32px 30px 18px;
  }

  :root.tablet-touch-layout .show-title-input {
    max-width: min(25vw, 286px);
  }

  :root.tablet-touch-layout .lineup-table {
    height: auto;
  }

  :root.tablet-touch-layout .lineup-heading,
  :root.tablet-touch-layout .lineup-row {
    grid-template-columns: 24px 32px minmax(200px, 1fr) minmax(126px, 0.42fr) 58px 42px 42px 42px;
  }

  :root.tablet-touch-layout .bank-panel .song-bank-list {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    overflow: auto;
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (orientation: portrait) {
  :root.tablet-touch-layout .show-panel.slide-preview-open {
    padding-bottom: 104px;
  }

  :root.tablet-touch-layout .show-panel.slide-preview-open .slide-preview-panel {
    top: 104px;
    right: 30px;
    left: 30px;
    width: auto;
    min-width: 0;
    max-height: none;
    border-radius: 14px;
    padding: 14px;
  }

  :root.tablet-touch-layout .show-panel.slide-preview-open .slide-preview-stage {
    aspect-ratio: 16 / 9;
    min-height: 0;
    max-height: 430px;
  }

  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-table {
    height: auto;
    margin-top: min(500px, 56vw);
    margin-right: 0;
  }

  :root.tablet-touch-layout .show-panel.slide-preview-open ~ .bank-panel,
  :root.tablet-touch-layout .app-shell:has(.show-panel.slide-preview-open) .bank-panel {
    height: 70px;
    overflow: hidden;
  }

  :root.tablet-touch-layout .app-shell:has(.show-panel.slide-preview-open) .bank-panel .side-panel-view {
    display: none;
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (min-height: 521px) and (orientation: landscape) {
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-table {
    width: min(58%, 600px);
    margin-right: 0;
  }

  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-heading,
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-row {
    grid-template-columns: 24px 32px minmax(170px, 1fr) 54px 42px 42px 42px;
  }

  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-heading span:nth-child(4),
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-row .line-song-note {
    display: none;
  }

  :root.tablet-touch-layout .show-panel.slide-preview-open .slide-preview-panel {
    top: 118px;
    right: 30px;
    left: auto;
    width: min(452px, 40vw);
    min-width: 420px;
    max-height: none;
    border-radius: 14px;
    padding: 14px;
  }

  :root.tablet-touch-layout .show-panel.slide-preview-open .slide-preview-stage {
    aspect-ratio: 16 / 9;
    min-height: 0;
  }
}

@media (min-width: 761px) and (max-width: 1366px) {
  :root.tablet-touch-layout .app-shell.manage-songs-open {
    display: block;
    min-height: var(--lineup-viewport-height, 100dvh);
    overflow: hidden;
  }

  :root.tablet-touch-layout .app-shell.manage-songs-open .bank-panel.manage-mode {
    position: fixed;
    inset: calc(36px + env(safe-area-inset-top, 0px)) 56px calc(36px + env(safe-area-inset-bottom, 0px));
    z-index: 90;
    width: auto;
    height: auto;
    max-height: none;
    border: 1px solid color-mix(in srgb, var(--green) 24%, var(--line-strong));
    border-radius: 22px;
    padding: 24px;
    background: rgba(18, 17, 22, 0.98);
  }

  :root.tablet-touch-layout .app-shell.manage-songs-open .bank-panel.manage-mode::before {
    content: none;
  }

  :root.tablet-touch-layout .app-shell.manage-songs-open .song-manager-view {
    display: flex;
    min-height: 0;
    border-radius: 16px;
  }

  :root.tablet-touch-layout .app-shell.manage-songs-open .song-manager-toolbar {
    grid-template-columns: minmax(180px, 1fr) minmax(260px, 2fr) 112px 112px 42px 42px 42px;
    gap: 10px;
  }

  :root.tablet-touch-layout .app-shell.manage-songs-open .song-manager-grid {
    min-height: 0;
    overflow: auto;
  }
}

@media (min-width: 761px) and (max-width: 1366px) {
  :root.tablet-touch-layout .lineup-next-steps {
    display: none !important;
  }

  :root.tablet-touch-layout .lineup-table {
    gap: 0;
  }

  :root.tablet-touch-layout .row-icon-actions,
  :root.tablet-touch-layout .note-inline-actions {
    display: none !important;
    opacity: 0 !important;
    pointer-events: none !important;
  }

  :root.tablet-touch-layout .lineup-add-actions:not([hidden]) {
    position: static !important;
    inset: auto !important;
    order: -1;
    display: inline-flex !important;
    align-self: flex-end;
    width: auto !important;
    min-width: 0;
    max-width: 100%;
    margin: 0 0 10px auto !important;
    padding: 0 !important;
    gap: 8px;
    overflow: visible;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    transform: none !important;
    transition: none !important;
    will-change: auto !important;
  }

  :root.tablet-touch-layout .lineup-add-actions::before,
  :root.tablet-touch-layout .lineup-add-actions::after {
    content: none !important;
    display: none !important;
  }

  :root.tablet-touch-layout .lineup-add-actions .icon-button,
  :root.tablet-touch-layout .lineup-add-actions #addNoteButton {
    width: auto;
    min-width: 90px;
    height: 36px;
    min-height: 36px;
    border-radius: 8px;
    padding: 0 12px;
    gap: 7px;
    border-color: color-mix(in srgb, var(--green) 18%, var(--line));
    background: color-mix(in srgb, var(--panel-2) 78%, transparent);
    color: var(--text);
    font-size: 0.74rem;
    font-weight: 870;
  }

  :root.tablet-touch-layout .lineup-add-actions .icon-button .add-action-icon-stack {
    display: inline-grid;
    width: 17px;
    height: 17px;
    place-items: center;
  }

  :root.tablet-touch-layout .lineup-add-actions .lineup-add-slide-button .add-action-main-icon,
  :root.tablet-touch-layout .lineup-add-actions .library-add-note-button .add-action-main-icon,
  :root.tablet-touch-layout .lineup-add-actions #addNoteButton .add-action-main-icon {
    width: 17px;
    height: 17px;
  }

  :root.tablet-touch-layout .lineup-add-actions .add-action-plus-icon,
  :root.tablet-touch-layout .lineup-add-actions #addNoteButton .note-plus-icon {
    display: none !important;
  }

  :root.tablet-touch-layout .bank-heading {
    display: none !important;
  }

  :root.tablet-touch-layout .bank-header::after {
    content: attr(data-panel-title);
    display: block;
    min-width: 0;
    overflow: hidden;
    color: var(--text);
    font-size: 1.15rem;
    font-weight: 850;
    letter-spacing: 0;
    line-height: 1.1;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  :root.tablet-touch-layout .bank-panel:not(.shows-mode):not(.manage-mode) .bank-header::after {
    content: "Song bank";
  }

  :root.tablet-touch-layout .bank-panel.shows-mode .bank-header::after {
    content: "Setlists";
  }

  :root.tablet-touch-layout .bank-panel.manage-mode .bank-header::after {
    content: "Manage songs";
  }

  :root.tablet-touch-layout .show-panel.slide-preview-open {
    overflow: hidden;
  }

  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-table {
    width: auto !important;
    max-width: none !important;
    margin: 0 !important;
  }

  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-heading,
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-row {
    grid-template-columns: 24px 32px minmax(180px, 1fr) minmax(118px, 0.38fr) 58px 42px 42px 42px !important;
  }

  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-heading span:nth-child(4),
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-row .line-song-note {
    display: block !important;
  }

  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-heading span:nth-child(5),
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-row .capo-cell {
    display: none !important;
  }

  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-add-actions:not([hidden]) {
    display: inline-flex !important;
  }

  :root.tablet-touch-layout .show-panel.slide-preview-open .slide-preview-panel {
    position: fixed !important;
    top: calc(104px + env(safe-area-inset-top, 0px));
    right: 24px;
    bottom: auto;
    left: auto;
    z-index: 95;
    width: min(444px, calc(100vw - 48px));
    min-width: 0;
    max-width: calc(100vw - 24px);
    max-height: calc(var(--lineup-visual-height, 100dvh) - 24px);
    gap: 10px;
    border-radius: 14px;
    padding: 12px;
    box-shadow: 0 24px 60px rgba(0, 0, 0, 0.38);
    touch-action: none;
  }

  :root.tablet-touch-layout .slide-preview-panel.is-dragging {
    cursor: grabbing;
  }

  :root.tablet-touch-layout .slide-preview-header {
    cursor: grab;
    touch-action: none;
  }

  :root.tablet-touch-layout .slide-preview-header .icon-button {
    cursor: pointer;
    touch-action: manipulation;
  }

  :root.tablet-touch-layout .show-panel.slide-preview-open .slide-preview-stage {
    width: 100%;
    min-height: 0;
    max-height: none;
    aspect-ratio: 16 / 9;
  }

  :root.tablet-touch-layout .app-shell.manage-songs-open .bank-panel.manage-mode {
    z-index: 120;
  }

  :root.tablet-touch-layout .app-shell.manage-songs-open .bank-panel.manage-mode .bank-header {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 12px;
    margin-bottom: 14px;
    padding-bottom: 14px;
    border-bottom: 1px solid color-mix(in srgb, var(--green) 18%, var(--line));
  }

  :root.tablet-touch-layout .app-shell.manage-songs-open .bank-panel.manage-mode .bank-header::after {
    content: "Manage songs";
    font-size: 1.28rem;
  }

  :root.tablet-touch-layout .app-shell.manage-songs-open .bank-panel.manage-mode .bank-title-actions {
    grid-column: 2;
  }

  :root.tablet-touch-layout .app-shell.manage-songs-open .song-manager-toolbar {
    grid-template-columns: minmax(150px, 0.75fr) minmax(260px, 2fr) 120px 138px 42px 42px 42px 42px !important;
    align-items: center;
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (orientation: portrait) {
  :root.tablet-touch-layout .show-panel.slide-preview-open {
    padding-bottom: 378px !important;
  }

  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-table {
    flex: 0 1 auto !important;
    height: min(636px, calc(var(--lineup-viewport-height, 100dvh) - 438px)) !important;
  }

  :root.tablet-touch-layout .app-shell:has(.show-panel.slide-preview-open) .bank-panel:not(.manage-mode) {
    height: 342px !important;
    overflow: visible !important;
  }

  :root.tablet-touch-layout .app-shell:has(.show-panel.slide-preview-open) .bank-panel:not(.manage-mode) .side-panel-view:not([hidden]) {
    display: flex !important;
  }

  :root.tablet-touch-layout .show-panel.slide-preview-open .slide-preview-panel {
    top: calc(104px + env(safe-area-inset-top, 0px));
    right: 24px;
    width: min(520px, calc(100vw - 48px));
  }

  :root.tablet-touch-layout .app-shell.manage-songs-open .song-manager-toolbar {
    grid-template-columns: minmax(0, 1fr) 42px 42px 42px 42px !important;
  }

  :root.tablet-touch-layout .app-shell.manage-songs-open .song-manager-title,
  :root.tablet-touch-layout .app-shell.manage-songs-open .song-manager-search {
    grid-column: 1 / -1;
  }

  :root.tablet-touch-layout .app-shell.manage-songs-open #songManagerCategoryFilter {
    grid-column: 1 / 3;
  }

  :root.tablet-touch-layout .app-shell.manage-songs-open #songManagerSort {
    grid-column: 3 / -1;
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (min-height: 521px) and (orientation: landscape) {
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-heading,
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-row {
    grid-template-columns: 24px 32px minmax(200px, 1fr) minmax(126px, 0.42fr) 58px 42px 42px 42px !important;
  }

  :root.tablet-touch-layout .show-panel.slide-preview-open .slide-preview-panel {
    top: calc(96px + env(safe-area-inset-top, 0px));
    right: 30px;
    width: min(448px, 42vw);
  }
}

@media (min-width: 761px) and (max-width: 1366px) {
  :root.tablet-touch-layout,
  :root.tablet-touch-layout body {
    height: var(--lineup-viewport-height, 100dvh);
    overflow: hidden;
  }

  :root.tablet-touch-layout .app-shell {
    width: 100vw !important;
    height: var(--lineup-viewport-height, 100dvh) !important;
    min-height: var(--lineup-viewport-height, 100dvh) !important;
    margin: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    overflow: hidden;
  }

  :root.tablet-touch-layout .lineup-next-steps {
    display: none !important;
  }

  :root.tablet-touch-layout .show-panel {
    min-width: 0;
    min-height: 0;
    padding: calc(16px + env(safe-area-inset-top, 0px)) max(12px, env(safe-area-inset-right, 0px)) calc(12px + env(safe-area-inset-bottom, 0px)) max(12px, env(safe-area-inset-left, 0px)) !important;
    overflow: hidden !important;
  }

  :root.tablet-touch-layout .show-header {
    gap: 12px;
    margin-bottom: 12px !important;
  }

  :root.tablet-touch-layout .header-actions {
    gap: 6px !important;
  }

  :root.tablet-touch-layout .top-icon-button,
  :root.tablet-touch-layout .header-menu summary,
  :root.tablet-touch-layout .header-actions > .history-button,
  :root.tablet-touch-layout .header-actions > #redoLineupButton,
  :root.tablet-touch-layout .header-actions > #exportButton,
  :root.tablet-touch-layout .header-actions > #saveLineupButton {
    width: 36px !important;
    min-width: 36px !important;
    height: 36px !important;
    min-height: 36px !important;
    border-radius: 8px !important;
  }

  :root.tablet-touch-layout .header-actions > #redoLineupButton,
  :root.tablet-touch-layout .header-actions > #exportButton {
    display: inline-grid !important;
  }

  :root.tablet-touch-layout .lineup-table {
    flex: 1 1 auto !important;
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    margin: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    overflow: hidden !important;
  }

  :root.tablet-touch-layout .lineup-heading,
  :root.tablet-touch-layout .lineup-row,
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-heading,
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-row {
    grid-template-columns: 22px 28px minmax(126px, 1fr) minmax(76px, 0.34fr) 46px 34px 34px 34px 68px !important;
    gap: 6px !important;
  }

  :root.tablet-touch-layout .lineup-heading {
    padding: 0 4px 6px !important;
    font-size: 0.64rem !important;
  }

  :root.tablet-touch-layout .lineup-heading span:nth-child(5),
  :root.tablet-touch-layout .lineup-row .capo-cell {
    display: none !important;
  }

  :root.tablet-touch-layout .lineup-heading span:nth-child(4),
  :root.tablet-touch-layout .lineup-row .line-song-note {
    display: block !important;
  }

  :root.tablet-touch-layout .lineup-rows,
  :root.tablet-touch-layout .app-shell.bank-collapsed .lineup-rows,
  :root.tablet-touch-layout .app-shell.mobile-library-minimized .lineup-rows,
  :root.tablet-touch-layout .app-shell.mobile-library-middle .lineup-rows,
  :root.tablet-touch-layout .app-shell.mobile-library-full .lineup-rows {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    padding: 0 2px 8px !important;
    gap: 5px !important;
    overflow: auto !important;
  }

  :root.tablet-touch-layout .lineup-row,
  :root.tablet-touch-layout .app-shell.bank-collapsed .lineup-row:not(.note-row),
  :root.tablet-touch-layout .app-shell.mobile-library-minimized .lineup-row:not(.note-row),
  :root.tablet-touch-layout .app-shell.mobile-library-middle .lineup-row:not(.note-row),
  :root.tablet-touch-layout .app-shell.mobile-library-full .lineup-row:not(.note-row) {
    min-height: 54px !important;
    border: 1px solid color-mix(in srgb, var(--line) 68%, transparent) !important;
    border-radius: 6px !important;
    padding: 6px 7px !important;
    background: color-mix(in srgb, var(--panel) 70%, transparent) !important;
    box-shadow: none !important;
  }

  :root.tablet-touch-layout .lineup-row.song-row::before,
  :root.tablet-touch-layout .app-shell.mobile-library-middle .lineup-row.song-row::before,
  :root.tablet-touch-layout .app-shell.mobile-library-full .lineup-row.song-row::before {
    top: 8px !important;
    bottom: 8px !important;
    width: 2px !important;
    border-radius: 999px !important;
  }

  :root.tablet-touch-layout .song-name {
    font-size: 0.92rem !important;
  }

  :root.tablet-touch-layout .subline {
    font-size: 0.7rem !important;
  }

  :root.tablet-touch-layout .line-song-note input {
    min-height: 28px !important;
    height: 28px !important;
    padding: 0 !important;
    font-size: 0.7rem !important;
  }

  :root.tablet-touch-layout .key-cell .key-picker-trigger {
    min-width: 42px !important;
    min-height: 28px !important;
    padding: 0 8px !important;
  }

  :root.tablet-touch-layout .lineup-row .icon-action,
  :root.tablet-touch-layout .lineup-row .slides-status-button,
  :root.tablet-touch-layout .lineup-row .sheets-status-button {
    width: 28px !important;
    min-width: 28px !important;
    height: 28px !important;
    min-height: 28px !important;
    border-radius: 7px !important;
  }

  :root.tablet-touch-layout .row-icon-actions,
  :root.tablet-touch-layout .note-inline-actions {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 4px !important;
    opacity: 1 !important;
    pointer-events: auto !important;
    position: static !important;
    grid-column: auto !important;
    justify-self: end !important;
    align-self: center !important;
    width: max-content !important;
    min-width: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    transform: none !important;
  }

  :root.tablet-touch-layout .note-row .song-text {
    grid-column: 3 / 8 !important;
  }

  :root.tablet-touch-layout .note-row .note-inline-actions {
    grid-column: 8 !important;
  }

  :root.tablet-touch-layout .slide-only-row .row-icon-actions .icon-action {
    width: 26px !important;
    min-width: 26px !important;
  }

  :root.tablet-touch-layout .bank-panel {
    overflow: hidden !important;
    border-color: color-mix(in srgb, var(--green) 16%, var(--line)) !important;
    box-shadow: 0 -18px 44px rgba(0, 0, 0, 0.26) !important;
  }

  :root.tablet-touch-layout .bank-header {
    flex: 0 0 auto !important;
    cursor: ns-resize;
    touch-action: none;
  }

  :root.tablet-touch-layout .bank-panel .side-panel-view:not([hidden]) {
    display: flex !important;
    flex: 1 1 auto !important;
    min-height: 0 !important;
    padding-bottom: 0 !important;
    overflow: hidden !important;
  }

  :root.tablet-touch-layout .bank-panel .song-bank-list {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    padding-bottom: 0 !important;
    overflow: auto !important;
  }

  :root.tablet-touch-layout .bank-song {
    min-height: 58px !important;
    border-radius: 6px !important;
    padding: 8px 8px 8px 13px !important;
  }

  :root.tablet-touch-layout .bank-song::before {
    top: 9px !important;
    bottom: 9px !important;
    width: 2px !important;
  }

  :root.tablet-touch-layout .lineup-add-actions:not([hidden]) {
    display: inline-flex !important;
    gap: 6px !important;
    width: auto !important;
    min-width: 0 !important;
    padding: 7px !important;
    border: 1px solid color-mix(in srgb, var(--green) 24%, rgba(255, 255, 255, 0.16)) !important;
    background: color-mix(in srgb, var(--panel) 64%, transparent) !important;
    -webkit-backdrop-filter: blur(18px);
    backdrop-filter: blur(18px);
    box-shadow: 0 12px 34px rgba(0, 0, 0, 0.28) !important;
  }

  :root.tablet-touch-layout .lineup-add-actions .icon-button,
  :root.tablet-touch-layout .lineup-add-actions #addNoteButton {
    width: auto !important;
    min-width: 86px !important;
    height: 34px !important;
    min-height: 34px !important;
    border-radius: 8px !important;
    padding: 0 10px !important;
    font-size: 0.72rem !important;
  }

  :root.tablet-touch-layout .app-shell.manage-songs-open {
    display: block !important;
  }

  :root.tablet-touch-layout .app-shell.manage-songs-open .bank-panel.manage-mode {
    position: fixed !important;
    inset: 0 !important;
    z-index: 140 !important;
    width: auto !important;
    height: var(--lineup-viewport-height, 100dvh) !important;
    max-height: none !important;
    border: 0 !important;
    border-radius: 0 !important;
    padding: calc(16px + env(safe-area-inset-top, 0px)) max(14px, env(safe-area-inset-right, 0px)) calc(14px + env(safe-area-inset-bottom, 0px)) max(14px, env(safe-area-inset-left, 0px)) !important;
    background: color-mix(in srgb, var(--panel) 96%, black) !important;
    box-shadow: none !important;
  }

  :root.tablet-touch-layout .app-shell.manage-songs-open .bank-panel.manage-mode .bank-header {
    margin-bottom: 12px !important;
    padding-bottom: 12px !important;
  }

  :root.tablet-touch-layout .app-shell.manage-songs-open .song-manager-view {
    min-height: 0 !important;
    height: calc(var(--lineup-viewport-height, 100dvh) - 86px) !important;
    border: 0 !important;
    border-radius: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
  }

  :root.tablet-touch-layout .app-shell.manage-songs-open .song-manager-grid {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    max-height: none !important;
  }

  :root.tablet-touch-layout .export-dialog {
    width: min(96vw, 1040px) !important;
    max-width: 96vw !important;
    max-height: calc(var(--lineup-visual-height, 100dvh) - 24px) !important;
    padding: 0 !important;
  }

  :root.tablet-touch-layout .export-dialog-inner {
    width: 100% !important;
    max-width: none !important;
    max-height: calc(var(--lineup-visual-height, 100dvh) - 24px) !important;
    grid-template-columns: minmax(260px, 330px) minmax(0, 1fr) !important;
    gap: 18px !important;
    padding: 18px !important;
  }

  :root.tablet-touch-layout .export-settings {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 10px !important;
  }

  :root.tablet-touch-layout .export-settings .orientation-control,
  :root.tablet-touch-layout .export-settings .export-option,
  :root.tablet-touch-layout .export-settings .export-toggle-row .export-option {
    min-width: 0 !important;
  }

  :root.tablet-touch-layout .export-settings .font-control span,
  :root.tablet-touch-layout .export-settings .page-control span,
  :root.tablet-touch-layout .export-settings .spacing-control label span,
  :root.tablet-touch-layout .export-settings .columns-control label span {
    min-width: 0 !important;
    padding: 0 7px !important;
    font-size: 0.72rem !important;
    white-space: nowrap !important;
  }

  :root.tablet-touch-layout .export-settings .orientation-control.font-control:not(.columns-control):not(.spacing-control) label:nth-of-type(2) span::after,
  :root.tablet-touch-layout .export-settings .orientation-control.font-control:not(.columns-control):not(.spacing-control) label:nth-of-type(3) span::after,
  :root.tablet-touch-layout .export-settings .orientation-control.font-control:not(.columns-control):not(.spacing-control) label:nth-of-type(4) span::after {
    content: none !important;
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (orientation: portrait) {
  :root.tablet-touch-layout .app-shell {
    --tablet-bank-height: min(38vh, 460px);
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    grid-template-rows: minmax(0, 1fr) !important;
  }

  :root.tablet-touch-layout .app-shell.mobile-library-minimized {
    --tablet-bank-height: 112px;
  }

  :root.tablet-touch-layout .app-shell.mobile-library-middle {
    --tablet-bank-height: min(38vh, 460px);
  }

  :root.tablet-touch-layout .app-shell.mobile-library-full {
    --tablet-bank-height: min(72vh, calc(var(--lineup-viewport-height, 100dvh) - 88px));
  }

  :root.tablet-touch-layout .show-panel,
  :root.tablet-touch-layout .show-panel.slide-preview-open {
    grid-column: 1 !important;
    grid-row: 1 !important;
    padding-bottom: calc(12px + env(safe-area-inset-bottom, 0px)) !important;
  }

  :root.tablet-touch-layout .show-title-input {
    max-width: min(42vw, 310px) !important;
  }

  :root.tablet-touch-layout .bank-panel:not(.manage-mode),
  :root.tablet-touch-layout .app-shell:has(.show-panel.slide-preview-open) .bank-panel:not(.manage-mode) {
    position: absolute !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    z-index: 50 !important;
    width: auto !important;
    max-width: none !important;
    height: var(--mobile-library-height, var(--tablet-bank-height)) !important;
    max-height: calc(var(--lineup-viewport-height, 100dvh) - 72px) !important;
    min-height: 0 !important;
    margin: 0 !important;
    border-right: 0 !important;
    border-bottom: 0 !important;
    border-left: 0 !important;
    border-radius: 18px 18px 0 0 !important;
    padding: 18px 12px calc(8px + env(safe-area-inset-bottom, 0px)) !important;
    transform: none !important;
  }

  :root.tablet-touch-layout .bank-panel:not(.manage-mode)::before {
    top: 8px !important;
    width: 70px !important;
    height: 4px !important;
  }

  :root.tablet-touch-layout .bank-header {
    margin-bottom: 10px !important;
    padding-top: 4px !important;
  }

  :root.tablet-touch-layout .bank-panel .song-bank-list {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 7px !important;
  }

  :root.tablet-touch-layout .app-shell.bank-collapsed .bank-panel:not(.manage-mode),
  :root.tablet-touch-layout .app-shell.mobile-library-minimized .bank-panel:not(.manage-mode) {
    display: flex !important;
    height: var(--mobile-library-height, var(--tablet-bank-height)) !important;
    overflow: hidden !important;
    padding-top: 18px !important;
  }

  :root.tablet-touch-layout .lineup-add-actions:not([hidden]) {
    position: fixed !important;
    right: max(12px, env(safe-area-inset-right, 0px)) !important;
    bottom: max(env(safe-area-inset-bottom, 0px), calc(var(--lineup-add-actions-bottom, var(--mobile-library-height, var(--tablet-bank-height))) - 1px)) !important;
    z-index: 62 !important;
    margin: 0 !important;
    border-radius: 14px 14px 0 0 !important;
    transform: none !important;
  }

  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-table {
    flex: 1 1 auto !important;
    height: auto !important;
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (min-height: 521px) and (orientation: landscape) {
  :root.tablet-touch-layout .app-shell {
    display: grid !important;
    grid-template-columns: clamp(268px, var(--bank-width, 29vw), min(520px, 43vw)) 12px minmax(0, 1fr) !important;
    grid-template-rows: minmax(0, 1fr) !important;
  }

  :root.tablet-touch-layout .bank-panel:not(.manage-mode),
  :root.tablet-touch-layout .app-shell.bank-collapsed .bank-panel:not(.manage-mode) {
    display: flex !important;
    position: relative !important;
    grid-column: 1 !important;
    grid-row: 1 !important;
    z-index: 3 !important;
    width: auto !important;
    height: var(--lineup-viewport-height, 100dvh) !important;
    min-height: 0 !important;
    margin: 0 !important;
    border-top: 0 !important;
    border-bottom: 0 !important;
    border-left: 0 !important;
    border-radius: 0 !important;
    padding: calc(16px + env(safe-area-inset-top, 0px)) 10px calc(10px + env(safe-area-inset-bottom, 0px)) max(10px, env(safe-area-inset-left, 0px)) !important;
    transform: none !important;
  }

  :root.tablet-touch-layout .bank-panel:not(.manage-mode)::before {
    content: none !important;
  }

  :root.tablet-touch-layout .panel-resizer,
  :root.tablet-touch-layout .app-shell.bank-collapsed .panel-resizer {
    display: block !important;
    grid-column: 2 !important;
    grid-row: 1 !important;
    width: 12px !important;
    min-width: 12px !important;
    height: var(--lineup-viewport-height, 100dvh) !important;
    cursor: col-resize !important;
    touch-action: none !important;
  }

  :root.tablet-touch-layout .panel-resizer::before {
    width: 3px !important;
    border-radius: 999px !important;
    background: color-mix(in srgb, var(--green) 30%, rgba(255, 255, 255, 0.15)) !important;
  }

  :root.tablet-touch-layout .show-panel,
  :root.tablet-touch-layout .show-panel.slide-preview-open {
    grid-column: 3 !important;
    grid-row: 1 !important;
    padding-left: 10px !important;
  }

  :root.tablet-touch-layout .lineup-heading,
  :root.tablet-touch-layout .lineup-row,
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-heading,
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-row {
    grid-template-columns: 22px 30px minmax(190px, 1fr) minmax(112px, 0.36fr) 48px 34px 34px 34px 74px !important;
  }

  :root.tablet-touch-layout .lineup-add-actions:not([hidden]) {
    position: fixed !important;
    left: clamp(74px, calc(var(--bank-width, 29vw) - 196px), calc(43vw - 196px)) !important;
    top: calc(62px + env(safe-area-inset-top, 0px)) !important;
    z-index: 62 !important;
    margin: 0 !important;
    border-radius: 14px !important;
  }

  :root.tablet-touch-layout .bank-panel .song-bank-list {
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 7px !important;
  }

  :root.tablet-touch-layout .show-panel.slide-preview-open .slide-preview-panel {
    right: 18px !important;
    width: min(430px, 40vw) !important;
  }

  :root.tablet-touch-layout .export-dialog {
    width: min(98vw, 1120px) !important;
    max-width: 98vw !important;
  }

  :root.tablet-touch-layout .export-dialog-inner {
    grid-template-columns: minmax(290px, 350px) minmax(0, 1fr) !important;
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (min-height: 521px) and (orientation: landscape) {
  :root.tablet-touch-layout .lineup-add-actions:not([hidden]) {
    position: fixed !important;
    top: auto !important;
    bottom: max(92px, calc(env(safe-area-inset-bottom, 0px) + 96px)) !important;
    left: clamp(268px, var(--bank-width, 29vw), min(520px, 43vw)) !important;
    z-index: 66 !important;
    display: inline-flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    width: 76px !important;
    min-width: 76px !important;
    margin: 0 !important;
    padding: 7px !important;
    gap: 7px !important;
    border-radius: 16px !important;
    transform: translateX(-50%) !important;
  }

  :root.tablet-touch-layout .lineup-add-actions .icon-button,
  :root.tablet-touch-layout .lineup-add-actions #addNoteButton {
    width: 62px !important;
    min-width: 62px !important;
    height: 58px !important;
    min-height: 58px !important;
    flex-direction: column !important;
    gap: 3px !important;
    padding: 5px 4px !important;
    font-size: 0.68rem !important;
    line-height: 1 !important;
  }

  :root.tablet-touch-layout .lineup-add-actions .icon-button .add-action-icon-stack {
    width: 20px !important;
    height: 20px !important;
  }

  :root.tablet-touch-layout .lineup-add-actions .lineup-add-slide-button .add-action-main-icon,
  :root.tablet-touch-layout .lineup-add-actions .library-add-note-button .add-action-main-icon,
  :root.tablet-touch-layout .lineup-add-actions #addNoteButton .add-action-main-icon {
    width: 20px !important;
    height: 20px !important;
  }

  :root.tablet-touch-layout .export-dialog [data-close-dialog] {
    touch-action: manipulation;
  }
}

@media (min-width: 761px) and (max-width: 1366px) {
  :root.tablet-touch-layout .header-menu-popover .top-icon-button,
  :root.tablet-touch-layout .header-menu-popover .app-home-menu-item {
    appearance: none;
    text-align: left;
  }

  :root.tablet-touch-layout .header-menu-popover .top-icon-button > svg,
  :root.tablet-touch-layout .header-menu-popover .app-home-menu-item > svg {
    flex: 0 0 21px !important;
    width: 21px !important;
    min-width: 21px !important;
    height: 21px !important;
    min-height: 21px !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: none !important;
    box-shadow: none !important;
    color: currentColor !important;
    fill: none !important;
    stroke: currentColor !important;
    stroke-width: 1.8;
  }

  :root.tablet-touch-layout .header-menu-popover .top-icon-button > svg *,
  :root.tablet-touch-layout .header-menu-popover .app-home-menu-item > svg * {
    fill: none !important;
    stroke: currentColor !important;
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (min-height: 521px) and (orientation: landscape) {
  :root.tablet-touch-layout .lineup-add-actions:not([hidden]) {
    bottom: max(54px, calc(env(safe-area-inset-bottom, 0px) + 54px)) !important;
    left: calc(clamp(268px, var(--bank-width, 29vw), min(520px, 43vw)) + 14px) !important;
    transform: none !important;
  }
}

@media (min-width: 761px) and (max-width: 1366px) {
  :root.tablet-touch-layout .header-menu-popover .top-icon-button,
  :root.tablet-touch-layout .header-menu-popover .app-home-menu-item,
  :root.tablet-touch-layout .header-menu-popover #presentationMenuButton {
    min-height: 42px !important;
    border-color: transparent !important;
    background: transparent !important;
    box-shadow: none !important;
  }

  :root.tablet-touch-layout .header-menu-popover .top-icon-button:is(:hover, :focus-visible),
  :root.tablet-touch-layout .header-menu-popover .app-home-menu-item:is(:hover, :focus-visible),
  :root.tablet-touch-layout .header-menu-popover #presentationMenuButton:is(:hover, :focus-visible) {
    border-color: color-mix(in srgb, var(--green) 18%, transparent) !important;
    background: color-mix(in srgb, var(--green) 9%, transparent) !important;
  }

  :root.tablet-touch-layout .header-menu-popover .top-icon-button > svg,
  :root.tablet-touch-layout .header-menu-popover .app-home-menu-item > svg,
  :root.tablet-touch-layout .header-menu-popover #presentationMenuButton > svg {
    display: block !important;
    flex: 0 0 20px !important;
    width: 20px !important;
    min-width: 20px !important;
    height: 20px !important;
    min-height: 20px !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    color: currentColor !important;
    fill: none !important;
    stroke: currentColor !important;
    stroke-width: 1.9 !important;
  }

  :root.tablet-touch-layout .header-menu-popover .top-icon-button > svg *,
  :root.tablet-touch-layout .header-menu-popover .app-home-menu-item > svg *,
  :root.tablet-touch-layout .header-menu-popover #presentationMenuButton > svg * {
    fill: none !important;
    stroke: currentColor !important;
  }

  :root.tablet-touch-layout .export-dialog {
    width: min(99vw, 1280px) !important;
    height: min(94dvh, 920px) !important;
    max-width: 99vw !important;
    max-height: calc(var(--lineup-visual-height, 100dvh) - 12px) !important;
    border-radius: 16px !important;
  }

  :root.tablet-touch-layout .export-dialog-inner {
    grid-template-columns: clamp(224px, 24vw, 276px) minmax(0, 1fr) !important;
    grid-template-rows: auto auto minmax(0, 1fr) auto !important;
    gap: 8px 12px !important;
    padding: 10px !important;
    max-height: none !important;
  }

  :root.tablet-touch-layout .export-tabs {
    grid-column: 1 / -1 !important;
    grid-row: 2 !important;
  }

  :root.tablet-touch-layout .export-settings {
    grid-column: 1 !important;
    grid-row: 3 !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    align-content: start !important;
    gap: 7px !important;
    overflow: auto !important;
    padding: 7px !important;
  }

  :root.tablet-touch-layout .export-settings .page-control {
    grid-column: 1 !important;
    order: 1 !important;
  }

  :root.tablet-touch-layout .export-settings .orientation-control.font-control:not(.columns-control):not(.spacing-control) {
    grid-column: 1 !important;
    order: 2 !important;
  }

  :root.tablet-touch-layout .export-settings .columns-control {
    grid-column: 1 !important;
    order: 3 !important;
  }

  :root.tablet-touch-layout .export-settings .spacing-control {
    grid-column: 1 !important;
    order: 4 !important;
  }

  :root.tablet-touch-layout .export-settings .export-toggle-row {
    grid-column: 1 !important;
    order: 5 !important;
  }

  :root.tablet-touch-layout .export-settings .fit-toggle {
    grid-column: 1 !important;
    order: 6 !important;
  }

  :root.tablet-touch-layout .export-settings .orientation-control span,
  :root.tablet-touch-layout .export-settings .export-option span {
    min-height: 32px !important;
    padding: 0 8px !important;
    font-size: 0.76rem !important;
    white-space: nowrap !important;
  }

  :root.tablet-touch-layout .export-settings .export-toggle-row .export-option span {
    min-height: 34px !important;
    font-size: 0.76rem !important;
  }

  :root.tablet-touch-layout .export-settings .export-toggle-row .credit-toggle span::before,
  :root.tablet-touch-layout .export-settings .export-toggle-row .real-key-toggle span::before {
    content: none !important;
  }

  :root.tablet-touch-layout .export-preview {
    grid-column: 2 !important;
    grid-row: 3 / 5 !important;
    min-height: 0 !important;
    max-height: none !important;
    padding: 6px !important;
  }

  :root.tablet-touch-layout .export-sheet-preview.image-preview {
    width: auto !important;
    height: min(100%, calc(var(--lineup-visual-height, 100dvh) - 132px)) !important;
    max-width: 100% !important;
    max-height: 100% !important;
    aspect-ratio: 210 / 297 !important;
  }

  :root.tablet-touch-layout .export-sheet-preview.image-preview.landscape {
    width: auto !important;
    height: min(100%, calc(var(--lineup-visual-height, 100dvh) - 132px)) !important;
    aspect-ratio: 297 / 210 !important;
  }

  :root.tablet-touch-layout .bank-song {
    grid-template-columns: minmax(0, 1fr) 30px 30px 30px 30px !important;
  }

  :root.tablet-touch-layout .bank-song .banger-toggle {
    display: inline-grid !important;
  }

  body.reordering-song-manager-column,
  body.reordering-song-manager-column * {
    user-select: none !important;
    -webkit-user-select: none !important;
  }

  :root.tablet-touch-layout .song-manager-head-cell,
  :root.tablet-touch-layout .song-manager-header-button {
    user-select: none !important;
    -webkit-user-select: none !important;
    touch-action: none;
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (orientation: portrait) {
  :root.tablet-touch-layout .app-shell.mobile-library-full {
    --tablet-bank-height: calc(var(--lineup-viewport-height, 100dvh) - 6px) !important;
  }

  :root.tablet-touch-layout .app-shell.mobile-library-full .bank-panel:not(.manage-mode) {
    max-height: calc(var(--lineup-viewport-height, 100dvh) - 6px) !important;
  }

  :root.tablet-touch-layout .lineup-add-actions:not([hidden]) {
    right: max(12px, env(safe-area-inset-right, 0px)) !important;
    padding: 6px !important;
    gap: 6px !important;
    border: 1px solid color-mix(in srgb, var(--green) 18%, rgba(255, 255, 255, 0.12)) !important;
    border-radius: 16px !important;
    background: color-mix(in srgb, var(--panel) 72%, transparent) !important;
    box-shadow: 0 14px 36px rgba(0, 0, 0, 0.24) !important;
    backdrop-filter: blur(14px);
  }

  :root.tablet-touch-layout .lineup-add-actions::before,
  :root.tablet-touch-layout .lineup-add-actions::after {
    content: none !important;
  }

  :root.tablet-touch-layout .lineup-add-actions .icon-button,
  :root.tablet-touch-layout .lineup-add-actions #addNoteButton {
    min-width: 74px !important;
    height: 40px !important;
    min-height: 40px !important;
    border-radius: 12px !important;
    background: color-mix(in srgb, var(--panel-2) 58%, transparent) !important;
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (min-height: 521px) and (orientation: landscape) {
  :root.tablet-touch-layout .lineup-add-actions:not([hidden]) {
    right: max(14px, env(safe-area-inset-right, 0px)) !important;
    bottom: max(18px, calc(env(safe-area-inset-bottom, 0px) + 18px)) !important;
    left: auto !important;
    width: 70px !important;
    min-width: 70px !important;
    transform: none !important;
  }

  :root.tablet-touch-layout .export-dialog {
    width: min(99vw, 1300px) !important;
    height: min(94dvh, 820px) !important;
  }

  :root.tablet-touch-layout .export-dialog-inner {
    grid-template-columns: clamp(224px, 24vw, 276px) minmax(0, 1fr) !important;
  }

  :root.tablet-touch-layout .export-sheet-preview.image-preview.landscape {
    height: min(100%, calc(var(--lineup-visual-height, 100dvh) - 118px)) !important;
    width: auto !important;
    aspect-ratio: 297 / 210 !important;
  }
}

body.is-pointer-dragging,
body.is-pointer-dragging .app-shell,
body.is-pointer-dragging .show-panel,
body.is-pointer-dragging .bank-panel,
body.is-pointer-dragging .song-bank-list,
body.is-pointer-dragging .bank-song,
body.is-pointer-dragging .lineup-rows,
body.is-pointer-dragging .lineup-row {
  touch-action: none !important;
  overscroll-behavior: contain !important;
  user-select: none !important;
  -webkit-user-select: none !important;
}

body.is-pointer-dragging .lineup-drag-ghost {
  z-index: 2147483000 !important;
  pointer-events: none !important;
}

.lineup-add-actions-tab {
  display: none;
}

@media (min-width: 761px) and (max-width: 1366px) and (min-height: 521px) and (orientation: landscape) {
  :root.tablet-touch-layout .lineup-add-actions:not([hidden]) {
    --lineup-add-tray-peek: 28px;
    position: fixed !important;
    top: auto !important;
    right: max(0px, env(safe-area-inset-right, 0px)) !important;
    bottom: max(18px, calc(env(safe-area-inset-bottom, 0px) + 18px)) !important;
    left: auto !important;
    z-index: 66 !important;
    display: inline-flex !important;
    flex-direction: column !important;
    align-items: flex-end !important;
    width: 98px !important;
    min-width: 98px !important;
    margin: 0 !important;
    padding: 7px 7px 7px 29px !important;
    gap: 7px !important;
    border-radius: 16px 0 0 16px !important;
    opacity: 0.9 !important;
    transform: translateX(calc(100% - var(--lineup-add-tray-peek))) !important;
    transition: transform 180ms ease, opacity 180ms ease, box-shadow 180ms ease !important;
    pointer-events: auto !important;
    touch-action: pan-x !important;
  }

  :root.tablet-touch-layout .lineup-add-actions.is-open:not([hidden]) {
    opacity: 1 !important;
    transform: translateX(0) !important;
    box-shadow: 0 18px 42px rgba(0, 0, 0, 0.34) !important;
  }

  :root.tablet-touch-layout .lineup-add-actions:not([hidden])::before,
  :root.tablet-touch-layout .lineup-add-actions:not([hidden])::after {
    content: none !important;
  }

  :root.tablet-touch-layout .lineup-add-actions-tab {
    appearance: none;
    position: absolute;
    top: 50%;
    left: 0;
    display: grid;
    place-items: center;
    width: 28px;
    min-width: 28px;
    height: 74px;
    min-height: 74px;
    padding: 0;
    border: 1px solid color-mix(in srgb, var(--green) 26%, rgba(255, 255, 255, 0.18));
    border-right: 0;
    border-radius: 14px 0 0 14px;
    background: color-mix(in srgb, var(--panel) 70%, transparent);
    color: var(--green);
    box-shadow: -8px 10px 26px rgba(0, 0, 0, 0.2);
    transform: translateY(-50%);
    touch-action: pan-x;
    backdrop-filter: blur(14px);
  }

  :root.tablet-touch-layout .lineup-add-actions-tab svg {
    width: 18px;
    height: 18px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2.2;
    stroke-linecap: round;
    stroke-linejoin: round;
    transition: transform 180ms ease;
  }

  :root.tablet-touch-layout .lineup-add-actions.is-open .lineup-add-actions-tab svg {
    transform: rotate(180deg);
  }

  :root.tablet-touch-layout .lineup-add-actions:not(.is-open) .icon-button {
    pointer-events: none !important;
  }

  :root.tablet-touch-layout .lineup-add-actions .icon-button,
  :root.tablet-touch-layout .lineup-add-actions #addNoteButton {
    width: 62px !important;
    min-width: 62px !important;
    height: 58px !important;
    min-height: 58px !important;
  }
}

@media (min-width: 761px) and (max-width: 1366px) {
  :root.tablet-touch-layout .export-preview {
    display: grid !important;
    place-items: center !important;
    align-items: center !important;
    justify-items: center !important;
    min-height: 0 !important;
    overflow: hidden !important;
  }

  :root.tablet-touch-layout #exportSheetsPanel {
    overflow: hidden !important;
  }

  :root.tablet-touch-layout .sheet-pack-export-layout {
    grid-template-columns: minmax(230px, 0.85fr) minmax(300px, 1fr);
    min-height: 0;
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (orientation: portrait) {
  :root.tablet-touch-layout .export-sheet-preview.image-preview {
    width: auto !important;
    height: min(100%, 72dvh, 720px) !important;
    max-width: 100% !important;
    max-height: none !important;
    aspect-ratio: 210 / 297 !important;
  }

  :root.tablet-touch-layout .export-sheet-preview.image-preview.landscape {
    width: min(100%, 82dvh, 820px) !important;
    height: auto !important;
    max-height: none !important;
    aspect-ratio: 297 / 210 !important;
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (orientation: landscape) {
  :root.tablet-touch-layout .export-sheet-preview.image-preview {
    width: auto !important;
    height: min(100%, 72dvh, 680px) !important;
    max-width: 100% !important;
    max-height: none !important;
    aspect-ratio: 210 / 297 !important;
  }

  :root.tablet-touch-layout .export-sheet-preview.image-preview.landscape {
    width: min(100%, 82dvh, 840px) !important;
    height: auto !important;
    max-width: 100% !important;
    max-height: none !important;
    aspect-ratio: 297 / 210 !important;
  }
}

@media (min-width: 761px) and (max-width: 1366px) {
  :root.tablet-touch-layout .export-settings .credit-toggle,
  :root.tablet-touch-layout .export-settings .real-key-toggle,
  :root.tablet-touch-layout .export-settings .export-toggle-row .credit-toggle,
  :root.tablet-touch-layout .export-settings .export-toggle-row .real-key-toggle {
    display: flex !important;
    align-items: stretch !important;
    justify-content: stretch !important;
    align-content: stretch !important;
    min-height: 38px !important;
    padding: 0 !important;
  }

  :root.tablet-touch-layout .export-settings .credit-toggle::before,
  :root.tablet-touch-layout .export-settings .real-key-toggle::before,
  :root.tablet-touch-layout .export-settings .export-toggle-row .credit-toggle::before,
  :root.tablet-touch-layout .export-settings .export-toggle-row .real-key-toggle::before,
  :root.tablet-touch-layout .export-settings .credit-toggle span::before,
  :root.tablet-touch-layout .export-settings .real-key-toggle span::before {
    display: none !important;
    content: none !important;
  }

  :root.tablet-touch-layout .export-settings .credit-toggle span,
  :root.tablet-touch-layout .export-settings .real-key-toggle span,
  :root.tablet-touch-layout .export-settings .export-toggle-row .credit-toggle span,
  :root.tablet-touch-layout .export-settings .export-toggle-row .real-key-toggle span {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    min-height: 38px !important;
    height: 100% !important;
    padding: 0 8px !important;
    font-size: 0.76rem !important;
    line-height: 1 !important;
    text-align: center !important;
    transform: none !important;
    white-space: nowrap !important;
  }
}

/* Shared modern skin: visual polish only, no layout or placement changes. */
:root {
  --modern-glass: color-mix(in srgb, var(--panel) 76%, transparent);
  --modern-glass-strong: color-mix(in srgb, var(--panel-2) 84%, transparent);
  --modern-glass-soft: color-mix(in srgb, var(--panel-3) 42%, transparent);
  --modern-line: color-mix(in srgb, var(--line) 68%, transparent);
  --modern-line-strong: color-mix(in srgb, var(--green) 20%, var(--line-strong));
  --modern-control: color-mix(in srgb, var(--panel-2) 62%, transparent);
  --modern-control-hover: color-mix(in srgb, var(--green) 10%, var(--panel-2));
  --modern-input: color-mix(in srgb, var(--panel) 70%, transparent);
  --modern-shadow-soft: 0 14px 34px rgba(0, 0, 0, 0.16);
  --modern-shadow-float: 0 20px 60px rgba(0, 0, 0, 0.34);
  --modern-inner-light: inset 0 1px 0 rgba(255, 255, 255, 0.07);
}

:root[data-theme="light"] {
  --modern-glass: rgba(255, 255, 255, 0.78);
  --modern-glass-strong: rgba(255, 255, 255, 0.9);
  --modern-glass-soft: rgba(238, 245, 252, 0.72);
  --modern-line: rgba(144, 164, 188, 0.42);
  --modern-line-strong: color-mix(in srgb, var(--green) 18%, #a8b8cc);
  --modern-control: rgba(255, 255, 255, 0.68);
  --modern-control-hover: color-mix(in srgb, var(--green) 9%, #ffffff);
  --modern-input: rgba(255, 255, 255, 0.82);
  --modern-shadow-soft: 0 12px 30px rgba(40, 58, 82, 0.11);
  --modern-shadow-float: 0 20px 54px rgba(40, 58, 82, 0.18);
  --modern-inner-light: inset 0 1px 0 rgba(255, 255, 255, 0.86);
}

.app-shell {
  border-color: color-mix(in srgb, var(--green) 12%, rgba(255, 255, 255, 0.12));
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.035), transparent 28%),
    color-mix(in srgb, var(--bg) 78%, rgba(10, 14, 18, 0.86));
  box-shadow:
    var(--shadow),
    inset 0 1px 0 rgba(255, 255, 255, 0.055);
  -webkit-backdrop-filter: blur(18px);
  backdrop-filter: blur(18px);
}

:root[data-theme="light"] .app-shell {
  border-color: rgba(124, 148, 178, 0.34);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.76), rgba(255, 255, 255, 0.48)),
    color-mix(in srgb, var(--accent-bg-light) 36%, #f7fbff);
  box-shadow:
    var(--shadow),
    inset 0 1px 0 rgba(255, 255, 255, 0.92);
}

.show-panel {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--modern-glass) 92%, transparent), transparent 62%),
    color-mix(in srgb, var(--panel) 18%, transparent);
}

.bank-panel {
  border-color: var(--modern-line);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--modern-glass-strong) 90%, transparent), color-mix(in srgb, var(--modern-glass) 72%, transparent)),
    color-mix(in srgb, var(--panel) 70%, transparent);
  box-shadow:
    inset -1px 0 0 var(--modern-line),
    var(--modern-inner-light);
}

:root[data-theme="light"] .show-panel {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.84), rgba(247, 251, 255, 0.54)),
    color-mix(in srgb, var(--accent-bg-light) 26%, transparent);
}

:root[data-theme="light"] .bank-panel {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.82), rgba(237, 245, 253, 0.78)),
    color-mix(in srgb, var(--accent-bg-light) 42%, #ffffff);
  box-shadow:
    inset -1px 0 0 rgba(152, 174, 199, 0.32),
    var(--modern-inner-light);
}

.lineup-row,
.bank-song,
.song-manager-row:not(.song-manager-head-row),
.song-transfer-row,
.duplicate-song-match,
.theme-export-card,
.slide-title-option,
.setlist-import-targets label,
.export-option,
.orientation-control,
.filter-options,
.category-choice-buttons {
  border-color: var(--modern-line);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.07), rgba(255, 255, 255, 0.018)),
    var(--modern-glass);
  box-shadow: var(--modern-inner-light);
}

:root[data-theme="light"] .lineup-row,
:root[data-theme="light"] .bank-song,
:root[data-theme="light"] .song-manager-row:not(.song-manager-head-row),
:root[data-theme="light"] .song-transfer-row,
:root[data-theme="light"] .duplicate-song-match,
:root[data-theme="light"] .theme-export-card,
:root[data-theme="light"] .slide-title-option,
:root[data-theme="light"] .setlist-import-targets label,
:root[data-theme="light"] .export-option,
:root[data-theme="light"] .orientation-control,
:root[data-theme="light"] .filter-options,
:root[data-theme="light"] .category-choice-buttons {
  border-color: var(--modern-line);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(245, 249, 254, 0.78)),
    var(--modern-glass);
  box-shadow:
    var(--modern-inner-light),
    0 1px 0 rgba(34, 53, 76, 0.035);
}

.lineup-row:hover,
.bank-song:hover,
.song-manager-row:hover:not(.song-manager-head-row),
.song-transfer-row:hover,
.duplicate-song-match:hover,
.theme-export-card:hover {
  border-color: color-mix(in srgb, var(--green) 32%, var(--line-strong));
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--green) 8%, rgba(255, 255, 255, 0.08)), rgba(255, 255, 255, 0.022)),
    var(--modern-glass-strong);
  box-shadow:
    var(--modern-inner-light),
    var(--modern-shadow-soft);
}

.lineup-row.song-row::before,
.bank-song::before {
  opacity: 0.94;
  box-shadow: 0 0 14px color-mix(in srgb, var(--category-color, var(--green)) 34%, transparent);
}

.lineup-row.note-row {
  border-color: color-mix(in srgb, var(--amber) 36%, var(--modern-line));
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--amber) 13%, transparent), rgba(255, 255, 255, 0.018)),
    var(--modern-glass);
}

.bank-song.is-in-lineup {
  border-color: color-mix(in srgb, var(--green) 48%, var(--modern-line));
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--green) 22%, transparent), transparent 72%),
    var(--modern-glass-strong);
}

.rail-button,
.icon-button,
.primary-button,
.ghost-button,
.outline-button,
.danger-button,
.mini-button,
.add-slot-button,
.top-icon-button,
.export-file-button,
.shows-tab-button,
.banger-toggle,
.icon-action,
.ready-toggle,
.slides-status-button,
.sheets-status-button,
.key-picker-trigger,
.manager-key-button,
.manager-category-toggles button,
.manager-hebrew-button,
.manager-banger-button,
.song-manager-columns-menu summary,
.song-manager-cell .slides-status-button,
.song-manager-cell .sheets-status-button,
.export-tab,
.key-picker-quality-row button,
.category-choice-button,
.tag-suggestion,
.setlist-bank-capture-button {
  border-color: color-mix(in srgb, var(--line-strong) 54%, transparent);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.075), rgba(255, 255, 255, 0.018)),
    var(--modern-control);
  box-shadow: var(--modern-inner-light);
  transition:
    border-color 140ms ease,
    background 140ms ease,
    box-shadow 140ms ease,
    color 140ms ease,
    transform 140ms ease;
}

.rail-button:hover,
.icon-button:hover,
.ghost-button:hover,
.outline-button:hover,
.danger-button:hover,
.mini-button:hover,
.add-slot-button:hover,
.top-icon-button:hover,
.export-file-button:hover,
.shows-tab-button:hover,
.banger-toggle:hover,
.icon-action:hover,
.ready-toggle:hover,
.slides-status-button:hover,
.sheets-status-button:hover,
.key-picker-trigger:hover,
.manager-key-button:hover,
.manager-category-toggles button:hover,
.manager-hebrew-button:hover,
.manager-banger-button:hover,
.song-manager-columns-menu summary:hover,
.song-manager-cell .slides-status-button:hover,
.song-manager-cell .sheets-status-button:hover,
.export-tab:hover,
.key-picker-quality-row button:hover,
.category-choice-button:hover,
.tag-suggestion:hover,
.setlist-bank-capture-button:hover {
  border-color: color-mix(in srgb, var(--green) 34%, var(--line-strong));
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--green) 9%, rgba(255, 255, 255, 0.09)), rgba(255, 255, 255, 0.02)),
    var(--modern-control-hover);
  box-shadow:
    var(--modern-inner-light),
    0 10px 24px color-mix(in srgb, var(--green) 13%, rgba(0, 0, 0, 0.18));
}

.primary-button,
.export-tab.active,
.orientation-control input:checked + span,
.export-option input:checked + span,
.key-picker-quality-row button.active,
.key-piano button.active,
.category-choice-button.active,
.manager-hebrew-button.active {
  border-color: color-mix(in srgb, var(--green) 58%, transparent);
  color: #06120d;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--green) 86%, #ffffff), var(--green-2));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.24),
    0 12px 28px color-mix(in srgb, var(--green) 24%, transparent);
}

.top-icon-button.is-active,
.shows-tab-button.active,
.rail-button.active,
.filter-toggle-button.active,
.key-picker-trigger[aria-expanded="true"],
.song-manager-columns-menu[open] summary {
  border-color: color-mix(in srgb, var(--green) 44%, var(--line-strong));
  color: var(--green);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--green) 17%, transparent), color-mix(in srgb, var(--green) 8%, transparent)),
    var(--modern-control);
  box-shadow:
    inset 0 1px 0 color-mix(in srgb, var(--green) 24%, transparent),
    0 10px 24px color-mix(in srgb, var(--green) 16%, transparent);
}

input:not([type="checkbox"]):not([type="radio"]):not([type="range"]):not([type="color"]):not([type="file"]),
select,
textarea,
.song-manager-input,
.song-manager-select {
  border-color: var(--modern-line);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.012)),
    var(--modern-input);
  box-shadow: var(--modern-inner-light);
}

:root[data-theme="light"] input:not([type="checkbox"]):not([type="radio"]):not([type="range"]):not([type="color"]):not([type="file"]),
:root[data-theme="light"] select,
:root[data-theme="light"] textarea,
:root[data-theme="light"] .song-manager-input,
:root[data-theme="light"] .song-manager-select {
  border-color: var(--modern-line);
  background: rgba(255, 255, 255, 0.9);
}

input:not([type="checkbox"]):not([type="radio"]):not([type="range"]):not([type="color"]):not([type="file"]):focus,
select:focus,
textarea:focus,
.song-manager-input:focus,
.song-manager-select:focus,
.manager-key-button:focus-visible {
  border-color: color-mix(in srgb, var(--green) 58%, var(--line-strong));
  outline: none;
  box-shadow:
    var(--modern-inner-light),
    0 0 0 3px color-mix(in srgb, var(--green) 14%, transparent);
}

.header-menu-popover,
.quick-add-menu-popover,
.saved-shows-menu,
.key-picker-menu,
.song-manager-columns-list,
.song-dialog,
.export-dialog,
.coach-tip,
.guest-mode-notice,
.slide-preview-panel,
.slides-editor-shell,
.song-manager-view {
  border-color: var(--modern-line-strong);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.075), rgba(255, 255, 255, 0.018)),
    var(--modern-glass-strong);
  box-shadow:
    var(--modern-shadow-float),
    var(--modern-inner-light);
  -webkit-backdrop-filter: blur(18px);
  backdrop-filter: blur(18px);
}

:root[data-theme="light"] .header-menu-popover,
:root[data-theme="light"] .quick-add-menu-popover,
:root[data-theme="light"] .saved-shows-menu,
:root[data-theme="light"] .key-picker-menu,
:root[data-theme="light"] .song-manager-columns-list,
:root[data-theme="light"] .song-dialog,
:root[data-theme="light"] .export-dialog,
:root[data-theme="light"] .coach-tip,
:root[data-theme="light"] .guest-mode-notice,
:root[data-theme="light"] .slide-preview-panel,
:root[data-theme="light"] .slides-editor-shell,
:root[data-theme="light"] .song-manager-view {
  border-color: var(--modern-line-strong);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(243, 248, 254, 0.86)),
    var(--modern-glass-strong);
  box-shadow:
    var(--modern-shadow-float),
    var(--modern-inner-light);
}

.song-dialog::backdrop,
.export-dialog::backdrop,
.slides-editor-dialog::backdrop {
  background: rgba(2, 6, 23, 0.58);
  -webkit-backdrop-filter: blur(12px);
  backdrop-filter: blur(12px);
}

.header-menu-popover .top-icon-button,
.header-menu-popover .app-home-menu-item,
.quick-add-menu-item,
.song-manager-column-choice {
  background: transparent;
  box-shadow: none;
}

.header-menu-popover .top-icon-button > svg,
.header-menu-popover .app-home-menu-item > svg {
  border: 0;
  background: transparent;
  box-shadow: none;
}

.header-menu-popover .top-icon-button:hover,
.header-menu-popover .app-home-menu-item:hover,
.quick-add-menu-item:hover,
.song-manager-column-choice:hover {
  background: color-mix(in srgb, var(--green) 9%, transparent);
}

.search-box input,
.filter-select,
.capo-select,
.line-song-note input,
.export-settings,
.song-transfer-list,
.song-manager-grid,
.song-manager-bulk-bar {
  border-color: var(--modern-line);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.012)),
    var(--modern-glass-soft);
  box-shadow: var(--modern-inner-light);
}

:root[data-theme="light"] .search-box input,
:root[data-theme="light"] .filter-select,
:root[data-theme="light"] .capo-select,
:root[data-theme="light"] .line-song-note input,
:root[data-theme="light"] .export-settings,
:root[data-theme="light"] .song-transfer-list,
:root[data-theme="light"] .song-manager-grid,
:root[data-theme="light"] .song-manager-bulk-bar {
  border-color: var(--modern-line);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(242, 247, 253, 0.78)),
    var(--modern-glass-soft);
}

.filter-chip.active,
.manager-category-toggles button.active {
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.22),
    0 10px 24px color-mix(in srgb, var(--chip-color, var(--green)) 28%, transparent);
}

.slides-status-button .slides-count-badge {
  box-shadow:
    0 0 0 2px color-mix(in srgb, var(--panel) 86%, transparent),
    0 7px 16px color-mix(in srgb, var(--green) 22%, transparent);
}

.hebrew-badge,
.song-transfer-meta span {
  background: color-mix(in srgb, var(--green) 9%, transparent);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

/* iPad setlist rows keep the desktop-style capo control visible. */
@media (min-width: 761px) and (max-width: 1366px) {
  :root.tablet-touch-layout .lineup-heading,
  :root.tablet-touch-layout .lineup-row,
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-heading,
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-row {
    grid-template-columns: 22px 28px minmax(104px, 1fr) minmax(70px, 0.32fr) 44px 42px 34px 34px 34px 64px !important;
  }

  :root.tablet-touch-layout .lineup-heading span:nth-child(5),
  :root.tablet-touch-layout .lineup-row .capo-cell,
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-heading span:nth-child(5),
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-row .capo-cell {
    display: block !important;
  }

  :root.tablet-touch-layout .lineup-row .capo-select {
    width: 100% !important;
    max-width: none !important;
    min-height: 28px !important;
    height: 28px !important;
    padding: 0 5px !important;
    font-size: 0.68rem !important;
  }

  :root.tablet-touch-layout .note-row .song-text {
    grid-column: 3 / 10 !important;
  }

  :root.tablet-touch-layout .note-row .note-inline-actions {
    grid-column: 10 !important;
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (min-height: 521px) and (orientation: landscape) {
  :root.tablet-touch-layout .lineup-heading,
  :root.tablet-touch-layout .lineup-row,
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-heading,
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-row {
    grid-template-columns: 22px 30px minmax(150px, 1fr) minmax(96px, 0.34fr) 46px 48px 34px 34px 34px 72px !important;
  }
}

/* Phone add actions visually attach to the Song Bank instead of floating in an old framed tray. */
@media (max-width: 760px) and (pointer: coarse),
  (max-height: 520px) and (orientation: landscape) and (pointer: coarse) {
  .lineup-add-actions:not([hidden]) {
    overflow: visible !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
  }

  .lineup-add-actions:not([hidden])::before {
    position: absolute;
    inset: 0 0 -1px;
    z-index: 0;
    border: 1px solid color-mix(in srgb, var(--green) 28%, var(--line-strong));
    border-bottom: 0;
    border-radius: 14px 14px 0 0;
    background:
      linear-gradient(180deg, rgb(var(--accent-rgb) / 0.14), rgb(var(--accent-secondary-rgb) / 0.07)),
      color-mix(in srgb, var(--modern-glass-strong, var(--panel-2)) 70%, var(--accent-bg-dark));
    box-shadow:
      0 -10px 28px color-mix(in srgb, var(--green) 12%, rgba(0, 0, 0, 0.24)),
      inset 0 1px 0 rgba(255, 255, 255, 0.13);
    -webkit-backdrop-filter: blur(16px);
    backdrop-filter: blur(16px);
    content: "";
    pointer-events: none;
  }

  :root[data-theme="light"] .lineup-add-actions:not([hidden])::before {
    border-color: color-mix(in srgb, var(--green) 24%, #a9d8de);
    background:
      linear-gradient(180deg, rgba(255, 255, 255, 0.92), color-mix(in srgb, var(--accent-bg-light) 70%, transparent)),
      var(--modern-glass-strong, var(--accent-bg-light));
    box-shadow:
      0 -10px 24px rgba(8, 16, 28, 0.12),
      inset 0 1px 0 rgba(255, 255, 255, 0.95);
  }

  .lineup-add-actions::after {
    content: none !important;
  }

  .lineup-add-actions .icon-button,
  .lineup-add-actions #addNoteButton {
    border: 1px solid color-mix(in srgb, var(--line) 68%, transparent) !important;
    background:
      linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.02)),
      color-mix(in srgb, var(--panel) 36%, transparent) !important;
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.12),
      0 6px 16px rgba(0, 0, 0, 0.1) !important;
  }

  :root[data-theme="light"] .lineup-add-actions .icon-button,
  :root[data-theme="light"] .lineup-add-actions #addNoteButton {
    border-color: color-mix(in srgb, var(--green) 18%, #c8d8e6) !important;
    background:
      linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(241, 248, 253, 0.72)),
      var(--modern-glass-soft, #f7fbff) !important;
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.96),
      0 6px 14px rgba(8, 16, 28, 0.08) !important;
  }

  .lineup-add-actions #addSlideOnlyButton {
    color: color-mix(in srgb, var(--green) 86%, var(--text)) !important;
  }

  .lineup-add-actions #addNoteButton {
    color: color-mix(in srgb, var(--amber) 86%, var(--text)) !important;
  }

  .lineup-add-actions .icon-button:active,
  .lineup-add-actions #addNoteButton:active {
    transform: translateY(1px);
  }

  .lineup-add-actions .add-action-plus-icon,
  .lineup-add-actions #addNoteButton .note-plus-icon {
    border-color: color-mix(in srgb, currentColor 64%, transparent) !important;
    background: color-mix(in srgb, var(--modern-glass-strong, var(--panel)) 86%, transparent) !important;
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--panel) 82%, transparent) !important;
  }
}

/* Final add-action tray: shared iPad-style hidden/peek design for phone, desktop, and tablet portrait. */
.lineup-next-steps:empty {
  display: none !important;
}

.settings-action-button.active {
  border-color: color-mix(in srgb, var(--green) 42%, var(--line));
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--green) 14%, transparent), transparent 72%),
    color-mix(in srgb, var(--modern-glass-soft, var(--panel-2)) 86%, transparent);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    0 10px 24px color-mix(in srgb, var(--green) 14%, transparent);
}

:root[data-theme="light"] .settings-action-button.active {
  border-color: color-mix(in srgb, var(--green) 34%, #b7cad9);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.96), color-mix(in srgb, var(--accent-bg-light) 72%, transparent)),
    var(--modern-glass-soft, #f7fbff);
}

.lineup-add-actions:not([hidden]) {
  --lineup-add-tray-peek: 30px;
  position: fixed !important;
  right: max(12px, env(safe-area-inset-right, 0px)) !important;
  bottom: max(env(safe-area-inset-bottom, 0px), calc(var(--lineup-add-actions-bottom, var(--mobile-library-height, var(--lineup-add-bar-bank-height, var(--tablet-bank-height, 0px)))) - 1px)) !important;
  left: auto !important;
  z-index: 66 !important;
  display: inline-flex !important;
  flex-direction: row !important;
  align-items: flex-end !important;
  justify-content: center !important;
  width: auto !important;
  min-width: 0 !important;
  max-width: calc(100vw - 24px - env(safe-area-inset-left, 0px) - env(safe-area-inset-right, 0px)) !important;
  height: auto !important;
  min-height: 0 !important;
  margin: 0 !important;
  padding: 30px 8px 8px !important;
  gap: 7px !important;
  overflow: visible !important;
  border: 1px solid color-mix(in srgb, var(--green) 28%, rgba(255, 255, 255, 0.16)) !important;
  border-bottom: 0 !important;
  border-radius: 16px 16px 0 0 !important;
  background:
    linear-gradient(180deg, rgb(var(--accent-rgb) / 0.14), rgb(var(--accent-secondary-rgb) / 0.07)),
    color-mix(in srgb, var(--modern-glass-strong, var(--panel-2)) 76%, var(--accent-bg-dark)) !important;
  box-shadow:
    0 -12px 30px rgba(0, 0, 0, 0.22),
    inset 0 1px 0 rgba(255, 255, 255, 0.13) !important;
  opacity: 0.94 !important;
  transform: translateY(calc(100% - var(--lineup-add-tray-peek))) !important;
  transition: transform 180ms ease, opacity 180ms ease, box-shadow 180ms ease !important;
  pointer-events: auto !important;
  touch-action: pan-y !important;
  -webkit-backdrop-filter: blur(16px) !important;
  backdrop-filter: blur(16px) !important;
}

:root[data-theme="light"] .lineup-add-actions:not([hidden]) {
  border-color: color-mix(in srgb, var(--green) 24%, #a9d8de) !important;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.94), color-mix(in srgb, var(--accent-bg-light) 72%, transparent)),
    var(--modern-glass-strong, var(--accent-bg-light)) !important;
  box-shadow:
    0 -10px 24px rgba(8, 16, 28, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.95) !important;
}

.lineup-add-actions.is-open:not([hidden]) {
  opacity: 1 !important;
  transform: translateY(0) !important;
  box-shadow:
    0 -18px 42px rgba(0, 0, 0, 0.3),
    inset 0 1px 0 rgba(255, 255, 255, 0.14) !important;
}

@media (max-width: 760px),
  (max-height: 520px) and (orientation: landscape) {
  .lineup-add-actions:not(.is-open):not([hidden]) {
    overflow: hidden !important;
    clip-path: inset(0 0 calc(100% - var(--lineup-add-tray-peek, 30px)) 0 round 16px 16px 0 0);
  }
}

.lineup-add-actions:not([hidden])::before,
.lineup-add-actions:not([hidden])::after {
  content: none !important;
  display: none !important;
}

.lineup-add-actions-tab {
  appearance: none;
  position: absolute;
  top: 0;
  left: 50%;
  display: grid;
  place-items: center;
  width: 86px;
  min-width: 86px;
  height: 30px;
  min-height: 30px;
  padding: 0;
  border: 0;
  border-radius: 14px 14px 0 0;
  background: transparent;
  color: var(--green);
  transform: translate(-50%, -1px);
  touch-action: pan-y;
}

.lineup-add-actions-tab svg {
  width: 18px;
  height: 18px;
  fill: none;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 2.3;
  transition: transform 180ms ease;
}

.lineup-add-actions.is-open .lineup-add-actions-tab svg {
  transform: rotate(180deg);
}

.lineup-add-actions:not(.is-open) .icon-button {
  pointer-events: none !important;
}

.lineup-add-actions .icon-button,
.lineup-add-actions #addNoteButton {
  position: relative !important;
  z-index: 1 !important;
  display: inline-grid !important;
  grid-template-rows: 24px 14px !important;
  align-content: center !important;
  justify-items: center !important;
  width: 62px !important;
  min-width: 62px !important;
  height: 58px !important;
  min-height: 58px !important;
  padding: 6px 5px 5px !important;
  gap: 3px !important;
  overflow: visible !important;
  border: 1px solid color-mix(in srgb, var(--line) 68%, transparent) !important;
  border-radius: 12px !important;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.02)),
    color-mix(in srgb, var(--panel) 36%, transparent) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    0 6px 16px rgba(0, 0, 0, 0.1) !important;
  font-size: 0.62rem !important;
  line-height: 1 !important;
  pointer-events: auto;
}

:root[data-theme="light"] .lineup-add-actions .icon-button,
:root[data-theme="light"] .lineup-add-actions #addNoteButton {
  border-color: color-mix(in srgb, var(--green) 18%, #c8d8e6) !important;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(241, 248, 253, 0.72)),
    var(--modern-glass-soft, #f7fbff) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.96),
    0 6px 14px rgba(8, 16, 28, 0.08) !important;
}

.lineup-add-actions #addSlideOnlyButton {
  color: color-mix(in srgb, var(--green) 86%, var(--text)) !important;
}

.lineup-add-actions #addNoteButton {
  color: color-mix(in srgb, var(--amber) 86%, var(--text)) !important;
}

.lineup-add-actions .icon-button span {
  display: block !important;
  margin: 0 !important;
  font-size: 0.62rem !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  letter-spacing: 0 !important;
  white-space: nowrap !important;
}

.lineup-add-actions .icon-button .add-action-icon-stack {
  flex: 0 0 22px !important;
  width: 22px !important;
  height: 22px !important;
  margin: 0 !important;
}

.lineup-add-actions .lineup-add-slide-button .add-action-main-icon,
.lineup-add-actions .library-add-note-button .add-action-main-icon,
.lineup-add-actions #addNoteButton .add-action-main-icon {
  width: 20px !important;
  height: 20px !important;
}

.lineup-add-actions .add-action-plus-icon,
.lineup-add-actions #addNoteButton .note-plus-icon {
  top: -4px !important;
  right: -5px !important;
  width: 11px !important;
  height: 11px !important;
  border: 1.35px solid color-mix(in srgb, currentColor 64%, transparent) !important;
  border-radius: 999px !important;
  background: color-mix(in srgb, var(--modern-glass-strong, var(--panel)) 86%, transparent) !important;
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--panel) 82%, transparent) !important;
}

@media (min-width: 900px) and (pointer: fine) {
  .lineup-add-actions:not([hidden]) {
    --lineup-add-tray-peek: 34px;
    right: max(24px, env(safe-area-inset-right, 0px)) !important;
    padding: 34px 10px 10px !important;
    gap: 9px !important;
  }

  .lineup-add-actions-tab {
    width: 104px;
    min-width: 104px;
    height: 34px;
    min-height: 34px;
  }

  .lineup-add-actions .icon-button,
  .lineup-add-actions #addNoteButton {
    grid-template-rows: 30px 16px !important;
    width: 82px !important;
    min-width: 82px !important;
    height: 74px !important;
    min-height: 74px !important;
    padding: 8px 8px 7px !important;
    border-radius: 14px !important;
    font-size: 0.72rem !important;
  }

  .lineup-add-actions .icon-button span {
    font-size: 0.72rem !important;
  }

  .lineup-add-actions .icon-button .add-action-icon-stack {
    flex-basis: 28px !important;
    width: 28px !important;
    height: 28px !important;
  }

  .lineup-add-actions .lineup-add-slide-button .add-action-main-icon,
  .lineup-add-actions .library-add-note-button .add-action-main-icon,
  .lineup-add-actions #addNoteButton .add-action-main-icon {
    width: 25px !important;
    height: 25px !important;
  }

  .lineup-add-actions .add-action-plus-icon,
  .lineup-add-actions #addNoteButton .note-plus-icon {
    width: 13px !important;
    height: 13px !important;
  }
}

@media (min-width: 761px) and (max-width: 1366px) {
  :root.tablet-touch-layout .lineup-heading,
  :root.tablet-touch-layout .lineup-row,
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-heading,
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-row {
    grid-template-columns: 22px 28px minmax(96px, 1fr) minmax(66px, 0.3fr) 78px 46px 34px 34px 34px 64px !important;
  }

  :root.tablet-touch-layout .lineup-row .capo-select {
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
    height: 30px !important;
    min-height: 30px !important;
    padding: 0 4px !important;
    font-size: 0.72rem !important;
    letter-spacing: 0 !important;
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (orientation: portrait) {
  :root.tablet-touch-layout .lineup-add-actions:not([hidden]) {
    --lineup-add-tray-peek: 30px;
    right: max(12px, env(safe-area-inset-right, 0px)) !important;
    bottom: max(env(safe-area-inset-bottom, 0px), calc(var(--lineup-add-actions-bottom, var(--mobile-library-height, var(--lineup-add-bar-bank-height, var(--tablet-bank-height, 0px)))) - 1px)) !important;
    left: auto !important;
    flex-direction: row !important;
    width: auto !important;
    min-width: 0 !important;
    padding: 30px 8px 8px !important;
    border-right: 1px solid color-mix(in srgb, var(--green) 28%, rgba(255, 255, 255, 0.16)) !important;
    border-bottom: 0 !important;
    border-radius: 16px 16px 0 0 !important;
    transform: translateY(calc(100% - var(--lineup-add-tray-peek))) !important;
    touch-action: pan-y !important;
  }

  :root.tablet-touch-layout .lineup-add-actions.is-open:not([hidden]) {
    transform: translateY(0) !important;
  }

  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) {
    overflow: hidden !important;
    clip-path: inset(0 0 calc(100% - var(--lineup-add-tray-peek, 30px)) 0 round 16px 16px 0 0);
  }

  :root.tablet-touch-layout .lineup-add-actions-tab {
    top: 0;
    left: 50%;
    width: 86px;
    min-width: 86px;
    height: 30px;
    min-height: 30px;
    border-radius: 14px 14px 0 0;
    transform: translate(-50%, -1px);
    touch-action: pan-y;
  }

  :root.tablet-touch-layout .app-shell.mobile-library-middle .lineup-rows,
  :root.tablet-touch-layout .app-shell.mobile-library-full .lineup-rows {
    padding-bottom: calc(var(--mobile-library-height, var(--tablet-bank-height, 342px)) + 96px + env(safe-area-inset-bottom, 0px)) !important;
    scroll-padding-bottom: calc(var(--mobile-library-height, var(--tablet-bank-height, 342px)) + 96px + env(safe-area-inset-bottom, 0px)) !important;
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (min-height: 521px) and (orientation: landscape) {
  :root.tablet-touch-layout .lineup-heading,
  :root.tablet-touch-layout .lineup-row,
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-heading,
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-row {
    grid-template-columns: 22px 30px minmax(142px, 1fr) minmax(92px, 0.33fr) 78px 50px 34px 34px 34px 72px !important;
  }

  :root.tablet-touch-layout .lineup-add-actions:not([hidden]) {
    --lineup-add-tray-peek: 30px;
    top: auto !important;
    right: max(0px, env(safe-area-inset-right, 0px)) !important;
    bottom: max(18px, calc(env(safe-area-inset-bottom, 0px) + 18px)) !important;
    left: auto !important;
    flex-direction: column !important;
    align-items: flex-end !important;
    width: 98px !important;
    min-width: 98px !important;
    padding: 8px 8px 8px 31px !important;
    gap: 8px !important;
    border: 1px solid color-mix(in srgb, var(--green) 28%, rgba(255, 255, 255, 0.16)) !important;
    border-right: 0 !important;
    border-bottom: 1px solid color-mix(in srgb, var(--green) 28%, rgba(255, 255, 255, 0.16)) !important;
    border-radius: 16px 0 0 16px !important;
    transform: translateX(calc(100% - var(--lineup-add-tray-peek))) !important;
    touch-action: pan-x !important;
  }

  :root.tablet-touch-layout .lineup-add-actions.is-open:not([hidden]) {
    transform: translateX(0) !important;
  }

  :root.tablet-touch-layout .lineup-add-actions-tab {
    top: 50%;
    left: 0;
    width: 30px;
    min-width: 30px;
    height: 78px;
    min-height: 78px;
    border-radius: 14px 0 0 14px;
    transform: translateY(-50%);
    touch-action: pan-x;
  }

  :root.tablet-touch-layout .lineup-add-actions .icon-button,
  :root.tablet-touch-layout .lineup-add-actions #addNoteButton {
    width: 62px !important;
    min-width: 62px !important;
    height: 58px !important;
    min-height: 58px !important;
  }
}

/* iPad dropdown labels stay on one line. */
@media (min-width: 761px) and (max-width: 1366px) {
  :root.tablet-touch-layout .header-menu-popover {
    width: max-content !important;
    min-width: 292px !important;
  }

  :root.tablet-touch-layout .header-menu-popover .top-icon-button,
  :root.tablet-touch-layout .header-menu-popover .app-home-menu-item {
    display: flex !important;
    flex-wrap: nowrap !important;
    align-items: center !important;
    width: 100% !important;
    min-width: 100% !important;
    white-space: nowrap !important;
  }

  :root.tablet-touch-layout .header-menu-popover .top-icon-button span,
  :root.tablet-touch-layout .header-menu-popover .app-home-menu-item span,
  :root.tablet-touch-layout .header-menu-popover #slidePreviewMenuButton span,
  :root.tablet-touch-layout .header-menu-popover .mobile-theme-menu-button span {
    display: inline-block !important;
    flex: 0 0 auto !important;
    min-width: max-content !important;
    max-width: none !important;
    overflow: visible !important;
    white-space: nowrap !important;
    text-overflow: clip !important;
    line-height: 1 !important;
  }
}

/* Setlist row control groups: note, key controls, and slide/sheet assets. */
.lineup-heading,
.lineup-row {
  grid-template-columns: 24px 32px minmax(190px, 1fr) 40px minmax(184px, max-content) minmax(104px, max-content) 68px;
  column-gap: 10px;
}

.lineup-heading {
  align-items: end;
}

.note-heading,
.key-controls-heading,
.asset-controls-heading {
  min-width: 0;
}

.note-heading {
  display: grid;
  place-items: center;
}

.note-heading::before {
  content: "";
  display: block;
  width: 15px;
  height: 12px;
  border: 1.7px solid currentColor;
  border-radius: 5px;
  opacity: 0.78;
  clip-path: polygon(0 0, 100% 0, 100% 82%, 42% 82%, 22% 100%, 25% 82%, 0 82%);
}

.key-controls-heading,
.asset-controls-heading {
  display: grid;
  align-items: center;
  color: var(--muted);
}

.key-controls-heading {
  grid-template-columns: 88px 58px 32px;
  gap: 6px;
}

.asset-controls-heading {
  grid-template-columns: minmax(46px, max-content) minmax(46px, max-content);
  justify-content: center;
  gap: 22px;
}

.key-controls-heading span,
.asset-controls-heading span {
  overflow: hidden;
  text-align: center;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.lineup-row .lineup-mobile-controls {
  grid-column: 4 / 7;
}

.lineup-mobile-controls {
  display: grid;
  grid-template-columns: 40px minmax(184px, max-content) minmax(104px, max-content);
  align-items: center;
  gap: 14px;
  min-width: 0;
}

.lineup-key-controls,
.lineup-asset-controls {
  display: grid;
  align-items: center;
  min-width: 0;
}

.lineup-key-controls {
  grid-template-columns: 88px 58px 32px;
  gap: 6px;
}

.lineup-asset-controls {
  grid-template-columns: 34px 34px;
  justify-content: center;
  gap: 14px;
}

.lineup-row .slide-only-controls {
  grid-template-columns: 34px minmax(8px, 1fr) minmax(8px, 1fr) minmax(8px, 1fr) 34px;
  gap: 6px;
}

.slide-only-controls .slide-only-control-spacer {
  min-width: 0;
}

.lineup-note-button,
.mobile-note-button.lineup-note-button {
  display: inline-grid !important;
  place-items: center;
  width: 32px;
  min-width: 32px;
  height: 32px;
  min-height: 32px;
  border: 1px solid var(--line);
  border-radius: 9px;
  padding: 0;
  color: var(--muted);
  background: rgba(255, 255, 255, 0.035);
  cursor: pointer;
}

.lineup-note-button.has-note,
.mobile-note-button.lineup-note-button.has-note {
  border-color: color-mix(in srgb, var(--amber) 54%, var(--line));
  color: var(--amber);
  background: color-mix(in srgb, var(--amber) 13%, transparent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--amber) 8%, transparent);
}

.lineup-note-button:hover,
.lineup-note-button:focus-visible {
  border-color: color-mix(in srgb, var(--amber) 48%, var(--line));
  color: var(--amber);
  background: color-mix(in srgb, var(--amber) 10%, transparent);
  outline: none;
}

.lineup-note-button svg {
  width: 16px;
  height: 16px;
  fill: none;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 2;
}

.lineup-row .line-song-note,
.lineup-row .line-song-note input {
  display: none !important;
}

.lineup-row .capo-select {
  width: 88px;
}

.lineup-row .key-cell .key-picker-trigger {
  width: 58px;
  min-width: 58px;
}

.lineup-row .key-preview-button,
.lineup-row .slides-status-button,
.lineup-row .sheets-status-button {
  width: 32px;
  min-width: 32px;
}

@media (max-width: 760px) {
  .lineup-row {
    grid-template-columns: 28px minmax(0, 1fr) 30px !important;
    grid-template-areas:
      "num song actions"
      "drag controls controls" !important;
  }

  .lineup-row .lineup-mobile-controls {
    grid-area: controls;
    grid-column: auto !important;
  }

  .lineup-mobile-controls {
    grid-template-columns: 30px minmax(128px, max-content) minmax(72px, max-content) !important;
    justify-content: end;
    justify-self: end;
    gap: 8px !important;
  }

  .lineup-key-controls {
    grid-template-columns: 48px 42px 30px !important;
    gap: 4px !important;
  }

  .lineup-asset-controls {
    grid-template-columns: 32px 32px !important;
    gap: 6px !important;
  }

  .lineup-row .slide-only-controls {
    grid-template-columns: 32px minmax(8px, 1fr) minmax(8px, 1fr) minmax(8px, 1fr) 32px !important;
  }

  .lineup-note-button,
  .mobile-note-button.lineup-note-button,
  .lineup-row .key-preview-button,
  .lineup-row .slides-status-button,
  .lineup-row .sheets-status-button {
    width: 30px !important;
    min-width: 30px !important;
    height: 28px !important;
    min-height: 28px !important;
  }

  .lineup-row .capo-select {
    width: 48px !important;
  }

  .lineup-row .key-cell .key-picker-trigger {
    width: 42px !important;
    min-width: 42px !important;
  }
}

@media (min-width: 761px) and (max-width: 1366px) {
  :root.tablet-touch-layout .lineup-heading,
  :root.tablet-touch-layout .lineup-row,
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-heading,
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-row {
    grid-template-columns: 22px 30px minmax(118px, 1fr) 34px minmax(154px, max-content) minmax(84px, max-content) 64px !important;
    column-gap: 8px !important;
  }

  :root.tablet-touch-layout .lineup-row .lineup-mobile-controls,
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-row .lineup-mobile-controls {
    grid-column: 4 / 7 !important;
  }

  :root.tablet-touch-layout .lineup-mobile-controls {
    display: grid !important;
    grid-template-columns: 34px minmax(154px, max-content) minmax(84px, max-content) !important;
    gap: 9px !important;
  }

  :root.tablet-touch-layout .key-controls-heading,
  :root.tablet-touch-layout .lineup-key-controls {
    grid-template-columns: 72px 44px 30px !important;
    gap: 5px !important;
  }

  :root.tablet-touch-layout .asset-controls-heading,
  :root.tablet-touch-layout .lineup-asset-controls {
    grid-template-columns: 30px 30px !important;
    gap: 12px !important;
  }

  :root.tablet-touch-layout .lineup-row .slide-only-controls {
    grid-template-columns: 30px minmax(8px, 1fr) minmax(8px, 1fr) minmax(8px, 1fr) 30px !important;
    gap: 5px !important;
  }

  :root.tablet-touch-layout .lineup-heading .note-heading,
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-heading .note-heading {
    display: grid !important;
  }

  :root.tablet-touch-layout .lineup-heading .key-controls-heading,
  :root.tablet-touch-layout .lineup-heading .asset-controls-heading,
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-heading .key-controls-heading,
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-heading .asset-controls-heading {
    display: grid !important;
  }

  :root.tablet-touch-layout .lineup-row .capo-cell {
    display: block !important;
  }

  :root.tablet-touch-layout .lineup-row .line-song-note {
    display: none !important;
  }

  :root.tablet-touch-layout .lineup-note-button,
  :root.tablet-touch-layout .lineup-row .key-preview-button,
  :root.tablet-touch-layout .lineup-row .slides-status-button,
  :root.tablet-touch-layout .lineup-row .sheets-status-button {
    width: 30px !important;
    min-width: 30px !important;
    height: 30px !important;
    min-height: 30px !important;
  }

  :root.tablet-touch-layout .lineup-row .capo-select {
    display: block !important;
    width: 72px !important;
    min-width: 0 !important;
    height: 30px !important;
    min-height: 30px !important;
    padding: 0 5px !important;
    font-size: 0.7rem !important;
  }

  :root.tablet-touch-layout .lineup-row .key-cell .key-picker-trigger {
    width: 44px !important;
    min-width: 44px !important;
    min-height: 30px !important;
    padding: 0 7px !important;
  }
}

/* Final Slide/Note add tray behavior and appearance. */
.lineup-add-actions:not([hidden]) {
  background:
    linear-gradient(180deg, rgba(16, 30, 43, 0.98), rgba(5, 10, 17, 0.98)),
    color-mix(in srgb, var(--accent-bg-dark) 78%, #02060b) !important;
  border-color: color-mix(in srgb, var(--green) 34%, rgba(134, 170, 190, 0.22)) !important;
  box-shadow:
    0 -16px 38px rgba(0, 0, 0, 0.36),
    0 0 0 1px rgba(255, 255, 255, 0.035),
    inset 0 1px 0 rgba(255, 255, 255, 0.14) !important;
  opacity: 1 !important;
}

:root[data-theme="light"] .lineup-add-actions:not([hidden]) {
  background:
    linear-gradient(180deg, rgba(12, 25, 37, 0.97), rgba(4, 10, 17, 0.97)),
    #06101a !important;
  border-color: color-mix(in srgb, var(--green) 32%, rgba(255, 255, 255, 0.18)) !important;
  box-shadow:
    0 -16px 34px rgba(8, 16, 28, 0.28),
    0 0 0 1px rgba(255, 255, 255, 0.045),
    inset 0 1px 0 rgba(255, 255, 255, 0.16) !important;
}

.lineup-add-actions:not([hidden])::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 0 !important;
  display: block !important;
  border-radius: inherit !important;
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--green) 18%, transparent), transparent 34%, color-mix(in srgb, var(--amber) 14%, transparent)),
    radial-gradient(circle at 50% 0%, rgba(255, 255, 255, 0.14), transparent 54%) !important;
  opacity: 0.72 !important;
  pointer-events: none !important;
}

.lineup-add-actions-tab {
  z-index: 3 !important;
  color: color-mix(in srgb, var(--green) 84%, #dffcff) !important;
  text-shadow: 0 0 12px color-mix(in srgb, var(--green) 42%, transparent);
}

.lineup-add-actions .icon-button,
.lineup-add-actions #addNoteButton {
  color: var(--text) !important;
  border-color: color-mix(in srgb, currentColor 36%, rgba(255, 255, 255, 0.13)) !important;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.085), rgba(255, 255, 255, 0.018)),
    rgba(4, 11, 18, 0.78) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    0 12px 24px rgba(0, 0, 0, 0.18) !important;
  opacity: 0 !important;
  transform: translateY(12px) scale(0.96) !important;
  transition:
    opacity 90ms ease,
    transform 120ms ease,
    border-color 140ms ease,
    background 140ms ease !important;
  transition-delay: 0ms !important;
  pointer-events: none !important;
}

.lineup-add-actions.is-open .icon-button,
.lineup-add-actions.is-open #addNoteButton {
  opacity: 1 !important;
  transform: translateY(0) scale(1) !important;
  transition-delay: 80ms, 80ms, 0ms, 0ms !important;
  pointer-events: auto !important;
}

.lineup-add-actions #addSlideOnlyButton {
  color: color-mix(in srgb, var(--green) 86%, #eefcff) !important;
  border-color: color-mix(in srgb, var(--green) 54%, rgba(255, 255, 255, 0.12)) !important;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--green) 16%, rgba(255, 255, 255, 0.07)), rgba(255, 255, 255, 0.018)),
    rgba(4, 14, 19, 0.86) !important;
}

.lineup-add-actions #addNoteButton {
  color: color-mix(in srgb, var(--amber) 88%, #fff7e4) !important;
  border-color: color-mix(in srgb, var(--amber) 58%, rgba(255, 255, 255, 0.12)) !important;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--amber) 16%, rgba(255, 255, 255, 0.07)), rgba(255, 255, 255, 0.018)),
    rgba(17, 11, 4, 0.86) !important;
}

.lineup-add-actions .add-action-plus-icon,
.lineup-add-actions #addNoteButton .note-plus-icon {
  background: rgba(2, 7, 12, 0.96) !important;
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.08),
    0 0 12px color-mix(in srgb, currentColor 32%, transparent) !important;
}

.lineup-add-actions:not(.is-open):not([hidden]) {
  overflow: hidden !important;
  clip-path: inset(0 0 calc(100% - var(--lineup-add-tray-peek, 30px)) 0 round 16px 16px 0 0) !important;
}

@media (min-width: 761px) and (max-width: 1366px) and (min-height: 521px) and (orientation: landscape) {
  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) {
    clip-path: inset(0 0 0 calc(100% - var(--lineup-add-tray-peek, 30px)) round 16px 0 0 16px) !important;
  }

  :root.tablet-touch-layout .lineup-add-actions .icon-button,
  :root.tablet-touch-layout .lineup-add-actions #addNoteButton {
    transform: translateX(12px) scale(0.96) !important;
  }

  :root.tablet-touch-layout .lineup-add-actions.is-open .icon-button,
  :root.tablet-touch-layout .lineup-add-actions.is-open #addNoteButton {
    transform: translateX(0) scale(1) !important;
  }
}

/* iPad portrait startup polish: readable grouped headings, contained bank controls, and a tray that peeks above the bank. */
@media (min-width: 761px) and (max-width: 1366px) and (orientation: portrait) {
  :root.tablet-touch-layout .show-date-inline {
    direction: ltr !important;
    unicode-bidi: isolate !important;
    text-align: center !important;
    font-variant-numeric: tabular-nums !important;
  }

  :root.tablet-touch-layout .lineup-heading,
  :root.tablet-touch-layout .lineup-row,
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-heading,
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-row {
    grid-template-columns: 22px 30px minmax(148px, 1fr) 34px minmax(176px, max-content) minmax(112px, max-content) 64px !important;
    column-gap: 10px !important;
  }

  :root.tablet-touch-layout .lineup-mobile-controls {
    grid-template-columns: 34px minmax(176px, max-content) minmax(112px, max-content) !important;
    gap: 12px !important;
  }

  :root.tablet-touch-layout .key-controls-heading,
  :root.tablet-touch-layout .lineup-key-controls {
    grid-template-columns: 78px 48px 30px !important;
    gap: 10px !important;
  }

  :root.tablet-touch-layout .asset-controls-heading {
    grid-template-columns: 48px 48px !important;
    gap: 16px !important;
  }

  :root.tablet-touch-layout .lineup-asset-controls {
    grid-template-columns: 32px 32px !important;
    gap: 20px !important;
  }

  :root.tablet-touch-layout .key-controls-heading span,
  :root.tablet-touch-layout .asset-controls-heading span {
    overflow: visible !important;
    font-size: 0.66rem !important;
    letter-spacing: 0 !important;
    text-overflow: clip !important;
    white-space: nowrap !important;
  }

  :root.tablet-touch-layout .lineup-row .capo-select {
    width: 78px !important;
    min-width: 78px !important;
  }

  :root.tablet-touch-layout .lineup-row .key-cell .key-picker-trigger {
    width: 48px !important;
    min-width: 48px !important;
  }

  :root.tablet-touch-layout .bank-panel:not(.manage-mode) {
    overflow-x: hidden !important;
  }

  :root.tablet-touch-layout .bank-panel .side-panel-view {
    min-width: 0 !important;
    overflow-x: hidden !important;
  }

  :root.tablet-touch-layout .search-row {
    grid-template-columns: minmax(0, 1fr) 46px 46px !important;
    gap: 8px !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }

  :root.tablet-touch-layout .search-row > .icon-button {
    width: 46px !important;
    min-width: 46px !important;
    height: 42px !important;
    min-height: 42px !important;
  }

  :root.tablet-touch-layout .lineup-add-actions:not([hidden]) {
    right: max(18px, env(safe-area-inset-right, 0px)) !important;
    bottom: max(env(safe-area-inset-bottom, 0px), calc(var(--lineup-add-actions-bottom, var(--mobile-library-height, var(--tablet-bank-height, 0px))) + 8px)) !important;
  }
}

/* Themed Slide/Note add tray: follows accent color, skin, and light/dark mode. */
.lineup-add-actions:not([hidden]) {
  --add-tray-surface: color-mix(in srgb, var(--modern-glass-strong, var(--panel-2)) 74%, var(--accent-bg-dark));
  --add-tray-sheen: rgb(var(--accent-rgb) / 0.14);
  --add-tray-secondary-sheen: rgb(var(--accent-secondary-rgb) / 0.09);
  --add-tray-border: color-mix(in srgb, var(--green) 36%, var(--modern-line-strong, var(--line)));
  --add-tray-button: color-mix(in srgb, var(--modern-control, var(--panel-2)) 80%, var(--accent-bg-dark));
  --add-tray-button-highlight: rgba(255, 255, 255, 0.09);
  --add-tray-note-tone: color-mix(in srgb, var(--amber) 76%, var(--green) 24%);
  border-color: var(--add-tray-border) !important;
  background:
    linear-gradient(135deg, var(--add-tray-sheen), transparent 40%, var(--add-tray-secondary-sheen)),
    linear-gradient(180deg, color-mix(in srgb, var(--add-tray-surface) 92%, rgba(255, 255, 255, 0.08)), var(--add-tray-surface)) !important;
  box-shadow:
    0 -16px 38px color-mix(in srgb, var(--green) 13%, rgba(0, 0, 0, 0.3)),
    0 0 0 1px color-mix(in srgb, var(--green) 10%, transparent),
    inset 0 1px 0 color-mix(in srgb, var(--text) 13%, transparent) !important;
}

:root[data-theme="light"] .lineup-add-actions:not([hidden]) {
  --add-tray-surface: color-mix(in srgb, var(--modern-glass-strong, #ffffff) 74%, var(--accent-bg-light));
  --add-tray-sheen: rgb(var(--accent-rgb) / 0.13);
  --add-tray-secondary-sheen: rgb(var(--accent-secondary-rgb) / 0.07);
  --add-tray-border: color-mix(in srgb, var(--green) 31%, var(--modern-line-strong, var(--line)));
  --add-tray-button: color-mix(in srgb, var(--modern-control, #ffffff) 82%, var(--accent-bg-light));
  --add-tray-button-highlight: rgba(255, 255, 255, 0.84);
  box-shadow:
    0 -14px 34px color-mix(in srgb, var(--green) 11%, rgba(40, 58, 82, 0.16)),
    0 0 0 1px color-mix(in srgb, var(--green) 10%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.92) !important;
}

:root[data-skin="premium"] .lineup-add-actions:not([hidden]) {
  --add-tray-surface: color-mix(in srgb, var(--modern-glass-strong, var(--panel-2)) 68%, var(--accent-bg-dark));
  --add-tray-secondary-sheen: color-mix(in srgb, var(--amber) 16%, transparent);
}

:root[data-skin="playful"] .lineup-add-actions:not([hidden]) {
  --add-tray-sheen: rgb(var(--accent-rgb) / 0.18);
  --add-tray-secondary-sheen: rgb(var(--accent-secondary-rgb) / 0.14);
}

.lineup-add-actions .icon-button,
.lineup-add-actions #addNoteButton {
  border-color: color-mix(in srgb, currentColor 32%, var(--modern-line, var(--line))) !important;
  background:
    linear-gradient(180deg, var(--add-tray-button-highlight), transparent 72%),
    var(--add-tray-button) !important;
  box-shadow:
    inset 0 1px 0 color-mix(in srgb, var(--text) 12%, transparent),
    0 8px 18px color-mix(in srgb, currentColor 10%, rgba(0, 0, 0, 0.16)) !important;
}

:root[data-theme="light"] .lineup-add-actions .icon-button,
:root[data-theme="light"] .lineup-add-actions #addNoteButton {
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.92),
    0 7px 16px color-mix(in srgb, currentColor 10%, rgba(40, 58, 82, 0.08)) !important;
}

.lineup-add-actions #addSlideOnlyButton {
  color: color-mix(in srgb, var(--green) 88%, var(--text)) !important;
  border-color: color-mix(in srgb, var(--green) 52%, var(--modern-line, var(--line))) !important;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--green) 16%, var(--add-tray-button-highlight)), transparent 72%),
    color-mix(in srgb, var(--add-tray-button) 84%, var(--green)) !important;
}

.lineup-add-actions #addNoteButton {
  color: color-mix(in srgb, var(--add-tray-note-tone) 88%, var(--text)) !important;
  border-color: color-mix(in srgb, var(--add-tray-note-tone) 52%, var(--modern-line, var(--line))) !important;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--add-tray-note-tone) 16%, var(--add-tray-button-highlight)), transparent 72%),
    color-mix(in srgb, var(--add-tray-button) 86%, var(--add-tray-note-tone)) !important;
}

.lineup-add-actions .add-action-plus-icon,
.lineup-add-actions #addNoteButton .note-plus-icon {
  background: color-mix(in srgb, var(--add-tray-surface) 78%, var(--panel)) !important;
  box-shadow:
    0 0 0 1px color-mix(in srgb, currentColor 22%, transparent),
    0 0 12px color-mix(in srgb, currentColor 30%, transparent) !important;
}

/* v319 touch layout density and iPad landscape split polish. */
.key-controls-heading .preview-heading {
  min-width: 0 !important;
  overflow: hidden !important;
  font-size: 0 !important;
  line-height: 0 !important;
  text-indent: -9999px !important;
}

.key-controls-heading .preview-heading::before {
  content: none !important;
}

@media (max-width: 760px) {
  .lineup-mobile-controls {
    grid-template-columns: 30px minmax(118px, max-content) minmax(78px, max-content) !important;
    gap: 8px !important;
  }

  .lineup-key-controls,
  .key-controls-heading {
    grid-template-columns: 50px 43px 30px !important;
    gap: 5px !important;
  }

  .lineup-asset-controls {
    grid-template-columns: 30px 30px !important;
    gap: 10px !important;
  }

  .asset-controls-heading {
    grid-template-columns: 44px 44px !important;
    gap: 14px !important;
  }

  .lineup-row .song-title-wrap,
  .lineup-row .song-text,
  .lineup-row .song-name {
    min-width: 0 !important;
  }
}

@media (min-width: 761px) and (max-width: 1366px) {
  :root.tablet-touch-layout .lineup-heading,
  :root.tablet-touch-layout .lineup-row,
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-heading,
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-row {
    grid-template-columns: 22px 30px minmax(170px, 1fr) 34px minmax(160px, max-content) minmax(104px, max-content) 58px !important;
    column-gap: 9px !important;
  }

  :root.tablet-touch-layout .lineup-mobile-controls,
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-mobile-controls {
    grid-template-columns: 34px minmax(160px, max-content) minmax(104px, max-content) !important;
    gap: 11px !important;
  }

  :root.tablet-touch-layout .lineup-key-controls,
  :root.tablet-touch-layout .key-controls-heading {
    grid-template-columns: 76px 48px 30px !important;
    gap: 7px !important;
  }

  :root.tablet-touch-layout .lineup-asset-controls {
    grid-template-columns: 30px 30px !important;
    gap: 18px !important;
  }

  :root.tablet-touch-layout .asset-controls-heading {
    grid-template-columns: 50px 50px !important;
    gap: 18px !important;
  }

  :root.tablet-touch-layout .key-controls-heading span,
  :root.tablet-touch-layout .asset-controls-heading span {
    overflow: visible !important;
    font-size: 0.64rem !important;
    line-height: 1 !important;
    letter-spacing: 0 !important;
    text-overflow: clip !important;
    white-space: nowrap !important;
  }

  :root.tablet-touch-layout .key-controls-heading .preview-heading {
    overflow: hidden !important;
    font-size: 0 !important;
    line-height: 0 !important;
    visibility: hidden !important;
  }

  :root.tablet-touch-layout .lineup-row .song-title-wrap,
  :root.tablet-touch-layout .lineup-row .song-text,
  :root.tablet-touch-layout .lineup-row .song-name {
    min-width: 0 !important;
  }

  :root.tablet-touch-layout .lineup-row .song-name {
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
  }

  :root.tablet-touch-layout .lineup-row .capo-select {
    width: 76px !important;
    min-width: 76px !important;
  }

  :root.tablet-touch-layout .lineup-row .key-cell .key-picker-trigger {
    width: 48px !important;
    min-width: 48px !important;
  }

  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton,
  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .icon-button {
    opacity: 0 !important;
    pointer-events: none !important;
  }

  :root.tablet-touch-layout .lineup-add-actions-tab {
    pointer-events: auto !important;
    touch-action: manipulation !important;
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (min-height: 521px) and (orientation: landscape) {
  :root.tablet-touch-layout .app-shell {
    grid-template-columns: clamp(340px, 35vw, 440px) 6px minmax(0, 1fr) !important;
  }

  :root.tablet-touch-layout .panel-resizer,
  :root.tablet-touch-layout .app-shell.bank-collapsed .panel-resizer {
    width: 6px !important;
    min-width: 6px !important;
    background: color-mix(in srgb, var(--panel) 76%, transparent) !important;
  }

  :root.tablet-touch-layout .panel-resizer::before {
    width: 2px !important;
    opacity: 0.62 !important;
    background: color-mix(in srgb, var(--green) 22%, var(--line-strong)) !important;
  }

  :root.tablet-touch-layout .bank-panel:not(.manage-mode),
  :root.tablet-touch-layout .app-shell.bank-collapsed .bank-panel:not(.manage-mode) {
    padding: calc(16px + env(safe-area-inset-top, 0px)) 12px calc(10px + env(safe-area-inset-bottom, 0px)) max(12px, env(safe-area-inset-left, 0px)) !important;
  }

  :root.tablet-touch-layout .bank-header {
    grid-template-columns: minmax(0, 1fr) auto !important;
    gap: 8px !important;
    margin-bottom: 8px !important;
  }

  :root.tablet-touch-layout .bank-header::after {
    font-size: 1.05rem !important;
    line-height: 1 !important;
  }

  :root.tablet-touch-layout .bank-title-actions {
    gap: 6px !important;
  }

  :root.tablet-touch-layout .bank-title-actions .icon-button {
    width: 36px !important;
    min-width: 36px !important;
    height: 36px !important;
    min-height: 36px !important;
    border-radius: 10px !important;
    background:
      linear-gradient(180deg, color-mix(in srgb, var(--text) 8%, transparent), transparent 72%),
      color-mix(in srgb, var(--modern-control, var(--panel-2)) 86%, var(--accent-bg-dark)) !important;
  }

  :root.tablet-touch-layout .bank-title-actions #manageSongBankButton,
  :root.tablet-touch-layout .bank-title-actions #closeBankButton {
    display: none !important;
  }

  :root.tablet-touch-layout .quick-add-menu-popover {
    right: 42px !important;
  }

  :root.tablet-touch-layout .search-row {
    grid-template-columns: minmax(0, 1fr) 40px 40px !important;
    gap: 6px !important;
    margin-bottom: 8px !important;
    width: 100% !important;
  }

  :root.tablet-touch-layout .search-box input {
    height: 40px !important;
    min-height: 40px !important;
    font-size: 0.82rem !important;
  }

  :root.tablet-touch-layout .search-row > .icon-button {
    width: 40px !important;
    min-width: 40px !important;
    height: 40px !important;
    min-height: 40px !important;
    border-radius: 10px !important;
  }

  :root.tablet-touch-layout .bank-panel .song-bank-list {
    gap: 7px !important;
  }

  :root.tablet-touch-layout .bank-song {
    grid-template-columns: minmax(0, 1fr) 30px 30px 30px !important;
    min-height: 58px !important;
    gap: 7px !important;
    padding: 8px 8px 8px 14px !important;
  }

  :root.tablet-touch-layout .bank-song:has(.banger-toggle.active) {
    grid-template-columns: minmax(0, 1fr) 30px 30px 30px 30px !important;
  }

  :root.tablet-touch-layout .bank-song .banger-toggle:not(.active) {
    display: none !important;
  }

  :root.tablet-touch-layout .bank-song .song-name {
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
  }

  :root.tablet-touch-layout .bank-title-line {
    min-width: 0 !important;
    gap: 6px !important;
  }

  :root.tablet-touch-layout .hebrew-badge {
    flex: 0 0 auto !important;
    max-width: 38px !important;
  }

  :root.tablet-touch-layout .bank-slides-button,
  :root.tablet-touch-layout .bank-sheets-button,
  :root.tablet-touch-layout .bank-edit-button,
  :root.tablet-touch-layout .bank-song .banger-toggle {
    width: 30px !important;
    min-width: 30px !important;
    height: 30px !important;
    min-height: 30px !important;
    border-radius: 9px !important;
  }

  :root.tablet-touch-layout .show-panel,
  :root.tablet-touch-layout .show-panel.slide-preview-open {
    padding: calc(18px + env(safe-area-inset-top, 0px)) 16px 14px !important;
  }

  :root.tablet-touch-layout .show-header {
    gap: 12px !important;
    margin-bottom: 12px !important;
  }

  :root.tablet-touch-layout .lineup-table {
    padding: 10px 10px !important;
  }

  :root.tablet-touch-layout .lineup-heading,
  :root.tablet-touch-layout .lineup-row,
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-heading,
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-row {
    grid-template-columns: 22px 30px minmax(200px, 1fr) 34px minmax(160px, max-content) minmax(104px, max-content) 58px !important;
    column-gap: 9px !important;
  }

  :root.tablet-touch-layout .lineup-row {
    min-height: 56px !important;
    padding: 7px 9px !important;
  }

  :root.tablet-touch-layout .lineup-heading {
    padding: 0 8px 9px !important;
  }

  :root.tablet-touch-layout .lineup-add-actions:not([hidden]) {
    right: max(0px, env(safe-area-inset-right, 0px)) !important;
    bottom: max(16px, calc(env(safe-area-inset-bottom, 0px) + 16px)) !important;
    z-index: 66 !important;
  }
}

/* v320 portrait tray clears the song bank instead of floating over it. */
@media (max-width: 760px) and (orientation: portrait) {
  .lineup-add-actions:not([hidden]) {
    bottom: max(
      env(safe-area-inset-bottom, 0px),
      calc(var(--lineup-add-actions-bottom, var(--mobile-library-height, var(--tablet-bank-height, 0px))) + 78px)
    ) !important;
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (orientation: portrait) {
  :root.tablet-touch-layout .lineup-add-actions:not([hidden]) {
    bottom: max(
      env(safe-area-inset-bottom, 0px),
      calc(var(--lineup-add-actions-bottom, var(--mobile-library-height, var(--tablet-bank-height, 0px))) + 78px)
    ) !important;
  }
}

/* v321 phone tray uses the phone bank height variable. */
@media (max-width: 760px) and (orientation: portrait) {
  .lineup-add-actions:not([hidden]) {
    bottom: max(
      env(safe-area-inset-bottom, 0px),
      calc(var(--lineup-add-actions-bottom, var(--mobile-library-height, var(--lineup-add-bar-bank-height, var(--tablet-bank-height, 0px)))) + 78px)
    ) !important;
  }
}

/* v322 stable touch layout, tray hit area, and swipe actions. */
.note-heading {
  display: grid !important;
  place-items: center !important;
  overflow: visible !important;
  font-size: 0.66rem !important;
  font-weight: 900 !important;
  letter-spacing: 0 !important;
  line-height: 1 !important;
  text-align: center !important;
  text-transform: uppercase !important;
  white-space: nowrap !important;
}

.note-heading::before {
  content: none !important;
  display: none !important;
}

.lineup-hebrew-badge {
  margin-inline-start: 2px;
}

.key-controls-heading {
  justify-items: center !important;
}

.key-controls-heading span:nth-child(2) {
  transform: translateX(6px);
}

.asset-controls-heading {
  justify-items: center !important;
}

.lineup-row,
.bank-song {
  transition:
    border-color 150ms ease,
    background 150ms ease,
    transform 180ms ease,
    box-shadow 150ms ease;
}

@media (max-width: 760px) {
  .lineup-table,
  .lineup-rows {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    overflow-x: hidden !important;
  }

  .lineup-row.song-row {
    grid-template-columns: 28px minmax(0, 1fr) 34px 70px !important;
    grid-template-areas:
      "num song note assets"
      "drag controls controls controls" !important;
    column-gap: 7px !important;
    row-gap: 7px !important;
    min-height: 82px !important;
    padding: 8px 8px 10px !important;
    overflow: hidden !important;
  }

  .lineup-row.song-row .lineup-mobile-controls {
    display: contents !important;
    grid-area: auto !important;
    grid-column: auto !important;
  }

  .lineup-row.song-row .lineup-note-button {
    grid-area: note !important;
    align-self: start !important;
    justify-self: end !important;
  }

  .lineup-row.song-row .lineup-asset-controls {
    grid-area: assets !important;
    align-self: start !important;
    justify-self: end !important;
    grid-template-columns: 30px 30px !important;
    gap: 7px !important;
  }

  .lineup-row.song-row .lineup-key-controls {
    grid-area: controls !important;
    align-self: start !important;
    justify-self: end !important;
    grid-template-columns: 50px 43px 30px !important;
    gap: 5px !important;
  }

  .lineup-row.song-row .row-icon-actions {
    position: absolute !important;
    top: 8px !important;
    right: 8px !important;
    z-index: 7 !important;
    display: flex !important;
    gap: 6px !important;
    padding: 2px !important;
    border: 1px solid var(--line) !important;
    border-radius: 10px !important;
    background: color-mix(in srgb, var(--panel) 94%, transparent) !important;
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.26) !important;
    opacity: 0 !important;
    pointer-events: none !important;
    transform: translateX(86px) !important;
    transition: opacity 140ms ease, transform 180ms ease !important;
  }

  :root[data-theme="light"] .lineup-row.song-row .row-icon-actions {
    background: rgba(255, 255, 255, 0.96) !important;
  }

  .lineup-row.song-row .row-icon-actions [data-action="info"],
  .lineup-row.song-row .row-icon-actions [data-action="remove"] {
    display: inline-grid !important;
    width: 30px !important;
    min-width: 30px !important;
    height: 30px !important;
    min-height: 30px !important;
  }

  .lineup-row.song-row.swipe-open .row-icon-actions {
    opacity: 1 !important;
    pointer-events: auto !important;
    transform: translateX(0) !important;
  }

  .lineup-row.song-row.swipe-open .lineup-asset-controls {
    opacity: 0.18;
  }

  .lineup-row.song-row.swipe-open {
    border-color: color-mix(in srgb, var(--green) 54%, var(--line)) !important;
    box-shadow:
      inset 0 0 0 1px color-mix(in srgb, var(--green) 18%, transparent),
      0 10px 24px rgba(0, 0, 0, 0.18) !important;
  }

  .bank-song {
    position: relative !important;
    grid-template-columns: minmax(0, 1fr) 28px 28px 28px !important;
    min-height: 42px !important;
    overflow: hidden !important;
    padding-right: 8px !important;
  }

  .bank-song .bank-edit-button {
    position: absolute !important;
    top: 50% !important;
    right: 8px !important;
    z-index: 6 !important;
    opacity: 0 !important;
    pointer-events: none !important;
    transform: translate(46px, -50%) !important;
    transition: opacity 140ms ease, transform 180ms ease !important;
  }

  .bank-song.swipe-open .bank-edit-button {
    opacity: 1 !important;
    pointer-events: auto !important;
    transform: translate(0, -50%) !important;
  }

  .bank-song.swipe-open .bank-sheets-button {
    opacity: 0.18;
  }

  .bank-song.swipe-open {
    border-color: color-mix(in srgb, var(--green) 54%, var(--line)) !important;
  }
}

@media (max-width: 760px) and (orientation: portrait),
  (min-width: 761px) and (max-width: 1366px) and (orientation: portrait) {
  .lineup-add-actions:not([hidden]),
  :root.tablet-touch-layout .lineup-add-actions:not([hidden]) {
    --lineup-add-tray-peek: 32px;
    right: max(18px, env(safe-area-inset-right, 0px)) !important;
    bottom: max(
      env(safe-area-inset-bottom, 0px),
      calc(var(--lineup-add-actions-bottom, var(--mobile-library-height, var(--lineup-add-bar-bank-height, var(--tablet-bank-height, 0px)))) + 8px)
    ) !important;
    left: auto !important;
    z-index: 88 !important;
    display: inline-flex !important;
    flex-direction: row !important;
    align-items: flex-end !important;
    justify-content: center !important;
    width: auto !important;
    min-width: 0 !important;
    height: auto !important;
    min-height: 0 !important;
    padding: 32px 8px 8px !important;
    gap: 7px !important;
    overflow: hidden !important;
    border-radius: 16px 16px 0 0 !important;
    clip-path: inset(0 0 calc(100% - var(--lineup-add-tray-peek)) 0 round 16px 16px 0 0) !important;
    transform: translateY(calc(100% - var(--lineup-add-tray-peek))) !important;
    pointer-events: auto !important;
    touch-action: manipulation !important;
  }

  .lineup-add-actions.is-open:not([hidden]),
  :root.tablet-touch-layout .lineup-add-actions.is-open:not([hidden]) {
    clip-path: none !important;
    overflow: visible !important;
    transform: translateY(0) !important;
  }

  .lineup-add-actions-tab,
  :root.tablet-touch-layout .lineup-add-actions-tab {
    top: 0 !important;
    left: 50% !important;
    z-index: 9 !important;
    width: 88px !important;
    min-width: 88px !important;
    height: 32px !important;
    min-height: 32px !important;
    transform: translate(-50%, -1px) !important;
    touch-action: manipulation !important;
    pointer-events: auto !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) .icon-button,
  .lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton,
  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .icon-button,
  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton {
    opacity: 0 !important;
    pointer-events: none !important;
    transform: translateY(0) scale(0.98) !important;
  }

  .lineup-add-actions.is-open .icon-button,
  .lineup-add-actions.is-open #addNoteButton,
  :root.tablet-touch-layout .lineup-add-actions.is-open .icon-button,
  :root.tablet-touch-layout .lineup-add-actions.is-open #addNoteButton {
    opacity: 1 !important;
    pointer-events: auto !important;
    transform: translateY(0) scale(1) !important;
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (min-height: 521px) and (orientation: landscape) {
  :root.tablet-touch-layout .app-shell,
  :root.tablet-touch-layout .app-shell.bank-collapsed {
    grid-template-columns: minmax(320px, var(--bank-width, clamp(340px, 35vw, 440px))) 10px minmax(0, 1fr) !important;
    width: 100vw !important;
    max-width: 100vw !important;
    min-width: 0 !important;
    overflow: hidden !important;
  }

  :root.tablet-touch-layout .panel-resizer,
  :root.tablet-touch-layout .app-shell.bank-collapsed .panel-resizer {
    display: block !important;
    width: 10px !important;
    min-width: 10px !important;
    cursor: col-resize !important;
    pointer-events: auto !important;
    z-index: 10 !important;
    background: color-mix(in srgb, var(--panel) 68%, transparent) !important;
  }

  :root.tablet-touch-layout .panel-resizer::before {
    width: 3px !important;
    opacity: 0.78 !important;
    background: color-mix(in srgb, var(--green) 34%, var(--line-strong)) !important;
  }

  :root.tablet-touch-layout .bank-panel,
  :root.tablet-touch-layout .show-panel,
  :root.tablet-touch-layout .show-panel.slide-preview-open {
    min-width: 0 !important;
    max-width: 100% !important;
    overflow-x: hidden !important;
  }

  :root.tablet-touch-layout .show-panel,
  :root.tablet-touch-layout .show-panel.slide-preview-open {
    padding-right: max(14px, env(safe-area-inset-right, 0px)) !important;
  }

  :root.tablet-touch-layout .lineup-table,
  :root.tablet-touch-layout .lineup-rows {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    overflow-x: hidden !important;
  }

  :root.tablet-touch-layout .lineup-heading,
  :root.tablet-touch-layout .lineup-row,
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-heading,
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-row {
    box-sizing: border-box !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    grid-template-columns: 22px 30px minmax(150px, 1fr) 34px minmax(152px, max-content) minmax(104px, max-content) 52px !important;
    column-gap: 7px !important;
  }

  :root.tablet-touch-layout .lineup-mobile-controls,
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-mobile-controls {
    grid-template-columns: 34px minmax(152px, max-content) minmax(104px, max-content) !important;
    gap: 9px !important;
  }

  :root.tablet-touch-layout .key-controls-heading,
  :root.tablet-touch-layout .lineup-key-controls {
    grid-template-columns: 72px 48px 30px !important;
    gap: 7px !important;
  }

  :root.tablet-touch-layout .asset-controls-heading {
    grid-template-columns: 48px 48px !important;
    gap: 18px !important;
  }

  :root.tablet-touch-layout .lineup-asset-controls {
    grid-template-columns: 30px 30px !important;
    gap: 18px !important;
  }

  :root.tablet-touch-layout .lineup-add-actions:not([hidden]) {
    --lineup-add-tray-peek: 30px;
    top: auto !important;
    right: max(0px, env(safe-area-inset-right, 0px)) !important;
    bottom: max(16px, calc(env(safe-area-inset-bottom, 0px) + 16px)) !important;
    left: auto !important;
    z-index: 88 !important;
    display: inline-flex !important;
    flex-direction: column !important;
    align-items: flex-end !important;
    width: 98px !important;
    min-width: 98px !important;
    padding: 8px 8px 8px 31px !important;
    gap: 8px !important;
    overflow: hidden !important;
    border-right: 0 !important;
    border-bottom: 1px solid var(--add-tray-border, var(--line)) !important;
    border-radius: 16px 0 0 16px !important;
    clip-path: inset(0 0 0 calc(100% - var(--lineup-add-tray-peek)) round 16px 0 0 16px) !important;
    transform: translateX(calc(100% - var(--lineup-add-tray-peek))) !important;
    touch-action: manipulation !important;
    pointer-events: auto !important;
  }

  :root.tablet-touch-layout .lineup-add-actions.is-open:not([hidden]) {
    clip-path: none !important;
    overflow: visible !important;
    transform: translateX(0) !important;
  }

  :root.tablet-touch-layout .lineup-add-actions-tab {
    top: 50% !important;
    left: 0 !important;
    z-index: 9 !important;
    width: 30px !important;
    min-width: 30px !important;
    height: 78px !important;
    min-height: 78px !important;
    border-radius: 14px 0 0 14px !important;
    transform: translateY(-50%) !important;
    touch-action: manipulation !important;
    pointer-events: auto !important;
  }

  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .icon-button,
  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton {
    opacity: 0 !important;
    pointer-events: none !important;
    transform: translateX(0) scale(0.98) !important;
  }

  :root.tablet-touch-layout .lineup-add-actions.is-open .icon-button,
  :root.tablet-touch-layout .lineup-add-actions.is-open #addNoteButton {
    opacity: 1 !important;
    pointer-events: auto !important;
    transform: translateX(0) scale(1) !important;
  }
}

/* v323 add tray collapse is only the visible tab, not a hidden panel over content. */
@media (max-width: 760px) and (orientation: portrait),
  (min-width: 761px) and (max-width: 1366px) and (orientation: portrait) {
  .lineup-add-actions:not(.is-open):not([hidden]),
  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) {
    width: 88px !important;
    min-width: 88px !important;
    max-width: 88px !important;
    height: 32px !important;
    min-height: 32px !important;
    max-height: 32px !important;
    padding: 0 !important;
    gap: 0 !important;
    clip-path: none !important;
    overflow: visible !important;
    transform: none !important;
    pointer-events: auto !important;
  }

  .lineup-add-actions.is-open:not([hidden]),
  :root.tablet-touch-layout .lineup-add-actions.is-open:not([hidden]) {
    width: auto !important;
    min-width: 0 !important;
    max-width: calc(100vw - 24px - env(safe-area-inset-left, 0px) - env(safe-area-inset-right, 0px)) !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    padding: 32px 8px 8px !important;
    transform: none !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab,
  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab {
    top: 0 !important;
    left: 0 !important;
    width: 88px !important;
    min-width: 88px !important;
    height: 32px !important;
    min-height: 32px !important;
    border-radius: 16px 16px 0 0 !important;
    transform: none !important;
  }

  .lineup-add-actions.is-open:not([hidden]) .lineup-add-actions-tab,
  :root.tablet-touch-layout .lineup-add-actions.is-open:not([hidden]) .lineup-add-actions-tab {
    top: 0 !important;
    left: 50% !important;
    transform: translate(-50%, -1px) !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) .icon-button,
  .lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton,
  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .icon-button,
  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton {
    display: none !important;
  }
}

/* v327 final override: must live after the v324 mobile block. */
@media (max-width: 760px) {
  .lineup-rows {
    grid-auto-rows: auto !important;
  }

  .lineup-row.song-row {
    display: block !important;
    height: auto !important;
    min-height: 84px !important;
    max-height: none !important;
    padding: 0 !important;
    overflow: hidden !important;
  }

  .lineup-row.song-row .lineup-row-main {
    min-height: 84px !important;
    height: auto !important;
    box-sizing: border-box !important;
  }

  .lineup-row.song-row .row-icon-actions {
    height: 100% !important;
    min-height: 84px !important;
  }

  .lineup-row.song-row .row-icon-actions .icon-action {
    min-height: 84px !important;
  }
}

@media (max-width: 760px) and (orientation: portrait),
  (min-width: 761px) and (max-width: 1366px) and (orientation: portrait) {
  .lineup-add-actions:not([hidden]),
  :root.tablet-touch-layout .lineup-add-actions:not([hidden]) {
    right: max(22px, env(safe-area-inset-right, 0px)) !important;
    bottom: max(
      env(safe-area-inset-bottom, 0px),
      calc(var(--lineup-add-actions-bottom, var(--mobile-library-height, var(--lineup-add-bar-bank-height, var(--tablet-bank-height, 0px)))) - 1px)
    ) !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]),
  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) {
    box-shadow:
      0 -8px 20px color-mix(in srgb, var(--green) 11%, rgba(0, 0, 0, 0.22)),
      0 0 0 1px color-mix(in srgb, var(--green) 10%, transparent),
      inset 0 1px 0 color-mix(in srgb, var(--text) 12%, transparent) !important;
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (min-height: 521px) and (orientation: landscape) {
  :root.tablet-touch-layout .lineup-add-actions.is-open:not([hidden]) {
    width: 94px !important;
    min-width: 94px !important;
    max-width: 94px !important;
    padding: 8px !important;
    overflow: visible !important;
    border-radius: 16px !important;
    border-right: 1px solid var(--add-tray-border, var(--line)) !important;
  }

  :root.tablet-touch-layout .lineup-add-actions.is-open:not([hidden]) .lineup-add-actions-tab {
    left: -43px !important;
    width: 34px !important;
    min-width: 34px !important;
    height: 76px !important;
    min-height: 76px !important;
    border-radius: 16px !important;
    border: 1px solid var(--add-tray-border, var(--line)) !important;
    background:
      linear-gradient(180deg, var(--add-tray-button-highlight), transparent 72%),
      var(--add-tray-button, var(--panel-2)) !important;
    box-shadow:
      0 10px 24px rgba(0, 0, 0, 0.22),
      inset 0 1px 0 color-mix(in srgb, var(--text) 12%, transparent) !important;
  }

  :root.tablet-touch-layout .lineup-add-actions.is-open:not([hidden])::before {
    border-radius: 16px !important;
  }
}

/* v327: fix clipped phone rows and clean up the floating Slide/Note tray. */
@media (max-width: 760px) {
  .lineup-rows {
    grid-auto-rows: auto !important;
  }

  .lineup-row.song-row {
    display: block !important;
    height: auto !important;
    min-height: 84px !important;
    max-height: none !important;
    overflow: hidden !important;
  }

  .lineup-row.song-row .lineup-row-main {
    min-height: 84px !important;
    height: auto !important;
    box-sizing: border-box !important;
  }

  .lineup-row.song-row .row-icon-actions {
    height: 100% !important;
    min-height: 84px !important;
  }

  .lineup-row.song-row .row-icon-actions .icon-action {
    min-height: 84px !important;
  }
}

@media (max-width: 760px) and (orientation: portrait),
  (min-width: 761px) and (max-width: 1366px) and (orientation: portrait) {
  .lineup-add-actions:not([hidden]),
  :root.tablet-touch-layout .lineup-add-actions:not([hidden]) {
    right: max(22px, env(safe-area-inset-right, 0px)) !important;
    bottom: max(
      env(safe-area-inset-bottom, 0px),
      calc(var(--lineup-add-actions-bottom, var(--mobile-library-height, var(--lineup-add-bar-bank-height, var(--tablet-bank-height, 0px)))) - 1px)
    ) !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]),
  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) {
    box-shadow:
      0 -8px 20px color-mix(in srgb, var(--green) 11%, rgba(0, 0, 0, 0.22)),
      0 0 0 1px color-mix(in srgb, var(--green) 10%, transparent),
      inset 0 1px 0 color-mix(in srgb, var(--text) 12%, transparent) !important;
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (min-height: 521px) and (orientation: landscape) {
  :root.tablet-touch-layout .lineup-add-actions.is-open:not([hidden]) {
    width: 94px !important;
    min-width: 94px !important;
    max-width: 94px !important;
    padding: 8px !important;
    overflow: visible !important;
    border-radius: 16px !important;
    border-right: 1px solid var(--add-tray-border, var(--line)) !important;
  }

  :root.tablet-touch-layout .lineup-add-actions.is-open:not([hidden]) .lineup-add-actions-tab {
    left: -43px !important;
    width: 34px !important;
    min-width: 34px !important;
    height: 76px !important;
    min-height: 76px !important;
    border-radius: 16px !important;
    border: 1px solid var(--add-tray-border, var(--line)) !important;
    background:
      linear-gradient(180deg, var(--add-tray-button-highlight), transparent 72%),
      var(--add-tray-button, var(--panel-2)) !important;
    box-shadow:
      0 10px 24px rgba(0, 0, 0, 0.22),
      inset 0 1px 0 color-mix(in srgb, var(--text) 12%, transparent) !important;
  }

  :root.tablet-touch-layout .lineup-add-actions.is-open:not([hidden])::before {
    border-radius: 16px !important;
  }
}

/* v324 phone filters, key/capo order, note preview, and true swipe reveal. */
.lineup-row-main,
.bank-song-main-content {
  display: contents;
}

.lineup-note-preview {
  display: none;
}

.key-controls-heading,
.lineup-key-controls {
  grid-template-columns: 58px 88px 32px !important;
}

.key-controls-heading span:nth-child(1),
.key-controls-heading span:nth-child(2) {
  transform: none !important;
}

@media (min-width: 761px) and (max-width: 1366px) {
  :root.tablet-touch-layout .key-controls-heading,
  :root.tablet-touch-layout .lineup-key-controls {
    grid-template-columns: 48px 72px 30px !important;
  }
}

@media (max-width: 760px) {
  .lineup-row.song-row {
    display: block !important;
    height: auto !important;
    min-height: 84px !important;
    max-height: none !important;
    padding: 0 !important;
    overflow: hidden !important;
    background:
      linear-gradient(90deg, color-mix(in srgb, var(--green) 12%, transparent), transparent 54%),
      color-mix(in srgb, var(--panel) 92%, #02060b) !important;
    touch-action: pan-y;
  }

  :root[data-theme="light"] .lineup-row.song-row {
    background: color-mix(in srgb, var(--panel) 96%, #ffffff) !important;
  }

  .lineup-row.song-row::before {
    display: none !important;
  }

  .lineup-row.song-row .lineup-row-main {
    position: relative;
    z-index: 2;
    display: grid !important;
    grid-template-columns: 28px 34px minmax(0, 1fr) minmax(128px, max-content) !important;
    grid-template-areas:
      "num song song assets"
      "drag noteIcon noteText controls" !important;
    align-items: center !important;
    min-height: 84px !important;
    height: auto !important;
    padding: 8px 8px 10px !important;
    column-gap: 7px !important;
    row-gap: 7px !important;
    border-radius: inherit;
    background:
      linear-gradient(180deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.025)),
      color-mix(in srgb, var(--panel) 92%, #02060b) !important;
    transform: translateX(0);
    transition: transform 190ms ease !important;
    will-change: transform;
  }

  :root[data-theme="light"] .lineup-row.song-row .lineup-row-main {
    background: linear-gradient(180deg, #ffffff, #f4f7fb) !important;
  }

  .lineup-row.song-row .lineup-row-main::before {
    content: "";
    position: absolute;
    top: 9px;
    bottom: 9px;
    left: 0;
    width: 4px;
    border-radius: 0 999px 999px 0;
    background: var(--category-color, var(--green));
    opacity: 0.9;
    pointer-events: none;
  }

  .lineup-row.song-row.swipe-open .lineup-row-main {
    transform: translateX(-112px) !important;
  }

  .lineup-row.song-row .drag-handle {
    grid-area: drag !important;
  }

  .lineup-row.song-row .song-number {
    grid-area: num !important;
  }

  .lineup-row.song-row .song-title-wrap {
    grid-area: song !important;
    min-width: 0 !important;
  }

  .lineup-row.song-row .lineup-mobile-controls {
    display: contents !important;
  }

  .lineup-row.song-row .lineup-note-button {
    grid-area: noteIcon !important;
    align-self: center !important;
    justify-self: start !important;
  }

  .lineup-row.song-row .lineup-note-preview {
    grid-area: noteText !important;
    display: block !important;
    min-width: 0 !important;
    max-width: 100% !important;
    overflow: hidden !important;
    color: var(--amber);
    font-size: 0.72rem;
    font-weight: 850;
    line-height: 1.1;
    opacity: 0;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .lineup-row.song-row .lineup-note-preview.has-note {
    opacity: 1;
  }

  .lineup-row.song-row .lineup-key-controls {
    grid-area: controls !important;
    align-self: center !important;
    justify-self: end !important;
    grid-template-columns: 43px 50px 30px !important;
    gap: 5px !important;
  }

  .lineup-row.song-row .lineup-asset-controls {
    grid-area: assets !important;
    align-self: center !important;
    justify-self: end !important;
    grid-template-columns: 30px 30px !important;
    gap: 7px !important;
  }

  .lineup-row.song-row .key-cell .key-picker-trigger {
    width: 43px !important;
    min-width: 43px !important;
  }

  .lineup-row.song-row .capo-select {
    width: 50px !important;
    max-width: 50px !important;
  }

  .lineup-row.song-row .row-icon-actions {
    position: absolute !important;
    top: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    left: auto !important;
    z-index: 1 !important;
    display: grid !important;
    grid-template-columns: 56px 56px !important;
    width: 112px !important;
    min-width: 112px !important;
    height: 100% !important;
    min-height: 84px !important;
    gap: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    opacity: 1 !important;
    pointer-events: none !important;
    transform: none !important;
  }

  .lineup-row.song-row.swipe-open .row-icon-actions {
    pointer-events: auto !important;
  }

  .lineup-row.song-row .row-icon-actions .icon-action {
    display: inline-grid !important;
    width: 56px !important;
    min-width: 56px !important;
    height: 100% !important;
    min-height: 84px !important;
    border: 0 !important;
    border-left: 1px solid color-mix(in srgb, var(--line) 76%, transparent) !important;
    border-radius: 0 !important;
    background:
      linear-gradient(180deg, rgba(255, 255, 255, 0.08), transparent 76%),
      color-mix(in srgb, var(--panel-2) 90%, #050910) !important;
  }

  .lineup-row.song-row .row-icon-actions .icon-action.danger {
    background:
      linear-gradient(180deg, rgba(255, 255, 255, 0.08), transparent 76%),
      color-mix(in srgb, #4c1414 68%, var(--panel-2)) !important;
  }

  .lineup-row.song-row.swipe-open .lineup-asset-controls {
    opacity: 1 !important;
  }

  .slide-only-row .lineup-row-main {
    grid-template-columns: 28px minmax(0, 1fr) 32px 32px !important;
    grid-template-areas: "num song image slides" !important;
    min-height: 56px !important;
    padding: 7px 8px !important;
  }

  .slide-only-row .drag-handle,
  .slide-only-row .slide-only-control-spacer,
  .slide-only-row .slide-only-subline {
    display: none !important;
  }

  .slide-only-row .slide-only-controls {
    display: contents !important;
  }

  .slide-only-row .slide-only-inline-image-button {
    grid-area: image !important;
    width: 30px !important;
    min-width: 30px !important;
    height: 28px !important;
    min-height: 28px !important;
  }

  .slide-only-row .slides-status-button {
    grid-area: slides !important;
  }

  .slide-only-row .row-icon-actions {
    grid-template-columns: 52px 52px 52px !important;
    width: 156px !important;
    min-width: 156px !important;
  }

  .slide-only-row .row-icon-actions .icon-action {
    width: 52px !important;
    min-width: 52px !important;
  }

  .slide-only-row.swipe-open .lineup-row-main {
    transform: translateX(-156px) !important;
  }

  .bank-song {
    display: block !important;
    height: auto !important;
    min-height: 54px !important;
    max-height: none !important;
    padding: 0 !important;
    overflow: hidden !important;
    background:
      linear-gradient(90deg, color-mix(in srgb, var(--green) 12%, transparent), transparent 54%),
      color-mix(in srgb, var(--panel) 92%, #02060b) !important;
  }

  .bank-song::before {
    z-index: 3;
  }

  .bank-song .bank-song-main-content {
    position: relative;
    z-index: 2;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 28px 28px 28px !important;
    align-items: center !important;
    min-height: 54px !important;
    height: auto !important;
    gap: 5px !important;
    padding: 5px 8px !important;
    border-radius: inherit;
    background:
      linear-gradient(180deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.025)),
      color-mix(in srgb, var(--panel) 92%, #02060b) !important;
    transform: translateX(0);
    transition: transform 190ms ease !important;
  }

  :root[data-theme="light"] .bank-song .bank-song-main-content {
    background: linear-gradient(180deg, #ffffff, #f4f7fb) !important;
  }

  .bank-song.swipe-open .bank-song-main-content {
    transform: translateX(-58px) !important;
  }

  .bank-song .bank-edit-button {
    position: absolute !important;
    top: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    z-index: 1 !important;
    display: inline-grid !important;
    width: 58px !important;
    min-width: 58px !important;
    height: 100% !important;
    min-height: 54px !important;
    border: 0 !important;
    border-left: 1px solid color-mix(in srgb, var(--line) 76%, transparent) !important;
    border-radius: 0 !important;
    background:
      linear-gradient(180deg, rgba(255, 255, 255, 0.08), transparent 76%),
      color-mix(in srgb, var(--panel-2) 90%, #050910) !important;
    opacity: 1 !important;
    pointer-events: none !important;
    transform: none !important;
  }

  .bank-song.swipe-open .bank-edit-button {
    pointer-events: auto !important;
    transform: none !important;
  }

  .bank-song.swipe-open .bank-sheets-button {
    opacity: 1 !important;
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (min-height: 521px) and (orientation: landscape) {
  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) {
    width: 30px !important;
    min-width: 30px !important;
    max-width: 30px !important;
    height: 78px !important;
    min-height: 78px !important;
    max-height: 78px !important;
    padding: 0 !important;
    gap: 0 !important;
    clip-path: none !important;
    overflow: visible !important;
    transform: none !important;
    pointer-events: auto !important;
  }

  :root.tablet-touch-layout .lineup-add-actions.is-open:not([hidden]) {
    width: 94px !important;
    min-width: 94px !important;
    max-width: 94px !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    padding: 8px !important;
    overflow: visible !important;
    border-right: 1px solid var(--add-tray-border, var(--line)) !important;
    border-radius: 16px !important;
    transform: none !important;
  }

  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab {
    top: 0 !important;
    left: 0 !important;
    width: 30px !important;
    min-width: 30px !important;
    height: 78px !important;
    min-height: 78px !important;
    border-radius: 14px 0 0 14px !important;
    transform: none !important;
  }

  :root.tablet-touch-layout .lineup-add-actions.is-open:not([hidden]) .lineup-add-actions-tab {
    top: 50% !important;
    left: -43px !important;
    width: 34px !important;
    min-width: 34px !important;
    height: 76px !important;
    min-height: 76px !important;
    border-radius: 16px !important;
    border: 1px solid var(--add-tray-border, var(--line)) !important;
    background:
      linear-gradient(180deg, var(--add-tray-button-highlight), transparent 72%),
      var(--add-tray-button, var(--panel-2)) !important;
    box-shadow:
      0 10px 24px rgba(0, 0, 0, 0.22),
      inset 0 1px 0 color-mix(in srgb, var(--text) 12%, transparent) !important;
    transform: translateY(-50%) !important;
  }

  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .icon-button,
  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton {
    display: none !important;
  }
}

/* v329 polished add tray and slide-only row density. */
.lineup-add-actions:not([hidden]) {
  --lineup-add-tray-peek: 36px;
  --add-polish-surface: color-mix(in srgb, var(--modern-glass-strong, var(--panel-2)) 82%, var(--accent-bg-dark));
  --add-polish-border: color-mix(in srgb, var(--green) 44%, var(--modern-line-strong, var(--line)));
  --add-polish-button: color-mix(in srgb, var(--modern-control, var(--panel-2)) 84%, #050b12);
  --add-polish-tab: color-mix(in srgb, var(--modern-control, var(--panel-2)) 78%, var(--accent-bg-dark));
  padding-top: 40px !important;
  border-color: var(--add-polish-border) !important;
  border-radius: 18px 18px 0 0 !important;
  background:
    linear-gradient(135deg, rgb(var(--accent-rgb) / 0.18), transparent 42%, rgb(var(--accent-secondary-rgb) / 0.1)),
    linear-gradient(180deg, color-mix(in srgb, var(--add-polish-surface) 88%, rgba(255, 255, 255, 0.12)), var(--add-polish-surface)) !important;
  box-shadow:
    0 -16px 38px color-mix(in srgb, var(--green) 14%, rgba(0, 0, 0, 0.34)),
    0 0 0 1px color-mix(in srgb, var(--green) 12%, transparent),
    inset 0 1px 0 color-mix(in srgb, var(--text) 14%, transparent) !important;
}

:root[data-theme="light"] .lineup-add-actions:not([hidden]) {
  --add-polish-surface: color-mix(in srgb, var(--modern-glass-strong, #ffffff) 78%, var(--accent-bg-light));
  --add-polish-button: color-mix(in srgb, var(--modern-control, #ffffff) 86%, var(--accent-bg-light));
  --add-polish-tab: color-mix(in srgb, var(--modern-control, #ffffff) 82%, var(--accent-bg-light));
  box-shadow:
    0 -14px 32px color-mix(in srgb, var(--green) 10%, rgba(42, 61, 84, 0.18)),
    0 0 0 1px color-mix(in srgb, var(--green) 12%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.88) !important;
}

:root[data-skin="premium"] .lineup-add-actions:not([hidden]) {
  --add-polish-surface: color-mix(in srgb, var(--modern-glass-strong, var(--panel-2)) 76%, var(--accent-bg-dark));
  --add-polish-border: color-mix(in srgb, var(--amber) 32%, var(--green) 28%, var(--modern-line-strong, var(--line)));
}

:root[data-skin="playful"] .lineup-add-actions:not([hidden]) {
  --add-polish-border: color-mix(in srgb, var(--green) 52%, var(--accent-secondary, var(--line)));
}

.lineup-add-actions:not([hidden])::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 0 !important;
  display: block !important;
  border-radius: inherit !important;
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--green) 16%, transparent), transparent 48%, color-mix(in srgb, var(--amber) 12%, transparent)),
    radial-gradient(circle at 50% 2px, color-mix(in srgb, var(--text) 14%, transparent), transparent 54%) !important;
  opacity: 0.72 !important;
  pointer-events: none !important;
}

.lineup-add-actions-tab {
  top: 6px !important;
  left: 50% !important;
  z-index: 4 !important;
  width: 62px !important;
  min-width: 62px !important;
  height: 28px !important;
  min-height: 28px !important;
  border: 1px solid color-mix(in srgb, var(--green) 42%, var(--modern-line, var(--line))) !important;
  border-radius: 999px !important;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--text) 13%, transparent), transparent 74%),
    var(--add-polish-tab, var(--panel-2)) !important;
  color: color-mix(in srgb, var(--green) 88%, var(--text)) !important;
  box-shadow:
    0 8px 18px color-mix(in srgb, var(--green) 14%, rgba(0, 0, 0, 0.2)),
    inset 0 1px 0 color-mix(in srgb, var(--text) 14%, transparent) !important;
  transform: translateX(-50%) !important;
}

.lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab,
.lineup-add-actions.is-open:not([hidden]) .lineup-add-actions-tab {
  top: 6px !important;
  left: 50% !important;
  width: 62px !important;
  min-width: 62px !important;
  height: 28px !important;
  min-height: 28px !important;
  border-radius: 999px !important;
  transform: translateX(-50%) !important;
}

.lineup-add-actions-tab svg {
  width: 17px !important;
  height: 17px !important;
  stroke-width: 2.7 !important;
}

.lineup-add-actions.is-open .lineup-add-actions-tab {
  color: color-mix(in srgb, var(--amber) 58%, var(--green)) !important;
}

.lineup-add-actions.is-open .lineup-add-actions-tab svg {
  transform: rotate(45deg) !important;
}

.lineup-add-actions .icon-button,
.lineup-add-actions #addNoteButton {
  grid-template-rows: 32px 14px !important;
  width: 70px !important;
  min-width: 70px !important;
  height: 66px !important;
  min-height: 66px !important;
  padding: 7px 6px 6px !important;
  gap: 4px !important;
  border-radius: 14px !important;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--text) 11%, transparent), transparent 76%),
    var(--add-polish-button, var(--panel-2)) !important;
  box-shadow:
    inset 0 1px 0 color-mix(in srgb, var(--text) 12%, transparent),
    0 10px 22px color-mix(in srgb, currentColor 11%, rgba(0, 0, 0, 0.18)) !important;
}

.lineup-add-actions .icon-button > span:not(.add-action-icon-stack),
.lineup-add-actions #addNoteButton > span:not(.add-action-icon-stack) {
  color: color-mix(in srgb, currentColor 82%, var(--text)) !important;
  font-size: 0.66rem !important;
  font-weight: 900 !important;
}

.lineup-add-actions .icon-button .add-action-icon-stack,
.lineup-add-actions #addNoteButton .add-action-icon-stack {
  display: grid !important;
  place-items: center !important;
  width: 32px !important;
  height: 30px !important;
  border-radius: 10px !important;
  background: color-mix(in srgb, currentColor 16%, transparent) !important;
  box-shadow: inset 0 0 0 1px color-mix(in srgb, currentColor 24%, transparent) !important;
}

.lineup-add-actions .lineup-add-slide-button .add-action-main-icon,
.lineup-add-actions .library-add-note-button .add-action-main-icon,
.lineup-add-actions #addNoteButton .add-action-main-icon {
  width: 22px !important;
  height: 22px !important;
}

.lineup-add-actions .add-action-plus-icon,
.lineup-add-actions #addNoteButton .note-plus-icon {
  display: none !important;
}

.lineup-add-actions #addSlideOnlyButton {
  color: color-mix(in srgb, var(--green) 90%, #eaffff) !important;
}

.lineup-add-actions #addNoteButton {
  color: color-mix(in srgb, var(--amber) 88%, #fff8e6) !important;
}

@media (min-width: 900px) and (pointer: fine) {
  .lineup-add-actions:not([hidden]) {
    --lineup-add-tray-peek: 38px;
    padding-top: 42px !important;
  }

  .lineup-add-actions-tab {
    width: 76px !important;
    min-width: 76px !important;
    height: 30px !important;
    min-height: 30px !important;
  }

  .lineup-add-actions .icon-button,
  .lineup-add-actions #addNoteButton {
    width: 82px !important;
    min-width: 82px !important;
    height: 74px !important;
    min-height: 74px !important;
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (min-height: 521px) and (orientation: landscape) {
  :root.tablet-touch-layout .lineup-add-actions:not([hidden]) {
    right: max(0px, env(safe-area-inset-right, 0px)) !important;
    border-radius: 18px 0 0 18px !important;
  }

  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) {
    width: 38px !important;
    min-width: 38px !important;
    max-width: 38px !important;
    height: 76px !important;
    min-height: 76px !important;
    max-height: 76px !important;
    padding: 0 !important;
    clip-path: none !important;
  }

  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab {
    top: 0 !important;
    left: 0 !important;
    width: 38px !important;
    min-width: 38px !important;
    height: 76px !important;
    min-height: 76px !important;
    border-radius: 18px 0 0 18px !important;
    transform: none !important;
  }

  :root.tablet-touch-layout .lineup-add-actions.is-open:not([hidden]) {
    width: 92px !important;
    min-width: 92px !important;
    max-width: 92px !important;
    padding: 8px !important;
    border-right: 0 !important;
    border-radius: 18px 0 0 18px !important;
  }

  :root.tablet-touch-layout .lineup-add-actions.is-open:not([hidden]) .lineup-add-actions-tab {
    top: 50% !important;
    left: -48px !important;
    width: 36px !important;
    min-width: 36px !important;
    height: 66px !important;
    min-height: 66px !important;
    border-radius: 999px !important;
    transform: translateY(-50%) !important;
  }

  :root.tablet-touch-layout .lineup-add-actions .icon-button,
  :root.tablet-touch-layout .lineup-add-actions #addNoteButton {
    width: 76px !important;
    min-width: 76px !important;
    height: 66px !important;
    min-height: 66px !important;
  }
}

.lineup-row.song-row.slide-only-row {
  min-height: 46px !important;
  padding-top: 5px !important;
  padding-bottom: 5px !important;
}

.lineup-row.note-row {
  min-height: 54px !important;
}

@media (max-width: 760px) {
  .app-shell.bank-collapsed .lineup-row.song-row.slide-only-row,
  .app-shell.mobile-library-minimized .lineup-row.song-row.slide-only-row,
  .app-shell.mobile-library-middle .lineup-row.song-row.slide-only-row,
  .app-shell.mobile-library-full .lineup-row.song-row.slide-only-row,
  .lineup-row.song-row.slide-only-row {
    height: auto !important;
    min-height: 58px !important;
    padding: 0 !important;
  }

  .lineup-row.song-row.slide-only-row .lineup-row-main {
    min-height: 58px !important;
    padding: 7px 8px !important;
  }

  .lineup-row.song-row.slide-only-row .row-icon-actions,
  .lineup-row.song-row.slide-only-row .row-icon-actions .icon-action {
    min-height: 58px !important;
  }

  .lineup-row.note-row {
    min-height: 74px !important;
  }
}

@media (min-width: 761px) and (max-width: 1366px) {
  :root.tablet-touch-layout .lineup-row.song-row.slide-only-row .row-icon-actions [data-action="slide-image"] {
    display: none !important;
  }

  :root.tablet-touch-layout .lineup-row.song-row.slide-only-row .row-icon-actions {
    gap: 6px !important;
  }
}

/* v330: the final setlist item must be scrollable above the Song Bank drawer. */
@media (max-width: 760px) and (orientation: portrait),
  (min-width: 761px) and (max-width: 1366px) and (orientation: portrait) {
  .app-shell .lineup-rows,
  .app-shell.bank-collapsed .lineup-rows,
  .app-shell.mobile-library-minimized .lineup-rows,
  .app-shell.mobile-library-middle .lineup-rows,
  .app-shell.mobile-library-full .lineup-rows,
  :root.tablet-touch-layout .app-shell .lineup-rows,
  :root.tablet-touch-layout .app-shell.bank-collapsed .lineup-rows,
  :root.tablet-touch-layout .app-shell.mobile-library-minimized .lineup-rows,
  :root.tablet-touch-layout .app-shell.mobile-library-middle .lineup-rows,
  :root.tablet-touch-layout .app-shell.mobile-library-full .lineup-rows {
    --lineup-bank-clearance: max(
      var(--lineup-add-actions-bottom, 0px),
      var(--mobile-library-height, var(--lineup-add-bar-bank-height, var(--tablet-bank-height, 0px)))
    );
    padding-bottom: calc(var(--lineup-bank-clearance) + 118px + env(safe-area-inset-bottom, 0px)) !important;
    scroll-padding-bottom: calc(var(--lineup-bank-clearance) + 118px + env(safe-area-inset-bottom, 0px)) !important;
  }
}

/* v331: tight measured drawer clearance and contained Slide/Note tray controls. */
.lineup-add-actions:not([hidden]) {
  --lineup-add-tray-gap: 9px;
  --lineup-add-button-width: 74px;
  --lineup-add-button-height: 60px;
  --lineup-add-open-width: 185px;
  box-sizing: border-box !important;
  overflow: visible !important;
  isolation: isolate !important;
  touch-action: manipulation !important;
}

.lineup-add-actions.is-open:not([hidden]) {
  display: grid !important;
  grid-template-columns: repeat(2, var(--lineup-add-button-width)) !important;
  grid-auto-flow: column !important;
  align-items: end !important;
  justify-content: center !important;
  gap: var(--lineup-add-tray-gap) !important;
  width: var(--lineup-add-open-width) !important;
  min-width: var(--lineup-add-open-width) !important;
  max-width: var(--lineup-add-open-width) !important;
  height: 104px !important;
  min-height: 104px !important;
  max-height: 104px !important;
  padding: 36px 14px 10px !important;
}

.lineup-add-actions:not(.is-open):not([hidden]) {
  width: 88px !important;
  min-width: 88px !important;
  max-width: 88px !important;
  height: 34px !important;
  min-height: 34px !important;
  max-height: 34px !important;
  padding: 0 !important;
}

.lineup-add-actions .icon-button,
.lineup-add-actions #addNoteButton {
  box-sizing: border-box !important;
  display: grid !important;
  grid-template-rows: 30px 14px !important;
  place-items: center !important;
  align-content: center !important;
  justify-content: center !important;
  width: var(--lineup-add-button-width) !important;
  min-width: var(--lineup-add-button-width) !important;
  max-width: var(--lineup-add-button-width) !important;
  height: var(--lineup-add-button-height) !important;
  min-height: var(--lineup-add-button-height) !important;
  max-height: var(--lineup-add-button-height) !important;
  padding: 6px 6px 5px !important;
  gap: 3px !important;
  overflow: hidden !important;
  line-height: 1 !important;
  contain: paint !important;
}

.lineup-add-actions .icon-button > span:not(.add-action-icon-stack),
.lineup-add-actions #addNoteButton > span:not(.add-action-icon-stack) {
  display: block !important;
  max-width: 100% !important;
  margin: 0 !important;
  overflow: hidden !important;
  white-space: nowrap !important;
  text-overflow: ellipsis !important;
  line-height: 1 !important;
  transform: none !important;
}

.lineup-add-actions .icon-button .add-action-icon-stack,
.lineup-add-actions #addNoteButton .add-action-icon-stack {
  position: relative !important;
  display: grid !important;
  place-items: center !important;
  width: 30px !important;
  min-width: 30px !important;
  max-width: 30px !important;
  height: 28px !important;
  min-height: 28px !important;
  max-height: 28px !important;
  overflow: hidden !important;
  transform: none !important;
}

.lineup-add-actions .lineup-add-slide-button .add-action-main-icon,
.lineup-add-actions .library-add-note-button .add-action-main-icon,
.lineup-add-actions #addNoteButton .add-action-main-icon {
  display: block !important;
  width: 20px !important;
  min-width: 20px !important;
  max-width: 20px !important;
  height: 20px !important;
  min-height: 20px !important;
  max-height: 20px !important;
  margin: 0 !important;
  overflow: visible !important;
  transform: none !important;
}

.lineup-add-actions .add-action-plus-icon,
.lineup-add-actions #addNoteButton .note-plus-icon {
  display: none !important;
}

.lineup-add-actions-tab {
  box-sizing: border-box !important;
  display: grid !important;
  place-items: center !important;
  overflow: hidden !important;
  touch-action: manipulation !important;
}

.lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab,
.lineup-add-actions.is-open:not([hidden]) .lineup-add-actions-tab {
  width: 72px !important;
  min-width: 72px !important;
  max-width: 72px !important;
  height: 30px !important;
  min-height: 30px !important;
  max-height: 30px !important;
}

.lineup-add-actions-tab svg {
  display: block !important;
  width: 17px !important;
  height: 17px !important;
  margin: 0 !important;
  overflow: visible !important;
}

@media (max-width: 760px) and (orientation: portrait),
  (min-width: 761px) and (max-width: 1366px) and (orientation: portrait) {
  .app-shell .lineup-rows,
  .app-shell.bank-collapsed .lineup-rows,
  .app-shell.mobile-library-minimized .lineup-rows,
  .app-shell.mobile-library-middle .lineup-rows,
  .app-shell.mobile-library-full .lineup-rows,
  :root.tablet-touch-layout .app-shell .lineup-rows,
  :root.tablet-touch-layout .app-shell.bank-collapsed .lineup-rows,
  :root.tablet-touch-layout .app-shell.mobile-library-minimized .lineup-rows,
  :root.tablet-touch-layout .app-shell.mobile-library-middle .lineup-rows,
  :root.tablet-touch-layout .app-shell.mobile-library-full .lineup-rows {
    padding-bottom: calc(var(--lineup-bank-scroll-clearance, 0px) + 16px + env(safe-area-inset-bottom, 0px)) !important;
    scroll-padding-bottom: calc(var(--lineup-bank-scroll-clearance, 0px) + 16px + env(safe-area-inset-bottom, 0px)) !important;
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (orientation: portrait) {
  :root.tablet-touch-layout .lineup-add-actions.is-open:not([hidden]) {
    --lineup-add-button-width: 76px;
    --lineup-add-button-height: 60px;
    --lineup-add-open-width: 189px;
    right: max(16px, env(safe-area-inset-right, 0px)) !important;
  }

  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) {
    right: max(16px, env(safe-area-inset-right, 0px)) !important;
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (min-height: 521px) and (orientation: landscape) {
  :root.tablet-touch-layout .lineup-add-actions.is-open:not([hidden]) {
    --lineup-add-button-width: 76px;
    --lineup-add-button-height: 60px;
    grid-template-columns: var(--lineup-add-button-width) !important;
    grid-template-rows: repeat(2, var(--lineup-add-button-height)) !important;
    grid-auto-flow: row !important;
    width: 104px !important;
    min-width: 104px !important;
    max-width: 104px !important;
    height: 154px !important;
    min-height: 154px !important;
    max-height: 154px !important;
    padding: 12px 12px !important;
    gap: 10px !important;
  }

  :root.tablet-touch-layout .lineup-add-actions.is-open:not([hidden]) .lineup-add-actions-tab {
    left: -44px !important;
    width: 36px !important;
    min-width: 36px !important;
    max-width: 36px !important;
    height: 66px !important;
    min-height: 66px !important;
    max-height: 66px !important;
  }

  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) {
    width: 38px !important;
    min-width: 38px !important;
    max-width: 38px !important;
    height: 78px !important;
    min-height: 78px !important;
    max-height: 78px !important;
  }
}

/* v362: phone filter buttons stay visible, and mouse users can peek the Slide/Note tray by hovering the plus. */
@media (max-width: 760px),
  (max-height: 520px) and (orientation: landscape) {
  .category-filters:not([hidden]) {
    display: grid !important;
    max-height: none !important;
    margin-bottom: 8px !important;
    overflow: visible !important;
  }

  .category-filters:not([hidden]) .filter-options {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    gap: 5px !important;
    min-width: 0 !important;
    padding: 4px !important;
  }

  .category-filters:not([hidden]) .filter-chip,
  .category-filters:not([hidden]) .hebrew-filter,
  .category-filters:not([hidden]) .banger-filter {
    display: inline-grid !important;
    place-items: center !important;
    flex: 0 0 auto !important;
    min-width: 42px !important;
    min-height: 32px !important;
    max-width: none !important;
    padding: 0 10px !important;
    overflow: visible !important;
    font-size: 0.76rem !important;
    text-overflow: clip !important;
  }

  .category-filters:not([hidden]) .filter-chip {
    min-width: 86px !important;
  }
}

@media (hover: hover) and (pointer: fine) {
  .lineup-add-actions:not([hidden]) {
    z-index: 82 !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]):hover,
  .lineup-add-actions:not(.is-open):not([hidden]):focus-within {
    display: grid !important;
    grid-template-columns: repeat(2, var(--lineup-add-button-width)) !important;
    grid-auto-flow: column !important;
    align-items: end !important;
    justify-content: center !important;
    gap: var(--lineup-add-tray-gap) !important;
    width: var(--lineup-add-open-width) !important;
    min-width: var(--lineup-add-open-width) !important;
    max-width: var(--lineup-add-open-width) !important;
    height: 104px !important;
    min-height: 104px !important;
    max-height: 104px !important;
    padding: 36px 14px 10px !important;
    opacity: 1 !important;
    transform: translateY(0) !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]):hover .icon-button,
  .lineup-add-actions:not(.is-open):not([hidden]):hover #addNoteButton,
  .lineup-add-actions:not(.is-open):not([hidden]):focus-within .icon-button,
  .lineup-add-actions:not(.is-open):not([hidden]):focus-within #addNoteButton {
    pointer-events: auto !important;
  }
}

.guest-mode-notice {
  pointer-events: none;
}

.guest-mode-notice button {
  pointer-events: auto;
}

/* v363: Song Bank controls order, visible Setlists button, Hebrew active state, and real hover-open add tray. */
.bank-title-actions .song-bank-setlists-button {
  color: var(--accent);
}

.bank-title-actions .song-bank-setlists-button.active,
.bank-title-actions .song-bank-setlists-button[aria-pressed="true"] {
  border-color: color-mix(in srgb, var(--accent) 62%, var(--line));
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--accent) 28%, transparent), color-mix(in srgb, var(--accent) 13%, transparent)),
    color-mix(in srgb, var(--accent) 18%, var(--panel-2));
  color: #ffffff;
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--accent) 24%, transparent),
    0 10px 22px color-mix(in srgb, var(--accent) 14%, transparent);
}

.quick-add-menu-item .manage-close-icon {
  display: none;
}

.quick-add-menu-item.active .manage-open-icon,
.quick-add-menu-item[aria-pressed="true"] .manage-open-icon {
  display: none;
}

.quick-add-menu-item.active .manage-close-icon,
.quick-add-menu-item[aria-pressed="true"] .manage-close-icon {
  display: block;
}

.category-filters:not([hidden]) .hebrew-filter.active,
.category-filters:not([hidden]) .hebrew-filter[aria-pressed="true"],
.hebrew-filter.active,
.hebrew-filter[aria-pressed="true"] {
  border-color: color-mix(in srgb, var(--accent) 68%, var(--line)) !important;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--accent) 32%, transparent), color-mix(in srgb, var(--accent) 16%, transparent)),
    var(--accent) !important;
  color: #ffffff !important;
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--accent) 28%, transparent),
    0 8px 18px color-mix(in srgb, var(--accent) 18%, transparent) !important;
}

@media (hover: hover) and (pointer: fine) {
  .lineup-add-actions:not([hidden]) {
    cursor: default;
  }

  .lineup-add-actions:not([hidden]):hover {
    z-index: 92 !important;
  }
}

/* v364: logged-in release polish for mobile history controls and the compact Slide/Note tray. */
.lineup-add-actions-tab .add-tray-mini-icons {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  line-height: 0;
}

.lineup-add-actions-tab .add-tray-mini-icons svg {
  display: block !important;
  width: 14px !important;
  height: 14px !important;
  fill: none;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 2.2;
}

.lineup-add-actions-tab .add-tray-mini-slide {
  color: var(--green);
}

.lineup-add-actions-tab .add-tray-mini-note {
  color: var(--amber);
}

@media (min-width: 1024px) and (hover: hover) and (pointer: fine) {
  .lineup-heading .note-heading {
    transform: translateX(-7px) !important;
  }
}

@media (max-width: 760px) {
  .show-header {
    grid-template-columns: minmax(0, 1fr) 72px !important;
    column-gap: 6px !important;
    align-items: start !important;
  }

  .show-tools {
    width: 72px !important;
    align-items: flex-end !important;
  }

  .header-actions {
    display: grid !important;
    grid-template-columns: repeat(2, 34px) !important;
    grid-template-rows: 34px 24px !important;
    align-items: stretch !important;
    justify-content: end !important;
    gap: 4px !important;
    width: 72px !important;
    overflow: visible !important;
  }

  .header-menu {
    grid-column: 1 !important;
    grid-row: 1 !important;
    width: 34px !important;
    min-width: 34px !important;
    height: 34px !important;
    min-height: 34px !important;
  }

  .header-actions > #exportButton {
    grid-column: 2 !important;
    grid-row: 1 !important;
  }

  .header-actions > #undoLineupButton {
    grid-column: 1 !important;
    grid-row: 2 !important;
  }

  .header-actions > #redoLineupButton {
    grid-column: 2 !important;
    grid-row: 2 !important;
  }

  .header-actions > #exportButton,
  .header-menu summary {
    display: inline-grid !important;
    width: 34px !important;
    min-width: 34px !important;
    height: 34px !important;
    min-height: 34px !important;
    border-radius: 9px !important;
  }

  .header-actions > .history-button {
    display: inline-grid !important;
    width: 34px !important;
    min-width: 34px !important;
    height: 24px !important;
    min-height: 24px !important;
    border-radius: 8px !important;
    padding: 0 !important;
  }

  .header-actions > .history-button svg {
    width: 14px !important;
    height: 14px !important;
  }
}

@media (max-width: 760px) and (orientation: portrait),
  (min-width: 761px) and (max-width: 1366px) and (orientation: portrait) {
  .lineup-add-actions:not([hidden]),
  :root.tablet-touch-layout .lineup-add-actions:not([hidden]) {
    --lineup-add-button-width: 64px;
    --lineup-add-button-height: 54px;
    --lineup-add-open-width: 150px;
    right: max(14px, env(safe-area-inset-right, 0px)) !important;
    bottom: max(
      env(safe-area-inset-bottom, 0px),
      calc(var(--lineup-add-actions-bottom, var(--mobile-library-height, var(--lineup-add-bar-bank-height, var(--tablet-bank-height, 0px)))) + 10px)
    ) !important;
  }

  .lineup-add-actions.is-open:not([hidden]),
  :root.tablet-touch-layout .lineup-add-actions.is-open:not([hidden]) {
    width: var(--lineup-add-open-width) !important;
    min-width: var(--lineup-add-open-width) !important;
    max-width: var(--lineup-add-open-width) !important;
    height: 94px !important;
    min-height: 94px !important;
    max-height: 94px !important;
    padding: 32px 10px 8px !important;
    gap: 8px !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]),
  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) {
    width: 58px !important;
    min-width: 58px !important;
    max-width: 58px !important;
    height: 28px !important;
    min-height: 28px !important;
    max-height: 28px !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab,
  .lineup-add-actions.is-open:not([hidden]) .lineup-add-actions-tab,
  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab,
  :root.tablet-touch-layout .lineup-add-actions.is-open:not([hidden]) .lineup-add-actions-tab {
    width: 58px !important;
    min-width: 58px !important;
    max-width: 58px !important;
    height: 28px !important;
    min-height: 28px !important;
    max-height: 28px !important;
  }

  .lineup-add-actions .icon-button,
  .lineup-add-actions #addNoteButton,
  :root.tablet-touch-layout .lineup-add-actions .icon-button,
  :root.tablet-touch-layout .lineup-add-actions #addNoteButton {
    grid-template-rows: 25px 12px !important;
    width: var(--lineup-add-button-width) !important;
    min-width: var(--lineup-add-button-width) !important;
    max-width: var(--lineup-add-button-width) !important;
    height: var(--lineup-add-button-height) !important;
    min-height: var(--lineup-add-button-height) !important;
    max-height: var(--lineup-add-button-height) !important;
    padding: 5px 5px 4px !important;
    font-size: 0.62rem !important;
  }

  .lineup-add-actions .icon-button .add-action-icon-stack,
  .lineup-add-actions #addNoteButton .add-action-icon-stack,
  :root.tablet-touch-layout .lineup-add-actions .icon-button .add-action-icon-stack,
  :root.tablet-touch-layout .lineup-add-actions #addNoteButton .add-action-icon-stack {
    width: 25px !important;
    min-width: 25px !important;
    max-width: 25px !important;
    height: 24px !important;
    min-height: 24px !important;
    max-height: 24px !important;
  }

  .lineup-add-actions .lineup-add-slide-button .add-action-main-icon,
  .lineup-add-actions .library-add-note-button .add-action-main-icon,
  .lineup-add-actions #addNoteButton .add-action-main-icon,
  :root.tablet-touch-layout .lineup-add-actions .lineup-add-slide-button .add-action-main-icon,
  :root.tablet-touch-layout .lineup-add-actions .library-add-note-button .add-action-main-icon,
  :root.tablet-touch-layout .lineup-add-actions #addNoteButton .add-action-main-icon {
    width: 18px !important;
    min-width: 18px !important;
    max-width: 18px !important;
    height: 18px !important;
    min-height: 18px !important;
    max-height: 18px !important;
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (min-height: 521px) and (orientation: landscape) {
  :root.tablet-touch-layout .lineup-add-actions:not([hidden]) {
    --lineup-add-button-width: 68px;
    --lineup-add-button-height: 54px;
  }

  :root.tablet-touch-layout .lineup-add-actions.is-open:not([hidden]) {
    width: 92px !important;
    min-width: 92px !important;
    max-width: 92px !important;
    height: 132px !important;
    min-height: 132px !important;
    max-height: 132px !important;
    padding: 10px !important;
    gap: 8px !important;
  }

  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) {
    width: 34px !important;
    min-width: 34px !important;
    max-width: 34px !important;
    height: 58px !important;
    min-height: 58px !important;
    max-height: 58px !important;
  }

  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab,
  :root.tablet-touch-layout .lineup-add-actions.is-open:not([hidden]) .lineup-add-actions-tab {
    width: 32px !important;
    min-width: 32px !important;
    max-width: 32px !important;
    height: 58px !important;
    min-height: 58px !important;
    max-height: 58px !important;
  }

  :root.tablet-touch-layout .lineup-add-actions.is-open:not([hidden]) .lineup-add-actions-tab {
    left: -40px !important;
  }

  :root.tablet-touch-layout .lineup-add-actions-tab .add-tray-mini-icons {
    flex-direction: column;
    gap: 3px;
  }
}

/* v366: iPad print preview uses the rendered export page while preserving export proportions. */
.saved-shows-list,
.saved-show-chip,
.saved-show-chip *,
.setlist-folder-header,
.setlist-folder-header * {
  -webkit-user-select: none !important;
  user-select: none !important;
}

.saved-show-chip {
  -webkit-touch-callout: none;
}

/* v367: desktop window drag strip and unified zooming Slide/Note tray. */
.desktop-window-drag-strip {
  display: none;
}

body.desktop-app-shell .desktop-window-drag-strip {
  position: fixed;
  top: 0;
  right: 0;
  left: 0;
  z-index: 10000;
  display: block;
  height: 22px;
  -webkit-app-region: drag;
}

body.desktop-app-shell .show-header,
body.desktop-app-shell .bank-header {
  -webkit-app-region: drag;
}

body.desktop-app-shell button,
body.desktop-app-shell input,
body.desktop-app-shell select,
body.desktop-app-shell textarea,
body.desktop-app-shell a,
body.desktop-app-shell summary,
body.desktop-app-shell details,
body.desktop-app-shell .lineup-row,
body.desktop-app-shell .bank-song,
body.desktop-app-shell .lineup-rows,
body.desktop-app-shell .song-bank-list,
body.desktop-app-shell .lineup-table,
body.desktop-app-shell .panel-resizer,
body.desktop-app-shell [role="button"],
body.desktop-app-shell dialog {
  -webkit-app-region: no-drag;
}

.lineup-add-actions:not([hidden]) {
  --lineup-add-open-height: 104px;
  --lineup-add-closed-scale: 0.54;
  transform-origin: right bottom !important;
  transition:
    transform 190ms cubic-bezier(0.2, 0.9, 0.2, 1),
    opacity 160ms ease,
    filter 190ms ease !important;
  will-change: transform;
}

.lineup-add-actions:not(.is-open):not([hidden]) {
  display: grid !important;
  grid-template-columns: repeat(2, var(--lineup-add-button-width)) !important;
  grid-auto-flow: column !important;
  align-items: end !important;
  justify-content: center !important;
  gap: var(--lineup-add-tray-gap) !important;
  width: var(--lineup-add-open-width) !important;
  min-width: var(--lineup-add-open-width) !important;
  max-width: var(--lineup-add-open-width) !important;
  height: var(--lineup-add-open-height) !important;
  min-height: var(--lineup-add-open-height) !important;
  max-height: var(--lineup-add-open-height) !important;
  padding: 36px 14px 10px !important;
  clip-path: none !important;
  overflow: visible !important;
  opacity: 0.94 !important;
  transform: scale(var(--lineup-add-closed-scale)) !important;
}

.lineup-add-actions.is-open:not([hidden]),
.lineup-add-actions:not(.is-open):not([hidden]):hover,
.lineup-add-actions:not(.is-open):not([hidden]):focus-within {
  opacity: 1 !important;
  transform: scale(1) !important;
}

.lineup-add-actions:not(.is-open):not([hidden]) .icon-button,
.lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .icon-button,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton {
  display: grid !important;
  pointer-events: none !important;
}

.lineup-add-actions.is-open .icon-button,
.lineup-add-actions.is-open #addNoteButton {
  pointer-events: auto !important;
}

.lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab {
  top: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  left: 0 !important;
  z-index: 8 !important;
  width: 100% !important;
  min-width: 100% !important;
  max-width: 100% !important;
  height: 100% !important;
  min-height: 100% !important;
  max-height: 100% !important;
  border: 0 !important;
  border-radius: inherit !important;
  background: transparent !important;
  box-shadow: none !important;
  opacity: 0 !important;
  transform: none !important;
}

.lineup-add-actions-tab .add-tray-mini-icons {
  display: none !important;
}

@media (max-width: 760px) and (orientation: portrait),
  (min-width: 761px) and (max-width: 1366px) and (orientation: portrait) {
  .lineup-add-actions:not([hidden]),
  :root.tablet-touch-layout .lineup-add-actions:not([hidden]) {
    --lineup-add-open-height: 94px;
    --lineup-add-closed-scale: 0.42;
  }

  .lineup-add-actions:not(.is-open):not([hidden]),
  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) {
    width: var(--lineup-add-open-width) !important;
    min-width: var(--lineup-add-open-width) !important;
    max-width: var(--lineup-add-open-width) !important;
    height: var(--lineup-add-open-height) !important;
    min-height: var(--lineup-add-open-height) !important;
    max-height: var(--lineup-add-open-height) !important;
    padding: 32px 10px 8px !important;
    gap: 8px !important;
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (min-height: 521px) and (orientation: landscape) {
  :root.tablet-touch-layout .lineup-add-actions:not([hidden]) {
    --lineup-add-open-height: 132px;
    --lineup-add-closed-scale: 0.48;
  }

  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) {
    display: grid !important;
    grid-template-columns: var(--lineup-add-button-width) !important;
    grid-template-rows: repeat(2, var(--lineup-add-button-height)) !important;
    grid-auto-flow: row !important;
    width: 92px !important;
    min-width: 92px !important;
    max-width: 92px !important;
    height: var(--lineup-add-open-height) !important;
    min-height: var(--lineup-add-open-height) !important;
    max-height: var(--lineup-add-open-height) !important;
    padding: 10px !important;
    gap: 8px !important;
    transform-origin: right bottom !important;
  }
}

.saved-show-chip.selected {
  border-color: color-mix(in srgb, var(--green) 68%, var(--line));
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--green) 16%, transparent), transparent 70%),
    color-mix(in srgb, var(--green) 9%, var(--panel-2));
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--green) 18%, transparent),
    0 8px 18px color-mix(in srgb, var(--green) 10%, transparent);
}

.saved-show-chip.long-press-ready {
  border-color: color-mix(in srgb, var(--amber) 62%, var(--line));
}

body.is-pointer-dragging[data-pointer-drag-type="setlist"] .saved-shows-list,
body.is-pointer-dragging[data-pointer-drag-type="setlist"] .saved-show-chip,
body.is-pointer-dragging[data-pointer-drag-type="setlist"] .setlist-folder-section {
  cursor: grabbing;
  -webkit-user-select: none !important;
  user-select: none !important;
}

body.is-pointer-dragging[data-pointer-drag-type="setlist"] .saved-show-open {
  pointer-events: none;
}

/* v368: closed Slide/Note tray is a clear miniature of the expanded controls. */
.lineup-add-actions:not([hidden]),
:root.tablet-touch-layout .lineup-add-actions:not([hidden]) {
  --lineup-add-mini-width: 136px;
  --lineup-add-mini-height: 56px;
  --lineup-add-mini-button-width: 62px;
  --lineup-add-mini-button-height: 44px;
  transform: none !important;
  transform-origin: right bottom !important;
  transition:
    width 190ms cubic-bezier(0.2, 0.9, 0.2, 1),
    height 190ms cubic-bezier(0.2, 0.9, 0.2, 1),
    padding 190ms cubic-bezier(0.2, 0.9, 0.2, 1),
    opacity 160ms ease,
    filter 190ms ease !important;
}

.lineup-add-actions:not(.is-open):not([hidden]),
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) {
  display: grid !important;
  grid-template-columns: repeat(2, var(--lineup-add-mini-button-width)) !important;
  grid-template-rows: var(--lineup-add-mini-button-height) !important;
  grid-auto-flow: column !important;
  align-items: center !important;
  justify-content: center !important;
  width: var(--lineup-add-mini-width) !important;
  min-width: var(--lineup-add-mini-width) !important;
  max-width: var(--lineup-add-mini-width) !important;
  height: var(--lineup-add-mini-height) !important;
  min-height: var(--lineup-add-mini-height) !important;
  max-height: var(--lineup-add-mini-height) !important;
  padding: 6px !important;
  gap: 6px !important;
  overflow: hidden !important;
  clip-path: none !important;
  opacity: 0.96 !important;
  transform: none !important;
}

.lineup-add-actions.is-open:not([hidden]),
.lineup-add-actions:not(.is-open):not([hidden]):hover,
.lineup-add-actions:not(.is-open):not([hidden]):focus-within,
:root.tablet-touch-layout .lineup-add-actions.is-open:not([hidden]),
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]):hover,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]):focus-within {
  width: var(--lineup-add-open-width) !important;
  min-width: var(--lineup-add-open-width) !important;
  max-width: var(--lineup-add-open-width) !important;
  height: var(--lineup-add-open-height) !important;
  min-height: var(--lineup-add-open-height) !important;
  max-height: var(--lineup-add-open-height) !important;
  padding: 12px !important;
  opacity: 1 !important;
  transform: none !important;
}

.lineup-add-actions:not(.is-open):not([hidden]) .icon-button,
.lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .icon-button,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton {
  display: grid !important;
  width: var(--lineup-add-mini-button-width) !important;
  min-width: var(--lineup-add-mini-button-width) !important;
  max-width: var(--lineup-add-mini-button-width) !important;
  height: var(--lineup-add-mini-button-height) !important;
  min-height: var(--lineup-add-mini-button-height) !important;
  max-height: var(--lineup-add-mini-button-height) !important;
  padding: 4px 5px !important;
  gap: 2px !important;
  border-radius: 12px !important;
  font-size: 0.58rem !important;
  line-height: 1 !important;
  pointer-events: none !important;
  opacity: 1 !important;
}

.lineup-add-actions:not(.is-open):not([hidden]) .icon-button span,
.lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton span,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .icon-button span,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton span {
  display: block !important;
  font-size: 0.58rem !important;
}

.lineup-add-actions:not(.is-open):not([hidden]) .icon-button .add-action-icon-stack,
.lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton .add-action-icon-stack,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .icon-button .add-action-icon-stack,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton .add-action-icon-stack {
  width: 23px !important;
  height: 20px !important;
}

.lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-slide-button .add-action-main-icon,
.lineup-add-actions:not(.is-open):not([hidden]) .library-add-note-button .add-action-main-icon,
.lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton .add-action-main-icon,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-slide-button .add-action-main-icon,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .library-add-note-button .add-action-main-icon,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton .add-action-main-icon {
  width: 19px !important;
  height: 19px !important;
}

.lineup-add-actions:not(.is-open):not([hidden]) .add-action-plus-icon,
.lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton .note-plus-icon,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .add-action-plus-icon,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton .note-plus-icon {
  width: 9px !important;
  height: 9px !important;
}

.lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab {
  top: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  left: 0 !important;
  width: 100% !important;
  height: 100% !important;
  opacity: 0 !important;
  pointer-events: auto !important;
  background: transparent !important;
  box-shadow: none !important;
  border: 0 !important;
}

.lineup-add-actions.is-open .lineup-add-actions-tab,
:root.tablet-touch-layout .lineup-add-actions.is-open .lineup-add-actions-tab {
  opacity: 0 !important;
  pointer-events: none !important;
}

.lineup-add-actions.is-open .icon-button,
.lineup-add-actions.is-open #addNoteButton,
:root.tablet-touch-layout .lineup-add-actions.is-open .icon-button,
:root.tablet-touch-layout .lineup-add-actions.is-open #addNoteButton {
  pointer-events: auto !important;
}

@media (max-width: 760px) and (orientation: portrait),
  (min-width: 761px) and (max-width: 1366px) and (orientation: portrait) {
  .lineup-add-actions:not([hidden]),
  :root.tablet-touch-layout .lineup-add-actions:not([hidden]) {
    --lineup-add-mini-width: 118px;
    --lineup-add-mini-height: 50px;
    --lineup-add-mini-button-width: 53px;
    --lineup-add-mini-button-height: 39px;
    --lineup-add-open-height: 94px;
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (min-height: 521px) and (orientation: landscape) {
  :root.tablet-touch-layout .lineup-add-actions:not([hidden]) {
    --lineup-add-mini-width: 64px;
    --lineup-add-mini-height: 100px;
    --lineup-add-mini-button-width: 52px;
    --lineup-add-mini-button-height: 42px;
    --lineup-add-open-height: 132px;
  }

  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) {
    grid-template-columns: var(--lineup-add-mini-button-width) !important;
    grid-template-rows: repeat(2, var(--lineup-add-mini-button-height)) !important;
    grid-auto-flow: row !important;
  }
}

@media (pointer: coarse) {
  .saved-show-chip,
  .saved-show-chip *,
  .setlist-folder-header,
  .setlist-folder-header * {
    -webkit-user-drag: none;
  }

  .saved-show-chip {
    touch-action: pan-y;
  }
}

/* v369: tighter Slide/Note tray, editable slide objects, and compact slide export controls. */
.lineup-add-actions:not([hidden]),
:root.tablet-touch-layout .lineup-add-actions:not([hidden]) {
  --lineup-add-mini-button-width: 55px;
  --lineup-add-mini-button-height: 38px;
  --lineup-add-open-height: 86px;
  --lineup-add-button-height: 58px;
}

.lineup-add-actions.is-open:not([hidden]),
.lineup-add-actions:not(.is-open):not([hidden]):hover,
.lineup-add-actions:not(.is-open):not([hidden]):focus-within,
:root.tablet-touch-layout .lineup-add-actions.is-open:not([hidden]),
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]):hover,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]):focus-within {
  padding: 10px !important;
  gap: 8px !important;
}

.lineup-add-actions:not(.is-open):not([hidden]),
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) {
  align-items: center !important;
  padding: 7px 8px !important;
  gap: 8px !important;
}

.lineup-add-actions:not(.is-open):not([hidden]) .icon-button,
.lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .icon-button,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton {
  grid-template-rows: 19px 11px !important;
  place-items: center !important;
  padding: 4px 4px 3px !important;
  gap: 1px !important;
  border-radius: 11px !important;
  font-size: 0.52rem !important;
  overflow: hidden !important;
}

.lineup-add-actions:not(.is-open):not([hidden]) .icon-button span,
.lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton span,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .icon-button span,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton span {
  max-width: 100% !important;
  overflow: hidden !important;
  font-size: 0.52rem !important;
  line-height: 1 !important;
  text-overflow: clip !important;
  white-space: nowrap !important;
}

.lineup-add-actions:not(.is-open):not([hidden]) .icon-button .add-action-icon-stack,
.lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton .add-action-icon-stack,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .icon-button .add-action-icon-stack,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton .add-action-icon-stack {
  width: 19px !important;
  height: 18px !important;
}

.lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-slide-button .add-action-main-icon,
.lineup-add-actions:not(.is-open):not([hidden]) .library-add-note-button .add-action-main-icon,
.lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton .add-action-main-icon,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-slide-button .add-action-main-icon,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .library-add-note-button .add-action-main-icon,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton .add-action-main-icon {
  width: 16px !important;
  height: 16px !important;
}

.lineup-add-actions:not(.is-open):not([hidden]) .add-action-plus-icon,
.lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton .note-plus-icon,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .add-action-plus-icon,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton .note-plus-icon {
  width: 7px !important;
  height: 7px !important;
}

@media (max-width: 760px) and (orientation: portrait),
  (min-width: 761px) and (max-width: 1366px) and (orientation: portrait) {
  .lineup-add-actions:not([hidden]),
  :root.tablet-touch-layout .lineup-add-actions:not([hidden]) {
    --lineup-add-mini-button-width: 48px;
    --lineup-add-mini-button-height: 34px;
    --lineup-add-open-height: 82px;
    --lineup-add-button-height: 50px;
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (min-height: 521px) and (orientation: landscape) {
  :root.tablet-touch-layout .lineup-add-actions:not([hidden]) {
    --lineup-add-mini-button-width: 48px;
    --lineup-add-mini-button-height: 38px;
    --lineup-add-open-height: 116px;
    --lineup-add-button-height: 50px;
  }
}

.slides-live-preview.rendered-slide-editor-preview {
  isolation: isolate;
}

.slides-editor-object-layer {
  position: absolute;
  inset: 0;
  z-index: 4;
  overflow: hidden;
  pointer-events: none;
}

.slides-editor-object {
  position: absolute;
  display: grid;
  min-width: 18px;
  min-height: 18px;
  border: 1px solid transparent;
  border-radius: 8px;
  cursor: move;
  pointer-events: auto;
  touch-action: none;
  user-select: none;
}

.slides-editor-object.selected {
  border-color: color-mix(in srgb, var(--green) 86%, white);
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--green) 32%, transparent),
    0 10px 28px rgba(0, 0, 0, 0.2);
}

.slides-editor-object-image {
  width: 100%;
  height: 100%;
  border-radius: inherit;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}

.slides-editor-object-text {
  display: grid;
  align-content: center;
  width: 100%;
  height: 100%;
  min-width: 0;
  min-height: 0;
  overflow: hidden;
  padding: 4px;
  border-radius: inherit;
  text-shadow: 0 2px 12px rgba(0, 0, 0, 0.48);
  outline: none;
  white-space: pre-wrap;
}

.slides-editor-object.text.selected .slides-editor-object-text {
  background: rgba(2, 6, 23, 0.2);
}

.slides-editor-object-handle {
  position: absolute;
  right: -5px;
  bottom: -5px;
  width: 13px;
  height: 13px;
  border: 2px solid var(--green);
  border-radius: 999px;
  background: var(--panel);
  box-shadow: 0 0 0 2px rgba(2, 6, 23, 0.58);
  cursor: nwse-resize;
}

.slides-editor-object-move {
  position: absolute;
  top: -7px;
  left: -7px;
  display: grid;
  width: 16px;
  height: 16px;
  place-items: center;
  border: 2px solid var(--green);
  border-radius: 999px;
  background: var(--panel);
  box-shadow: 0 0 0 2px rgba(2, 6, 23, 0.58);
  cursor: move;
  opacity: 0;
}

.slides-editor-object:hover .slides-editor-object-move,
.slides-editor-object.selected .slides-editor-object-move {
  opacity: 1;
}

.slides-editor-object-move::before {
  content: "";
  width: 6px;
  height: 6px;
  border-top: 2px solid currentColor;
  border-left: 2px solid currentColor;
  transform: rotate(45deg);
}

.slides-object-panel {
  display: grid;
  gap: 8px;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 9px;
  background: rgba(255, 255, 255, 0.025);
}

.slides-object-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.slides-object-toolbar .ghost-button,
.slides-object-toolbar .danger-button {
  min-height: 32px;
  padding: 0 9px;
  border-radius: 9px;
  font-size: 0.72rem;
}

.slides-object-inspector {
  display: grid;
  gap: 7px;
}

.slides-object-inspector label {
  display: grid;
  gap: 3px;
}

.slides-object-inspector span {
  color: var(--muted);
  font-size: 0.66rem;
  font-weight: 850;
  text-transform: uppercase;
}

#slidesExportDialog {
  width: min(980px, calc(100vw - 24px));
}

#slidesExportForm {
  gap: 10px;
}

#slidesExportForm .utility-copy,
.slides-background-dialog .utility-copy {
  margin: -2px 0 0;
  font-size: 0.88rem;
  line-height: 1.25;
}

#slidesExportForm .dialog-header {
  margin-bottom: 0;
}

#slidesExportForm .theme-export-grid {
  gap: 8px;
}

#slidesExportForm .theme-export-card {
  min-height: 58px;
  border-radius: 10px;
  padding: 8px 10px;
}

#slidesExportForm .theme-export-card strong {
  font-size: 0.84rem;
  line-height: 1;
}

#slidesExportForm .theme-export-card small {
  font-size: 0.67rem;
  line-height: 1.1;
}

.theme-export-card.color {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
}

.theme-export-card.color input[type="color"] {
  position: static;
  width: 38px;
  height: 34px;
  border: 1px solid var(--line);
  border-radius: 9px;
  padding: 3px;
  opacity: 1;
  background: var(--panel-2);
}

.slides-theme-export-layout {
  gap: 10px;
}

.slides-theme-controls {
  gap: 9px;
}

.slide-export-options {
  grid-template-columns: minmax(132px, 1.1fr) minmax(98px, 0.8fr) minmax(92px, 0.74fr) auto auto;
  gap: 7px;
}

.slide-title-mode-control,
.slide-title-numbers-control,
.slide-title-size-control {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.slide-title-mode-control span,
.slide-title-numbers-control span,
.slide-title-size-control span {
  color: var(--muted);
  font-size: 0.64rem;
  font-weight: 850;
  text-transform: uppercase;
}

.slide-title-mode-control select,
.slide-title-numbers-control input,
.slide-title-size-control select {
  min-height: 34px;
  border-radius: 9px;
  font-size: 0.78rem;
}

.slide-title-option {
  min-height: 34px;
  border-radius: 9px;
  padding: 7px 9px;
  font-size: 0.76rem;
}

.slide-title-option input {
  width: 16px;
  height: 16px;
}

.slides-export-preview-shell {
  display: grid;
  gap: 8px;
  min-width: 0;
}

.slides-export-jump-control {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 7px;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 850;
}

.slides-export-jump-control input {
  width: 74px;
  min-height: 32px;
  border-radius: 9px;
  text-align: center;
}

.slides-background-dialog {
  width: min(520px, calc(100vw - 24px));
}

.slides-background-dialog form {
  gap: 10px;
}

.slides-background-settings {
  gap: 9px;
}

.slides-background-settings > label:not(.text-color-control) {
  display: grid;
  gap: 4px;
}

.slides-background-settings input[type="file"] {
  min-height: 38px;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 7px 9px;
  background: rgba(255, 255, 255, 0.035);
}

.theme-preset-row .icon-only-button {
  width: 38px;
  height: 38px;
}

.text-color-control {
  grid-template-columns: auto 44px;
  justify-content: space-between;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 8px 10px;
  background: rgba(255, 255, 255, 0.025);
}

.text-color-control input[type="color"] {
  width: 40px;
  height: 34px;
  border-radius: 9px;
}

.theme-crop-controls {
  gap: 6px;
  border-radius: 10px;
  padding: 8px;
}

.theme-image-actions {
  gap: 7px;
}

.theme-image-actions .ghost-button {
  min-height: 38px;
  border-radius: 10px;
}

@media (max-width: 760px) {
  #slidesExportDialog,
  .slides-background-dialog {
    width: min(100vw - 14px, 560px);
  }

  .slides-theme-export-layout {
    grid-template-columns: 1fr;
  }

  .slide-export-options {
    grid-template-columns: 1fr 1fr;
  }

  .slide-title-mode-control {
    grid-column: 1 / -1;
  }
}

/* v370: cleaner export slide tab and smaller collapsed Slide/Note tray. */
#exportSlidesPanel #slidesExportForm {
  overflow: hidden;
}

#exportSlidesPanel .slides-theme-export-layout {
  grid-template-columns: 1fr !important;
  gap: 10px;
  min-width: 0;
  overflow: auto;
  padding-right: 2px;
}

#exportSlidesPanel .slides-theme-controls {
  overflow: visible;
  padding-right: 0;
}

#exportSlidesPanel .theme-export-grid {
  grid-template-columns: repeat(auto-fit, minmax(168px, 1fr));
  gap: 8px;
}

#exportSlidesPanel .theme-export-card {
  min-width: 0;
}

#exportSlidesPanel .theme-export-card.color {
  min-height: 58px;
}

.theme-export-card.color input[type="color"] {
  cursor: pointer;
}

.theme-export-card.color.is-color-selected input[type="color"],
.theme-export-card.color:has(input[type="radio"]:checked) input[type="color"] {
  border-color: color-mix(in srgb, var(--green) 72%, white);
  box-shadow: 0 0 0 2px rgba(91, 146, 255, 0.22);
}

#exportSlidesPanel .slide-export-options {
  grid-template-columns: repeat(auto-fit, minmax(132px, 1fr)) !important;
  align-items: end;
  overflow: visible;
}

#exportSlidesPanel .slide-title-mode-control,
#exportSlidesPanel .slide-title-numbers-control,
#exportSlidesPanel .slide-title-size-control {
  min-width: 0;
}

#exportSlidesPanel .slide-title-mode-control select,
#exportSlidesPanel .slide-title-numbers-control input,
#exportSlidesPanel .slide-title-size-control select {
  width: 100%;
  min-width: 0;
}

#exportSlidesPanel .slide-title-option {
  align-self: end;
  justify-content: center;
}

#exportSlidesPanel .slides-export-preview-shell {
  width: min(100%, 760px);
  justify-self: center;
}

#exportSlidesPanel .slides-theme-preview {
  min-height: clamp(240px, 42dvh, 540px);
}

.lineup-add-actions:not([hidden]),
:root.tablet-touch-layout .lineup-add-actions:not([hidden]) {
  --lineup-add-mini-width: 88px;
  --lineup-add-mini-height: 48px;
  --lineup-add-mini-button-width: 34px;
  --lineup-add-mini-button-height: 34px;
  --lineup-add-open-height: 82px;
  --lineup-add-button-height: 56px;
}

.lineup-add-actions:not(.is-open):not([hidden]),
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) {
  width: var(--lineup-add-mini-width) !important;
  min-width: var(--lineup-add-mini-width) !important;
  max-width: var(--lineup-add-mini-width) !important;
  height: var(--lineup-add-mini-height) !important;
  min-height: var(--lineup-add-mini-height) !important;
  max-height: var(--lineup-add-mini-height) !important;
  grid-template-columns: repeat(2, var(--lineup-add-mini-button-width)) !important;
  grid-template-rows: var(--lineup-add-mini-button-height) !important;
  padding: 6px 7px !important;
  gap: 6px !important;
  border-radius: 18px !important;
}

.lineup-add-actions:not(.is-open):not([hidden]) .icon-button,
.lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .icon-button,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton {
  width: var(--lineup-add-mini-button-width) !important;
  min-width: var(--lineup-add-mini-button-width) !important;
  max-width: var(--lineup-add-mini-button-width) !important;
  height: var(--lineup-add-mini-button-height) !important;
  min-height: var(--lineup-add-mini-button-height) !important;
  max-height: var(--lineup-add-mini-button-height) !important;
  grid-template-rows: 1fr !important;
  padding: 4px !important;
  gap: 0 !important;
  border-radius: 12px !important;
}

.lineup-add-actions:not(.is-open):not([hidden]) .icon-button span,
.lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton span,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .icon-button span,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton span {
  display: none !important;
}

.lineup-add-actions:not(.is-open):not([hidden]) .icon-button .add-action-icon-stack,
.lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton .add-action-icon-stack,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .icon-button .add-action-icon-stack,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton .add-action-icon-stack {
  width: 23px !important;
  height: 23px !important;
}

.lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-slide-button .add-action-main-icon,
.lineup-add-actions:not(.is-open):not([hidden]) .library-add-note-button .add-action-main-icon,
.lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton .add-action-main-icon,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-slide-button .add-action-main-icon,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .library-add-note-button .add-action-main-icon,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton .add-action-main-icon {
  width: 20px !important;
  height: 20px !important;
}

.lineup-add-actions:not(.is-open):not([hidden]) .add-action-plus-icon,
.lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton .note-plus-icon,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .add-action-plus-icon,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton .note-plus-icon {
  display: none !important;
}

@media (max-width: 760px) and (orientation: portrait),
  (min-width: 761px) and (max-width: 1366px) and (orientation: portrait) {
  .lineup-add-actions:not([hidden]),
  :root.tablet-touch-layout .lineup-add-actions:not([hidden]) {
    --lineup-add-mini-width: 76px;
    --lineup-add-mini-height: 42px;
    --lineup-add-mini-button-width: 30px;
    --lineup-add-mini-button-height: 30px;
    --lineup-add-open-height: 80px;
    --lineup-add-button-height: 50px;
  }
}

@media (min-width: 761px) and (max-width: 1366px) and (min-height: 521px) and (orientation: landscape) {
  :root.tablet-touch-layout .lineup-add-actions:not([hidden]) {
    --lineup-add-mini-width: 42px;
    --lineup-add-mini-height: 82px;
    --lineup-add-mini-button-width: 30px;
    --lineup-add-mini-button-height: 30px;
    --lineup-add-open-height: 112px;
    --lineup-add-button-height: 50px;
  }

  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) {
    grid-template-columns: var(--lineup-add-mini-button-width) !important;
    grid-template-rows: repeat(2, var(--lineup-add-mini-button-height)) !important;
    grid-auto-flow: row !important;
  }
}

/* v371: phone uses a simple plus launcher; larger screens keep aligned tiny Slide/Note icons. */
.lineup-add-actions:not(.is-open):not([hidden]) .icon-button > span:not(.add-action-icon-stack),
.lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton > span:not(.add-action-icon-stack),
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .icon-button > span:not(.add-action-icon-stack),
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton > span:not(.add-action-icon-stack) {
  display: none !important;
}

.lineup-add-actions:not(.is-open):not([hidden]) .icon-button span.add-action-icon-stack,
.lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton span.add-action-icon-stack,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .icon-button span.add-action-icon-stack,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton span.add-action-icon-stack {
  display: grid !important;
  place-items: center !important;
  width: 24px !important;
  min-width: 24px !important;
  max-width: 24px !important;
  height: 24px !important;
  min-height: 24px !important;
  max-height: 24px !important;
  margin: 0 !important;
}

.lineup-add-actions:not(.is-open):not([hidden]) .icon-button svg.add-action-main-icon,
.lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton svg.add-action-main-icon,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .icon-button svg.add-action-main-icon,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton svg.add-action-main-icon {
  display: block !important;
  width: 20px !important;
  min-width: 20px !important;
  max-width: 20px !important;
  height: 20px !important;
  min-height: 20px !important;
  max-height: 20px !important;
  margin: 0 !important;
  opacity: 1 !important;
  stroke: currentColor !important;
  stroke-width: 2.35 !important;
  transform: none !important;
}

.lineup-add-actions:not(.is-open):not([hidden]) .add-action-plus-icon,
.lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton .note-plus-icon,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .add-action-plus-icon,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton .note-plus-icon {
  display: none !important;
}

.lineup-add-actions:not(.is-open):not([hidden]),
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) {
  align-items: center !important;
  justify-content: center !important;
}

.lineup-add-actions:not(.is-open):not([hidden]) .icon-button,
.lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .icon-button,
:root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton {
  display: grid !important;
  place-items: center !important;
  grid-template-rows: 1fr !important;
  align-content: center !important;
  justify-content: center !important;
  overflow: hidden !important;
}

@media (max-width: 760px) and (orientation: portrait) and (pointer: coarse) {
  .app-shell:has(.lineup-add-actions:not([hidden])) .bank-panel {
    border-top-right-radius: 20px !important;
  }

  .lineup-add-actions:not([hidden]) {
    --lineup-add-mini-width: 54px;
    --lineup-add-mini-height: 46px;
    --lineup-add-mini-button-width: 42px;
    --lineup-add-mini-button-height: 38px;
    right: max(12px, env(safe-area-inset-right, 0px)) !important;
    bottom: max(
      env(safe-area-inset-bottom, 0px),
      calc(var(--lineup-add-actions-bottom, var(--mobile-library-height, var(--lineup-add-bar-bank-height, 0px))) + 8px)
    ) !important;
    border-bottom-color: var(--lineup-add-bar-border) !important;
    border-radius: 18px !important;
    transform: none !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) {
    display: grid !important;
    width: var(--lineup-add-mini-width) !important;
    min-width: var(--lineup-add-mini-width) !important;
    max-width: var(--lineup-add-mini-width) !important;
    height: var(--lineup-add-mini-height) !important;
    min-height: var(--lineup-add-mini-height) !important;
    max-height: var(--lineup-add-mini-height) !important;
    grid-template-columns: var(--lineup-add-mini-button-width) !important;
    grid-template-rows: var(--lineup-add-mini-button-height) !important;
    padding: 4px 5px !important;
    gap: 0 !important;
    border-radius: 999px !important;
    overflow: hidden !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) .icon-button,
  .lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton {
    display: none !important;
    pointer-events: none !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab {
    position: relative !important;
    inset: auto !important;
    z-index: 9 !important;
    display: grid !important;
    place-items: center !important;
    width: var(--lineup-add-mini-button-width) !important;
    min-width: var(--lineup-add-mini-button-width) !important;
    max-width: var(--lineup-add-mini-button-width) !important;
    height: var(--lineup-add-mini-button-height) !important;
    min-height: var(--lineup-add-mini-button-height) !important;
    max-height: var(--lineup-add-mini-button-height) !important;
    border: 1px solid color-mix(in srgb, var(--green) 48%, var(--line)) !important;
    border-radius: 999px !important;
    background:
      linear-gradient(180deg, color-mix(in srgb, var(--green) 20%, transparent), color-mix(in srgb, var(--green) 8%, transparent)),
      color-mix(in srgb, var(--panel) 52%, transparent) !important;
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.12),
      0 0 0 1px color-mix(in srgb, var(--green) 12%, transparent) !important;
    color: color-mix(in srgb, var(--green) 86%, white) !important;
    opacity: 1 !important;
    pointer-events: auto !important;
    transform: none !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab .add-tray-mini-icons {
    display: none !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab::before,
  .lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    display: block !important;
    border-radius: 999px;
    background: currentColor;
    transform: translate(-50%, -50%);
  }

  .lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab::before {
    width: 18px;
    height: 3px;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab::after {
    width: 3px;
    height: 18px;
  }

  .lineup-add-actions.is-open:not([hidden]) {
    width: var(--lineup-add-open-width) !important;
    min-width: var(--lineup-add-open-width) !important;
    max-width: var(--lineup-add-open-width) !important;
    height: var(--lineup-add-open-height) !important;
    min-height: var(--lineup-add-open-height) !important;
    max-height: var(--lineup-add-open-height) !important;
    grid-template-columns: repeat(2, var(--lineup-add-button-width)) !important;
    grid-template-rows: var(--lineup-add-button-height) !important;
    padding: 8px !important;
    gap: 8px !important;
    border-radius: 18px 18px 0 0 !important;
  }
}

@media (min-width: 761px), (hover: hover) and (pointer: fine) {
  .lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab {
    display: grid !important;
    place-items: center !important;
    opacity: 1 !important;
    pointer-events: auto !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab .add-tray-mini-icons {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: center;
    justify-items: center;
    width: calc(100% - 14px);
    height: 100%;
    gap: 6px;
    margin: 0 auto;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab .add-tray-mini-icons svg {
    display: block !important;
    width: 20px !important;
    height: 20px !important;
    opacity: 1 !important;
    stroke-width: 2.4 !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) .icon-button span.add-action-icon-stack,
  .lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton span.add-action-icon-stack,
  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .icon-button span.add-action-icon-stack,
  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton span.add-action-icon-stack {
    visibility: hidden !important;
  }
}

@media (max-width: 760px) and (orientation: portrait) and (pointer: coarse) {
  .lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab .add-tray-mini-icons {
    display: none !important;
  }
}

/* v372: restore Export Slides to controls-left / preview-right and make colors/picker clearer. */
#slidesExportDialog {
  width: min(1280px, calc(100vw - 24px)) !important;
}

#exportSlidesPanel #slidesExportForm {
  overflow: hidden !important;
}

#exportSlidesPanel .slides-theme-export-layout {
  display: grid !important;
  grid-template-columns: minmax(320px, 430px) minmax(0, 1fr) !important;
  gap: 16px !important;
  align-items: start !important;
  min-height: 0 !important;
  overflow: hidden !important;
  padding-right: 0 !important;
}

#exportSlidesPanel .slides-theme-controls {
  display: grid !important;
  align-content: start !important;
  gap: 10px !important;
  min-width: 0 !important;
  max-height: min(68dvh, 680px) !important;
  overflow: auto !important;
  padding-right: 6px !important;
}

#exportSlidesPanel .theme-export-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 8px !important;
}

#exportSlidesPanel .theme-export-card {
  min-width: 0 !important;
  min-height: 62px !important;
  padding: 10px 12px !important;
}

#exportSlidesPanel .theme-export-card.color {
  min-height: 62px !important;
}

.theme-card-swatch {
  width: 34px;
  height: 30px;
  border: 2px solid rgba(248, 251, 255, 0.72);
  border-radius: 8px;
  background: var(--theme-card-color, #07111f);
  box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.28);
}

.theme-export-card.color.is-color-selected .theme-card-swatch {
  border-color: color-mix(in srgb, var(--green) 78%, white);
  box-shadow:
    inset 0 0 0 1px rgba(0, 0, 0, 0.28),
    0 0 0 2px rgba(91, 146, 255, 0.22);
}

.slides-color-controls {
  display: grid;
  grid-template-columns: minmax(112px, 0.85fr) minmax(0, 1.15fr);
  gap: 8px;
  align-items: center;
  padding: 10px;
  border: 1px solid color-mix(in srgb, var(--line) 82%, transparent);
  border-radius: 12px;
  background: color-mix(in srgb, var(--panel) 70%, transparent);
}

.slides-color-picker-control {
  display: grid;
  grid-template-columns: 1fr 42px;
  align-items: center;
  gap: 8px;
  min-width: 0;
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.slides-color-picker-control input[type="color"] {
  width: 42px;
  height: 34px;
  padding: 4px;
  border: 1px solid color-mix(in srgb, var(--line) 82%, transparent);
  border-radius: 10px;
  background: color-mix(in srgb, var(--surface) 88%, transparent);
  cursor: pointer;
}

.slides-color-picker-control.is-color-selected input[type="color"] {
  border-color: color-mix(in srgb, var(--green) 72%, white);
  box-shadow: 0 0 0 2px rgba(91, 146, 255, 0.2);
}

.slides-color-swatch-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  min-width: 0;
}

.slides-color-swatch-row button {
  width: 28px;
  height: 28px;
  border: 1px solid rgba(248, 251, 255, 0.34);
  border-radius: 999px;
  background: var(--swatch);
  box-shadow:
    inset 0 0 0 1px rgba(0, 0, 0, 0.18),
    0 1px 4px rgba(0, 0, 0, 0.24);
  cursor: pointer;
}

.slides-color-swatch-row button:hover,
.slides-color-swatch-row button:focus-visible {
  border-color: color-mix(in srgb, var(--green) 70%, white);
  box-shadow:
    inset 0 0 0 1px rgba(0, 0, 0, 0.18),
    0 0 0 2px rgba(91, 146, 255, 0.24);
  outline: none;
}

#exportSlidesPanel .slide-export-options {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 8px !important;
  overflow: visible !important;
}

#exportSlidesPanel .slide-title-mode-control {
  grid-column: 1 / -1 !important;
}

#exportSlidesPanel .slide-title-option {
  min-height: 42px !important;
  justify-content: flex-start !important;
}

#exportSlidesPanel .slides-export-preview-shell {
  position: relative !important;
  display: grid !important;
  width: 100% !important;
  min-width: 0 !important;
  justify-self: stretch !important;
}

#exportSlidesPanel .slides-theme-preview {
  width: 100% !important;
  min-height: clamp(320px, 56dvh, 640px) !important;
  max-height: min(64dvh, 680px) !important;
  aspect-ratio: 16 / 9 !important;
}

#exportSlidesPanel .slides-export-jump-control {
  position: absolute !important;
  left: 50% !important;
  bottom: 16px !important;
  z-index: 4 !important;
  display: grid !important;
  grid-template-columns: 1fr !important;
  width: min(340px, calc(100% - 96px)) !important;
  transform: translateX(-50%) !important;
  border: 1px solid rgba(248, 251, 255, 0.18) !important;
  border-radius: 999px !important;
  background: rgba(7, 17, 31, 0.76) !important;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.26) !important;
  padding: 0 !important;
}

#exportSlidesPanel .slides-export-jump-control > span {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  clip: rect(0 0 0 0) !important;
  white-space: nowrap !important;
}

.slides-export-jump-control select {
  width: 100%;
  min-width: 0;
  height: 42px;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: var(--text);
  font-size: 0.92rem;
  font-weight: 900;
  text-align: center;
  text-align-last: center;
  padding: 0 36px 0 18px;
  cursor: pointer;
}

.slides-export-jump-control select:focus {
  outline: 2px solid color-mix(in srgb, var(--green) 70%, white);
  outline-offset: 2px;
}

@media (max-width: 980px) {
  #exportSlidesPanel .slides-theme-export-layout {
    grid-template-columns: 1fr !important;
    overflow: auto !important;
  }

  #exportSlidesPanel .slides-theme-controls {
    max-height: none !important;
    overflow: visible !important;
    padding-right: 0 !important;
  }

  #exportSlidesPanel .slides-theme-preview {
    min-height: clamp(220px, 42dvh, 440px) !important;
  }
}

@media (max-width: 640px) {
  #exportSlidesPanel .theme-export-grid,
  #exportSlidesPanel .slide-export-options,
  .slides-color-controls {
    grid-template-columns: 1fr !important;
  }

  .slides-color-picker-control {
    grid-template-columns: 1fr 46px;
  }

  #exportSlidesPanel .slides-export-jump-control {
    width: min(280px, calc(100% - 76px)) !important;
    bottom: 12px !important;
  }
}

/* v373: keep preview controls from selecting text and stabilize the collapsed add tray. */
.slides-theme-preview,
.slides-theme-preview *,
.slides-export-preview-shell,
.slides-export-preview-nav,
.slides-export-preview-nav *,
.slides-export-jump-control,
.slides-export-jump-control * {
  -webkit-user-select: none;
  user-select: none;
  -webkit-tap-highlight-color: transparent;
}

.slides-export-preview-image,
.slides-live-rendered-image {
  user-select: none;
  -webkit-user-drag: none;
}

.slides-export-preview-nav button:focus:not(:focus-visible) {
  outline: none;
}

.slide-only-row .song-title-wrap,
.slide-only-row .song-text,
.slide-only-row .song-name-line,
.slide-only-row .song-name,
.slide-only-row .slide-only-subline {
  min-width: 0;
}

.slide-only-row .slide-only-subline {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

@media (min-width: 761px), (hover: hover) and (pointer: fine) {
  .lineup-add-actions:not([hidden]) {
    --lineup-add-mini-width: 94px;
    --lineup-add-mini-height: 54px;
  }

  .lineup-add-actions:not(.is-open):not([hidden]),
  .lineup-add-actions:not(.is-open):not(:hover):not([hidden]):focus-within {
    display: grid !important;
    width: var(--lineup-add-mini-width) !important;
    min-width: var(--lineup-add-mini-width) !important;
    max-width: var(--lineup-add-mini-width) !important;
    height: var(--lineup-add-mini-height) !important;
    min-height: var(--lineup-add-mini-height) !important;
    max-height: var(--lineup-add-mini-height) !important;
    grid-template-columns: 1fr !important;
    grid-template-rows: 1fr !important;
    align-items: center !important;
    justify-items: center !important;
    gap: 0 !important;
    overflow: hidden !important;
    padding: 6px 8px !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) > .icon-button,
  .lineup-add-actions:not(.is-open):not([hidden]) > #addNoteButton {
    display: none !important;
    pointer-events: none !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab {
    position: relative !important;
    inset: auto !important;
    display: grid !important;
    width: 100% !important;
    height: 100% !important;
    place-items: center !important;
    opacity: 1 !important;
    pointer-events: auto !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    transform: none !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab::before,
  .lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab::after {
    display: none !important;
    content: none !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) .add-tray-plus {
    display: none !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) .add-tray-mini-icons {
    display: grid !important;
    width: 100% !important;
    height: 100% !important;
    grid-template-columns: repeat(2, 32px) !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) .add-tray-mini-icons svg {
    display: block !important;
    width: 32px !important;
    height: 32px !important;
    box-sizing: border-box !important;
    padding: 6px !important;
    border: 1.5px solid currentColor !important;
    border-radius: 12px !important;
    background: color-mix(in srgb, currentColor 18%, transparent) !important;
    opacity: 1 !important;
    transform: none !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) .add-tray-mini-slide {
    color: color-mix(in srgb, var(--green) 82%, white);
  }

  .lineup-add-actions:not(.is-open):not([hidden]) .add-tray-mini-note {
    color: color-mix(in srgb, var(--amber) 84%, white);
  }
}

/* v374: dedicated slide-only editing surface. */
.slides-editor-dialog.slide-only-editor .slides-editor-title-block .eyebrow {
  color: color-mix(in srgb, var(--amber) 86%, white);
}

.slides-editor-dialog.slide-only-editor .slides-editor-delete-all,
.slides-editor-dialog.slide-only-editor .slides-strip,
.slides-editor-dialog.slide-only-editor .slides-current-text,
.slides-editor-dialog.slide-only-editor .slides-line-control-panel,
.slides-editor-dialog.slide-only-editor #slidesEditFullLyricsButton,
.slides-editor-dialog.slide-only-editor #slidesAddSlideButton,
.slides-editor-dialog.slide-only-editor #slidesSplitButton,
.slides-editor-dialog.slide-only-editor #slidesJoinNextButton,
.slides-editor-dialog.slide-only-editor #slidesDuplicateButton,
.slides-editor-dialog.slide-only-editor #slidesDeleteButton,
.slides-editor-dialog.slide-only-editor .danger-group,
.slides-editor-dialog.slide-only-editor .slides-selection-bar,
.slides-editor-dialog.slide-only-editor .slides-action-group:has(#slidesSplitButton),
.slides-editor-dialog.slide-only-editor .slides-design-panel > div:has(#slidesFontDownButton) {
  display: none !important;
}

.slides-editor-dialog.slide-only-editor .slides-workspace-view {
  grid-template-columns: minmax(0, 1fr) minmax(250px, 340px);
}

.slides-editor-dialog.slide-only-editor .slides-live-area {
  min-height: min(66vh, 640px);
}

.slides-editor-dialog.slide-only-editor .slides-quick-actions {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.slides-editor-dialog.slide-only-editor .slides-action-group {
  align-content: start;
}

.slides-editor-dialog.slide-only-editor .slides-object-panel {
  border-color: color-mix(in srgb, var(--amber) 28%, var(--line));
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--amber) 8%, transparent), transparent 64%),
    rgba(255, 255, 255, 0.025);
}

.slides-object-toolbar #slidesObjectCropButton.is-active {
  border-color: color-mix(in srgb, var(--green) 72%, white);
  color: var(--text);
  background: color-mix(in srgb, var(--green) 20%, transparent);
}

.slides-object-inspector:not(.is-media) .slides-media-inspector,
.slides-object-inspector:not(.is-text) .slides-text-inspector {
  display: none !important;
}

.slides-text-style-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.slides-text-style-row label {
  display: flex;
  align-items: center;
  min-height: 34px;
  gap: 7px;
  border: 1px solid color-mix(in srgb, var(--line) 76%, transparent);
  border-radius: 10px;
  padding: 0 9px;
  color: var(--text);
  background: rgba(255, 255, 255, 0.028);
  font-size: 0.78rem;
  font-weight: 850;
}

.slides-text-style-row input {
  width: 16px;
  height: 16px;
  accent-color: var(--green);
}

.slide-only-background-panel {
  display: none;
  gap: 8px;
  border: 1px solid color-mix(in srgb, var(--line) 80%, transparent);
  border-radius: 12px;
  padding: 10px;
  background: rgba(255, 255, 255, 0.024);
}

.slides-editor-dialog.slide-only-editor .slide-only-background-panel {
  display: grid;
}

.slide-only-background-mode,
.slide-only-background-color {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 8px;
  min-height: 36px;
  border: 1px solid color-mix(in srgb, var(--line) 72%, transparent);
  border-radius: 10px;
  padding: 0 9px;
  background: rgba(255, 255, 255, 0.026);
  color: var(--text);
  font-size: 0.78rem;
  font-weight: 850;
}

.slide-only-background-color {
  grid-template-columns: minmax(0, 1fr) 42px;
}

.slide-only-background-color span {
  color: var(--muted);
  font-weight: 850;
}

.slide-only-background-color input[type="color"] {
  width: 38px;
  height: 30px;
  padding: 3px;
  border: 1px solid var(--line);
  border-radius: 9px;
  background: color-mix(in srgb, var(--surface) 84%, transparent);
}

.slides-editor-crop-bar {
  position: absolute;
  right: 8px;
  bottom: 8px;
  left: 8px;
  z-index: 5;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 8px;
  min-height: 30px;
  border: 1px solid rgba(248, 251, 255, 0.2);
  border-radius: 999px;
  padding: 0 10px;
  color: #f8fbff;
  background: rgba(2, 6, 23, 0.68);
  box-shadow: 0 8px 22px rgba(0, 0, 0, 0.28);
  cursor: default;
  backdrop-filter: blur(8px);
}

.slides-editor-crop-bar span {
  font-size: 0.68rem;
  font-weight: 900;
  text-transform: uppercase;
}

.slides-editor-crop-bar input {
  min-width: 0;
  accent-color: var(--green);
}

.lineup-row.song-row.slide-only-row {
  grid-template-columns: 24px 32px minmax(130px, 1fr) minmax(118px, max-content) max-content;
}

.lineup-row.slide-only-row .row-icon-actions {
  position: static !important;
  display: grid !important;
  grid-auto-flow: column !important;
  grid-auto-columns: 34px !important;
  gap: 6px !important;
  width: max-content !important;
  min-width: max-content !important;
  height: auto !important;
  min-height: 0 !important;
  border-radius: 12px !important;
  padding: 4px !important;
  opacity: 1 !important;
  pointer-events: auto !important;
  transform: none !important;
}

.lineup-row.slide-only-row .row-icon-actions .icon-action {
  width: 34px !important;
  min-width: 34px !important;
  height: 34px !important;
  min-height: 34px !important;
  border-radius: 10px !important;
}

@media (max-width: 760px) {
  .slides-editor-dialog.slide-only-editor .slides-workspace-view {
    grid-template-columns: 1fr;
  }

  .slides-editor-dialog.slide-only-editor .slides-live-area {
    min-height: 0;
  }

  .lineup-row.song-row.slide-only-row .lineup-row-main {
    grid-template-columns: 28px minmax(0, 1fr) 32px 32px !important;
  }

  .lineup-row.song-row.slide-only-row .row-icon-actions {
    position: absolute !important;
    top: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    left: auto !important;
    grid-auto-columns: 44px !important;
    width: 132px !important;
    min-width: 132px !important;
    height: 100% !important;
    border-radius: 0 !important;
    padding: 0 !important;
    gap: 0 !important;
    pointer-events: none !important;
  }

  .lineup-row.song-row.slide-only-row.swipe-open .row-icon-actions {
    pointer-events: auto !important;
  }

  .lineup-row.song-row.slide-only-row .row-icon-actions .icon-action {
    width: 44px !important;
    min-width: 44px !important;
    height: 100% !important;
    min-height: 56px !important;
    border-radius: 0 !important;
  }

  .lineup-row.song-row.slide-only-row.swipe-open .lineup-row-main {
    transform: translateX(-132px) !important;
  }
}

/* v375: center the collapsed tray, simplify slide-only rows, and add slide-only presets. */
.slide-only-preset-dialog {
  width: min(440px, calc(100vw - 24px));
}

.slide-only-preset-picker,
.slide-only-preset-controls label {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 850;
}

.slide-only-preset-picker select,
.slide-only-preset-controls select {
  width: 100%;
  min-width: 0;
}

.slide-only-preset-controls {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  align-items: end;
  gap: 7px;
}

.slide-only-preset-controls .ghost-button {
  min-height: 36px;
  padding-inline: 10px;
  white-space: nowrap;
}

@media (min-width: 761px), (hover: hover) and (pointer: fine) {
  :root:not(.tablet-touch-layout) .lineup-add-actions:not([hidden]) {
    --lineup-add-center-offset: calc((var(--lineup-add-open-width, 185px) - var(--lineup-add-mini-width, 94px)) / 2);
  }

  :root:not(.tablet-touch-layout) .lineup-add-actions:not(.is-open):not([hidden]) {
    transform: translateX(calc(-1 * var(--lineup-add-center-offset))) !important;
  }

  :root:not(.tablet-touch-layout) .lineup-add-actions.is-open:not([hidden]) {
    transform: none !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) .add-tray-mini-icons {
    grid-template-columns: repeat(2, 30px) !important;
    width: 70px !important;
    gap: 8px !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) .add-tray-mini-icons svg {
    width: 30px !important;
    height: 30px !important;
    padding: 5px !important;
    border-radius: 11px !important;
  }
}

@media (max-width: 760px) {
  .lineup-add-actions:not(.is-open):not([hidden]) {
    transform: none !important;
  }
}

.lineup-row.song-row.slide-only-row {
  grid-template-columns: 24px 32px minmax(0, 1fr) max-content !important;
  min-height: 54px !important;
  padding: 6px 8px !important;
}

.lineup-row.song-row.slide-only-row .song-title-wrap,
.lineup-row.song-row.slide-only-row .song-text,
.lineup-row.song-row.slide-only-row .song-name-line {
  min-width: 0 !important;
}

.lineup-row.song-row.slide-only-row .slide-only-subline,
.lineup-row.song-row.slide-only-row .slide-only-inline-image-button,
.lineup-row.song-row.slide-only-row .slide-only-control-spacer,
.lineup-row.song-row.slide-only-row [data-action="edit-slide-title"],
.lineup-row.song-row.slide-only-row [data-action="slide-image"] {
  display: none !important;
}

.lineup-row.song-row.slide-only-row .row-icon-actions {
  position: static !important;
  display: grid !important;
  grid-auto-flow: column !important;
  grid-auto-columns: 36px !important;
  gap: 6px !important;
  width: max-content !important;
  min-width: max-content !important;
  height: auto !important;
  min-height: 0 !important;
  border-radius: 12px !important;
  padding: 4px !important;
  opacity: 1 !important;
  transform: none !important;
}

.lineup-row.song-row.slide-only-row .row-icon-actions .icon-action {
  position: relative !important;
  width: 36px !important;
  min-width: 36px !important;
  height: 36px !important;
  min-height: 36px !important;
  border-radius: 10px !important;
}

.lineup-row.song-row.slide-only-row .row-icon-actions .slides-count-badge {
  position: absolute;
  top: -5px;
  right: -5px;
  min-width: 18px;
  height: 18px;
  border-radius: 999px;
  font-size: 0.62rem;
  line-height: 18px;
}

@media (max-width: 760px) {
  .slide-only-preset-controls {
    grid-template-columns: 1fr 1fr;
  }

  .slide-only-preset-controls label {
    grid-column: 1 / -1;
  }

  .lineup-row.song-row.slide-only-row {
    display: block !important;
    min-height: 56px !important;
    padding: 0 !important;
  }

  .lineup-row.song-row.slide-only-row .lineup-row-main {
    grid-template-columns: 28px 34px minmax(0, 1fr) !important;
    grid-template-areas: "num drag song" !important;
    min-height: 56px !important;
    padding: 6px 8px !important;
    row-gap: 0 !important;
  }

  .lineup-row.song-row.slide-only-row .drag-handle {
    display: grid !important;
    grid-area: drag !important;
  }

  .lineup-row.song-row.slide-only-row .song-number {
    grid-area: num !important;
  }

  .lineup-row.song-row.slide-only-row .song-title-wrap {
    grid-area: song !important;
  }

  .lineup-row.song-row.slide-only-row .row-icon-actions {
    position: absolute !important;
    top: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    left: auto !important;
    grid-template-columns: 52px 52px !important;
    grid-auto-columns: 52px !important;
    width: 104px !important;
    min-width: 104px !important;
    height: 100% !important;
    min-height: 56px !important;
    border-radius: 0 !important;
    padding: 0 !important;
    gap: 0 !important;
    pointer-events: none !important;
  }

  .lineup-row.song-row.slide-only-row.swipe-open .row-icon-actions {
    pointer-events: auto !important;
  }

  .lineup-row.song-row.slide-only-row .row-icon-actions .icon-action {
    width: 52px !important;
    min-width: 52px !important;
    height: 100% !important;
    min-height: 56px !important;
    border-radius: 0 !important;
  }

  .lineup-row.song-row.slide-only-row.swipe-open .lineup-row-main {
    transform: translateX(-104px) !important;
  }
}

/* v376: slide-only canvas controls, compact floating preview, and setlist folder polish. */
.slides-editor-object-layer {
  overflow: visible !important;
}

.slides-editor-object.text:not(.editing) .slides-editor-object-text {
  cursor: move;
  user-select: none;
}

.slides-editor-object.text.editing {
  cursor: text;
}

.slides-editor-object.text.editing .slides-editor-object-text {
  cursor: text;
  user-select: text;
}

.slides-editor-object.text.is-empty:not(.editing) .slides-editor-object-text {
  color: color-mix(in srgb, currentColor 56%, transparent);
}

.slides-editor-object-handle {
  display: none;
}

.slides-editor-object.selected .slides-editor-object-handle {
  display: block;
}

.slides-editor-object-handle.nw {
  top: -5px;
  right: auto;
  bottom: auto;
  left: -5px;
  cursor: nwse-resize;
}

.slides-editor-object-handle.ne {
  top: -5px;
  right: -5px;
  bottom: auto;
  left: auto;
  cursor: nesw-resize;
}

.slides-editor-object-handle.sw {
  top: auto;
  right: auto;
  bottom: -5px;
  left: -5px;
  cursor: nesw-resize;
}

.slides-editor-object-handle.se {
  right: -5px;
  bottom: -5px;
  cursor: nwse-resize;
}

.slides-editor-crop-bar {
  position: absolute;
  top: calc(100% + 8px);
  left: 50%;
  z-index: 8;
  display: grid;
  grid-template-columns: auto minmax(92px, 1fr);
  align-items: center;
  gap: 8px;
  width: min(240px, 84vw);
  padding: 7px;
  border: 1px solid color-mix(in srgb, var(--green) 48%, var(--line));
  border-radius: 12px;
  background: color-mix(in srgb, var(--panel) 94%, transparent);
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.32);
  transform: translateX(-50%);
}

.slides-editor-crop-bar label {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 6px;
  min-width: 0;
}

.slides-editor-crop-bar span {
  color: var(--muted);
  font-size: 0.64rem;
  font-weight: 900;
  text-transform: uppercase;
}

.slides-editor-inline-crop-toggle {
  min-height: 30px;
  border: 1px solid var(--line);
  border-radius: 9px;
  padding: 0 10px;
  color: var(--text);
  background: color-mix(in srgb, var(--panel-2) 92%, transparent);
  font-size: 0.72rem;
  font-weight: 900;
}

.slides-editor-inline-crop-toggle.is-active {
  border-color: color-mix(in srgb, var(--green) 64%, var(--line));
  background: color-mix(in srgb, var(--green) 24%, var(--panel-2));
  color: #ffffff;
}

.slides-object-inspector.is-media .slides-media-inspector {
  display: none !important;
}

.mini-slide.rendered {
  padding: 0;
  background: #05070b;
}

.mini-slide-rendered-image {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  background: #05070b;
}

.slide-preview-jump {
  display: inline-grid;
  grid-template-columns: 3.3ch auto;
  align-items: center;
  gap: 4px;
  min-width: 0;
  color: var(--muted);
  font-weight: 900;
}

.slide-preview-jump input {
  width: 3.3ch;
  min-width: 0;
  height: 26px;
  border: 0;
  border-radius: 8px;
  padding: 0;
  color: var(--text);
  background: transparent;
  font: inherit;
  text-align: right;
  -moz-appearance: textfield;
}

.slide-preview-jump input::-webkit-outer-spin-button,
.slide-preview-jump input::-webkit-inner-spin-button {
  margin: 0;
  -webkit-appearance: none;
}

.slide-preview-header {
  cursor: grab;
}

.slide-preview-panel.is-dragging .slide-preview-header {
  cursor: grabbing;
}

.setlist-selection-bar {
  grid-template-columns: auto minmax(0, 1fr) auto auto !important;
}

@media (min-width: 761px) {
  .show-panel.slide-preview-open .lineup-table,
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-table {
    width: auto !important;
    height: auto !important;
    margin-top: 0 !important;
    margin-right: 0 !important;
  }

  .show-panel.slide-preview-open .lineup-heading,
  .show-panel.slide-preview-open .lineup-row,
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-heading,
  :root.tablet-touch-layout .show-panel.slide-preview-open .lineup-row {
    grid-template-columns: 24px 34px minmax(170px, 1fr) minmax(128px, 0.34fr) 96px 68px 42px 46px 46px 48px !important;
  }

  .show-panel.slide-preview-open .slide-preview-panel,
  :root.tablet-touch-layout .show-panel.slide-preview-open .slide-preview-panel {
    position: absolute !important;
    top: clamp(112px, 13dvh, 150px) !important;
    right: 20px !important;
    bottom: auto !important;
    left: auto !important;
    width: min(236px, 24vw) !important;
    min-width: 196px !important;
    max-height: none !important;
    gap: 8px !important;
    border-radius: 14px !important;
    padding: 9px !important;
  }

  .show-panel.slide-preview-open .slide-preview-stage,
  :root.tablet-touch-layout .show-panel.slide-preview-open .slide-preview-stage {
    min-height: 0 !important;
    padding: 5px !important;
  }
}

@media (max-width: 760px) {
  .slides-editor-crop-bar {
    grid-template-columns: 1fr;
    width: min(220px, 74vw);
  }
}

/* v377: keep the expanded add tray as its own rounded frame while preserving button expansion. */
.lineup-add-actions.is-open:not([hidden]),
:root.tablet-touch-layout .lineup-add-actions.is-open:not([hidden]) {
  border-bottom-width: 1px !important;
  border-bottom-style: solid !important;
  border-bottom-color: color-mix(in srgb, var(--green) 28%, rgba(255, 255, 255, 0.16)) !important;
  border-radius: 18px !important;
}

:root[data-theme="light"] .lineup-add-actions.is-open:not([hidden]),
:root[data-theme="light"].tablet-touch-layout .lineup-add-actions.is-open:not([hidden]) {
  border-bottom-color: color-mix(in srgb, var(--green) 24%, #a9d8de) !important;
}

/* v378: local music-provider links for songs. */
.song-recording-panel {
  display: grid;
  gap: 8px;
  border: 1px solid color-mix(in srgb, var(--green) 22%, var(--line));
  border-radius: 12px;
  padding: 10px;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--green) 8%, transparent), transparent 56%),
    rgba(255, 255, 255, 0.035);
}

.song-recording-header,
.song-recording-actions,
.song-recording-search-row {
  display: flex;
  align-items: center;
  gap: 8px;
}

.song-recording-header {
  justify-content: space-between;
}

.song-recording-header span {
  display: block;
  color: var(--text);
  font-size: 0.82rem;
  font-weight: 900;
}

.song-recording-header small,
.song-recording-status,
.song-recording-card span,
.song-recording-result small {
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 800;
}

.song-recording-provider-buttons {
  display: inline-grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 4px;
  padding: 3px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.04);
}

.song-recording-provider-buttons button {
  min-height: 30px;
  border: 0;
  border-radius: 8px;
  padding: 0 9px;
  color: var(--muted);
  background: transparent;
  font-size: 0.72rem;
  font-weight: 900;
  cursor: pointer;
}

.song-recording-provider-buttons button.active {
  color: var(--text);
  background: color-mix(in srgb, var(--green) 22%, rgba(255, 255, 255, 0.08));
}

.song-recording-card {
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr) auto;
  align-items: center;
  gap: 9px;
  min-height: 58px;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 7px;
  background: rgba(0, 0, 0, 0.12);
}

.song-recording-card.empty {
  grid-template-columns: 38px minmax(0, 1fr);
  opacity: 0.88;
}

.song-recording-art,
.song-recording-empty-icon,
.song-recording-result-art {
  display: grid;
  place-items: center;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--green) 34%, var(--line));
  border-radius: 8px;
  color: var(--green);
  background: color-mix(in srgb, var(--green) 10%, transparent);
}

.song-recording-art {
  width: 44px;
  height: 44px;
}

.song-recording-empty-icon {
  width: 38px;
  height: 38px;
}

.song-recording-art img,
.song-recording-result-art img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.song-recording-art svg,
.song-recording-empty-icon svg,
.song-recording-result-art svg,
.recording-play-button svg {
  width: 18px;
  height: 18px;
  fill: none;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 2;
}

.song-recording-copy {
  display: grid;
  min-width: 0;
  gap: 2px;
}

.song-recording-copy strong,
.song-recording-result strong {
  overflow: hidden;
  color: var(--text);
  font-size: 0.86rem;
  font-weight: 900;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.song-recording-provider-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 5px 8px;
  color: var(--muted);
  white-space: nowrap;
}

.song-recording-provider-badge svg {
  width: 14px;
  height: 14px;
}

.song-recording-search-row input {
  flex: 1 1 auto;
  min-width: 0;
}

.song-recording-actions {
  flex-wrap: wrap;
}

.song-recording-actions .ghost-button,
.song-recording-search-row .ghost-button {
  min-height: 34px;
  border-radius: 9px;
  padding: 0 10px;
  font-size: 0.74rem;
}

.song-recording-status[data-tone="success"] {
  color: var(--green);
}

.song-recording-status[data-tone="warning"] {
  color: var(--amber);
}

.song-recording-results {
  display: grid;
  gap: 6px;
}

.song-recording-result {
  display: grid;
  grid-template-columns: 36px minmax(0, 1fr);
  align-items: center;
  gap: 8px;
  min-height: 44px;
  border: 1px solid var(--line);
  border-radius: 9px;
  padding: 5px;
  color: inherit;
  background: rgba(255, 255, 255, 0.035);
  text-align: left;
  cursor: pointer;
}

.song-recording-result:hover,
.song-recording-result:focus-visible {
  border-color: color-mix(in srgb, var(--green) 48%, var(--line));
  background: color-mix(in srgb, var(--green) 11%, rgba(255, 255, 255, 0.035));
  outline: none;
}

.song-recording-result-art {
  width: 36px;
  height: 36px;
}

.recording-play-button {
  display: inline-grid;
  place-items: center;
  width: 32px;
  min-width: 32px;
  height: 32px;
  min-height: 32px;
  border: 1px solid color-mix(in srgb, var(--green) 38%, var(--line));
  border-radius: 9px;
  color: var(--green);
  background: color-mix(in srgb, var(--green) 10%, transparent);
  cursor: pointer;
}

.recording-play-button:hover,
.recording-play-button:focus-visible {
  border-color: color-mix(in srgb, var(--green) 68%, var(--line));
  background: color-mix(in srgb, var(--green) 17%, transparent);
  outline: none;
}

.lineup-key-controls.has-recording {
  grid-template-columns: 58px 88px 32px 32px !important;
}

.bank-song .bank-recording-button {
  width: 30px;
  min-width: 30px;
  height: 30px;
  min-height: 30px;
}

@media (min-width: 761px) and (max-width: 1366px) {
  :root.tablet-touch-layout .lineup-key-controls.has-recording {
    grid-template-columns: 48px 72px 30px 30px !important;
  }
}

@media (max-width: 760px) {
  .song-recording-header,
  .song-recording-search-row {
    align-items: stretch;
    flex-direction: column;
  }

  .song-recording-provider-buttons {
    width: 100%;
  }

  .song-recording-card {
    grid-template-columns: 40px minmax(0, 1fr);
  }

  .song-recording-provider-badge {
    grid-column: 1 / -1;
    justify-self: start;
  }

  .lineup-key-controls.has-recording {
    grid-template-columns: 42px 48px 30px 30px !important;
  }

  .lineup-row .recording-play-button {
    width: 30px !important;
    min-width: 30px !important;
    height: 28px !important;
    min-height: 28px !important;
  }

  .bank-song.has-recording .bank-song-main-content {
    grid-template-columns: minmax(0, 1fr) 28px 28px 28px 28px !important;
  }
}

@media (pointer: coarse) {
  :root.tablet-touch-layout .bank-song.has-recording {
    grid-template-columns: minmax(0, 1fr) 30px 30px 30px 30px !important;
  }

  :root.tablet-touch-layout .bank-song.has-recording:has(.banger-toggle.active) {
    grid-template-columns: minmax(0, 1fr) 30px 30px 30px 30px 30px !important;
  }

  :root.tablet-touch-layout .bank-recording-button {
    width: 30px !important;
    min-width: 30px !important;
    height: 30px !important;
    min-height: 30px !important;
    border-radius: 9px !important;
  }
}

/* v379: multi-platform recording slots and compact song-bank icon rows. */
.recording-provider-spotify,
.recording-provider-icon-spotify {
  --recording-provider-color: #1ed760;
  --recording-provider-mark: #06130a;
  color: var(--recording-provider-color) !important;
}

.recording-provider-apple,
.recording-provider-icon-apple {
  --recording-provider-color: #fa2d55;
  --recording-provider-mark: #ffffff;
  color: var(--recording-provider-color) !important;
}

.recording-provider-youtube,
.recording-provider-icon-youtube {
  --recording-provider-color: #ff0033;
  --recording-provider-mark: #ffffff;
  color: var(--recording-provider-color) !important;
}

.recording-provider-icon {
  width: 18px;
  height: 18px;
  fill: currentColor !important;
  stroke: none !important;
}

.recording-provider-icon-bg,
.recording-provider-icon-apple path {
  fill: currentColor !important;
  stroke: none !important;
}

.recording-provider-icon-mark {
  fill: none !important;
  stroke: var(--recording-provider-mark, currentColor) !important;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 1.65;
}

.recording-provider-icon-youtube .recording-provider-icon-mark {
  fill: var(--recording-provider-mark, #ffffff) !important;
  stroke: none !important;
}

.song-recording-provider-buttons {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 6px !important;
  border: 0 !important;
  padding: 0 !important;
  background: transparent !important;
}

.song-recording-provider-buttons .song-recording-platform {
  display: grid;
  grid-template-columns: 22px minmax(0, 1fr);
  align-items: center;
  min-height: 44px;
  border: 1px solid color-mix(in srgb, currentColor 34%, var(--line));
  border-radius: 10px;
  padding: 7px 8px;
  gap: 3px 7px;
  background:
    linear-gradient(180deg, color-mix(in srgb, currentColor 10%, transparent), transparent 80%),
    rgba(255, 255, 255, 0.035);
  text-align: left;
}

.song-recording-provider-buttons .song-recording-platform span,
.song-recording-provider-buttons .song-recording-platform small {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.song-recording-provider-buttons .song-recording-platform span {
  color: var(--text);
  font-size: 0.76rem;
  font-weight: 950;
}

.song-recording-provider-buttons .song-recording-platform small {
  grid-column: 2;
  color: var(--muted);
  font-size: 0.62rem;
  font-weight: 800;
}

.song-recording-provider-buttons .song-recording-platform.active {
  box-shadow: 0 0 0 2px color-mix(in srgb, currentColor 28%, transparent);
  background:
    linear-gradient(180deg, color-mix(in srgb, currentColor 18%, transparent), transparent 80%),
    rgba(255, 255, 255, 0.055);
}

.song-recording-provider-buttons .song-recording-platform.has-recording:not(.active) {
  background:
    linear-gradient(180deg, color-mix(in srgb, currentColor 13%, transparent), transparent 82%),
    rgba(255, 255, 255, 0.04);
}

.song-recording-search-row[hidden],
.song-recording-actions[hidden],
.song-recording-results[hidden] {
  display: none !important;
}

.recording-button-cluster {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: max-content;
  gap: 2px;
}

.recording-button-cluster .recording-play-button {
  width: 25px;
  min-width: 25px;
  height: 28px;
  min-height: 28px;
  border-radius: 8px;
  padding: 0;
}

.recording-button-cluster .recording-provider-icon {
  width: 15px;
  height: 15px;
}

.bank-song {
  grid-template-columns: minmax(0, 1fr) 26px 26px 26px 26px !important;
  gap: 5px !important;
  min-height: 40px !important;
  padding: 6px 7px !important;
}

.bank-song.has-recording {
  grid-template-columns: minmax(0, 1fr) 25px max-content 25px 25px 25px !important;
}

.bank-song .banger-toggle,
.bank-slides-button,
.bank-sheets-button,
.bank-edit-button {
  width: 26px !important;
  min-width: 26px !important;
  height: 28px !important;
  min-height: 28px !important;
  border-radius: 8px !important;
}

.bank-recording-cluster .recording-play-button {
  width: 23px;
  min-width: 23px;
  height: 28px;
  min-height: 28px;
}

.lineup-key-controls.has-recording {
  grid-template-columns: 58px 88px 30px max-content !important;
  gap: 4px !important;
}

.lineup-recording-cluster .recording-play-button {
  width: 24px;
  min-width: 24px;
}

@media (max-width: 760px) {
  .song-recording-provider-buttons {
    grid-template-columns: 1fr !important;
  }

  .song-recording-provider-buttons .song-recording-platform {
    min-height: 40px;
  }

  .lineup-key-controls.has-recording {
    grid-template-columns: 42px 48px 28px max-content !important;
  }

  .recording-button-cluster .recording-play-button {
    width: 23px !important;
    min-width: 23px !important;
    height: 28px !important;
    min-height: 28px !important;
  }

  .bank-song.has-recording .bank-song-main-content {
    grid-template-columns: minmax(0, 1fr) 25px max-content 25px 25px !important;
    gap: 4px !important;
  }
}

@media (pointer: coarse) {
  :root.tablet-touch-layout .bank-song.has-recording {
    grid-template-columns: minmax(0, 1fr) 28px max-content 28px 28px 28px !important;
  }

  :root.tablet-touch-layout .bank-song.has-recording:has(.banger-toggle.active) {
    grid-template-columns: minmax(0, 1fr) 28px max-content 28px 28px 28px !important;
  }
}

/* v385: native iPhone uses the browser UI in a full-screen WKWebView; keep content inside safe areas and cancel the later compact bank-row squeeze. */
@media (max-width: 760px) {
  html.lineup-native-ios-shell .show-panel {
    padding-top: calc(12px + env(safe-area-inset-top, 0px)) !important;
  }

  html.lineup-native-ios-shell .bank-song {
    display: block !important;
    height: auto !important;
    min-height: 54px !important;
    max-height: none !important;
    padding: 0 !important;
    overflow: hidden !important;
  }

  html.lineup-native-ios-shell .bank-song .bank-song-main-content {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 28px 28px 28px !important;
    min-height: 54px !important;
    height: auto !important;
    gap: 5px !important;
    padding: 5px 8px !important;
  }

  html.lineup-native-ios-shell .bank-song.has-recording .bank-song-main-content {
    grid-template-columns: minmax(0, 1fr) 28px max-content 28px 28px !important;
  }

  html.lineup-native-ios-shell .bank-song .banger-toggle,
  html.lineup-native-ios-shell .bank-slides-button,
  html.lineup-native-ios-shell .bank-sheets-button,
  html.lineup-native-ios-shell .bank-edit-button,
  html.lineup-native-ios-shell .bank-recording-cluster .recording-play-button {
    width: 28px !important;
    min-width: 28px !important;
    height: 28px !important;
    min-height: 28px !important;
  }
}

/* v386: the native iPhone viewport stops above the home-indicator safe area, so extend only that drawer layer through it. */
@media (max-width: 760px) and (orientation: portrait) {
  html.lineup-native-ios-shell .bank-panel:not(.manage-mode) {
    bottom: calc(0px - env(safe-area-inset-bottom, 0px)) !important;
    height: calc(var(--mobile-library-height, min(56dvh, 540px)) + env(safe-area-inset-bottom, 0px)) !important;
    min-height: calc(var(--mobile-library-height, min(56dvh, 540px)) + env(safe-area-inset-bottom, 0px)) !important;
    max-height: calc(var(--lineup-viewport-height, 100dvh) + env(safe-area-inset-bottom, 0px)) !important;
    padding-bottom: calc(10px + env(safe-area-inset-bottom, 0px)) !important;
  }

  html.lineup-native-ios-shell .app-shell.mobile-library-middle .show-panel,
  html.lineup-native-ios-shell .app-shell.mobile-library-full .show-panel {
    padding-bottom: max(
      0px,
      calc(var(--mobile-library-height, var(--lineup-add-bar-bank-height, 0px)) - 96px + env(safe-area-inset-bottom, 0px))
    ) !important;
  }

  html.lineup-native-ios-shell .app-shell.bank-collapsed .bank-panel:not(.manage-mode),
  html.lineup-native-ios-shell .app-shell.mobile-library-minimized .bank-panel:not(.manage-mode) {
    height: calc(var(--mobile-library-height, 52px) + env(safe-area-inset-bottom, 0px)) !important;
    min-height: calc(var(--mobile-library-height, 52px) + env(safe-area-inset-bottom, 0px)) !important;
    max-height: calc(var(--mobile-library-height, 52px) + env(safe-area-inset-bottom, 0px)) !important;
  }

  html.lineup-native-ios-shell .bank-panel.is-dragging,
  html.lineup-native-ios-shell .app-shell.mobile-library-dragging .lineup-add-actions:not([hidden]) {
    transition: none !important;
  }

  html.lineup-native-ios-shell .lineup-add-actions:not([hidden]) {
    z-index: 90 !important;
    -webkit-backdrop-filter: none !important;
    backdrop-filter: none !important;
  }
}

/* v390: focused polish for native iPhone drawer, compact recording panel, export phone layout, and drag previews. */
@media (min-width: 1120px) and (pointer: fine) {
  .app-shell:not(.bank-collapsed):not(.manage-songs-open) {
    grid-template-columns: clamp(390px, var(--bank-width, 430px), min(640px, 48vw)) 10px minmax(420px, 1fr) !important;
  }
}

.show-title-input,
.show-title-input:hover,
.show-title-input:focus,
:root[data-theme="light"] .show-title-input:hover,
:root[data-theme="light"] .show-title-input:focus {
  border-color: transparent !important;
  background: transparent !important;
  box-shadow: none !important;
  padding: 0 !important;
}

.show-title-input:focus-visible {
  outline: none !important;
  text-shadow: 0 0 22px color-mix(in srgb, var(--green) 18%, transparent);
}

.hebrew-filter.active,
.hebrew-filter[aria-pressed="true"] {
  border: 1px solid color-mix(in srgb, var(--green) 78%, white) !important;
  color: #071428 !important;
  background: var(--green) !important;
  box-shadow:
    0 0 0 2px color-mix(in srgb, var(--green) 18%, transparent),
    0 8px 20px color-mix(in srgb, var(--green) 18%, transparent) !important;
}

.song-recording-panel {
  gap: 0 !important;
  padding: 7px 9px !important;
}

.song-recording-header {
  min-height: 38px;
  margin: -2px;
  border-radius: 10px;
  padding: 5px 7px;
  cursor: pointer;
  user-select: none;
}

.song-recording-header:hover,
.song-recording-header:focus-visible {
  background: color-mix(in srgb, var(--green) 9%, transparent);
  outline: none;
}

.song-recording-summary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 54px;
  min-height: 28px;
  border: 1px solid color-mix(in srgb, var(--green) 36%, var(--line));
  border-radius: 999px;
  padding: 0 9px;
  color: var(--green);
  background: color-mix(in srgb, var(--green) 10%, transparent);
  font-size: 0.68rem;
  font-weight: 900;
}

.song-recording-body {
  display: grid;
  gap: 8px;
  margin-top: 8px;
}

.song-recording-panel.is-collapsed .song-recording-body {
  display: none;
}

.song-recording-panel.is-collapsed {
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--green) 5%, transparent), transparent 62%),
    rgba(255, 255, 255, 0.025);
}

.slide-only-inline-slides-button {
  display: inline-grid;
  flex: 0 0 34px;
  place-items: center;
  width: 34px;
  min-width: 34px;
  height: 30px;
  min-height: 30px;
  margin-left: 8px;
  border-radius: 9px;
  padding: 0;
}

.lineup-row.slide-only-row .song-title-wrap {
  align-items: center;
  justify-content: space-between;
}

.lineup-drag-ghost.note-row .note-inline-actions,
.lineup-drag-ghost.slide-only-row .row-icon-actions,
.lineup-drag-preview-row .row-icon-actions,
.lineup-drag-preview-row .note-inline-actions {
  display: none !important;
}

.lineup-drag-ghost.note-row,
.lineup-drag-preview-row.note-row {
  grid-template-columns: 28px minmax(0, 1fr) !important;
  min-height: 58px !important;
  height: auto !important;
  padding: 8px 10px !important;
  overflow: hidden !important;
}

.lineup-drag-ghost.note-row::before,
.lineup-drag-ghost.note-row::after,
.lineup-drag-preview-row.note-row::before,
.lineup-drag-preview-row.note-row::after {
  content: none !important;
}

.lineup-drag-ghost.slide-only-row,
.lineup-drag-preview-row.slide-only-row {
  grid-template-columns: 28px 30px minmax(0, 1fr) !important;
  min-height: 58px !important;
  height: 58px !important;
  padding: 7px 9px !important;
  overflow: hidden !important;
}

.lineup-drag-ghost.slide-only-row .lineup-row-main,
.lineup-drag-preview-row.slide-only-row .lineup-row-main {
  display: contents !important;
  min-height: 0 !important;
  padding: 0 !important;
}

.lineup-drag-ghost.slide-only-row .slide-only-inline-slides-button,
.lineup-drag-preview-row.slide-only-row .slide-only-inline-slides-button {
  display: none !important;
}

@media (max-width: 760px) {
  .lineup-row.song-row.slide-only-row {
    min-height: 62px !important;
  }

  .lineup-row.song-row.slide-only-row .lineup-row-main {
    min-height: 54px !important;
    padding: 7px 8px !important;
  }

  .lineup-row.song-row.slide-only-row .row-icon-actions,
  .lineup-row.song-row.slide-only-row .row-icon-actions .icon-action {
    min-height: 0 !important;
  }

  .lineup-row.song-row.slide-only-row .row-icon-actions {
    align-self: center !important;
  }

  .lineup-row.song-row.slide-only-row .row-icon-actions .icon-action {
    width: 30px !important;
    min-width: 30px !important;
    height: 30px !important;
    min-height: 30px !important;
  }
}

@media (max-width: 760px) and (orientation: portrait) {
  html.lineup-native-ios-shell .app-shell {
    --lineup-add-bar-min-height: 84px !important;
  }

  html.lineup-native-ios-shell .bank-panel:not(.manage-mode) {
    --native-bank-bottom: max(14px, env(safe-area-inset-bottom, 0px));
    bottom: var(--native-bank-bottom) !important;
    height: min(
      var(--mobile-library-height, min(56dvh, 540px)),
      calc(var(--lineup-viewport-height, 100dvh) - var(--native-bank-bottom))
    ) !important;
    min-height: min(
      var(--mobile-library-height, min(56dvh, 540px)),
      calc(var(--lineup-viewport-height, 100dvh) - var(--native-bank-bottom))
    ) !important;
    max-height: calc(var(--lineup-viewport-height, 100dvh) - var(--native-bank-bottom)) !important;
    padding-bottom: 10px !important;
    box-shadow:
      0 var(--native-bank-bottom) 0 0 color-mix(in srgb, var(--accent-bg-dark) 72%, #05090b),
      0 -18px 44px rgba(0, 0, 0, 0.34) !important;
    transform: translateZ(0);
    backface-visibility: hidden;
    contain: layout paint;
  }

  html.lineup-native-ios-shell .app-shell.bank-collapsed .bank-panel:not(.manage-mode),
  html.lineup-native-ios-shell .app-shell.mobile-library-minimized .bank-panel:not(.manage-mode) {
    height: var(--mobile-library-height, 84px) !important;
    min-height: var(--mobile-library-height, 84px) !important;
    max-height: var(--mobile-library-height, 84px) !important;
  }

  html.lineup-native-ios-shell .app-shell.mobile-library-middle .show-panel,
  html.lineup-native-ios-shell .app-shell.mobile-library-full .show-panel {
    padding-bottom: max(0px, calc(var(--mobile-library-height, var(--lineup-add-bar-bank-height, 0px)) - 76px)) !important;
  }

  html.lineup-native-ios-shell .bank-panel.is-dragging,
  html.lineup-native-ios-shell .app-shell.mobile-library-dragging .lineup-add-actions:not([hidden]) {
    transition: none !important;
  }

  html.lineup-native-ios-shell .lineup-add-actions:not([hidden]) {
    z-index: 120 !important;
    opacity: 1 !important;
    -webkit-backdrop-filter: none !important;
    backdrop-filter: none !important;
  }
}

@media (max-width: 760px) {
  .export-dialog {
    inset: calc(8px + env(safe-area-inset-top, 0px)) 10px calc(10px + env(safe-area-inset-bottom, 0px)) !important;
    transform: none !important;
    width: auto !important;
    height: auto !important;
    max-width: none !important;
    max-height: none !important;
    border: 1px solid var(--line-strong) !important;
    border-radius: 16px !important;
    overflow: hidden !important;
  }

  html.lineup-native-ios-shell .export-dialog {
    inset: calc(14px + env(safe-area-inset-top, 0px)) 10px calc(12px + env(safe-area-inset-bottom, 0px)) !important;
  }

  .export-dialog-inner {
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto auto minmax(0, 1fr) auto !important;
    gap: 6px !important;
    padding: 8px !important;
  }

  .export-dialog .dialog-header {
    grid-column: 1 !important;
    grid-row: 1 !important;
    min-height: 42px !important;
    margin: 0 !important;
  }

  .export-dialog .dialog-header .eyebrow {
    display: none !important;
  }

  .export-dialog .dialog-header h2 {
    font-size: 1.36rem !important;
    line-height: 1 !important;
  }

  .export-dialog .dialog-header [data-close-dialog] {
    width: 40px !important;
    min-width: 40px !important;
    height: 40px !important;
    min-height: 40px !important;
    border-radius: 12px !important;
  }

  .export-tabs {
    grid-column: 1 !important;
    grid-row: 2 !important;
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 5px !important;
    overflow: visible !important;
    padding-bottom: 0 !important;
  }

  .export-tab {
    min-width: 0 !important;
    min-height: 34px !important;
    border-radius: 10px !important;
    padding: 0 4px !important;
    font-size: 0 !important;
  }

  .export-tab::after {
    font-size: 0.66rem !important;
    font-weight: 950 !important;
    line-height: 1 !important;
  }

  .export-tab[data-export-tab="setlist"]::after {
    content: "Setlist";
  }

  .export-tab[data-export-tab="slides"]::after {
    content: "Slides";
  }

  .export-tab[data-export-tab="sheets"]::after {
    content: "Sheets";
  }

  .export-settings {
    grid-column: 1 !important;
    grid-row: 3 !important;
    grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
    gap: 4px !important;
    padding: 6px !important;
    overflow: visible !important;
  }

  .export-settings .page-control {
    grid-column: span 2 !important;
  }

  .export-settings .orientation-control.font-control:not(.columns-control):not(.spacing-control) {
    grid-column: span 4 !important;
  }

  .export-settings .columns-control,
  .export-settings .pages-control {
    grid-column: span 3 !important;
  }

  .export-settings .spacing-control {
    grid-column: 1 / -1 !important;
  }

  .export-settings .export-toggle-row,
  .export-settings .fit-toggle {
    grid-column: span 3 !important;
  }

  .export-settings .orientation-control,
  .export-settings .export-option {
    min-height: 34px !important;
    padding: 4px !important;
  }

  .export-settings .orientation-control span,
  .export-settings .export-option span {
    min-height: 28px !important;
    padding: 0 4px !important;
    font-size: 0.64rem !important;
  }

  .export-preview {
    grid-column: 1 !important;
    grid-row: 4 !important;
    min-height: 0 !important;
    overflow: hidden !important;
    padding: 6px !important;
  }

  .export-sheet-preview.image-preview {
    width: min(100%, 41dvh) !important;
    max-height: 100% !important;
  }

  .dialog-actions.export-actions {
    grid-column: 1 !important;
    grid-row: 5 !important;
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 6px !important;
    justify-content: stretch !important;
  }

  .dialog-actions.export-actions .export-file-button {
    justify-content: center !important;
    min-width: 0 !important;
    min-height: 42px !important;
    padding: 0 8px !important;
    font-size: 0.72rem !important;
  }

  .export-tab-panel {
    grid-column: 1 !important;
    grid-row: 3 / 6 !important;
    min-height: 0 !important;
    overflow: auto !important;
    padding: 8px !important;
  }

  #exportSlidesPanel #slidesExportForm {
    grid-template-rows: minmax(0, 1fr) auto !important;
    gap: 8px !important;
    height: auto !important;
    min-height: 0 !important;
    overflow: visible !important;
  }

  #exportSlidesPanel #slidesExportForm > .utility-copy {
    display: none !important;
  }

  #exportSlidesPanel .slides-theme-export-layout {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
    overflow: visible !important;
  }

  #exportSlidesPanel .slides-export-preview-shell {
    order: 1 !important;
  }

  #exportSlidesPanel .slides-theme-controls {
    order: 2 !important;
    max-height: none !important;
    gap: 7px !important;
    overflow: visible !important;
    padding-right: 0 !important;
  }

  #exportSlidesPanel .slides-theme-preview {
    min-height: auto !important;
    max-height: none !important;
    aspect-ratio: 16 / 9 !important;
  }

  #exportSlidesPanel .theme-export-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 5px !important;
  }

  #exportSlidesPanel .theme-export-card,
  #exportSlidesPanel .theme-export-card.color {
    min-height: 40px !important;
    border-radius: 9px !important;
    padding: 6px 7px !important;
  }

  #exportSlidesPanel .theme-export-card strong {
    font-size: 0.74rem !important;
  }

  #exportSlidesPanel .theme-export-card small {
    display: none !important;
  }

  #exportSlidesPanel .slides-color-controls {
    grid-template-columns: 1fr 1fr !important;
    gap: 5px !important;
    padding: 6px !important;
  }

  #exportSlidesPanel .slides-color-swatch-row {
    gap: 4px !important;
  }

  #exportSlidesPanel .slides-color-swatch-row button {
    width: 22px !important;
    height: 22px !important;
  }

  #exportSlidesPanel .slides-more-background-button,
  #exportSlidesPanel .theme-image-actions .ghost-button,
  #exportSlidesPanel .ghost-button,
  #exportSlidesPanel .primary-button {
    min-height: 34px !important;
    border-radius: 9px !important;
    padding: 0 8px !important;
    font-size: 0.74rem !important;
  }

  #exportSlidesPanel .slide-export-options {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 5px !important;
  }

  #exportSlidesPanel .slide-title-mode-control {
    grid-column: 1 / -1 !important;
  }

  #exportSlidesPanel .slide-title-numbers-control,
  #exportSlidesPanel .slide-title-size-control {
    grid-column: span 2 !important;
  }

  #exportSlidesPanel .slide-title-option {
    min-height: 32px !important;
    justify-content: center !important;
    padding: 5px 6px !important;
    font-size: 0.7rem !important;
  }

  #exportSlidesPanel .dialog-actions.compact {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 6px !important;
  }

  #exportSlidesPanel .dialog-actions.compact > span {
    display: none !important;
  }
}

/* v391: compact slide background controls and stabilize the browser phone bank drawer. */
#exportSlidesPanel .slides-theme-controls {
  gap: 6px !important;
}

#exportSlidesPanel .theme-export-grid {
  grid-template-columns: repeat(auto-fit, minmax(108px, 1fr)) !important;
  gap: 6px !important;
}

#exportSlidesPanel .theme-export-card,
#exportSlidesPanel .theme-export-card.color {
  min-height: 42px !important;
  border-radius: 9px !important;
  padding: 6px 8px !important;
}

#exportSlidesPanel .theme-export-card strong {
  font-size: 0.75rem !important;
  line-height: 1.05 !important;
}

#exportSlidesPanel .theme-export-card small {
  display: none !important;
}

#exportSlidesPanel .theme-card-swatch {
  width: 25px !important;
  height: 22px !important;
  border-radius: 7px !important;
}

#exportSlidesPanel .slides-color-controls {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 6px !important;
  padding: 6px !important;
  border-radius: 10px !important;
}

#exportSlidesPanel .slides-color-picker-control {
  grid-template-columns: minmax(0, 1fr) 34px !important;
  gap: 5px !important;
  font-size: 0.66rem !important;
}

#exportSlidesPanel .slides-color-picker-control input[type="color"] {
  width: 34px !important;
  height: 28px !important;
  border-radius: 8px !important;
  padding: 3px !important;
}

#exportSlidesPanel .slides-color-swatch-row {
  gap: 4px !important;
}

#exportSlidesPanel .slides-color-swatch-row button {
  width: 20px !important;
  height: 20px !important;
}

#exportSlidesPanel .slides-more-background-button {
  min-height: 32px !important;
}

@media (max-width: 760px) {
  #exportSlidesPanel .theme-export-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  #exportSlidesPanel .theme-export-card,
  #exportSlidesPanel .theme-export-card.color {
    min-height: 34px !important;
    padding: 5px 7px !important;
  }

  #exportSlidesPanel .slides-color-controls {
    grid-template-columns: 1fr 1fr !important;
  }

  html:not(.lineup-native-ios-shell) .song-bank-list {
    gap: 8px !important;
    padding-bottom: calc(18px + env(safe-area-inset-bottom, 0px)) !important;
  }

  html:not(.lineup-native-ios-shell) .bank-song {
    display: block !important;
    height: auto !important;
    min-height: 62px !important;
    max-height: none !important;
    padding: 0 !important;
    overflow: hidden !important;
  }

  html:not(.lineup-native-ios-shell) .bank-song .bank-song-main-content {
    position: relative !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 32px 32px 32px !important;
    align-items: center !important;
    min-height: 58px !important;
    height: auto !important;
    gap: 6px !important;
    padding: 7px 9px !important;
    transform: translateX(0);
  }

  html:not(.lineup-native-ios-shell) .bank-song.has-recording .bank-song-main-content {
    grid-template-columns: minmax(0, 1fr) 30px max-content 30px 30px !important;
  }

  html:not(.lineup-native-ios-shell) .bank-song .song-name {
    min-height: 1.1em !important;
    line-height: 1.1 !important;
  }

  html:not(.lineup-native-ios-shell) .bank-song .banger-toggle,
  html:not(.lineup-native-ios-shell) .bank-slides-button,
  html:not(.lineup-native-ios-shell) .bank-sheets-button,
  html:not(.lineup-native-ios-shell) .bank-edit-button,
  html:not(.lineup-native-ios-shell) .bank-recording-cluster .recording-play-button {
    width: 30px !important;
    min-width: 30px !important;
    height: 30px !important;
    min-height: 30px !important;
    border-radius: 9px !important;
  }

  html:not(.lineup-native-ios-shell) .lineup-add-actions:not([hidden]) {
    bottom: max(
      env(safe-area-inset-bottom, 0px),
      calc(var(--lineup-add-actions-bottom, var(--mobile-library-height, var(--lineup-add-bar-bank-height, 0px))) - 23px)
    ) !important;
  }

  html:not(.lineup-native-ios-shell) .lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab .add-tray-mini-icons {
    display: none !important;
  }

  html:not(.lineup-native-ios-shell) .lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab::before,
  html:not(.lineup-native-ios-shell) .lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab::after {
    content: "" !important;
    position: absolute !important;
    top: 50% !important;
    left: 50% !important;
    z-index: 2 !important;
    display: block !important;
    border-radius: 999px !important;
    background: currentColor !important;
    transform: translate(-50%, -50%) !important;
  }

  html:not(.lineup-native-ios-shell) .lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab::before {
    width: 19px !important;
    height: 3px !important;
  }

  html:not(.lineup-native-ios-shell) .lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab::after {
    width: 3px !important;
    height: 19px !important;
  }

  html.lineup-native-ios-shell .lineup-add-actions:not([hidden]) {
    bottom: max(
      env(safe-area-inset-bottom, 0px),
      calc(
        var(--lineup-add-actions-bottom, var(--mobile-library-height, var(--lineup-add-bar-bank-height, 0px)))
        + max(14px, env(safe-area-inset-bottom, 0px))
        + 8px
      )
    ) !important;
    transform: none !important;
    will-change: bottom;
  }

  html.lineup-native-ios-shell .app-shell.mobile-library-dragging .bank-panel:not(.manage-mode),
  html.lineup-native-ios-shell .app-shell.mobile-library-settling .bank-panel:not(.manage-mode),
  html.lineup-native-ios-shell .bank-panel.is-dragging {
    transition: none !important;
    -webkit-backdrop-filter: none !important;
    backdrop-filter: none !important;
  }

  html.lineup-native-ios-shell .app-shell.mobile-library-dragging .lineup-add-actions:not([hidden]),
  html.lineup-native-ios-shell .app-shell.mobile-library-settling .lineup-add-actions:not([hidden]) {
    transition: none !important;
  }

  html.lineup-native-ios-shell .lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab .add-tray-mini-icons {
    display: none !important;
  }

  html.lineup-native-ios-shell .lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab::before,
  html.lineup-native-ios-shell .lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab::after {
    content: "" !important;
    position: absolute !important;
    top: 50% !important;
    left: 50% !important;
    z-index: 2 !important;
    display: block !important;
    border-radius: 999px !important;
    background: currentColor !important;
    transform: translate(-50%, -50%) !important;
  }

  html.lineup-native-ios-shell .lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab::before {
    width: 19px !important;
    height: 3px !important;
  }

  html.lineup-native-ios-shell .lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab::after {
    width: 3px !important;
    height: 19px !important;
  }
}

/* v395: compact phone export screens, opt-in note slides, and paged sheet-pack previews. */
.more-background-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

#exportSlidesPanel .theme-export-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
}

#exportSlidesPanel .theme-export-card,
#exportSlidesPanel .theme-export-card.color,
.slides-background-dialog .theme-export-card {
  min-height: 42px !important;
  padding: 7px 9px !important;
}

#exportSlidesPanel .theme-export-card strong,
.slides-background-dialog .theme-export-card strong {
  font-size: 0.75rem !important;
}

#exportSlidesPanel .theme-export-card small,
.slides-background-dialog .theme-export-card small {
  display: none !important;
}

.note-slide-action {
  position: relative;
}

.note-slide-action.has-slides,
.note-slide-action.ready {
  border-color: color-mix(in srgb, var(--green) 64%, var(--line));
  color: var(--green);
  background: color-mix(in srgb, var(--green) 14%, transparent);
}

.sheet-pack-choose-button {
  display: none;
  justify-content: center;
}

.sheet-pack-chooser-dialog {
  width: min(560px, calc(100vw - 18px));
}

.sheet-pack-chooser-dialog form {
  max-height: calc(var(--lineup-viewport-height, 100dvh) - 18px);
}

.sheet-pack-mobile-selection {
  max-height: min(62dvh, 560px);
}

.sheet-pack-preview-toolbar {
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr) 38px auto;
  align-items: center;
  width: min(100%, 360px);
  gap: 8px;
  color: #111827;
}

.sheet-pack-preview-toolbar .ghost-button {
  width: 38px;
  min-width: 38px;
  height: 34px;
  min-height: 34px;
  border-radius: 10px;
  padding: 0;
  color: #111827;
  background: rgba(255, 255, 255, 0.76);
}

.sheet-pack-preview-toolbar svg {
  width: 18px;
  height: 18px;
}

.sheet-pack-preview-toolbar strong,
.sheet-pack-preview-toolbar span {
  justify-self: center;
  color: #111827;
  font-size: 0.78rem;
  font-weight: 900;
}

.sheet-pack-preview-toolbar span {
  justify-self: end;
  color: rgba(15, 23, 42, 0.62);
  font-size: 0.68rem;
}

.sheet-pack-preview-page-shell {
  position: relative;
  display: grid;
  justify-items: center;
  gap: 7px;
}

.sheet-pack-page-mark {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 3;
  min-height: 28px;
  border: 1px solid rgba(15, 23, 42, 0.18);
  border-radius: 999px;
  padding: 0 10px;
  color: #1f2937;
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 8px 20px rgba(15, 23, 42, 0.16);
  font-size: 0.66rem;
  font-weight: 900;
}

.sheet-pack-page-mark[aria-pressed="true"] {
  border-color: color-mix(in srgb, var(--green) 78%, #1f2937);
  color: #071428;
  background: var(--green);
}

.sheet-pack-preview-page-shell:not(.selected) .sheet-pack-preview-page {
  opacity: 0.42;
  filter: grayscale(0.45);
}

.sheet-pack-export-preview {
  align-content: center !important;
  justify-items: center !important;
  overflow: hidden !important;
}

.sheet-pack-preview-page {
  width: min(100%, 360px) !important;
}

@media (min-width: 761px) {
  .sheet-pack-export-layout {
    grid-template-columns: minmax(230px, 320px) minmax(360px, 1fr) !important;
  }

  .sheet-pack-selection {
    max-height: 100%;
    padding-right: 3px;
  }
}

@media (max-width: 760px) {
  .export-dialog {
    inset: max(6px, env(safe-area-inset-top, 0px)) 8px max(8px, env(safe-area-inset-bottom, 0px)) !important;
    border-radius: 14px !important;
  }

  .export-dialog-inner {
    grid-template-rows: auto auto auto minmax(0, 1fr) auto !important;
    gap: 5px !important;
    padding: 7px !important;
  }

  .export-tabs {
    gap: 4px !important;
  }

  .export-tab {
    min-height: 31px !important;
    border-radius: 9px !important;
  }

  .export-settings {
    grid-template-columns: repeat(8, minmax(0, 1fr)) !important;
    gap: 4px !important;
    padding: 5px !important;
  }

  .export-settings .page-control {
    grid-column: span 2 !important;
  }

  .export-settings .orientation-control.font-control:not(.columns-control):not(.spacing-control):not(.pages-control) {
    grid-column: span 6 !important;
  }

  .export-settings .columns-control {
    grid-column: span 4 !important;
  }

  .export-settings .pages-control {
    grid-column: span 4 !important;
    display: grid !important;
  }

  .export-settings .spacing-control {
    grid-column: span 4 !important;
  }

  .export-settings .export-toggle-row {
    grid-column: span 4 !important;
  }

  .export-settings .fit-toggle {
    grid-column: span 4 !important;
  }

  .export-settings .orientation-control,
  .export-settings .export-option {
    min-height: 31px !important;
    border-radius: 9px !important;
    padding: 3px !important;
  }

  .export-settings legend {
    font-size: 0.54rem !important;
    line-height: 1 !important;
  }

  .export-settings .orientation-control span,
  .export-settings .export-option span {
    min-height: 24px !important;
    border-radius: 7px !important;
    padding: 0 3px !important;
    font-size: 0.6rem !important;
    line-height: 1 !important;
  }

  .export-settings .fit-toggle span {
    font-size: 0 !important;
  }

  .export-settings .fit-toggle span::after {
    content: "Fit";
    font-size: 0.6rem;
  }

  .export-preview {
    padding: 6px !important;
  }

  .export-sheet-preview-stack {
    width: 100% !important;
    height: 100% !important;
    display: grid !important;
    place-items: center !important;
  }

  .export-sheet-preview.image-preview {
    width: auto !important;
    max-width: 100% !important;
    height: auto !important;
    max-height: 100% !important;
    aspect-ratio: 595 / 842 !important;
  }

  .export-sheet-preview.image-preview.landscape {
    aspect-ratio: 842 / 595 !important;
  }

  .dialog-actions.export-actions {
    gap: 5px !important;
  }

  .dialog-actions.export-actions .export-file-button {
    min-height: 38px !important;
    border-radius: 10px !important;
    padding: 0 6px !important;
    font-size: 0.68rem !important;
  }

  #exportSlidesPanel {
    overflow: hidden !important;
    padding: 7px !important;
  }

  #exportSlidesPanel #slidesExportForm {
    grid-template-rows: minmax(0, 1fr) auto !important;
    height: 100% !important;
    overflow: hidden !important;
  }

  #exportSlidesPanel .slides-theme-export-layout {
    display: grid !important;
    grid-template-columns: 1fr !important;
    grid-template-rows: auto minmax(0, 1fr) !important;
    gap: 7px !important;
    overflow: hidden !important;
  }

  #exportSlidesPanel .slides-export-preview-shell {
    order: 1 !important;
    min-height: 0 !important;
  }

  #exportSlidesPanel .slides-theme-preview {
    min-height: 164px !important;
    max-height: 28dvh !important;
    aspect-ratio: 16 / 9 !important;
  }

  #exportSlidesPanel .slides-theme-controls {
    order: 2 !important;
    max-height: none !important;
    min-height: 0 !important;
    overflow: auto !important;
    gap: 6px !important;
  }

  #exportSlidesPanel .theme-export-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 5px !important;
  }

  #exportSlidesPanel .theme-export-card,
  #exportSlidesPanel .theme-export-card.color {
    min-height: 31px !important;
    border-radius: 8px !important;
    padding: 4px 6px !important;
  }

  #exportSlidesPanel .theme-export-card strong {
    font-size: 0.66rem !important;
  }

  #exportSlidesPanel .theme-card-swatch {
    width: 22px !important;
    height: 20px !important;
  }

  #exportSlidesPanel .slides-color-controls {
    grid-template-columns: 1fr 1fr !important;
    gap: 4px !important;
    padding: 5px !important;
  }

  #exportSlidesPanel .slides-color-picker-control {
    grid-template-columns: 1fr 30px !important;
    font-size: 0.58rem !important;
  }

  #exportSlidesPanel .slides-color-picker-control input[type="color"] {
    width: 30px !important;
    height: 26px !important;
  }

  #exportSlidesPanel .slides-color-swatch-row {
    display: none !important;
  }

  #exportSlidesPanel .slides-more-background-button,
  #exportSlidesPanel .slide-title-option,
  #exportSlidesPanel .ghost-button,
  #exportSlidesPanel .primary-button {
    min-height: 32px !important;
    border-radius: 9px !important;
    font-size: 0.68rem !important;
  }

  #exportSlidesPanel .slide-export-options {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 5px !important;
  }

  #exportSlidesPanel .slide-title-mode-control {
    grid-column: 1 / -1 !important;
  }

  #exportSlidesPanel .slide-title-numbers-control,
  #exportSlidesPanel .slide-title-size-control {
    grid-column: span 2 !important;
  }

  #exportSlidesPanel .slide-title-option {
    justify-content: center !important;
    padding: 4px 5px !important;
  }

  #exportSlidesPanel .dialog-actions.compact {
    position: relative !important;
    z-index: 8 !important;
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 5px !important;
    border: 1px solid color-mix(in srgb, var(--line) 80%, transparent) !important;
    border-radius: 12px !important;
    padding: 6px !important;
    background: color-mix(in srgb, var(--panel) 98%, #05070b) !important;
    box-shadow: 0 -10px 22px rgba(0, 0, 0, 0.22) !important;
  }

  #exportSlidesPanel .dialog-actions.compact > span {
    display: none !important;
  }

  #exportSheetsPanel {
    grid-template-rows: auto auto minmax(0, 1fr) auto !important;
    overflow: hidden !important;
  }

  #exportSheetsPanel > .utility-copy {
    display: none !important;
  }

  .sheet-pack-choose-button {
    display: flex !important;
    min-height: 36px !important;
    border-radius: 10px !important;
  }

  .sheet-pack-export-layout {
    grid-template-columns: 1fr !important;
    gap: 7px !important;
  }

  #exportSheetsPanel .sheet-pack-selection {
    display: none !important;
  }

  .sheet-pack-export-preview {
    padding: 8px !important;
  }

  .sheet-pack-preview-toolbar {
    width: min(100%, 320px) !important;
    grid-template-columns: 34px minmax(0, 1fr) 34px auto !important;
    gap: 5px !important;
  }

  .sheet-pack-preview-toolbar .ghost-button {
    width: 34px !important;
    min-width: 34px !important;
    height: 32px !important;
  }

  .sheet-pack-preview-page {
    width: min(100%, 300px) !important;
    max-height: 48dvh !important;
  }

  .sheet-pack-chooser-dialog {
    inset: max(6px, env(safe-area-inset-top, 0px)) 8px max(8px, env(safe-area-inset-bottom, 0px)) !important;
    width: auto !important;
    height: auto !important;
    max-width: none !important;
    max-height: none !important;
    border-radius: 14px !important;
  }

  .sheet-pack-chooser-dialog form {
    height: 100% !important;
    max-height: none !important;
    grid-template-rows: auto minmax(0, 1fr) auto !important;
  }

  .sheet-pack-mobile-selection {
    max-height: none !important;
    overflow: auto !important;
  }

  .slides-editor-dialog {
    overflow: hidden !important;
  }

  .slides-workspace-view {
    grid-template-columns: 1fr !important;
    grid-template-rows: minmax(160px, 34dvh) 86px minmax(118px, 1fr) auto !important;
    grid-template-areas:
      "preview"
      "strip"
      "edit"
      "tools" !important;
    gap: 6px !important;
    padding: 6px 7px calc(7px + env(safe-area-inset-bottom, 0px)) !important;
  }

  .slides-strip {
    min-height: 0 !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
  }

  .slides-editor-list {
    grid-auto-flow: column !important;
    grid-auto-columns: minmax(108px, 132px) !important;
    grid-template-columns: none !important;
  }

  .slides-live-area {
    min-height: 0 !important;
  }

  .slides-edit-panel,
  .slides-tools-panel {
    min-height: 0 !important;
    overflow: auto !important;
  }
}

/* v396: keep the phone slide editor in clean stacked lanes. */
@media (max-width: 760px) {
  .slides-workspace-view {
    grid-template-rows: minmax(168px, 33dvh) 106px minmax(214px, 1fr) 82px !important;
    overflow: hidden !important;
  }

  .slides-strip {
    display: block !important;
    min-height: 0 !important;
    border: 0 !important;
    background: #f8fafc !important;
    overflow: hidden !important;
  }

  .slides-selection-bar {
    display: none !important;
  }

  .slides-editor-list {
    display: flex !important;
    align-items: stretch !important;
    gap: 7px !important;
    width: 100% !important;
    height: 100% !important;
    min-height: 0 !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    padding: 0 26px 8px 2px !important;
    scroll-snap-type: x proximity !important;
    -webkit-overflow-scrolling: touch !important;
  }

  .slides-list-item {
    flex: 0 0 122px !important;
    height: 100% !important;
    min-height: 0 !important;
  }

  .slides-workspace-view .slides-live-preview-wrap,
  .slides-workspace-view .slides-edit-panel,
  .slides-workspace-view .slides-quick-actions {
    position: relative !important;
    z-index: 1 !important;
    overflow: hidden !important;
  }

  .slides-workspace-view .slides-quick-actions {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    grid-template-rows: repeat(2, minmax(0, 1fr)) !important;
    grid-auto-rows: minmax(0, 1fr) !important;
    align-content: stretch !important;
  }

  .slides-quick-actions .ghost-button,
  .slides-quick-actions .danger-button {
    height: 100% !important;
    min-height: 0 !important;
    padding: 3px 1px !important;
    gap: 2px !important;
  }

  .slides-workspace-view .slides-edit-panel {
    overflow: auto !important;
  }

  .slides-object-toolbar {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 5px !important;
  }

  .slides-object-toolbar .ghost-button,
  .slides-object-toolbar .danger-button {
    min-width: 0 !important;
    min-height: 30px !important;
    padding: 0 6px !important;
    border-radius: 9px !important;
    font-size: 0.64rem !important;
  }

  #slidesJoinNextButton span,
  #slidesDuplicateButton span,
  #slidesDeleteButton span {
    font-size: 0 !important;
  }

  #slidesJoinNextButton span::after,
  #slidesDuplicateButton span::after,
  #slidesDeleteButton span::after {
    font-size: 0.56rem !important;
    font-weight: 800 !important;
    line-height: 1 !important;
    white-space: nowrap !important;
  }

  #slidesJoinNextButton span::after {
    content: "Join";
  }

  #slidesDuplicateButton span::after {
    content: "Copy";
  }

  #slidesDeleteButton span::after {
    content: "Delete";
  }

  .export-settings .fit-toggle::before,
  .export-settings .fit-toggle span::before {
    display: none !important;
    content: none !important;
  }

  .export-settings .fit-toggle span {
    font-size: 0 !important;
  }

  .export-settings .fit-toggle span::after {
    content: "Fit" !important;
    font-size: 0.6rem !important;
  }

  .export-settings .orientation-control.font-control label span::before,
  .export-settings .orientation-control.font-control label span::after,
  .export-settings .export-option span::before,
  .export-settings .export-option span::after {
    display: none !important;
    content: none !important;
  }

  .export-settings .orientation-control.font-control label span,
  .export-settings .export-option span {
    font-size: 0 !important;
  }

  .export-settings .orientation-control.font-control label span::after,
  .export-settings .export-option span::after {
    display: inline !important;
    font-size: 0.6rem !important;
    font-weight: 850 !important;
    line-height: 1 !important;
    content: attr(data-export-phone-label) !important;
  }

  .export-settings .orientation-control.font-control:not(.columns-control):not(.spacing-control):not(.pages-control) label:nth-of-type(1) span::after {
    content: "Auto" !important;
  }

  .export-settings .orientation-control.font-control:not(.columns-control):not(.spacing-control):not(.pages-control) label:nth-of-type(2) span::after {
    content: "S" !important;
  }

  .export-settings .orientation-control.font-control:not(.columns-control):not(.spacing-control):not(.pages-control) label:nth-of-type(3) span::after {
    content: "M" !important;
  }

  .export-settings .orientation-control.font-control:not(.columns-control):not(.spacing-control):not(.pages-control) label:nth-of-type(4) span::after {
    content: "L" !important;
  }

  .export-settings .columns-control label:nth-of-type(1) span::after,
  .export-settings .pages-control label:nth-of-type(1) span::after {
    content: "Auto" !important;
  }

  .export-settings .columns-control label:nth-of-type(2) span::after,
  .export-settings .pages-control label:nth-of-type(2) span::after,
  .export-settings .spacing-control label:nth-of-type(1) span::after {
    content: "1" !important;
  }

  .export-settings .columns-control label:nth-of-type(3) span::after,
  .export-settings .pages-control label:nth-of-type(3) span::after,
  .export-settings .spacing-control label:nth-of-type(2) span::after {
    content: "2" !important;
  }

  .export-settings .pages-control label:nth-of-type(4) span::after,
  .export-settings .spacing-control label:nth-of-type(3) span::after {
    content: "3" !important;
  }

  .export-settings .credit-toggle span::after {
    content: "Credits" !important;
    font-size: 0.52rem !important;
  }

  .export-settings .real-key-toggle span::after {
    content: "Real key" !important;
    font-size: 0.52rem !important;
  }

  .export-settings .fit-toggle span::after {
    content: "Fit" !important;
  }

  .export-settings {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    align-items: stretch !important;
    gap: 4px !important;
  }

  .export-settings .page-control {
    grid-column: span 1 !important;
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    grid-template-rows: 1fr !important;
    gap: 3px !important;
    min-height: 40px !important;
  }

  .export-settings .page-control legend {
    display: none !important;
  }

  .export-settings .orientation-control.font-control {
    display: grid !important;
    grid-template-rows: 12px 32px !important;
    gap: 2px !important;
    align-items: stretch !important;
    min-height: 50px !important;
  }

  .export-settings .orientation-control.font-control:not(.columns-control):not(.spacing-control):not(.pages-control) {
    grid-column: span 3 !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  }

  .export-settings .pages-control {
    grid-column: 1 / -1 !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  }

  .export-settings .columns-control,
  .export-settings .spacing-control {
    grid-column: span 2 !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }

  .export-settings .orientation-control.font-control legend {
    display: none !important;
  }

  .export-settings .orientation-control.font-control legend::before,
  .export-settings .orientation-control.font-control legend::after {
    display: none !important;
    content: none !important;
  }

  .export-settings .orientation-control.font-control::before {
    grid-column: 1 / -1 !important;
    display: block !important;
    height: 12px !important;
    overflow: hidden !important;
    color: var(--muted) !important;
    font-size: 0.5rem !important;
    font-weight: 950 !important;
    line-height: 1 !important;
    letter-spacing: 0 !important;
    text-transform: uppercase !important;
  }

  .export-settings .orientation-control.font-control:not(.columns-control):not(.spacing-control):not(.pages-control)::before {
    content: "Text size" !important;
  }

  .export-settings .columns-control::before {
    content: "Columns" !important;
  }

  .export-settings .pages-control::before {
    content: "Pages" !important;
  }

  .export-settings .spacing-control::before {
    content: "Spacing" !important;
  }

  .export-settings .orientation-control.font-control label,
  .export-settings .orientation-control.font-control span {
    min-height: 0 !important;
    height: 100% !important;
  }

  .export-settings .export-toggle-row {
    grid-column: span 2 !important;
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 4px !important;
  }

  .export-settings .fit-toggle {
    grid-column: span 2 !important;
    display: grid !important;
    min-height: 50px !important;
  }

  .export-sheet-preview-stack {
    align-items: center !important;
    justify-items: center !important;
  }

  .export-sheet-preview.image-preview {
    width: min(100%, calc(50dvh * 595 / 842), 340px) !important;
    height: auto !important;
    max-width: 100% !important;
    max-height: 100% !important;
    aspect-ratio: 595 / 842 !important;
  }

  .export-sheet-preview.image-preview.landscape {
    width: 100% !important;
    height: auto !important;
    aspect-ratio: 842 / 595 !important;
  }
}

/* v397 final overrides: keep these after the older accumulated phone rules. */
@media (max-width: 760px) {
  .export-settings {
    display: none !important;
  }

  .phone-export-compact-controls:not([hidden]) {
    grid-column: 1 !important;
    grid-row: 3 !important;
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 5px !important;
  }

  .export-preview,
  .export-sheet-preview-stack {
    display: grid !important;
    place-items: center !important;
    overflow: hidden !important;
  }

  .export-sheet-preview.image-preview {
    width: auto !important;
    height: min(100%, 62dvh) !important;
    max-width: 100% !important;
    max-height: 100% !important;
    aspect-ratio: 595 / 842 !important;
  }

  .export-sheet-preview.image-preview.landscape {
    width: min(100%, 72dvw) !important;
    height: auto !important;
    aspect-ratio: 842 / 595 !important;
  }

  #exportSlidesPanel .slides-other-tools {
    display: grid !important;
    grid-template-columns: auto repeat(3, 34px) !important;
  }

  #exportSlidesPanel .slide-export-options {
    grid-template-columns: minmax(0, .85fr) minmax(0, 1.1fr) minmax(0, .9fr) minmax(0, .9fr) !important;
  }

  #exportSlidesPanel .dialog-actions.compact {
    position: sticky !important;
    bottom: 0 !important;
    z-index: 12 !important;
    background: color-mix(in srgb, var(--panel) 98%, #05070b) !important;
  }

  .slides-editor-dialog .slides-object-panel,
  .slides-editor-dialog.note-slide-editor .slides-line-control-panel {
    display: none !important;
  }

  .lineup-add-actions:not([hidden]) {
    bottom: max(env(safe-area-inset-bottom, 0px), calc(var(--lineup-add-actions-bottom, var(--mobile-library-height, var(--lineup-add-bar-bank-height, 0px))) + 10px)) !important;
  }

  html.lineup-native-ios-shell .lineup-add-actions:not([hidden]) {
    bottom: max(env(safe-area-inset-bottom, 0px), calc(var(--lineup-add-actions-bottom, var(--mobile-library-height, var(--lineup-add-bar-bank-height, 0px))) + max(14px, env(safe-area-inset-bottom, 0px)) + 8px)) !important;
  }
}

/* v398 final phone drawer alignment: override the older shell-specific tray rules. */
@media (max-width: 760px) {
  html:not(.lineup-native-ios-shell) .lineup-add-actions:not([hidden]) {
    bottom: max(
      env(safe-area-inset-bottom, 0px),
      calc(var(--lineup-add-actions-bottom, var(--mobile-library-height, var(--lineup-add-bar-bank-height, 0px))) + 16px)
    ) !important;
  }

  html.lineup-native-ios-shell .lineup-add-actions:not([hidden]) {
    bottom: max(
      env(safe-area-inset-bottom, 0px),
      calc(
        var(--lineup-add-actions-bottom, var(--mobile-library-height, var(--lineup-add-bar-bank-height, 0px)))
        + max(18px, env(safe-area-inset-bottom, 0px))
        + 12px
      )
    ) !important;
  }

  .app-shell.mobile-library-dragging .lineup-add-actions:not([hidden]),
  .app-shell.mobile-library-settling .lineup-add-actions:not([hidden]),
  html.lineup-native-ios-shell .app-shell.mobile-library-dragging .lineup-add-actions:not([hidden]),
  html.lineup-native-ios-shell .app-shell.mobile-library-settling .lineup-add-actions:not([hidden]) {
    transition: none !important;
  }

  body.guest-mode .app-shell {
    --lineup-guest-bottom-reserve: 48px;
  }

  body.guest-mode .app-shell.bank-collapsed .show-panel,
  body.guest-mode .app-shell.mobile-library-minimized .show-panel,
  body.guest-mode .app-shell.mobile-library-middle .show-panel,
  body.guest-mode .app-shell.mobile-library-full .show-panel {
    padding-bottom: max(
      0px,
      calc(var(--mobile-library-height, var(--lineup-add-bar-bank-height, 0px)) - var(--lineup-guest-bottom-reserve, 0px))
    ) !important;
  }
}

/* v400: final phone export, drawer ceiling, logo actions, and tight add button alignment. */
.logo-action-button {
  appearance: none;
  -webkit-appearance: none;
  border: 0;
  padding: 0;
  color: inherit;
  background: transparent;
  font: inherit;
  cursor: pointer;
}

.logo-action-button:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--green) 72%, white);
  outline-offset: 3px;
}

@media (max-width: 760px) {
  .export-actions[hidden],
  .export-settings[hidden],
  .export-preview[hidden],
  .phone-export-compact-controls[hidden],
  .export-tab-panel[hidden],
  #exportSlidesPanel[hidden],
  #exportSheetsPanel[hidden] {
    display: none !important;
  }

  .export-dialog {
    inset: calc(8px + env(safe-area-inset-top, 0px)) 10px calc(8px + env(safe-area-inset-bottom, 0px)) !important;
    border-radius: 16px !important;
  }

  html.lineup-native-ios-shell .export-dialog {
    inset: calc(12px + env(safe-area-inset-top, 0px)) 10px calc(10px + env(safe-area-inset-bottom, 0px)) !important;
  }

  .export-dialog-inner {
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto auto minmax(0, 1fr) auto !important;
    gap: 7px !important;
    padding: 8px !important;
    overflow: hidden !important;
  }

  .export-dialog .dialog-header {
    min-height: 44px !important;
  }

  .export-dialog .dialog-header h2 {
    font-size: 1.45rem !important;
    line-height: 1 !important;
  }

  .export-tabs {
    gap: 5px !important;
  }

  .export-tab {
    min-height: 36px !important;
    border-radius: 10px !important;
    font-size: 0 !important;
  }

  .export-tab::after {
    font-size: 0.72rem !important;
    font-weight: 950 !important;
  }

  .export-tab[data-export-tab="setlist"]::after {
    content: "Setlist";
  }

  .export-tab[data-export-tab="slides"]::after {
    content: "Slides";
  }

  .export-tab[data-export-tab="sheets"]::after {
    content: "Sheets";
  }

  .phone-export-compact-controls:not([hidden]) {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 5px !important;
    border-radius: 13px !important;
    padding: 6px !important;
    background: color-mix(in srgb, var(--panel) 84%, #05070b) !important;
  }

  .phone-export-compact-controls label {
    gap: 3px !important;
    font-size: 0.54rem !important;
  }

  .phone-export-compact-controls select,
  .phone-export-compact-controls .compact-check {
    min-height: 34px !important;
    border-radius: 10px !important;
    font-size: 0.75rem !important;
  }

  .phone-export-compact-controls .compact-check {
    justify-content: flex-start !important;
    padding: 0 8px !important;
  }

  .phone-export-compact-controls .compact-check input {
    flex: 0 0 auto !important;
  }

  .phone-export-compact-controls select:disabled {
    opacity: 0.42 !important;
  }

  .export-preview {
    grid-column: 1 !important;
    grid-row: 4 !important;
    min-height: 0 !important;
    border: 1px solid color-mix(in srgb, var(--line) 82%, transparent) !important;
    border-radius: 13px !important;
    padding: 8px !important;
    background: color-mix(in srgb, var(--panel) 82%, #05070b) !important;
  }

  .export-sheet-preview-stack {
    width: 100% !important;
    height: 100% !important;
    max-height: 100% !important;
    align-items: center !important;
    justify-items: center !important;
    gap: 8px !important;
    overflow: auto !important;
    overscroll-behavior: contain !important;
  }

  .export-sheet-preview.image-preview {
    width: min(100%, calc((100dvh - 292px) * 210 / 297), 360px) !important;
    height: auto !important;
    max-height: 100% !important;
    aspect-ratio: 210 / 297 !important;
    border-radius: 8px !important;
  }

  .export-sheet-preview.image-preview.landscape {
    width: min(100%, 78dvw, 430px) !important;
    height: auto !important;
    aspect-ratio: 297 / 210 !important;
  }

  .export-sheet-preview.image-preview img {
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
  }

  .dialog-actions.export-actions {
    grid-row: 5 !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 6px !important;
    padding: 0 !important;
    background: transparent !important;
  }

  .dialog-actions.export-actions .export-file-button {
    min-height: 42px !important;
    border-radius: 11px !important;
    font-size: 0.7rem !important;
  }

  #exportSlidesPanel {
    grid-column: 1 !important;
    grid-row: 3 / 6 !important;
    display: grid !important;
    min-height: 0 !important;
    border-radius: 13px !important;
    padding: 7px !important;
    overflow: hidden !important;
    background: color-mix(in srgb, var(--panel) 88%, #05070b) !important;
  }

  #exportSlidesPanel #slidesExportForm {
    display: grid !important;
    grid-template-rows: minmax(0, 1fr) auto !important;
    gap: 7px !important;
    height: 100% !important;
    min-height: 0 !important;
    overflow: hidden !important;
  }

  #exportSlidesPanel #slidesExportForm > .utility-copy,
  #exportSlidesPanel #slidesExportForm > .dialog-header {
    display: none !important;
  }

  #exportSlidesPanel .slides-theme-export-layout {
    display: grid !important;
    grid-template-columns: 1fr !important;
    grid-template-rows: auto minmax(0, 1fr) !important;
    gap: 7px !important;
    min-height: 0 !important;
    overflow: hidden !important;
  }

  #exportSlidesPanel .slides-export-preview-shell {
    order: 1 !important;
    display: grid !important;
    grid-template-rows: auto auto !important;
    gap: 6px !important;
    min-height: 0 !important;
    overflow: visible !important;
  }

  #exportSlidesPanel .slides-theme-preview {
    width: 100% !important;
    min-height: 168px !important;
    height: min(29dvh, 250px) !important;
    max-height: 250px !important;
    aspect-ratio: 16 / 9 !important;
    border-radius: 12px !important;
  }

  #exportSlidesPanel .slides-export-preview-image {
    object-fit: contain !important;
  }

  #exportSlidesPanel .slides-export-include-control {
    top: 8px !important;
    left: 8px !important;
    min-height: 26px !important;
    gap: 5px !important;
    padding: 0 8px !important;
    font-size: 0.62rem !important;
  }

  #exportSlidesPanel .slides-export-include-control input {
    width: 14px !important;
    height: 14px !important;
  }

  #exportSlidesPanel .slides-export-preview-nav {
    left: 8px !important;
    right: 8px !important;
  }

  #exportSlidesPanel .slides-export-preview-nav button {
    width: 32px !important;
    height: 32px !important;
  }

  #exportSlidesPanel .slides-export-jump-control {
    position: static !important;
    inset: auto !important;
    z-index: 1 !important;
    display: grid !important;
    grid-template-columns: auto minmax(0, 1fr) !important;
    align-items: center !important;
    width: 100% !important;
    transform: none !important;
    border: 1px solid color-mix(in srgb, var(--line) 82%, transparent) !important;
    border-radius: 11px !important;
    padding: 4px 6px !important;
    background: color-mix(in srgb, var(--surface, var(--panel-2)) 78%, #05070b) !important;
    box-shadow: none !important;
  }

  #exportSlidesPanel .slides-export-jump-control > span {
    position: static !important;
    width: auto !important;
    height: auto !important;
    clip: auto !important;
    overflow: visible !important;
    color: var(--muted) !important;
    font-size: 0.58rem !important;
    font-weight: 950 !important;
    text-transform: uppercase !important;
    white-space: nowrap !important;
  }

  #exportSlidesPanel .slides-export-jump-control select {
    height: 32px !important;
    border-radius: 9px !important;
    padding: 0 26px 0 8px !important;
    font-size: 0.74rem !important;
    text-align: left !important;
    text-align-last: left !important;
  }

  #exportSlidesPanel .slides-theme-controls {
    order: 2 !important;
    display: grid !important;
    align-content: start !important;
    gap: 6px !important;
    max-width: 100% !important;
    min-height: 0 !important;
    min-width: 0 !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    padding-right: 0 !important;
    overscroll-behavior: contain !important;
  }

  #exportSlidesPanel .slides-theme-controls > *,
  #exportSlidesPanel .theme-export-grid,
  #exportSlidesPanel .slides-other-tools,
  #exportSlidesPanel .slide-export-options,
  #exportSlidesPanel .dialog-actions.compact {
    max-width: 100% !important;
    min-width: 0 !important;
  }

  #exportSlidesPanel .theme-export-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 5px !important;
  }

  #exportSlidesPanel .theme-icon-card {
    min-height: 34px !important;
    border-radius: 9px !important;
    padding: 4px 6px !important;
  }

  #exportSlidesPanel .theme-icon-card strong {
    font-size: 0 !important;
  }

  #exportSlidesPanel .theme-icon-card strong::after {
    font-size: 0.7rem !important;
  }

  #exportSlidesPanel .theme-export-card:has(input[value="default"]) strong::after {
    content: "Dark";
  }

  #exportSlidesPanel .theme-export-card:has(input[value="bright"]) strong::after {
    content: "Bright";
  }

  #exportSlidesPanel .slides-other-tools {
    grid-template-columns: auto repeat(3, 34px) !important;
    min-height: 38px !important;
    gap: 5px !important;
    border-radius: 10px !important;
    padding: 4px 6px !important;
  }

  #exportSlidesPanel .slides-other-tools > span {
    font-size: 0.58rem !important;
  }

  #exportSlidesPanel .icon-color-control,
  #exportSlidesPanel .icon-background-button {
    width: 34px !important;
    min-width: 34px !important;
    height: 32px !important;
    min-height: 32px !important;
    border-radius: 9px !important;
  }

  #exportSlidesPanel .slide-export-options {
    display: grid !important;
    grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.2fr) minmax(0, 0.9fr) minmax(0, 0.85fr) !important;
    gap: 5px !important;
  }

  #exportSlidesPanel .slide-title-size-control {
    grid-column: auto !important;
    gap: 3px !important;
  }

  #exportSlidesPanel .slide-title-size-control > span {
    font-size: 0.52rem !important;
  }

  #exportSlidesPanel .slide-title-option,
  #exportSlidesPanel .slide-title-size-control select {
    min-height: 32px !important;
    border-radius: 9px !important;
  }

  #exportSlidesPanel .slide-title-option {
    padding: 4px 5px !important;
  }

  #exportSlidesPanel .slide-title-option span {
    font-size: 0.62rem !important;
  }

  #exportSlidesPanel .slide-title-size-control select {
    font-size: 0.66rem !important;
  }

  #exportSlidesPanel .dialog-actions.compact {
    position: relative !important;
    bottom: auto !important;
    z-index: 12 !important;
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 6px !important;
    border: 1px solid color-mix(in srgb, var(--line) 82%, transparent) !important;
    border-radius: 12px !important;
    padding: 6px !important;
    background: color-mix(in srgb, var(--panel) 98%, #05070b) !important;
    box-shadow: 0 -10px 22px rgba(0, 0, 0, 0.22) !important;
  }

  #exportSlidesPanel .dialog-actions.compact > span {
    display: none !important;
  }

  #exportSlidesPanel .dialog-actions.compact .ghost-button,
  #exportSlidesPanel .dialog-actions.compact .primary-button {
    min-height: 38px !important;
    border-radius: 10px !important;
    padding: 0 6px !important;
    font-size: 0.72rem !important;
  }

  #exportSheetsPanel {
    grid-column: 1 !important;
    grid-row: 3 / 6 !important;
    min-height: 0 !important;
    border-radius: 13px !important;
    overflow: hidden !important;
  }

  .sheet-pack-export-layout {
    grid-template-columns: 1fr !important;
    grid-template-rows: auto minmax(0, 1fr) !important;
    min-height: 0 !important;
  }

  .mobile-show-symbol.logo-action-button,
  .bank-logo.logo-action-button {
    -webkit-tap-highlight-color: transparent;
  }

  .lineup-add-actions:not([hidden]),
  html:not(.lineup-native-ios-shell) .lineup-add-actions:not([hidden]),
  html.lineup-native-ios-shell .lineup-add-actions:not([hidden]) {
    bottom: max(
      env(safe-area-inset-bottom, 0px),
      calc(var(--lineup-add-actions-bottom, var(--mobile-library-height, var(--lineup-add-bar-bank-height, 0px))) + 7px)
    ) !important;
  }

  .app-shell.mobile-library-dragging .lineup-add-actions:not([hidden]),
  .app-shell.mobile-library-settling .lineup-add-actions:not([hidden]),
  html.lineup-native-ios-shell .app-shell.mobile-library-dragging .lineup-add-actions:not([hidden]),
  html.lineup-native-ios-shell .app-shell.mobile-library-settling .lineup-add-actions:not([hidden]) {
    transition: none !important;
  }
}

/* v401 row overflow, compact exports, and drawer controls */
.logo-action-button.brand-mark {
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  padding: 0 !important;
  border-radius: 0 !important;
}

.logo-action-button.brand-mark:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--accent) 78%, white) !important;
  outline-offset: 4px !important;
  box-shadow: none !important;
}

.row-overflow-menu {
  display: none;
  position: relative;
  z-index: 16;
  flex: 0 0 auto;
}

.row-overflow-menu summary {
  list-style: none;
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border: 1px solid var(--line);
  border-radius: 12px;
  color: var(--muted);
  font-weight: 950;
  line-height: 1;
  background: linear-gradient(180deg, rgba(255,255,255,0.055), rgba(255,255,255,0.018));
  cursor: pointer;
}

.row-overflow-menu summary::-webkit-details-marker {
  display: none;
}

.lineup-row-more .bank-row-more-menu {
  right: 0;
  left: auto;
}

.overflow-level-1 .row-overflow-menu,
.overflow-level-2 .row-overflow-menu,
.overflow-level-3 .row-overflow-menu,
.overflow-level-4 .row-overflow-menu,
.overflow-level-5 .row-overflow-menu,
.overflow-level-6 .row-overflow-menu,
.overflow-level-7 .row-overflow-menu,
.overflow-level-8 .row-overflow-menu {
  display: block;
}

.bank-song.overflow-level-1 .bank-edit-button,
.bank-song.overflow-level-2 .bank-edit-button,
.bank-song.overflow-level-3 .bank-edit-button,
.bank-song.overflow-level-4 .bank-edit-button,
.bank-song.overflow-level-5 .bank-edit-button {
  display: none !important;
}

.bank-song.overflow-level-2 .banger-toggle,
.bank-song.overflow-level-3 .banger-toggle,
.bank-song.overflow-level-4 .banger-toggle,
.bank-song.overflow-level-5 .banger-toggle {
  display: none !important;
}

.bank-song.overflow-level-3 .bank-recording-cluster,
.bank-song.overflow-level-4 .bank-recording-cluster,
.bank-song.overflow-level-5 .bank-recording-cluster {
  display: none !important;
}

.bank-song.overflow-level-4 .bank-sheets-button,
.bank-song.overflow-level-5 .bank-sheets-button {
  display: none !important;
}

.bank-song.overflow-level-5 .bank-slides-button {
  display: none !important;
}

.bank-song.overflow-level-1 .bank-row-more,
.bank-song.overflow-level-2 .bank-row-more,
.bank-song.overflow-level-3 .bank-row-more,
.bank-song.overflow-level-4 .bank-row-more,
.bank-song.overflow-level-5 .bank-row-more {
  display: block !important;
}

.lineup-row.overflow-level-1 .row-icon-actions .danger,
.lineup-row.overflow-level-2 .row-icon-actions .danger,
.lineup-row.overflow-level-3 .row-icon-actions .danger,
.lineup-row.overflow-level-4 .row-icon-actions .danger,
.lineup-row.overflow-level-5 .row-icon-actions .danger,
.lineup-row.overflow-level-6 .row-icon-actions .danger,
.lineup-row.overflow-level-7 .row-icon-actions .danger,
.lineup-row.overflow-level-8 .row-icon-actions .danger {
  display: none !important;
}

.lineup-row.overflow-level-2 .row-icon-actions [data-action="info"],
.lineup-row.overflow-level-3 .row-icon-actions [data-action="info"],
.lineup-row.overflow-level-4 .row-icon-actions [data-action="info"],
.lineup-row.overflow-level-5 .row-icon-actions [data-action="info"],
.lineup-row.overflow-level-6 .row-icon-actions [data-action="info"],
.lineup-row.overflow-level-7 .row-icon-actions [data-action="info"],
.lineup-row.overflow-level-8 .row-icon-actions [data-action="info"],
.lineup-row.note-row.overflow-level-2 .note-inline-actions [data-action="edit-note"],
.lineup-row.note-row.overflow-level-3 .note-inline-actions [data-action="edit-note"],
.lineup-row.slide-only-row.overflow-level-2 .row-icon-actions [data-action="edit-slide-title"],
.lineup-row.slide-only-row.overflow-level-3 .row-icon-actions [data-action="edit-slide-title"] {
  display: none !important;
}

.lineup-row.overflow-level-3 .lineup-note-button,
.lineup-row.overflow-level-4 .lineup-note-button,
.lineup-row.overflow-level-5 .lineup-note-button,
.lineup-row.overflow-level-6 .lineup-note-button,
.lineup-row.overflow-level-7 .lineup-note-button,
.lineup-row.overflow-level-8 .lineup-note-button {
  display: none !important;
}

.lineup-row.overflow-level-4 .lineup-recording-cluster,
.lineup-row.overflow-level-5 .lineup-recording-cluster,
.lineup-row.overflow-level-6 .lineup-recording-cluster,
.lineup-row.overflow-level-7 .lineup-recording-cluster,
.lineup-row.overflow-level-8 .lineup-recording-cluster {
  display: none !important;
}

.lineup-row.overflow-level-5 .key-preview-button,
.lineup-row.overflow-level-6 .key-preview-button,
.lineup-row.overflow-level-7 .key-preview-button,
.lineup-row.overflow-level-8 .key-preview-button {
  display: none !important;
}

.lineup-row.overflow-level-6 .capo-cell,
.lineup-row.overflow-level-7 .capo-cell,
.lineup-row.overflow-level-8 .capo-cell {
  display: none !important;
}

.lineup-row.overflow-level-7 .sheets-status-button,
.lineup-row.overflow-level-8 .sheets-status-button {
  display: none !important;
}

.lineup-row.overflow-level-8 .slides-status-button {
  display: none !important;
}

@media (min-width: 761px) {
  .lineup-row.note-row {
    display: grid !important;
    grid-template-columns: 28px 42px minmax(0, 1fr) 180px !important;
    align-items: center !important;
    gap: 10px !important;
  }

  .lineup-row.note-row .note-inline-actions {
    position: static !important;
    grid-column: 4 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    justify-self: start !important;
    gap: 8px !important;
    transform: none !important;
    opacity: 1 !important;
    pointer-events: auto !important;
  }

  .lineup-row.note-row .note-row-more {
    grid-column: 4 !important;
    justify-self: end !important;
  }

  .lineup-rows,
  .song-bank-list,
  .show-panel,
  .bank-panel {
    padding-bottom: 0 !important;
  }
}

.phone-export-compact-controls .compact-check {
  justify-content: center;
}

.phone-export-compact-controls .compact-check.active,
.phone-export-compact-controls .compact-check[aria-pressed="true"] {
  color: #07101d !important;
  border-color: color-mix(in srgb, var(--accent) 78%, white) !important;
  background: linear-gradient(180deg, #6ea0ff, #3977eb) !important;
  box-shadow: 0 10px 26px color-mix(in srgb, var(--accent) 28%, transparent) !important;
}

.phone-export-compact-controls .compact-pages-field {
  display: grid;
  gap: 3px;
  min-width: 72px;
}

.phone-export-compact-controls .compact-pages-field select {
  text-align: center;
  text-align-last: center;
}

.phone-export-compact-controls .compact-pages-inline {
  display: grid;
  grid-template-columns: minmax(34px, 1fr) max-content;
  gap: 4px;
  align-items: stretch;
}

.phone-export-compact-controls .compact-pages-inline .compact-auto-pages {
  width: auto;
  min-width: 42px;
  padding-inline: 6px;
}

#exportSlidesPanel .theme-export-grid {
  display: grid !important;
  grid-template-columns: repeat(2, max-content) !important;
  justify-content: start !important;
  gap: 8px !important;
}

#exportSlidesPanel .theme-icon-card {
  width: 44px !important;
  min-width: 44px !important;
  height: 40px !important;
  min-height: 40px !important;
  padding: 0 !important;
  border-radius: 10px !important;
}

#exportSlidesPanel .theme-icon-wrap {
  display: grid !important;
  place-items: center !important;
  width: 100% !important;
  height: 100% !important;
}

#exportSlidesPanel .theme-icon-wrap svg {
  width: 21px !important;
  height: 21px !important;
}

#exportSlidesPanel .slides-other-tools {
  display: inline-grid !important;
  grid-template-columns: auto repeat(3, 38px) !important;
  width: max-content !important;
  max-width: 100% !important;
  gap: 7px !important;
  align-items: center !important;
  padding: 6px 8px !important;
  border-radius: 12px !important;
}

#exportSlidesPanel .slides-other-tools > span {
  font-size: 0.72rem !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
}

#exportSlidesPanel .icon-color-control,
#exportSlidesPanel .icon-background-button {
  width: 38px !important;
  min-width: 38px !important;
  height: 36px !important;
  min-height: 36px !important;
  padding: 0 !important;
  border-radius: 10px !important;
}

#exportSlidesPanel .slide-export-options {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 8px !important;
}

#exportSlidesPanel .slide-title-size-control,
#exportSlidesPanel .slide-title-option {
  width: auto !important;
  min-width: 0 !important;
  min-height: 36px !important;
  border-radius: 10px !important;
}

#exportSlidesPanel .slide-title-option[hidden],
#exportSlidesPanel select[hidden],
#exportSlidesPanel .slide-title-numbers-control[hidden] {
  display: none !important;
}

#exportSlidesPanel .slide-title-size-control {
  display: inline-grid !important;
  grid-template-columns: auto auto !important;
  align-items: center !important;
  gap: 7px !important;
  padding: 5px 7px !important;
}

#exportSlidesPanel .slide-title-size-control > span {
  font-size: 0.74rem !important;
  font-weight: 900 !important;
  text-transform: none !important;
}

#exportSlidesPanel .slide-title-size-control select {
  width: auto !important;
  min-width: 86px !important;
  height: 30px !important;
  min-height: 30px !important;
  padding-block: 0 !important;
}

#exportSlidesPanel .slide-title-option {
  display: inline-flex !important;
  padding: 5px 8px !important;
  gap: 6px !important;
}

#exportSlidesPanel .slide-title-option input {
  width: 18px !important;
  height: 18px !important;
}

#exportSlidesPanel .slide-title-option span {
  font-size: 0.76rem !important;
}

#exportSlidesPanel .slides-export-include-control {
  display: grid !important;
  place-items: center !important;
  min-width: 30px !important;
  width: 30px !important;
  height: 30px !important;
  min-height: 30px !important;
  padding: 0 !important;
  border-radius: 999px !important;
}

#exportSlidesPanel .slides-export-include-control input {
  margin: 0 !important;
}

#exportSlidesPanel .slides-export-preview-nav {
  top: auto !important;
  bottom: 8px !important;
  transform: none !important;
  align-items: flex-end !important;
}

#exportSlidesPanel .slides-export-preview-nav button {
  width: 30px !important;
  height: 30px !important;
}

@media (max-width: 760px) {
  #exportDialog.song-dialog.utility-dialog {
    max-height: min(82dvh, 760px) !important;
    overflow: hidden !important;
  }

  #exportDialog form {
    min-height: 0 !important;
  }

  #exportDialog .dialog-header {
    padding-right: 76px !important;
  }

  .phone-export-compact-controls:not([hidden]) {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 6px !important;
    padding: 8px !important;
  }

  .phone-export-compact-controls label,
  .phone-export-compact-controls .compact-pages-field,
  .phone-export-compact-controls .compact-check {
    min-width: 0 !important;
  }

  .phone-export-compact-controls label,
  .phone-export-compact-controls .compact-pages-field {
    display: grid !important;
    gap: 3px !important;
  }

  .phone-export-compact-controls label > span,
  .phone-export-compact-controls .compact-pages-field > span:first-child,
  .phone-export-compact-controls .compact-check span {
    font-size: 0.58rem !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }

  .phone-export-compact-controls select,
  .phone-export-compact-controls .compact-check {
    min-height: 36px !important;
    height: 36px !important;
    border-radius: 10px !important;
    padding: 0 8px !important;
    font-size: 0.74rem !important;
    width: 100% !important;
  }

  .phone-export-compact-controls .compact-check {
    padding-inline: 6px !important;
  }

  .phone-export-compact-controls .compact-pages-field {
    min-width: 0 !important;
  }

  .phone-export-compact-controls .compact-pages-inline {
    grid-template-columns: minmax(30px, 1fr) max-content !important;
    gap: 3px !important;
  }

  .phone-export-compact-controls .compact-auto-pages {
    min-width: 38px !important;
    width: auto !important;
  }

  .phone-export-compact-controls .compact-fit-page {
    min-width: 0 !important;
  }

  .export-preview {
    min-height: 0 !important;
    overflow: hidden !important;
  }

  .export-sheet-preview-stack {
    display: grid !important;
    place-items: center !important;
    width: 100% !important;
    height: 100% !important;
    min-height: 0 !important;
    overflow: hidden !important;
  }

  .export-sheet-preview.image-preview {
    width: min(100%, 360px, calc((82dvh - 290px) * 0.707)) !important;
    height: auto !important;
    max-height: calc(82dvh - 290px) !important;
    aspect-ratio: 210 / 297 !important;
    object-fit: contain !important;
    padding: 8px !important;
  }

  .export-sheet-preview.image-preview.landscape {
    width: min(100%, 430px) !important;
    max-height: calc((100vw - 72px) * 0.707) !important;
    aspect-ratio: 297 / 210 !important;
  }

  .export-sheet-preview.image-preview img {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
    border-radius: 8px !important;
  }

  #exportSlidesPanel .slides-theme-export-layout {
    gap: 6px !important;
  }

  #exportSlidesPanel .slides-theme-preview {
    min-height: 172px !important;
    height: min(26dvh, 220px) !important;
    max-height: 220px !important;
  }

  #exportSlidesPanel .slides-theme-controls {
    overflow: visible !important;
    gap: 6px !important;
  }

  #exportSlidesPanel .theme-export-grid {
    grid-template-columns: repeat(2, 42px) !important;
  }

  #exportSlidesPanel .theme-icon-card {
    width: 42px !important;
    min-width: 42px !important;
    height: 38px !important;
    min-height: 38px !important;
  }

  #exportSlidesPanel .slides-other-tools {
    grid-template-columns: auto repeat(3, 34px) !important;
    padding: 5px 6px !important;
    gap: 5px !important;
  }

  #exportSlidesPanel .icon-color-control,
  #exportSlidesPanel .icon-background-button {
    width: 34px !important;
    min-width: 34px !important;
    height: 32px !important;
    min-height: 32px !important;
  }

  #exportSlidesPanel .slide-export-options {
    gap: 5px !important;
  }

  #exportSlidesPanel .slide-title-size-control,
  #exportSlidesPanel .slide-title-option {
    min-height: 32px !important;
    border-radius: 9px !important;
  }

  #exportSlidesPanel .slide-title-size-control select {
    min-width: 74px !important;
    height: 28px !important;
  }

  #exportSlidesPanel .slide-title-option {
    padding: 4px 6px !important;
  }

  #exportSlidesPanel .dialog-actions.compact {
    position: relative !important;
    bottom: auto !important;
    margin-top: 6px !important;
    background: color-mix(in srgb, var(--panel) 98%, #05070b) !important;
    opacity: 1 !important;
  }

  .lineup-add-actions:not([hidden]),
  html:not(.lineup-native-ios-shell) .lineup-add-actions:not([hidden]),
  html.lineup-native-ios-shell .lineup-add-actions:not([hidden]) {
    bottom: max(
      env(safe-area-inset-bottom, 0px),
      calc(var(--lineup-add-actions-bottom, var(--mobile-library-height, var(--lineup-add-bar-bank-height, 0px))) + 6px)
    ) !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]),
  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) {
    display: flex !important;
    width: auto !important;
    min-width: 0 !important;
    height: auto !important;
    min-height: 0 !important;
    gap: 6px !important;
    padding: 5px !important;
    border-radius: 16px !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden])::before,
  .lineup-add-actions:not(.is-open):not([hidden])::after,
  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden])::before,
  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden])::after {
    display: none !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab,
  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab {
    display: none !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) > .icon-button,
  .lineup-add-actions:not(.is-open):not([hidden]) > #addNoteButton,
  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) > .icon-button,
  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) > #addNoteButton {
    display: grid !important;
    width: 38px !important;
    min-width: 38px !important;
    height: 38px !important;
    min-height: 38px !important;
    opacity: 1 !important;
    pointer-events: auto !important;
    transform: none !important;
    border-radius: 13px !important;
    padding: 0 !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) > .icon-button > span:not(.add-action-icon-stack),
  .lineup-add-actions:not(.is-open):not([hidden]) > #addNoteButton > span:not(.add-action-icon-stack),
  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) > .icon-button > span:not(.add-action-icon-stack),
  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) > #addNoteButton > span:not(.add-action-icon-stack) {
    display: none !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) .add-action-icon-stack,
  .lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton .add-action-icon-stack,
  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .add-action-icon-stack,
  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton .add-action-icon-stack {
    display: grid !important;
    place-items: center !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) svg.add-action-main-icon,
  .lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton svg.add-action-main-icon,
  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) svg.add-action-main-icon,
  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton svg.add-action-main-icon {
    width: 19px !important;
    height: 19px !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) .add-action-plus-icon,
  .lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton .note-plus-icon,
  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) .add-action-plus-icon,
  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) #addNoteButton .note-plus-icon {
    width: 10px !important;
    height: 10px !important;
  }
}

/* v402: phone portrait keeps direct row controls; export uses stable compact controls. */
.compact-layout-field select[hidden] {
  display: none !important;
}

.compact-layout-buttons {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4px;
  min-width: 0;
}

.compact-layout-buttons button {
  display: grid;
  place-items: center;
  min-width: 0;
  height: 36px;
  min-height: 36px;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 0;
  color: var(--muted);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.02));
  cursor: pointer;
}

.compact-layout-buttons button.active,
.compact-layout-buttons button[aria-pressed="true"] {
  color: #07101d;
  border-color: color-mix(in srgb, var(--accent) 78%, white);
  background: linear-gradient(180deg, #6ea0ff, #3977eb);
  box-shadow: 0 10px 26px color-mix(in srgb, var(--accent) 28%, transparent);
}

.compact-layout-icon {
  display: block;
  border: 2px solid currentColor;
  border-radius: 3px;
}

.compact-layout-icon-portrait {
  width: 13px;
  height: 22px;
}

.compact-layout-icon-landscape {
  width: 24px;
  height: 13px;
}

@media (max-width: 760px) and (orientation: portrait) and (pointer: coarse) {
  .lineup-row.overflow-level-1 .row-overflow-menu,
  .lineup-row.overflow-level-2 .row-overflow-menu,
  .lineup-row.overflow-level-3 .row-overflow-menu,
  .lineup-row.overflow-level-4 .row-overflow-menu,
  .lineup-row.overflow-level-5 .row-overflow-menu,
  .lineup-row.overflow-level-6 .row-overflow-menu,
  .lineup-row.overflow-level-7 .row-overflow-menu,
  .lineup-row.overflow-level-8 .row-overflow-menu,
  .bank-song.overflow-level-1 .bank-row-more,
  .bank-song.overflow-level-2 .bank-row-more,
  .bank-song.overflow-level-3 .bank-row-more,
  .bank-song.overflow-level-4 .bank-row-more,
  .bank-song.overflow-level-5 .bank-row-more,
  .row-overflow-menu,
  .bank-row-more {
    display: none !important;
  }

  .lineup-row.overflow-level-1 .row-icon-actions .danger,
  .lineup-row.overflow-level-2 .row-icon-actions .danger,
  .lineup-row.overflow-level-3 .row-icon-actions .danger,
  .lineup-row.overflow-level-4 .row-icon-actions .danger,
  .lineup-row.overflow-level-5 .row-icon-actions .danger,
  .lineup-row.overflow-level-6 .row-icon-actions .danger,
  .lineup-row.overflow-level-7 .row-icon-actions .danger,
  .lineup-row.overflow-level-8 .row-icon-actions .danger,
  .lineup-row.overflow-level-2 .row-icon-actions [data-action="info"],
  .lineup-row.overflow-level-3 .row-icon-actions [data-action="info"],
  .lineup-row.overflow-level-4 .row-icon-actions [data-action="info"],
  .lineup-row.overflow-level-5 .row-icon-actions [data-action="info"],
  .lineup-row.overflow-level-6 .row-icon-actions [data-action="info"],
  .lineup-row.overflow-level-7 .row-icon-actions [data-action="info"],
  .lineup-row.overflow-level-8 .row-icon-actions [data-action="info"],
  .lineup-row.note-row.overflow-level-2 .note-inline-actions [data-action="edit-note"],
  .lineup-row.note-row.overflow-level-3 .note-inline-actions [data-action="edit-note"] {
    display: inline-grid !important;
  }

  .lineup-row.note-row {
    display: grid !important;
    grid-template-columns: 28px 34px minmax(0, 1fr) auto !important;
    align-items: center !important;
    min-height: 78px !important;
    gap: 7px !important;
    padding: 8px !important;
    overflow: hidden !important;
  }

  .lineup-row.note-row .drag-handle {
    grid-column: 1 !important;
    grid-row: 2 !important;
  }

  .lineup-row.note-row .song-number {
    grid-column: 1 !important;
    grid-row: 1 !important;
  }

  .lineup-row.note-row .song-text {
    grid-column: 2 / 4 !important;
    grid-row: 1 / 3 !important;
    min-width: 0 !important;
    align-self: center !important;
  }

  .lineup-row.note-row .note-inline-actions {
    position: static !important;
    grid-column: 4 !important;
    grid-row: 1 / 3 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 4px !important;
    width: max-content !important;
    max-width: 112px !important;
    padding: 2px !important;
    transform: none !important;
    opacity: 1 !important;
    pointer-events: auto !important;
  }

  .lineup-row.note-row .note-inline-actions .icon-action {
    width: 30px !important;
    min-width: 30px !important;
    height: 30px !important;
    min-height: 30px !important;
  }

  .phone-export-compact-controls:not([hidden]) {
    grid-template-columns: minmax(82px, 1fr) minmax(72px, 0.86fr) minmax(60px, 0.74fr) minmax(94px, 1.05fr) !important;
    align-items: end !important;
  }

  .phone-export-compact-controls .compact-layout-field {
    min-width: 82px !important;
  }

  .phone-export-compact-controls .compact-check {
    min-height: 34px !important;
    height: 34px !important;
  }

  .phone-export-compact-controls label.compact-check {
    justify-content: start !important;
    gap: 4px !important;
    padding-inline: 6px !important;
  }

  .phone-export-compact-controls label.compact-check input {
    width: 13px !important;
    height: 13px !important;
    flex: 0 0 auto !important;
  }

  .phone-export-compact-controls label.compact-check span {
    font-size: 0.54rem !important;
  }

  .export-preview {
    min-height: 360px !important;
  }

  .export-sheet-preview-stack.multi-page {
    display: grid !important;
    place-items: center !important;
    overflow: hidden !important;
  }

  .export-sheet-preview-stack.multi-page > .export-sheet-preview.image-preview:not(:first-child) {
    display: none !important;
  }

  .export-sheet-preview.image-preview {
    width: min(100%, 350px, calc((82dvh - 282px) * 210 / 297)) !important;
    min-width: 220px !important;
    aspect-ratio: 210 / 297 !important;
  }

  .export-sheet-preview.image-preview.landscape {
    width: min(100%, 420px) !important;
    min-width: 220px !important;
    aspect-ratio: 297 / 210 !important;
  }

  .lineup-add-actions:not([hidden]),
  html:not(.lineup-native-ios-shell) .lineup-add-actions:not([hidden]),
  html.lineup-native-ios-shell .lineup-add-actions:not([hidden]) {
    right: max(10px, env(safe-area-inset-right, 0px)) !important;
    bottom: max(
      env(safe-area-inset-bottom, 0px),
      calc(var(--lineup-add-actions-bottom, var(--mobile-library-height, var(--lineup-add-bar-bank-height, 0px))) + 3px)
    ) !important;
    z-index: 96 !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) > .icon-button svg,
  .lineup-add-actions:not(.is-open):not([hidden]) > #addNoteButton svg {
    color: #eef5ff !important;
    filter: drop-shadow(0 0 5px color-mix(in srgb, var(--accent) 42%, transparent)) !important;
    visibility: visible !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) > .icon-button svg path,
  .lineup-add-actions:not(.is-open):not([hidden]) > #addNoteButton svg path {
    stroke: currentColor !important;
    stroke-width: 2.7px !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) > .icon-button .add-action-icon-stack,
  .lineup-add-actions:not(.is-open):not([hidden]) > #addNoteButton .add-action-icon-stack {
    visibility: visible !important;
  }
}

/* v403: measured row overflow, editable slide-only text boxes, and cleaner phone tray. */
.show-panel,
.lineup-table,
.lineup-rows,
.bank-panel,
.song-bank-list {
  max-width: 100%;
  overflow-x: hidden !important;
}

.lineup-row,
.bank-song,
.lineup-row-main,
.bank-song-main-content,
.lineup-mobile-controls,
.song-title-wrap,
.song-text,
.song-name-line,
.song-name {
  min-width: 0;
  max-width: 100%;
}

.lineup-row .row-overflow-menu,
.bank-song .bank-row-more {
  align-self: center;
  justify-self: end;
}

.bank-song .bank-row-more {
  order: 4;
}

.bank-song .bank-slides-button {
  order: 5;
}

.bank-song .bank-sheets-button {
  order: 6;
}

.bank-song .bank-edit-button {
  order: 7;
}

.lineup-row.overflow-level-0 .row-overflow-menu,
.bank-song.overflow-level-0 .bank-row-more {
  display: none !important;
}

@media (min-width: 761px), (hover: hover) and (pointer: fine) {
  .lineup-row.overflow-level-1,
  .lineup-row.overflow-level-2,
  .lineup-row.overflow-level-3,
  .lineup-row.overflow-level-4,
  .lineup-row.overflow-level-5,
  .lineup-row.overflow-level-6,
  .lineup-row.overflow-level-7,
  .lineup-row.overflow-level-8 {
    grid-template-columns: 24px 32px minmax(0, 1fr) auto auto auto auto !important;
    column-gap: 8px !important;
  }

  .lineup-row.overflow-level-1 .lineup-mobile-controls,
  .lineup-row.overflow-level-2 .lineup-mobile-controls,
  .lineup-row.overflow-level-3 .lineup-mobile-controls,
  .lineup-row.overflow-level-4 .lineup-mobile-controls,
  .lineup-row.overflow-level-5 .lineup-mobile-controls,
  .lineup-row.overflow-level-6 .lineup-mobile-controls,
  .lineup-row.overflow-level-7 .lineup-mobile-controls,
  .lineup-row.overflow-level-8 .lineup-mobile-controls {
    display: contents !important;
  }

  .lineup-row.overflow-level-1 .lineup-note-button,
  .lineup-row.overflow-level-2 .lineup-note-button,
  .lineup-row.overflow-level-3 .lineup-note-button,
  .lineup-row.overflow-level-4 .lineup-note-button,
  .lineup-row.overflow-level-5 .lineup-note-button,
  .lineup-row.overflow-level-6 .lineup-note-button,
  .lineup-row.overflow-level-7 .lineup-note-button,
  .lineup-row.overflow-level-8 .lineup-note-button {
    grid-column: 4 !important;
  }

  .lineup-row.overflow-level-1 .lineup-key-controls,
  .lineup-row.overflow-level-2 .lineup-key-controls,
  .lineup-row.overflow-level-3 .lineup-key-controls,
  .lineup-row.overflow-level-4 .lineup-key-controls,
  .lineup-row.overflow-level-5 .lineup-key-controls,
  .lineup-row.overflow-level-6 .lineup-key-controls,
  .lineup-row.overflow-level-7 .lineup-key-controls,
  .lineup-row.overflow-level-8 .lineup-key-controls {
    grid-column: 5 !important;
  }

  .lineup-row.overflow-level-1 .row-overflow-menu,
  .lineup-row.overflow-level-2 .row-overflow-menu,
  .lineup-row.overflow-level-3 .row-overflow-menu,
  .lineup-row.overflow-level-4 .row-overflow-menu,
  .lineup-row.overflow-level-5 .row-overflow-menu,
  .lineup-row.overflow-level-6 .row-overflow-menu,
  .lineup-row.overflow-level-7 .row-overflow-menu,
  .lineup-row.overflow-level-8 .row-overflow-menu {
    grid-column: 6 !important;
    justify-self: end !important;
  }

  .lineup-row.overflow-level-1 .lineup-asset-controls,
  .lineup-row.overflow-level-2 .lineup-asset-controls,
  .lineup-row.overflow-level-3 .lineup-asset-controls,
  .lineup-row.overflow-level-4 .lineup-asset-controls,
  .lineup-row.overflow-level-5 .lineup-asset-controls,
  .lineup-row.overflow-level-6 .lineup-asset-controls,
  .lineup-row.overflow-level-7 .lineup-asset-controls,
  .lineup-row.overflow-level-8 .lineup-asset-controls {
    grid-column: 7 !important;
  }

  .lineup-row.overflow-level-1 .row-icon-actions,
  .lineup-row.overflow-level-2 .row-icon-actions,
  .lineup-row.overflow-level-3 .row-icon-actions,
  .lineup-row.overflow-level-4 .row-icon-actions,
  .lineup-row.overflow-level-5 .row-icon-actions,
  .lineup-row.overflow-level-6 .row-icon-actions,
  .lineup-row.overflow-level-7 .row-icon-actions,
  .lineup-row.overflow-level-8 .row-icon-actions {
    display: none !important;
  }

  .lineup-row.overflow-level-7 .lineup-asset-controls,
  .lineup-row.overflow-level-8 .lineup-asset-controls {
    display: none !important;
  }

  .lineup-row.overflow-level-8 .lineup-key-controls {
    display: none !important;
  }

  .lineup-row .row-overflow-menu {
    position: static !important;
    transform: none !important;
  }

  .lineup-row .row-overflow-menu summary {
    width: 32px !important;
    height: 32px !important;
  }

  .lineup-row .row-overflow-menu .bank-row-more-menu {
    right: 0 !important;
    left: auto !important;
  }
}

@media (max-width: 760px) and (orientation: portrait) and (pointer: coarse) {
  .lineup-row .row-overflow-menu,
  .bank-song .bank-row-more,
  .lineup-row.overflow-level-1 .row-overflow-menu,
  .lineup-row.overflow-level-2 .row-overflow-menu,
  .lineup-row.overflow-level-3 .row-overflow-menu,
  .lineup-row.overflow-level-4 .row-overflow-menu,
  .lineup-row.overflow-level-5 .row-overflow-menu,
  .lineup-row.overflow-level-6 .row-overflow-menu,
  .lineup-row.overflow-level-7 .row-overflow-menu,
  .lineup-row.overflow-level-8 .row-overflow-menu,
  .bank-song.overflow-level-1 .bank-row-more,
  .bank-song.overflow-level-2 .bank-row-more,
  .bank-song.overflow-level-3 .bank-row-more,
  .bank-song.overflow-level-4 .bank-row-more,
  .bank-song.overflow-level-5 .bank-row-more {
    display: none !important;
  }

  .bank-song .bank-slides-button,
  .bank-song .bank-sheets-button,
  .bank-song .bank-edit-button,
  .bank-song .banger-toggle {
    display: inline-grid !important;
  }

  .bank-song .bank-recording-cluster {
    display: inline-flex !important;
  }

  .lineup-add-actions:not([hidden]),
  html:not(.lineup-native-ios-shell) .lineup-add-actions:not([hidden]),
  html.lineup-native-ios-shell .lineup-add-actions:not([hidden]) {
    right: max(18px, env(safe-area-inset-right, 0px)) !important;
    bottom: max(
      env(safe-area-inset-bottom, 0px),
      calc(var(--lineup-add-actions-bottom, var(--mobile-library-height, var(--lineup-add-bar-bank-height, 0px))) + 4px)
    ) !important;
    z-index: 180 !important;
    border: 1px solid color-mix(in srgb, var(--green) 36%, var(--line)) !important;
    background: color-mix(in srgb, #07101a 96%, var(--panel)) !important;
    box-shadow:
      0 12px 28px rgba(0, 0, 0, 0.38),
      inset 0 1px 0 rgba(255, 255, 255, 0.13) !important;
    -webkit-backdrop-filter: none !important;
    backdrop-filter: none !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]),
  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) {
    display: flex !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    gap: 5px !important;
    padding: 4px !important;
    border-radius: 15px !important;
    overflow: hidden !important;
    transform: translateX(-10px) !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab {
    display: none !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden])::before,
  .lineup-add-actions:not(.is-open):not([hidden])::after {
    display: none !important;
    content: none !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) > .icon-button,
  .lineup-add-actions:not(.is-open):not([hidden]) > #addNoteButton {
    display: grid !important;
    width: 34px !important;
    min-width: 34px !important;
    height: 34px !important;
    min-height: 34px !important;
    border-radius: 11px !important;
    background: color-mix(in srgb, var(--panel-2) 92%, #040810) !important;
    opacity: 1 !important;
    pointer-events: auto !important;
    transform: none !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) > .icon-button > span:not(.add-action-icon-stack),
  .lineup-add-actions:not(.is-open):not([hidden]) > #addNoteButton > span:not(.add-action-icon-stack) {
    display: none !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) > .icon-button .add-action-icon-stack,
  .lineup-add-actions:not(.is-open):not([hidden]) > #addNoteButton .add-action-icon-stack {
    position: relative !important;
    display: inline-grid !important;
    place-items: center !important;
    flex: 0 0 19px !important;
    width: 19px !important;
    height: 19px !important;
    margin: 0 !important;
    overflow: visible !important;
    visibility: visible !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) > .icon-button svg.add-action-main-icon,
  .lineup-add-actions:not(.is-open):not([hidden]) > #addNoteButton svg.add-action-main-icon {
    width: 18px !important;
    height: 18px !important;
    color: #f7fbff !important;
    display: block !important;
    position: static !important;
    transform: none !important;
    visibility: visible !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) > .icon-button .add-action-plus-icon,
  .lineup-add-actions:not(.is-open):not([hidden]) > #addNoteButton .add-action-plus-icon,
  .lineup-add-actions:not(.is-open):not([hidden]) > #addNoteButton .note-plus-icon {
    display: none !important;
  }
}

/* v413: phone add actions stay compact and leave the last setlist row reachable. */
@media (max-width: 760px) and (orientation: portrait) {
  .app-shell.mobile-library-minimized .lineup-rows,
  .app-shell.mobile-library-middle .lineup-rows,
  .app-shell.mobile-library-full .lineup-rows {
    padding-bottom: calc(var(--lineup-bank-scroll-clearance, 0px) + 40px + env(safe-area-inset-bottom, 0px)) !important;
    scroll-padding-bottom: calc(var(--lineup-bank-scroll-clearance, 0px) + 40px + env(safe-area-inset-bottom, 0px)) !important;
  }

  .lineup-add-actions.is-open:not([hidden]) {
    display: flex !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    gap: 5px !important;
    padding: 4px !important;
    border-radius: 15px !important;
    overflow: hidden !important;
    transform: translateX(-10px) !important;
    opacity: 0.94 !important;
  }

  .lineup-add-actions.is-open:not([hidden])::before,
  .lineup-add-actions.is-open:not([hidden])::after {
    display: none !important;
    content: none !important;
  }

  .lineup-add-actions.is-open:not([hidden]) .lineup-add-actions-tab {
    display: none !important;
  }

  .lineup-add-actions.is-open:not([hidden]) > .icon-button,
  .lineup-add-actions.is-open:not([hidden]) > #addNoteButton {
    display: grid !important;
    width: 34px !important;
    min-width: 34px !important;
    height: 34px !important;
    min-height: 34px !important;
    border-radius: 11px !important;
    background: color-mix(in srgb, var(--panel-2) 92%, #040810) !important;
    opacity: 1 !important;
    pointer-events: auto !important;
    transform: none !important;
  }

  .lineup-add-actions.is-open:not([hidden]) > .icon-button > span:not(.add-action-icon-stack),
  .lineup-add-actions.is-open:not([hidden]) > #addNoteButton > span:not(.add-action-icon-stack) {
    display: none !important;
  }

  .lineup-add-actions.is-open:not([hidden]) > .icon-button .add-action-icon-stack,
  .lineup-add-actions.is-open:not([hidden]) > #addNoteButton .add-action-icon-stack {
    position: relative !important;
    display: inline-grid !important;
    place-items: center !important;
    flex: 0 0 19px !important;
    width: 19px !important;
    height: 19px !important;
    margin: 0 !important;
    overflow: visible !important;
    visibility: visible !important;
  }

  .lineup-add-actions.is-open:not([hidden]) > .icon-button svg.add-action-main-icon,
  .lineup-add-actions.is-open:not([hidden]) > #addNoteButton svg.add-action-main-icon {
    display: block !important;
    position: static !important;
    width: 18px !important;
    height: 18px !important;
    color: #f7fbff !important;
    transform: none !important;
    visibility: visible !important;
  }

  .lineup-add-actions.is-open:not([hidden]) > .icon-button .add-action-plus-icon,
  .lineup-add-actions.is-open:not([hidden]) > #addNoteButton .add-action-plus-icon,
  .lineup-add-actions.is-open:not([hidden]) > #addNoteButton .note-plus-icon {
    display: none !important;
  }
}

/* v408: notes use the same slide column and hover-side edit/delete lane as song rows. */
.lineup-row.note-row .note-inline-actions {
  display: none !important;
}

.lineup-row.note-row .note-slide-cell {
  display: grid !important;
  place-items: center !important;
}

.lineup-row.note-row .note-slide-action {
  display: inline-grid !important;
}

@media (min-width: 761px) {
  .lineup-row.note-row {
    grid-template-columns: 24px 32px minmax(180px, 1fr) 40px minmax(184px, max-content) minmax(104px, max-content) 68px !important;
    align-items: center !important;
    gap: 8px !important;
  }

  .lineup-row.note-row .song-text {
    grid-column: 3 / 6 !important;
    min-width: 0 !important;
  }

  .lineup-row.note-row .note-slide-cell {
    grid-column: 6 !important;
    justify-self: center !important;
    align-self: center !important;
    width: 104px !important;
    grid-template-columns: 34px 34px !important;
    justify-content: center !important;
    gap: 14px !important;
  }

  .lineup-row.note-row .row-icon-actions.note-row-actions {
    grid-column: 7 !important;
    justify-self: end !important;
    align-self: center !important;
    display: flex !important;
    opacity: 0 !important;
    pointer-events: none !important;
  }

  .lineup-row.note-row:hover .row-icon-actions.note-row-actions,
  .lineup-row.note-row:focus-within .row-icon-actions.note-row-actions {
    opacity: 1 !important;
    pointer-events: auto !important;
  }
}

@media (max-width: 760px) {
  .lineup-row.note-row {
    position: relative !important;
    grid-template-columns: 30px minmax(0, 1fr) auto !important;
    grid-template-areas:
      "num song slide"
      "drag song slide" !important;
    overflow: hidden !important;
  }

  .lineup-row.note-row .note-slide-cell {
    grid-area: slide !important;
    align-self: center !important;
    justify-self: end !important;
  }

  .lineup-row.note-row .drag-handle,
  .lineup-row.note-row .song-number,
  .lineup-row.note-row .song-text,
  .lineup-row.note-row .note-slide-cell {
    position: relative !important;
    z-index: 2 !important;
    transition: transform 190ms ease !important;
    will-change: transform;
  }

  .lineup-row.note-row.swipe-open .drag-handle,
  .lineup-row.note-row.swipe-open .song-number,
  .lineup-row.note-row.swipe-open .song-text,
  .lineup-row.note-row.swipe-open .note-slide-cell {
    transform: translateX(-112px) !important;
  }

  .lineup-row.note-row .row-icon-actions.note-row-actions {
    position: absolute !important;
    top: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    left: auto !important;
    z-index: 1 !important;
    display: grid !important;
    grid-template-columns: 56px 56px !important;
    width: 112px !important;
    min-width: 112px !important;
    height: 100% !important;
    min-height: 64px !important;
    gap: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    opacity: 1 !important;
    pointer-events: none !important;
    transform: none !important;
  }

  .lineup-row.note-row.swipe-open .row-icon-actions.note-row-actions {
    pointer-events: auto !important;
  }

  .lineup-row.note-row .row-icon-actions.note-row-actions .icon-action {
    display: inline-grid !important;
    width: 56px !important;
    min-width: 56px !important;
    height: 100% !important;
    min-height: 64px !important;
    border: 0 !important;
    border-left: 1px solid color-mix(in srgb, var(--line) 76%, transparent) !important;
    border-radius: 0 !important;
    background:
      linear-gradient(180deg, rgba(255, 255, 255, 0.08), transparent 76%),
      color-mix(in srgb, var(--panel-2) 90%, #050910) !important;
  }

  .lineup-row.note-row .row-icon-actions.note-row-actions .icon-action.danger {
    background:
      linear-gradient(180deg, rgba(255, 255, 255, 0.08), transparent 76%),
      color-mix(in srgb, #4c1414 68%, var(--panel-2)) !important;
  }
}

@media (max-width: 760px) and (orientation: portrait) {
  .lineup-row .row-overflow-menu,
  .bank-song .bank-row-more,
  .lineup-row.overflow-level-1 .row-overflow-menu,
  .lineup-row.overflow-level-2 .row-overflow-menu,
  .lineup-row.overflow-level-3 .row-overflow-menu,
  .lineup-row.overflow-level-4 .row-overflow-menu,
  .lineup-row.overflow-level-5 .row-overflow-menu,
  .lineup-row.overflow-level-6 .row-overflow-menu,
  .lineup-row.overflow-level-7 .row-overflow-menu,
  .lineup-row.overflow-level-8 .row-overflow-menu,
  .bank-song.overflow-level-1 .bank-row-more,
  .bank-song.overflow-level-2 .bank-row-more,
  .bank-song.overflow-level-3 .bank-row-more,
  .bank-song.overflow-level-4 .bank-row-more,
  .bank-song.overflow-level-5 .bank-row-more {
    display: none !important;
  }

  .lineup-add-actions:not([hidden]),
  html:not(.lineup-native-ios-shell) .lineup-add-actions:not([hidden]),
  html.lineup-native-ios-shell .lineup-add-actions:not([hidden]) {
    right: max(18px, env(safe-area-inset-right, 0px)) !important;
    bottom: max(
      env(safe-area-inset-bottom, 0px),
      calc(var(--lineup-add-actions-bottom, var(--mobile-library-height, var(--lineup-add-bar-bank-height, 0px))) + 4px)
    ) !important;
    border: 1px solid color-mix(in srgb, var(--green) 36%, var(--line)) !important;
    background: color-mix(in srgb, #07101a 96%, var(--panel)) !important;
    box-shadow:
      0 12px 28px rgba(0, 0, 0, 0.38),
      inset 0 1px 0 rgba(255, 255, 255, 0.13) !important;
    -webkit-backdrop-filter: none !important;
    backdrop-filter: none !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]),
  :root.tablet-touch-layout .lineup-add-actions:not(.is-open):not([hidden]) {
    display: flex !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    gap: 5px !important;
    padding: 4px !important;
    border-radius: 15px !important;
    overflow: hidden !important;
    transform: translateX(-10px) !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden])::before,
  .lineup-add-actions:not(.is-open):not([hidden])::after {
    display: none !important;
    content: none !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) .lineup-add-actions-tab {
    display: none !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) > .icon-button,
  .lineup-add-actions:not(.is-open):not([hidden]) > #addNoteButton {
    display: grid !important;
    width: 34px !important;
    min-width: 34px !important;
    height: 34px !important;
    min-height: 34px !important;
    border-radius: 11px !important;
    background: color-mix(in srgb, var(--panel-2) 92%, #040810) !important;
    opacity: 1 !important;
    pointer-events: auto !important;
    transform: none !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) > .icon-button > span:not(.add-action-icon-stack),
  .lineup-add-actions:not(.is-open):not([hidden]) > #addNoteButton > span:not(.add-action-icon-stack) {
    display: none !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) > .icon-button .add-action-icon-stack,
  .lineup-add-actions:not(.is-open):not([hidden]) > #addNoteButton .add-action-icon-stack {
    position: relative !important;
    display: inline-grid !important;
    place-items: center !important;
    flex: 0 0 19px !important;
    width: 19px !important;
    height: 19px !important;
    margin: 0 !important;
    overflow: visible !important;
    visibility: visible !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) > .icon-button svg.add-action-main-icon,
  .lineup-add-actions:not(.is-open):not([hidden]) > #addNoteButton svg.add-action-main-icon {
    display: block !important;
    position: static !important;
    width: 18px !important;
    height: 18px !important;
    color: #f7fbff !important;
    transform: none !important;
    visibility: visible !important;
  }

  .lineup-add-actions:not(.is-open):not([hidden]) > .icon-button .add-action-plus-icon,
  .lineup-add-actions:not(.is-open):not([hidden]) > #addNoteButton .add-action-plus-icon,
  .lineup-add-actions:not(.is-open):not([hidden]) > #addNoteButton .note-plus-icon {
    display: none !important;
  }
}
