@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;1,300;1,400&family=Lato:ital,wght@0,300;0,400;0,700;1,400&display=swap');

:root {
  /* ── Dark Mode (fotografie-schneider.de) ── */
  --bg: #000000;
  --bg-soft: #0A0A0A;
  --panel: #0E0E0E;
  --panel-strong: #161616;
  --line: rgba(255, 255, 255, 0.07);
  --line-strong: rgba(255, 255, 255, 0.13);
  --text: #F2F2F2;
  --muted: #7A7A7A;
  --accent: #20a0b9;
  --accent-strong: #1a8fa6;
  --accent-muted: rgba(32, 160, 185, 0.14);
  --danger: #ef4444;
  --green: #22c55e;
  --yellow: #f59e0b;
  --orange: #ff8f1f;
  --red: #ef4444;
  --black-flag: #3a3a3a;
  --shadow: 0 8px 32px rgba(0, 0, 0, 0.55);
  --shadow-lg: 0 20px 60px rgba(0, 0, 0, 0.7);
  --radius-xl: 12px;
  --radius-lg: 8px;
  --radius-md: 6px;
  --font-body: 'Lato', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --font-display: 'Cormorant Garamond', Georgia, 'Times New Roman', serif;
}

* {
  box-sizing: border-box;
}

img,
svg {
  max-width: 100%;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  font-family: var(--font-body);
  color: var(--text);
  background: var(--bg);
}

/* ── Light Mode (Hochzeits-Eleganz: Champagner & Warmweiß) ── */
body[data-theme="light"] {
  --bg: #FAFAF8;
  --bg-soft: #FFFFFF;
  --panel: #FFFFFF;
  --panel-strong: #F5F0EA;
  --line: rgba(36, 22, 8, 0.08);
  --line-strong: rgba(36, 22, 8, 0.15);
  --text: #18130F;
  --muted: #7A6E65;
  --accent: #C4933F;
  --accent-strong: #A87B2E;
  --accent-muted: rgba(196, 147, 63, 0.12);
  --shadow: 0 4px 24px rgba(20, 12, 4, 0.07);
  --shadow-lg: 0 12px 48px rgba(20, 12, 4, 0.10);
  background: var(--bg);
}

body.is-overlay-open {
  overflow: hidden;
}

a {
  color: inherit;
}

button,
input,
textarea {
  font: inherit;
}

.ss-home-page,
.ss-gallery-app,
.ss-admin-shell {
  width: calc(100% - 100px);
  margin: 0 auto;
}

.ss-home-page,
.ss-admin-shell {
  padding: 32px 0 48px;
}

.ss-site-footer-wrap {
  width: calc(100% - 100px);
  margin: auto auto 28px;
  padding-top: 32px;
}

.ss-site-footer {
  padding: 28px 24px 20px;
  border-radius: 0 0 28px 28px;
  border: 1px solid var(--line);
  background: var(--panel);
  box-shadow: var(--shadow);
  display: grid;
  gap: 18px;
  justify-items: center;
  text-align: center;
}

.ss-site-footer-brand {
  display: grid;
  gap: 4px;
}

.ss-site-footer-brand strong {
  font-size: 1.1rem;
}

.ss-site-footer-brand a {
  color: var(--muted);
  text-decoration: none;
}

.ss-site-footer-socials {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  justify-content: center;
}

.ss-site-footer-social {
  width: 54px;
  height: 54px;
  border-radius: var(--radius-md);
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--panel-strong) 92%, white 8%);
  color: var(--text);
  display: inline-grid;
  place-items: center;
  text-decoration: none;
}

.ss-site-footer-social svg {
  width: 25px;
  height: 25px;
}

.ss-site-footer-links {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: center;
}

.ss-site-footer-link {
  min-height: 44px;
  padding: 10px 16px;
  border-radius: 12px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--bg-soft) 88%, white 12%);
  color: var(--text);
  text-decoration: none;
  cursor: pointer;
}

/* ── Theme Toggle ── */
.ss-theme-toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 14px;
  border-radius: 20px;
  border: 1px solid var(--line-strong);
  background: var(--panel);
  color: var(--muted);
  font-size: 0.82rem;
  cursor: pointer;
  transition: border-color 140ms, color 140ms, background 140ms;
  white-space: nowrap;
}
.ss-theme-toggle:hover {
  color: var(--text);
  border-color: var(--accent);
}
.ss-theme-toggle svg {
  flex-shrink: 0;
  transition: transform 300ms cubic-bezier(0.34, 1.56, 0.64, 1);
}
.ss-theme-toggle:hover svg {
  transform: rotate(20deg);
}
/* Welches Icon anzeigen je nach Theme */
.ss-theme-toggle .icon-sun { display: none; }
.ss-theme-toggle .icon-moon { display: block; }
body[data-theme="light"] .ss-theme-toggle .icon-sun { display: block; }
body[data-theme="light"] .ss-theme-toggle .icon-moon { display: none; }

/* Toggle im Footer */
.ss-site-footer-theme {
  display: flex;
  justify-content: center;
  padding-top: 8px;
}

/* Toggle im Admin-Header */
.ss-admin-theme-toggle {
  margin-left: auto;
}

.ss-cookie-banner {
  position: fixed;
  left: 24px;
  right: 24px;
  bottom: 24px;
  z-index: 25000;
  padding: 20px 22px;
  border-radius: 22px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--panel-strong) 96%, white 4%);
  box-shadow: var(--shadow);
  display: grid;
  gap: 16px;
}

.ss-cookie-banner[hidden] {
  display: none;
}

.ss-cookie-banner-copy {
  display: grid;
  gap: 8px;
}

.ss-cookie-banner-copy strong {
  font-size: 1.1rem;
}

.ss-cookie-banner-copy p {
  margin: 0;
  color: var(--muted);
}

.ss-cookie-banner-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.ss-cookie-action {
  min-height: 46px;
  padding: 0 18px;
  border-radius: 14px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--panel) 88%, white 12%);
  color: var(--text);
  cursor: pointer;
}

.ss-cookie-action-secondary {
  background: transparent;
}

.ss-cookie-panel {
  width: min(640px, calc(100% - 24px));
}

.ss-cookie-settings-list {
  display: grid;
  gap: 14px;
}

.ss-cookie-setting {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 16px;
  align-items: center;
  padding: 18px 0;
  border-top: 1px solid var(--line);
}

.ss-cookie-setting:first-child {
  border-top: 0;
  padding-top: 0;
}

.ss-cookie-setting span {
  display: grid;
  gap: 6px;
}

.ss-cookie-setting small {
  color: var(--muted);
  line-height: 1.45;
}

.ss-cookie-panel-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
  margin-top: 18px;
}

.ss-branding-links {
  display: grid;
  gap: 14px;
}

.ss-legal-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.ss-legal-editor-list {
  display: grid;
  gap: 12px;
}

.ss-legal-editor-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  padding: 16px 0;
  border-top: 1px solid var(--line);
}

.ss-legal-editor-row:first-child {
  border-top: 0;
  padding-top: 0;
}

.ss-legal-editor-row strong {
  display: block;
  margin-bottom: 4px;
}

.ss-branding-link-row {
  display: grid;
  grid-template-columns: 52px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
}

.ss-branding-link-icon {
  width: 52px;
  height: 52px;
  border-radius: var(--radius-md);
  background: #111;
  color: #fff;
  display: inline-grid;
  place-items: center;
}

.ss-branding-link-icon svg {
  width: 24px;
  height: 24px;
}

.ss-legal-editor-panel {
  width: min(1040px, calc(100% - 24px));
}

.ss-legal-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 14px;
}

.ss-legal-toolbar button {
  min-height: 42px;
  padding: 0 14px;
  border-radius: 12px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--bg-soft) 88%, white 12%);
  color: var(--text);
  cursor: pointer;
}

.ss-legal-editor-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 0.9fr);
  gap: 18px;
}

.ss-legal-editor-grid textarea {
  min-height: 420px;
  border-radius: 18px;
}

.ss-legal-preview {
  border: 1px solid var(--line);
  border-radius: 22px;
  padding: 18px;
  background: color-mix(in srgb, var(--panel) 90%, white 10%);
}

.ss-legal-content {
  line-height: 1.7;
}

.ss-legal-content h2,
.ss-legal-content h3 {
  margin-top: 0;
  margin-bottom: 12px;
}

.ss-legal-content p,
.ss-legal-content ul,
.ss-legal-content ol {
  margin: 0 0 14px;
}

.ss-legal-shell {
  flex: 1 0 auto;
}

.ss-legal-card {
  padding: 28px;
}

.ss-legal-actions {
  margin-top: 20px;
}

.ss-password-shell {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 32px 16px;
}

.ss-password-card,
.ss-hero,
.ss-hero-panel,
.ss-admin-card,
.ss-summary-card,
.ss-home-card,
.ss-admin-form {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow);
  backdrop-filter: blur(18px);
}

.ss-password-card {
  width: min(560px, 100%);
  padding: 32px;
}

.ss-kicker {
  margin: 0 0 8px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-size: 0.72rem;
  color: var(--muted);
}

h1,
h2,
h3,
p {
  margin-top: 0;
}

/* Display-Font nur auf kundenseitigen Seiten */
.ss-gallery-app h1,
.ss-gallery-app h2,
.ss-home-page h1,
.ss-home-page h2,
.ss-gallery-opener-title {
  font-family: var(--font-display);
  font-weight: 400;
  letter-spacing: 0.01em;
}

.ss-home-page h1,
.ss-password-card h1,
.ss-gallery-header h1,
.ss-admin-header h1 {
  margin-bottom: 12px;
  font-size: clamp(2.4rem, 4vw, 4.6rem);
  font-weight: 400;
  line-height: 0.98;
}

.ss-copy,
.ss-password-card p,
.ss-home-card p,
.ss-admin-card p,
.ss-summary-card p {
  color: var(--muted);
  line-height: 1.7;
}

.ss-primary-link,
.ss-primary-button,
.ss-secondary-link,
.ss-password-card button,
.ss-grid-footer button,
.ss-download-link,
.ss-admin-form button,
.ss-secondary-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-height: 48px;
  border-radius: var(--radius-md);
  padding: 0 18px;
  text-decoration: none;
  cursor: pointer;
  transition: transform 140ms ease, border-color 140ms ease, background 140ms ease;
}

.ss-primary-link,
.ss-primary-button,
.ss-password-card button,
.ss-grid-footer button,
.ss-download-link,
.ss-admin-form button {
  border: 1px solid rgba(32, 160, 185, 0.3);
  background: linear-gradient(180deg, var(--accent), var(--accent-strong));
  color: #ffffff;
  font-weight: 700;
}

.ss-primary-button:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.ss-danger-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-height: 48px;
  border-radius: var(--radius-md);
  padding: 0 18px;
  text-decoration: none;
  cursor: pointer;
  transition: transform 140ms ease, background 140ms ease;
  border: 1px solid rgba(239, 68, 68, 0.3);
  background: #ef4444;
  color: #ffffff;
  font-weight: 700;
}

.ss-danger-button:hover { transform: translateY(-1px); background: #dc2626; }

.ss-secondary-link,
.ss-secondary-button {
  border: 1px solid var(--line-strong);
  background: transparent;
  color: var(--text);
}

.ss-secondary-button {
  position: relative;
}

.ss-primary-link:hover,
.ss-primary-button:hover,
.ss-secondary-link:hover,
.ss-password-card button:hover,
.ss-grid-footer button:hover,
.ss-admin-form button:hover,
.ss-secondary-button:hover {
  transform: translateY(-1px);
}

.ss-inline-link {
  color: var(--accent);
  text-decoration: none;
}

.ss-action-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 0 18px;
  border-radius: 16px;
  border: 1px solid color-mix(in srgb, var(--accent-strong) 55%, transparent);
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent) 92%, white 8%), var(--accent-strong));
  color: #17120d;
  font-weight: 700;
  text-decoration: none;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.12);
}

.ss-action-chip:hover {
  transform: translateY(-1px);
}

.ss-icon-nav {
  gap: 8px;
}

.ss-icon-nav.has-unread::after {
  content: "";
  position: absolute;
  top: 10px;
  right: 10px;
  width: 9px;
  height: 9px;
  border-radius: var(--radius-md);
  background: var(--accent-strong);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--panel) 78%, transparent);
}

.ss-icon-nav span[aria-hidden="true"] {
  font-size: 1.1rem;
  line-height: 1;
}

.ss-search-form {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.ss-sort-menu {
  display: inline-flex;
}

.ss-sort-menu-trigger {
  gap: 10px;
}

.ss-sort-menu-trigger svg,
.ss-sort-menu-option svg {
  width: 15px;
  height: 15px;
  display: block;
}

.ss-sort-menu-option {
  min-height: 50px;
  padding: 0 12px;
  border-radius: 16px;
  display: grid;
  grid-template-columns: 16px minmax(0, 1fr);
  gap: 10px;
  align-items: center;
  text-decoration: none;
  font-size: 0.96rem;
}

.ss-sort-menu-option:hover,
.ss-sort-menu-option.is-active {
  background: color-mix(in srgb, var(--accent) 12%, var(--panel-strong));
}

.ss-floating-menu[hidden] {
  display: none;
}

.ss-floating-menu {
  position: fixed;
  inset: 0;
  z-index: 120;
}

.ss-floating-menu-backdrop {
  position: absolute;
  inset: 0;
  background: transparent;
}

.ss-floating-menu-panel {
  position: fixed;
  width: min(330px, calc(100vw - 32px));
  padding: 10px;
  border-radius: 22px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--panel-strong) 96%, white 4%);
  box-shadow: var(--shadow);
  display: grid;
  gap: 4px;
}

.ss-search-field {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-height: 48px;
  padding: 0 14px;
  border-radius: var(--radius-md);
  border: 1px solid var(--line-strong);
  background: var(--panel-strong);
  color: var(--muted);
}

.ss-search-field input {
  width: min(240px, 35vw);
  min-width: 120px;
  border: 0;
  outline: 0;
  background: transparent;
  color: var(--text);
}

.ss-search-summary {
  grid-column: 1 / -1;
}

.ss-search-summary[hidden] {
  display: none;
}

.ss-home-page {
  display: grid;
  gap: 28px;
}

.ss-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(320px, 0.9fr);
  gap: 24px;
  padding: 34px;
}

.ss-hero-copy {
  display: grid;
  align-content: start;
  gap: 12px;
}

.ss-brand-logo-wrap {
  display: flex;
  align-items: center;
  min-height: 68px;
}

.ss-brand-logo {
  max-width: min(220px, 48vw);
  max-height: 72px;
  object-fit: contain;
  display: block;
}

.ss-hero-panel {
  padding: 28px;
}

.ss-hero-actions,
.ss-admin-actions,
.ss-admin-links,
.ss-stat-row,
.ss-home-meta,
.ss-summary-stats,
.ss-filter-group,
.ss-mode-switch {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.ss-admin-actions {
  justify-content: flex-end;
  margin-left: auto;
}

.ss-feature-list {
  margin: 18px 0 0;
  padding-left: 18px;
  color: var(--muted);
  line-height: 1.7;
}

.ss-section {
  display: grid;
  gap: 18px;
}

.ss-section-heading h2 {
  margin: 0;
  font-size: clamp(1.8rem, 2vw, 2.6rem);
  font-weight: 400;
}

.ss-home-grid,
.ss-admin-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 280px), 1fr));
  gap: 16px;
}

.ss-admin-gallery-sections {
  display: grid;
  gap: 26px;
}

.ss-admin-gallery-section {
  display: grid;
  gap: 16px;
}

.ss-admin-gallery-section-head {
  display: grid;
  gap: 4px;
}

.ss-admin-gallery-section-head h2 {
  margin: 0;
  font-size: clamp(1.6rem, 2vw, 2.2rem);
}

.ss-admin-grid {
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 22px;
  align-items: start;
}

.ss-home-card,
.ss-admin-card {
  padding: 24px;
}

.ss-card-cover {
  margin: -24px -24px 18px;
  aspect-ratio: 16 / 8;
  overflow: hidden;
  border-bottom: 1px solid var(--line);
}

.ss-card-cover-link {
  display: block;
  cursor: pointer;
}

.ss-card-cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.ss-admin-gallery-card {
  min-width: 0;
}

.ss-admin-gallery-link {
  display: grid;
  gap: 12px;
  text-decoration: none;
}

.ss-admin-gallery-thumb {
  position: relative;
  aspect-ratio: 16 / 10;
  border-radius: 22px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--panel) 82%, transparent);
  box-shadow: var(--shadow);
}

.ss-admin-gallery-thumb-link {
  display: block;
  width: 100%;
  height: 100%;
  border-radius: inherit;
  overflow: hidden;
}

.ss-admin-gallery-thumb img,
.ss-admin-gallery-placeholder {
  width: 100%;
  height: 100%;
}

.ss-admin-gallery-thumb img {
  object-fit: cover;
  display: block;
  transition: transform 180ms ease;
}

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

.ss-admin-gallery-placeholder {
  display: grid;
  place-items: center;
  border-radius: inherit;
  background:
    radial-gradient(circle at 20% 20%, color-mix(in srgb, var(--accent) 26%, transparent), transparent 28%),
    linear-gradient(180deg, color-mix(in srgb, var(--bg-soft) 88%, white 12%), color-mix(in srgb, var(--bg-soft) 90%, black 10%));
}

.ss-admin-gallery-placeholder span {
  font-size: clamp(2.6rem, 5vw, 4rem);
  color: color-mix(in srgb, var(--accent) 72%, white 28%);
}

.ss-admin-gallery-flags {
  position: absolute;
  top: 12px;
  left: 12px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  max-width: calc(100% - 24px);
}

.ss-admin-gallery-flag {
  width: 34px;
  height: 34px;
  display: inline-grid;
  place-items: center;
  border-radius: 12px;
  background: color-mix(in srgb, var(--panel-strong) 90%, white 10%);
  border: 1px solid color-mix(in srgb, var(--line-strong) 88%, transparent);
  color: var(--text);
  backdrop-filter: blur(10px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.22);
  position: relative;
}

.ss-admin-gallery-flag svg {
  width: 18px;
  height: 18px;
  display: block;
}

.ss-admin-gallery-flag::after {
  content: attr(data-tooltip);
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  min-width: max-content;
  max-width: 220px;
  padding: 8px 10px;
  border-radius: 12px;
  border: 1px solid color-mix(in srgb, var(--line-strong) 92%, transparent);
  background: color-mix(in srgb, var(--panel-strong) 94%, white 6%);
  color: var(--text);
  font-size: 0.86rem;
  line-height: 1.3;
  white-space: normal;
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.24);
  opacity: 0;
  pointer-events: none;
  transform: translateY(-4px);
  transition: opacity 140ms ease, transform 140ms ease;
  z-index: 3;
}

.ss-admin-gallery-flag:hover::after,
.ss-admin-gallery-flag:focus-visible::after {
  opacity: 1;
  transform: translateY(0);
}

.ss-admin-gallery-flag--warn {
  color: #f59e0b;
  border-color: rgba(245,158,11,0.35);
  background: rgba(245,158,11,0.12);
  animation: ss-warn-pulse 2s ease-in-out infinite;
}
@keyframes ss-warn-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.55; }
}

.ss-admin-gallery-name h2 {
  margin: 0;
  font-size: 1.12rem;
  line-height: 1.28;
  font-weight: 600;
}

.ss-admin-gallery-menu {
  position: absolute;
  right: 12px;
  bottom: 12px;
  z-index: 4;
}

.ss-admin-gallery-menu-trigger {
  width: 42px;
  height: 42px;
  min-height: 42px;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  border: 1px solid color-mix(in srgb, var(--line-strong) 92%, transparent);
  background: color-mix(in srgb, var(--panel-strong) 92%, white 8%);
  color: var(--text);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.22);
  opacity: 0;
  transform: translateY(4px);
  transition: opacity 140ms ease, transform 140ms ease, background 140ms ease;
}

.ss-admin-gallery-thumb:hover .ss-admin-gallery-menu-trigger,
.ss-admin-gallery-thumb:focus-within .ss-admin-gallery-menu-trigger,
.ss-admin-gallery-menu-trigger[aria-expanded="true"] {
  opacity: 1;
  transform: translateY(0);
}

.ss-admin-gallery-menu-panel {
  position: absolute;
  right: 0;
  bottom: calc(100% + 10px);
  width: min(300px, calc(100vw - 32px));
  padding: 12px;
  border-radius: 24px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--panel-strong) 96%, white 4%);
  box-shadow: var(--shadow);
  display: grid;
  gap: 4px;
  z-index: 12;
}

.ss-admin-gallery-menu-panel[hidden] {
  display: none;
}

.ss-admin-gallery-menu-panel button {
  min-height: 50px;
  padding: 0 14px;
  border: 0;
  border-radius: 14px;
  background: transparent;
  color: var(--text);
  text-align: left;
  cursor: pointer;
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  font-size: 0.98rem;
}

.ss-admin-gallery-menu-panel button:hover {
  background: color-mix(in srgb, var(--accent) 12%, var(--panel-strong));
}

.ss-admin-gallery-menu-panel button svg {
  width: 24px;
  height: 24px;
  display: block;
}

.ss-admin-gallery-menu-panel button span {
  line-height: 1.25;
}

.ss-admin-gallery-menu-panel hr {
  width: 100%;
  border: 0;
  border-top: 1px solid var(--line);
  margin: 6px 0;
}

.ss-cover-overlay-panel {
  width: min(980px, calc(100% - 24px));
}

.ss-cover-picker-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: 14px;
}

.ss-cover-picker-item {
  padding: 10px;
  border-radius: 18px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--panel) 84%, transparent);
  color: var(--text);
  display: grid;
  gap: 10px;
  text-align: left;
}

.ss-cover-picker-item img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border-radius: 14px;
  display: block;
}

.ss-cover-picker-item span {
  font-size: 0.92rem;
  line-height: 1.25;
}

.ss-cover-picker-item.is-selected {
  border-color: color-mix(in srgb, var(--accent-strong) 76%, transparent);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent) 22%, transparent);
}

.ss-admin-body {
  min-height: 100vh;
}

.ss-admin-header,
.ss-gallery-header {
  display: flex;
  justify-content: space-between;
  align-items: end;
  gap: 20px;
  margin-bottom: 24px;
  flex-wrap: wrap;
}

.ss-admin-header {
  padding: 18px 22px;
  border-radius: 24px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--panel-strong) 94%, white 6%);
  box-shadow: var(--shadow);
}

.ss-admin-header > *,
.ss-gallery-header > *,
.ss-admin-card-head > * {
  min-width: 0;
}

.ss-admin-brand-block {
  display: flex;
  align-items: center;
  gap: 16px;
  min-width: 0;
}

.ss-admin-brand-link {
  display: inline-flex;
  align-items: center;
  flex: 0 0 auto;
  text-decoration: none;
}

.ss-admin-brand-logo {
  width: auto;
  max-width: min(240px, 26vw);
  max-height: 64px;
  object-fit: contain;
  display: block;
}

.ss-gallery-cover {
  width: min(180px, 100%);
  aspect-ratio: 4 / 3;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid var(--line);
  flex: 0 0 auto;
}

.ss-gallery-cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.ss-admin-card-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: start;
}

.ss-media-search {
  display: block;
  min-width: min(100%, 320px);
}

.ss-media-search-row label {
  color: var(--muted);
  font-size: 0.85rem;
  white-space: nowrap;
}

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

.ss-media-search-input {
  width: 100%;
  min-width: 0;
  min-height: 44px;
  border-radius: var(--radius-md);
  border: 1px solid var(--line);
  background: var(--bg-soft);
  color: var(--text);
  padding: 10px 12px;
}

.ss-media-search-status {
  color: var(--muted);
  font-size: 0.86rem;
  white-space: nowrap;
  text-align: right;
}

@media (max-width: 760px) {
  .ss-media-search-row {
    grid-template-columns: 1fr;
    align-items: start;
  }

  .ss-media-search-status {
    text-align: left;
  }
}

.ss-badge {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: var(--radius-md);
  border: 1px solid rgba(96, 170, 104, 0.32);
  color: #bfe0c4;
}

.ss-badge.is-danger {
  border-color: rgba(185, 90, 79, 0.4);
  color: #ffb1a9;
}

.ss-admin-form-shell {
  display: grid;
  gap: 24px;
}

.ss-admin-form-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(280px, 0.8fr);
  gap: 18px;
}

.ss-admin-form-layout.is-gallery-workbench {
  grid-template-columns: 300px minmax(0, 1fr);
  align-items: start;
}

.ss-admin-form-stack {
  display: grid;
  gap: 18px;
  position: relative;
}

.ss-settings-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 18px;
}

.ss-admin-form {
  padding: 24px;
  display: grid;
  gap: 16px;
}

.ss-admin-form label {
  display: grid;
  gap: 8px;
}

.ss-admin-form span {
  font-size: 13px;
  color: var(--muted);
}

.ss-admin-form input[type="text"],
.ss-admin-form input[type="url"],
.ss-admin-form input[type="email"],
.ss-admin-form input[type="number"],
.ss-admin-form input[type="password"],
.ss-admin-form select,
.ss-admin-form textarea,
.ss-user-fields input[type="text"],
.ss-user-fields input[type="url"],
.ss-user-fields input[type="email"],
.ss-user-fields input[type="number"],
.ss-user-fields input[type="password"],
.ss-user-fields select,
.ss-password-card input {
  width: 100%;
  min-height: 44px;
  border-radius: var(--radius-md);
  border: 1px solid var(--line);
  background: var(--bg-soft);
  color: var(--text);
  padding: 10px 14px;
}

.ss-admin-form textarea {
  min-height: 130px;
  resize: vertical;
}

/* ── Coming Soon ─────────────────────────────────────────────────────────── */
.ss-coming-soon-card {
  width: min(600px, 100%);
}

.ss-coming-soon-icon {
  color: var(--accent);
  margin-bottom: 16px;
}

.ss-coming-soon-desc {
  margin-bottom: 24px;
}

.ss-coming-soon-form {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.ss-coming-soon-label {
  font-size: 0.85rem;
  color: var(--muted);
  margin-bottom: -6px;
}

.ss-coming-soon-input {
  width: 100%;
  min-height: 52px;
  border-radius: var(--radius-md);
  border: 1px solid var(--line);
  background: var(--bg-soft);
  color: var(--text);
  padding: 12px 14px;
  font-size: 1rem;
  box-sizing: border-box;
}
.ss-coming-soon-input.ss-input-error {
  border-color: rgba(239,68,68,0.6);
}
.ss-coming-soon-input:focus {
  outline: none;
  border-color: var(--accent);
}

.ss-coming-soon-consent {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 10px;
  align-items: flex-start;
  font-size: 0.82rem;
  color: var(--muted);
  line-height: 1.6;
  cursor: pointer;
}
.ss-coming-soon-consent input[type="checkbox"] {
  margin-top: 3px;
  accent-color: var(--accent);
  width: 16px;
  height: 16px;
  cursor: pointer;
}
.ss-coming-soon-consent a {
  color: var(--accent);
  text-decoration: none;
}

.ss-coming-soon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 48px;
  border-radius: var(--radius-md);
  padding: 0 20px;
  text-decoration: none;
  cursor: pointer;
  border: 1px solid rgba(32,160,185,0.3);
  background: linear-gradient(180deg, var(--accent), var(--accent-strong));
  color: #fff;
  font-weight: 700;
  font-size: 0.92rem;
  transition: transform 140ms ease;
}
.ss-coming-soon-btn:hover { transform: translateY(-1px); }

.ss-coming-soon-error {
  color: #ffb3aa;
  font-size: 0.85rem;
  margin: 0;
}

.ss-coming-soon-hint {
  font-size: 0.78rem;
  color: var(--muted);
  margin: 0;
}

.ss-coming-soon-success {
  display: flex;
  flex-direction: column;
  gap: 8px;
  border: 1px solid rgba(34,130,58,0.35);
  background: rgba(34,86,40,0.12);
  border-radius: var(--radius-md);
  padding: 20px;
  color: #1a6b2e;
}
.ss-coming-soon-success svg {
  color: #1a6b2e;
}
.ss-coming-soon-success p { color: #1a6b2e; margin: 0; }
.ss-coming-soon-success strong { color: #0f4a1f; }
.ss-coming-soon-success .ss-coming-soon-hint { color: rgba(26,107,46,0.75); }

body[data-theme="dark"] .ss-coming-soon-success {
  border-color: rgba(96,170,104,0.3);
  background: rgba(34,86,40,0.18);
  color: #a3e8b0;
}
body[data-theme="dark"] .ss-coming-soon-success svg { color: #22c55e; }
body[data-theme="dark"] .ss-coming-soon-success p { color: #a3e8b0; }
body[data-theme="dark"] .ss-coming-soon-success strong { color: #d4f8dc; }
body[data-theme="dark"] .ss-coming-soon-success .ss-coming-soon-hint { color: rgba(163,232,176,0.7); }

/* Admin subscriber panel */
.ss-notify-subscriber-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 0;
  border-bottom: 1px solid var(--line);
  font-size: 0.83rem;
}
.ss-notify-subscriber-row:last-child { border-bottom: none; }
.ss-notify-subscriber-email { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; }
.ss-notify-subscriber-badge {
  font-size: 0.7rem;
  padding: 2px 7px;
  border-radius: 10px;
  white-space: nowrap;
}
.ss-notify-subscriber-badge.confirmed {
  background: rgba(34,197,94,0.15);
  color: #22c55e;
  border: 1px solid rgba(34,197,94,0.25);
}
.ss-notify-subscriber-badge.pending {
  background: rgba(255,143,31,0.12);
  color: #ff8f1f;
  border: 1px solid rgba(255,143,31,0.25);
}

.ss-check {
  grid-template-columns: auto 1fr;
  align-items: center;
}

.ss-form-errors {
  border: 1px solid rgba(185, 90, 79, 0.3);
  background: rgba(110, 38, 32, 0.22);
  color: #ffb3aa;
  border-radius: var(--radius-md);
  padding: 14px 16px;
}

.ss-form-success {
  border: 1px solid rgba(96, 170, 104, 0.3);
  background: rgba(45, 93, 58, 0.22);
  color: #cbe8cf;
  border-radius: var(--radius-md);
  padding: 14px 16px;
}

body[data-theme="light"] .ss-form-success {
  border-color: rgba(34, 130, 58, 0.4);
  background: rgba(34, 130, 58, 0.12);
  color: #000;
}

body[data-theme="light"] .ss-form-errors {
  border-color: rgba(185, 70, 55, 0.4);
  background: rgba(185, 70, 55, 0.1);
  color: #000;
}

.ss-form-errors p:last-child {
  margin-bottom: 0;
}

.ss-admin-side {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 16px;
  position: sticky;
  top: 18px;
  align-self: start;
}

.ss-admin-form-layout.is-gallery-workbench .ss-admin-side {
  order: -1;
}

.ss-admin-form-layout.is-gallery-workbench .ss-admin-form-stack {
  gap: 22px;
}

.ss-gallery-settings-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 18px;
  align-items: center;
}

.ss-gallery-admin-hero-image {
  margin-bottom: 8px;
  border-radius: 30px;
  overflow: hidden;
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
}

.ss-gallery-admin-hero-image img {
  width: 100%;
  height: min(380px, 34vw);
  object-fit: cover;
  display: block;
}

.ss-gallery-settings-summary {
  display: grid;
  grid-template-columns: minmax(220px, 320px) minmax(0, 1fr);
  gap: 18px;
  align-items: stretch;
}

.ss-gallery-settings-cover {
  min-height: 220px;
  border-radius: 24px;
  overflow: hidden;
  border: 1px solid var(--line);
}

.ss-gallery-settings-cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.ss-gallery-settings-copy {
  display: grid;
  align-content: center;
  gap: 12px;
}

.ss-gallery-settings-copy h2 {
  margin: 0;
  font-size: clamp(1.9rem, 2.8vw, 3rem);
  font-weight: 500;
}

.ss-gallery-settings-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.ss-gallery-settings-launch {
  display: flex;
  justify-content: flex-end;
}

.ss-gallery-settings-open {
  min-width: 220px;
}

.ss-gallery-identity-form {
  gap: 20px;
  position: relative;
  z-index: 2;
}

.ss-gallery-identity-form.is-hidden-storage {
  display: none;
}

.ss-gallery-identity-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 16px;
}

.ss-logo-preview {
  margin-top: 8px;
  padding: 18px;
  border: 1px dashed var(--line-strong);
  border-radius: 18px;
  background: var(--bg-soft);
}

.ss-logo-preview img {
  max-width: min(100%, 320px);
  max-height: 120px;
  object-fit: contain;
  display: block;
}

/* ── Wallpaper-Upload (Admin Settings) ── */
.ss-wallpaper-upload-row {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 12px 0;
}
.ss-wallpaper-upload-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 8px 16px;
  background: var(--accent);
  color: #fff;
  border-radius: var(--radius-md);
  font-size: 0.85rem;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  transition: background .15s;
}
.ss-wallpaper-upload-btn:hover { background: var(--accent-strong); }
body[data-theme="light"] .ss-wallpaper-upload-btn { color: #18130F; }
.ss-wallpaper-upload-hint {
  font-size: 0.82rem;
  color: var(--muted);
}
.ss-wallpaper-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
  gap: 8px;
  margin-top: 8px;
}
.ss-wallpaper-item {
  position: relative;
  aspect-ratio: 3/2;
  border-radius: var(--radius-md);
  overflow: hidden;
  background: var(--panel-strong);
}
.ss-wallpaper-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.ss-wallpaper-delete {
  position: absolute;
  top: 4px;
  right: 4px;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: rgba(0,0,0,0.6);
  color: #fff;
  border: none;
  cursor: pointer;
  font-size: 14px;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity .15s;
}
.ss-wallpaper-item:hover .ss-wallpaper-delete { opacity: 1; }

.ss-color-input-row {
  display: grid;
  grid-template-columns: 56px minmax(0, 1fr);
  gap: 10px;
}

.ss-color-picker {
  width: 56px;
  min-width: 56px;
  height: 52px;
  padding: 4px;
  border-radius: 14px;
  border: 1px solid var(--line);
  background: var(--bg-soft);
  cursor: pointer;
}

.ss-watermark-set-list {
  display: grid;
  gap: 18px;
  margin-top: 18px;
}

.ss-watermark-set-card {
  display: grid;
  gap: 14px;
  padding: 18px;
  border-radius: 20px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--panel) 86%, transparent);
}

.ss-watermark-set-summary {
  display: grid;
  gap: 6px;
  color: var(--muted);
}

.ss-watermark-set-summary strong {
  color: var(--text);
  font-size: 1.05rem;
}

.ss-watermark-set-preview {
  display: grid;
  place-items: center;
  min-height: 160px;
  padding: 16px;
  border-radius: 18px;
  border: 1px dashed var(--line-strong);
  background: var(--bg-soft);
}

.ss-watermark-set-preview img {
  max-width: min(100%, 320px);
  max-height: 120px;
  object-fit: contain;
  display: block;
}

.ss-watermark-actions {
  display: flex;
  justify-content: flex-end;
}

.ss-watermark-editor-panel {
  width: min(1120px, calc(100% - 24px));
}

.ss-watermark-editor-form {
  padding: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
  backdrop-filter: none;
}

.ss-watermark-editor-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(280px, 0.8fr);
  gap: 18px;
}

.ss-watermark-editor-preview,
.ss-watermark-editor-controls {
  display: grid;
  gap: 16px;
}

.ss-watermark-brand-preview {
  min-height: 180px;
}

.ss-watermark-stage {
  padding: 18px;
  border-radius: 22px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--panel) 78%, transparent);
}

.ss-watermark-stage-scene {
  position: relative;
  min-height: 360px;
  overflow: hidden;
  border-radius: 20px;
  border: 1px solid color-mix(in srgb, var(--line-strong) 85%, transparent);
  background:
    linear-gradient(180deg, rgba(211, 218, 220, 0.95) 0%, rgba(175, 186, 175, 0.88) 34%, rgba(86, 97, 70, 0.82) 35%, rgba(95, 110, 71, 0.92) 52%, rgba(52, 52, 47, 0.96) 53%, rgba(36, 32, 29, 1) 100%);
}

.ss-watermark-stage-scene::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 22% 30%, rgba(255, 255, 255, 0.34), transparent 24%),
    radial-gradient(circle at 72% 24%, rgba(255, 255, 255, 0.22), transparent 20%),
    radial-gradient(circle at 58% 55%, rgba(163, 176, 82, 0.58), transparent 20%),
    radial-gradient(circle at 48% 50%, rgba(78, 86, 36, 0.78), transparent 28%);
  pointer-events: none;
}

.ss-watermark-stage-mark {
  position: absolute;
  max-width: min(92%, 460px);
  height: auto;
  pointer-events: none;
  transition: width 140ms ease, opacity 140ms ease, inset 140ms ease, transform 140ms ease;
}

.ss-watermark-stage-mark[data-overlay="1"] {
  filter: drop-shadow(0 10px 24px rgba(0, 0, 0, 0.18));
}

.ss-watermark-stage-mark[data-overlay="0"] {
  max-width: min(68%, 320px);
}

.ss-watermark-stage-mark[data-position="top-left"] {
  top: 18px;
  left: 18px;
}

.ss-watermark-stage-mark[data-position="top-center"] {
  top: 18px;
  left: 50%;
  transform: translateX(-50%);
}

.ss-watermark-stage-mark[data-position="top-right"] {
  top: 18px;
  right: 18px;
}

.ss-watermark-stage-mark[data-position="middle-left"] {
  top: 50%;
  left: 18px;
  transform: translateY(-50%);
}

.ss-watermark-stage-mark[data-position="center"] {
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.ss-watermark-stage-mark[data-position="middle-right"] {
  top: 50%;
  right: 18px;
  transform: translateY(-50%);
}

.ss-watermark-stage-mark[data-position="bottom-left"] {
  left: 18px;
  bottom: 18px;
}

.ss-watermark-stage-mark[data-position="bottom-center"] {
  left: 50%;
  bottom: 18px;
  transform: translateX(-50%);
}

.ss-watermark-stage-mark[data-position="bottom-right"] {
  right: 18px;
  bottom: 18px;
}

.ss-watermark-position-picker {
  display: grid;
  gap: 12px;
}

.ss-watermark-position-grid {
  display: grid;
  grid-template-columns: repeat(3, 56px);
  gap: 8px;
}

.ss-watermark-pos {
  width: 56px;
  height: 56px;
  min-height: 56px;
  border-radius: 14px;
  border: 1px solid var(--line);
  background: linear-gradient(180deg, color-mix(in srgb, var(--bg-soft) 96%, white 4%), color-mix(in srgb, var(--bg-soft) 88%, black 12%));
  position: relative;
  cursor: pointer;
}

.ss-watermark-pos::before {
  content: "";
  position: absolute;
  width: 22px;
  height: 22px;
  border-radius: 8px;
  background: color-mix(in srgb, var(--accent) 82%, white 18%);
  box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.14);
}

.ss-watermark-pos[data-position-choice="top-left"]::before {
  top: 8px;
  left: 8px;
}

.ss-watermark-pos[data-position-choice="top-center"]::before {
  top: 8px;
  left: 50%;
  transform: translateX(-50%);
}

.ss-watermark-pos[data-position-choice="top-right"]::before {
  top: 8px;
  right: 8px;
}

.ss-watermark-pos[data-position-choice="middle-left"]::before {
  top: 50%;
  left: 8px;
  transform: translateY(-50%);
}

.ss-watermark-pos[data-position-choice="center"]::before {
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.ss-watermark-pos[data-position-choice="middle-right"]::before {
  top: 50%;
  right: 8px;
  transform: translateY(-50%);
}

.ss-watermark-pos[data-position-choice="bottom-left"]::before {
  left: 8px;
  bottom: 8px;
}

.ss-watermark-pos[data-position-choice="bottom-center"]::before {
  left: 50%;
  bottom: 8px;
  transform: translateX(-50%);
}

.ss-watermark-pos[data-position-choice="bottom-right"]::before {
  right: 8px;
  bottom: 8px;
}

.ss-watermark-pos.is-active {
  border-color: color-mix(in srgb, var(--accent-strong) 70%, transparent);
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent) 92%, white 8%), var(--accent-strong));
}

.ss-watermark-editor-actions,
.ss-watermark-editor-submit {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  flex-wrap: wrap;
}

.ss-asset-admin-list {
  display: grid;
  gap: 12px;
}

.ss-admin-form-layout.is-gallery-workbench .ss-upload-form {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  clip-path: inset(50%);
  border: 0;
  padding: 0;
  margin: -1px;
}

.ss-admin-form-layout.is-gallery-workbench .ss-admin-card {
  padding: 22px;
  border-radius: 26px;
}

.ss-admin-form-layout.is-gallery-workbench .ss-asset-admin-list {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}
.ss-admin-form-layout.is-gallery-workbench .ss-asset-admin-list::after {
  content: "";
  flex-grow: 999;
}

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

.ss-asset-admin-item {
  display: grid;
  grid-template-columns: 88px minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  padding: 12px 0;
  border-top: 1px solid var(--line);
}

.ss-asset-admin-item:first-child {
  border-top: 0;
  padding-top: 0;
}

.ss-asset-admin-item[hidden] {
  display: none;
}

.ss-asset-admin-media {
  position: relative;
}

.ss-asset-admin-item img {
  width: 88px;
  height: 66px;
  object-fit: cover;
  border-radius: 14px;
  border: 1px solid var(--line);
  background: var(--bg-soft);
}

.ss-asset-admin-copy {
  display: grid;
  gap: 4px;
}

.ss-asset-admin-copy span {
  color: var(--muted);
  overflow-wrap: anywhere;
}

.ss-admin-form-layout.is-gallery-workbench .ss-asset-admin-item {
  flex-grow: var(--aspect, 1.5);
  flex-shrink: 0;
  flex-basis: calc(180px * var(--aspect, 1.5));
  max-width: 100%;
  display: flex;
  flex-direction: column;
  padding: 0;
  border-top: 0;
  position: relative;
  z-index: 1;
}

.ss-admin-form-layout.is-gallery-workbench .ss-asset-admin-item[hidden] {
  display: none;
}

.ss-admin-form-layout.is-gallery-workbench .ss-asset-admin-media {
  width: 100%;
  aspect-ratio: var(--aspect, 1.5);
  height: auto;
  position: relative;
  border-radius: 6px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.1);
}

.ss-admin-form-layout.is-gallery-workbench .ss-asset-admin-item:hover,
.ss-admin-form-layout.is-gallery-workbench .ss-asset-admin-item:focus-within {
  z-index: 40;
}

.ss-admin-form-layout.is-gallery-workbench .ss-asset-admin-item img {
  width: 100%;
  height: 100%;
  object-fit: fill;
  border-radius: 6px;
  display: block;
}

.ss-admin-form-layout.is-gallery-workbench .ss-asset-admin-media:hover .ss-admin-gallery-menu-trigger,
.ss-admin-form-layout.is-gallery-workbench .ss-asset-admin-media:focus-within .ss-admin-gallery-menu-trigger,
.ss-admin-form-layout.is-gallery-workbench .ss-admin-asset-menu .ss-admin-gallery-menu-trigger[aria-expanded="true"] {
  opacity: 1;
  transform: translateY(0);
}

@media (hover: none) {
  .ss-admin-form-layout.is-gallery-workbench .ss-admin-gallery-menu-trigger {
    opacity: 1;
    transform: translateY(0);
  }
}


.ss-admin-asset-menu {
  right: 10px;
  bottom: 10px;
  z-index: 60;
}

/* ── Admin card hover buttons (shared base) ─────────────────────────────── */
.ss-admin-card-btn {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(6px);
  border: 0;
  color: #fff;
  cursor: pointer;
  opacity: 0;
  transition: opacity 0.15s, transform 0.15s, background 0.15s;
  padding: 0;
  text-decoration: none;
  z-index: 55;
}
.ss-asset-admin-item:hover .ss-admin-card-btn,
.ss-admin-card-btn.is-active {
  opacity: 1;
}
.ss-admin-card-btn:hover {
  background: rgba(0,0,0,0.8);
  transform: scale(1.1);
}
.ss-admin-card-btn--tl { top: 8px; left: 8px; }
.ss-admin-card-btn--bl { bottom: 8px; left: 8px; }

/* Selected state for + button */
.ss-admin-card-btn--tl.is-active {
  background: var(--accent);
  color: #fff;
}

/* ── Admin flag overlay (top-right) ─────────────────────────────────────── */
.ss-admin-flag-overlay {
  position: absolute;
  top: 8px;
  right: 8px;
  z-index: 55;
}

.ss-admin-flag-trigger {
  display: flex;
  align-items: center;
  gap: 5px;
  height: 30px;
  border-radius: 20px;
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(6px);
  border: 0;
  color: #fff;
  cursor: pointer;
  opacity: 0;
  transition: opacity 0.15s, transform 0.15s, background 0.15s;
  padding: 0 10px 0 8px;
  font-size: 0.78rem;
  font-weight: 600;
  white-space: nowrap;
  letter-spacing: 0.02em;
}
/* When rated: always visible as colored badge */
.ss-admin-flag-trigger[data-rating="red"],
.ss-admin-flag-trigger[data-rating="orange"],
.ss-admin-flag-trigger[data-rating="green"],
.ss-admin-flag-trigger[data-rating="black"] {
  opacity: 1;
}
.ss-asset-admin-item:hover .ss-admin-flag-trigger,
.ss-admin-flag-overlay.is-open .ss-admin-flag-trigger {
  opacity: 1;
}
.ss-admin-flag-trigger:hover {
  transform: scale(1.05);
}
/* Badge colors when rated — same as voting mode color tokens */
.ss-admin-flag-trigger[data-rating="red"]    { background: var(--red);        color: #fff; }
.ss-admin-flag-trigger[data-rating="orange"] { background: var(--orange);     color: #fff; }
.ss-admin-flag-trigger[data-rating="green"]  { background: var(--green);      color: #fff; }
.ss-admin-flag-trigger[data-rating="black"]  { background: var(--black-flag); color: #ccc; }
/* No-rating state: small icon only, no pill padding */
.ss-admin-flag-trigger:not([data-rating]):not([data-rating=""]) { padding: 0; width: 30px; justify-content: center; }
.ss-admin-flag-trigger[data-rating=""] { padding: 0; width: 30px; justify-content: center; }

/* Admin flag popup reuses .ss-flag-dropdown — override positioning for top-right context */
.ss-admin-flag-overlay .ss-flag-dropdown {
  top: calc(100% + 6px);
  right: 0;
  left: auto;
}
/* Always visible on touch devices */
@media (hover: none) {
  .ss-admin-card-btn  { opacity: 1; }
  .ss-admin-flag-trigger { opacity: 1; }
}

/* ── Batch-Rating Toolbar ────────────────────────────────────────────────── */
.ss-batch-toolbar {
  position: sticky;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 60;
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  padding: 10px 16px;
  background: var(--panel-strong);
  border-top: 1px solid rgba(255,255,255,.08);
  border-radius: 12px 12px 0 0;
  box-shadow: 0 -4px 20px rgba(0,0,0,.4);
}
.ss-batch-count {
  font-size: .8rem;
  color: var(--muted);
  min-width: 80px;
}
.ss-batch-flags {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  flex: 1;
}
.ss-batch-flag-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 10px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 6px;
  background: transparent;
  color: var(--text);
  font-size: .78rem;
  cursor: pointer;
  transition: background .15s, border-color .15s;
}
.ss-batch-flag-btn:hover {
  background: rgba(255,255,255,.07);
  border-color: rgba(255,255,255,.22);
}
.ss-batch-flag-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--flag-color, #888);
  flex-shrink: 0;
}
.ss-batch-flag-btn--clear {
  color: var(--muted);
}
/* In batch mode: highlight selected cards */
.is-batch-mode .ss-asset-admin-item[data-admin-selected="1"] {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
  border-radius: 6px;
}
/* Show checkbox overlay in batch mode */
.is-batch-mode .ss-admin-card-btn--tl {
  opacity: 1;
}
.is-batch-mode .ss-asset-admin-item[data-admin-selected="1"] .ss-admin-card-btn--tl {
  background: var(--accent);
  color: #000;
}

.ss-admin-asset-menu .ss-admin-gallery-menu-trigger {
  width: 32px;
  height: 32px;
  min-height: 32px;
  border-radius: 10px;
  font-size: 1.1rem;
}

.ss-admin-asset-menu .ss-admin-gallery-menu-trigger svg {
  width: 16px;
  height: 16px;
  display: block;
}

.ss-admin-asset-menu-panel {
  width: min(300px, calc(100vw - 32px));
  z-index: 80;
}

.ss-admin-form-layout.is-gallery-workbench .ss-asset-admin-item form {
  margin-top: auto;
}

.ss-admin-form-layout.is-gallery-workbench .ss-asset-admin-copy strong {
  display: none;
}

.ss-admin-form-layout.is-gallery-workbench .ss-asset-admin-copy {
  display: block;
  text-align: center;
  margin-top: 6px;
  padding: 0 4px;
}

.ss-admin-form-layout.is-gallery-workbench .ss-asset-admin-copy span {
  font-size: 0.8rem;
  line-height: 1.2;
  color: var(--muted);
  display: block;
}

.ss-admin-form-layout.is-gallery-workbench .ss-asset-admin-item .ss-assets-meta,
.ss-admin-form-layout.is-gallery-workbench .ss-asset-admin-item .ss-asset-admin-date {
  display: none !important;
}


.ss-gallery-sidebar-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 16px;
}

.ss-gallery-sidebar-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: start;
  margin-bottom: 14px;
}

.ss-gallery-sidebar-head > div:first-child {
  min-width: 0;
}

.ss-gallery-sidebar-head h2 {
  margin: 0;
  font-size: 1.8rem;
  line-height: 1.08;
  overflow-wrap: break-word;
}

.ss-gallery-sidebar-cover {
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid var(--line);
  aspect-ratio: 5 / 4;
  background: var(--bg-soft);
}

.ss-gallery-sidebar-cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.ss-gallery-sidebar-actions {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 12px;
}

.ss-gallery-sidebar-actions--stack {
  grid-template-columns: 1fr;
}

.ss-gallery-sidebar-actions .ss-gallery-tool,
.ss-gallery-sidebar-actions .ss-primary-link {
  width: 100%;
}

.ss-gallery-tool {
  min-height: 98px;
  padding: 14px 10px;
  border-radius: 18px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--bg-soft) 88%, white 12%);
  color: var(--text);
  display: grid;
  grid-template-rows: auto auto;
  justify-items: center;
  align-content: center;
  gap: 8px;
  text-decoration: none;
  text-align: center;
  cursor: pointer;
}

.ss-gallery-tool svg {
  width: 30px;
  height: 30px;
  display: block;
  margin-inline: auto;
}

.ss-gallery-tool span {
  width: 100%;
  font-size: 0.98rem;
  line-height: 1.1;
  text-align: center;
}

.ss-gallery-tool:hover {
  background: color-mix(in srgb, var(--accent) 10%, var(--bg-soft));
}

.ss-gallery-sidebar-actions--stack .ss-primary-link {
  min-height: 56px;
}

.ss-button-muted {
  opacity: 0.74;
}

.ss-gallery-sidebar-stats {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 0.96rem;
}

.ss-gallery-arrangement-card {
  display: grid;
  gap: 18px;
}

.ss-gallery-arrangement-form {
  display: grid;
  gap: 18px;
}

.ss-gallery-arrangement-form--inline {
  display: flex;
  gap: 8px 12px;
  align-items: end;
  flex-wrap: wrap;
}

.ss-gallery-arrangement-form label {
  display: grid;
  gap: 10px;
}

.ss-gallery-arrangement-form label > span {
  color: var(--text);
  font-size: 1rem;
  font-weight: 700;
}

.ss-gallery-arrangement-form--inline label {
  gap: 6px;
}

.ss-gallery-arrangement-form--inline label > span {
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.ss-arrangement-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 52px;
  gap: 10px;
  align-items: center;
}

.ss-gallery-arrangement-form select {
  min-height: 50px;
  border-radius: 18px;
  border: 1px solid var(--line-strong);
  background: color-mix(in srgb, var(--panel-strong) 92%, white 8%);
  color: var(--text);
  padding: 0 16px;
}

.ss-gallery-arrangement-form--inline select {
  min-height: 38px;
  border-radius: 14px;
  padding: 0 12px;
}

.ss-arrangement-direction {
  width: 52px;
  height: 50px;
  border-radius: 16px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--bg-soft) 88%, white 12%);
  color: var(--muted);
  display: inline-grid;
  place-items: center;
  cursor: pointer;
  transition: border-color 140ms ease, background 140ms ease, color 140ms ease;
}

.ss-arrangement-direction.is-desc {
  color: var(--text);
  border-color: color-mix(in srgb, var(--accent-strong) 42%, var(--line));
  background: color-mix(in srgb, var(--accent) 18%, var(--panel-strong));
}

.ss-gallery-arrangement-form--inline .ss-arrangement-row {
  grid-template-columns: minmax(170px, 1fr) 40px;
  gap: 8px;
}

.ss-gallery-arrangement-form--inline .ss-arrangement-direction {
  width: 40px;
  height: 38px;
  border-radius: 12px;
}

.ss-gallery-sidebar-filter-card {
  display: grid;
  gap: 12px;
  padding: 18px 18px 16px;
  border-radius: 22px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--bg-soft) 86%, white 14%);
}

.ss-gallery-sidebar-filter-card strong {
  font-size: 1.08rem;
}

.ss-gallery-sidebar-filter-card .ss-copy {
  margin: 0;
  font-size: 0.9rem;
  color: var(--muted);
}

.ss-gallery-rating-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.ss-gallery-rating-filter {
  width: 46px;
  height: 46px;
  padding: 0;
  border-radius: 14px;
  border: 1px solid var(--line);
  background: var(--panel-strong);
  color: var(--muted);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: transform 140ms ease, border-color 140ms ease, background 140ms ease, color 140ms ease;
}

.ss-gallery-rating-filter svg {
  width: 24px;
  height: 24px;
}

.ss-gallery-rating-filter[data-admin-rating-filter="green"] {
  color: #a8d85b;
}

.ss-gallery-rating-filter[data-admin-rating-filter="orange"] {
  color: #ff8f1f;
}

.ss-gallery-rating-filter[data-admin-rating-filter="black"] {
  color: #aaaaaa;
}

.ss-gallery-rating-filter[data-admin-rating-filter="red"] {
  color: #ea3200;
}

.ss-gallery-rating-filter[data-admin-rating-filter="commented"] {
  color: var(--text);
}

.ss-gallery-rating-filter:hover {
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--accent-strong) 40%, var(--line));
}

.ss-gallery-rating-filter.is-active {
  background: color-mix(in srgb, currentColor 14%, var(--panel-strong));
  border-color: currentColor;
  box-shadow: inset 0 0 0 1px color-mix(in srgb, currentColor 38%, transparent);
}

/* Colors for public gallery filter buttons (data-filter, not data-admin-rating-filter) */
.ss-gallery-rating-filter[data-filter="green"]    { color: #a8d85b; }
.ss-gallery-rating-filter[data-filter="orange"]   { color: #ff8f1f; }
.ss-gallery-rating-filter[data-filter="red"]      { color: #ea3200; }
.ss-gallery-rating-filter[data-filter="black"]    { color: #aaaaaa; }
.ss-gallery-rating-filter[data-filter="commented"]{ color: var(--text); }
.ss-gallery-rating-filter[data-filter="flagged"]  { color: var(--muted); }

/* ── Public gallery sidebar overrides ───────────────────────────────────────── */

/* Cards fill the sidebar width, separated by gap (not border-top lines) */
.ss-gallery-sidebar .ss-sidebar-section {
  margin-top: 0;
  padding-top: 0;
  border-top: none;
}

/* Tighter gap between cards inside the narrow sidebar */
.ss-gallery-sidebar .ss-sidebar-inner {
  gap: 7px;
}

/* Compact button size (40px fits 3/row in 220px sidebar) */
.ss-gallery-sidebar .ss-gallery-rating-filter {
  width: 40px;
  height: 40px;
  border-radius: 12px;
}
.ss-gallery-sidebar .ss-gallery-rating-filters {
  gap: 7px;
}

/* Slightly smaller padding in the narrow sidebar */
.ss-gallery-sidebar .ss-gallery-sidebar-filter-card {
  padding: 14px 14px 12px;
  border-radius: 16px;
}

/* Subsection labels (Sortieren/Gruppieren) inside a card: no top gap on the first one */
.ss-gallery-sidebar .ss-gallery-sidebar-filter-card .ss-sidebar-subsection-label:first-of-type {
  margin-top: 0;
}

/* Buttons inside a card: remove bottom margin (card gap handles spacing) */
.ss-gallery-sidebar .ss-gallery-sidebar-filter-card .ss-sidebar-big-btn {
  margin-bottom: 0;
}

.ss-gallery-title-menu {
  position: relative;
}

.ss-gallery-title-menu-trigger {
  min-width: 46px;
  min-height: 46px;
  padding: 0;
  font-size: 1.2rem;
}

.ss-gallery-title-menu-panel {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  width: 240px;
  padding: 6px;
  border-radius: var(--radius-xl, 14px);
  border: 1px solid rgba(255,255,255,.09);
  background: var(--panel-strong);
  box-shadow: 0 8px 32px rgba(0,0,0,.45);
  z-index: 300;
  display: grid;
  gap: 1px;
}

.ss-gallery-title-menu-panel[hidden] {
  display: none;
}

.ss-gallery-title-menu-panel button {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 40px;
  border: 0;
  background: transparent;
  color: var(--text);
  text-align: left;
  padding: 0 10px;
  border-radius: 8px;
  cursor: pointer;
  font-size: 0.9rem;
  width: 100%;
}

.ss-gallery-title-menu-panel button svg {
  flex-shrink: 0;
  color: var(--muted);
}

.ss-gallery-title-menu-panel button:hover {
  background: rgba(255,255,255,.07);
}
.ss-gallery-title-menu-panel button:hover svg {
  color: var(--text);
}

.ss-gallery-title-menu-panel button.ss-menu-danger {
  color: #ef4444;
}
.ss-gallery-title-menu-panel button.ss-menu-danger svg {
  color: #ef4444;
}
.ss-gallery-title-menu-panel button.ss-menu-danger:hover {
  background: rgba(239,68,68,.1);
}

.ss-gallery-title-menu-panel hr {
  width: 100%;
  border: 0;
  border-top: 1px solid rgba(255,255,255,.08);
  margin: 4px 0;
}

/* ── Galeriebild / Titelbild / Verschieben / Bulk-Rename Overlays ──────────── */

.ss-picker-panel {
  width: min(760px, calc(100% - 24px));
  max-height: 80vh;
  display: flex;
  flex-direction: column;
}

.ss-picker-hint {
  font-size: 0.88rem;
  color: var(--muted);
  margin: -4px 0 8px;
}

.ss-picker-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
  gap: 8px;
  overflow-y: auto;
  padding: 4px 2px;
  flex: 1;
}

.ss-picker-thumb {
  position: relative;
  border: 2px solid transparent;
  border-radius: 10px;
  overflow: hidden;
  cursor: pointer;
  background: var(--bg-soft);
  padding: 0;
  aspect-ratio: 4/3;
}

.ss-picker-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.ss-picker-thumb .ss-picker-check {
  display: none;
  position: absolute;
  top: 4px;
  right: 4px;
  background: var(--accent);
  color: #fff;
  border-radius: 50%;
  width: 20px;
  height: 20px;
  font-size: 12px;
  line-height: 20px;
  text-align: center;
}

.ss-picker-thumb.is-selected {
  border-color: var(--accent);
}

.ss-picker-thumb.is-selected .ss-picker-check {
  display: block;
}

.ss-picker-thumb:hover {
  border-color: rgba(32, 160, 185, .5);
}

.ss-picker-loading,
.ss-picker-empty {
  grid-column: 1 / -1;
  color: var(--muted);
  font-size: 0.9rem;
  padding: 24px 0;
  text-align: center;
}

.ss-dialog-panel {
  width: min(420px, calc(100% - 24px));
}

.ss-dialog-message {
  color: var(--text);
  font-size: 0.95rem;
  line-height: 1.5;
  margin-bottom: 20px;
  min-height: 1em;
}

.ss-move-parent-panel,
.ss-bulk-rename-panel {
  width: min(480px, calc(100% - 24px));
}

.ss-move-parent-list {
  display: flex;
  flex-direction: column;
  gap: 4px;
  max-height: 50vh;
  overflow-y: auto;
  margin-bottom: 16px;
}

.ss-move-parent-item {
  text-align: left;
  padding: 10px 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--bg-soft);
  color: var(--text);
  cursor: pointer;
  font-size: 0.9rem;
  transition: border-color .15s, background .15s;
}

.ss-move-parent-item:hover {
  border-color: var(--accent);
}

.ss-move-parent-item.is-selected {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 12%, var(--bg-soft));
}

.ss-overlay-footer {
  display: flex;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 10px;
  padding-top: 16px;
  border-top: 1px solid var(--line);
  margin-top: 4px;
}
@media (max-width: 480px) {
  .ss-dialog-panel .ss-overlay-footer {
    flex-direction: column-reverse;
    gap: 8px;
  }
  .ss-dialog-panel .ss-overlay-footer button {
    width: 100%;
  }
}

.ss-bulk-rename-body {
  display: grid;
  gap: 10px;
  margin-bottom: 16px;
}

.ss-field-label {
  font-size: 0.88rem;
  color: var(--muted);
  font-weight: 600;
}

.ss-text-input {
  width: 100%;
  padding: 10px 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--bg-soft);
  color: var(--text);
  font-size: 0.95rem;
  font-family: inherit;
}

.ss-text-input:focus {
  outline: none;
  border-color: var(--accent);
}

.ss-asset-info-panel {
  width: min(520px, calc(100% - 24px));
  max-height: min(90vh, 700px);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.ss-asset-info-panel .ss-overlay-tab-content {
  overflow-y: auto;
  flex: 1;
}

.ss-asset-info-list {
  display: grid;
  gap: 14px;
  margin: 0;
}

.ss-asset-info-list div {
  display: grid;
  gap: 4px;
  padding: 14px 0;
  border-top: 1px solid var(--line);
}

.ss-asset-info-list div:first-child {
  border-top: 0;
  padding-top: 0;
}

.ss-asset-info-list dt {
  color: var(--muted);
  font-size: 0.88rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.ss-asset-info-list dd {
  margin: 0;
  font-size: 1rem;
  overflow-wrap: anywhere;
}

/* ── Overlay Tabs (Info / Kommentare) ─────────────────────────────────── */
.ss-overlay-tabs {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--line);
  margin: 0 -26px;
  padding: 0 26px;
}

.ss-overlay-tab {
  padding: 10px 16px;
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--muted);
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  cursor: pointer;
  transition: color 140ms, border-color 140ms;
  display: flex;
  align-items: center;
  gap: 6px;
}

.ss-overlay-tab:hover { color: var(--text); }
.ss-overlay-tab.is-active { color: var(--accent); border-bottom-color: var(--accent); }

.ss-overlay-tab-badge {
  background: var(--accent);
  color: #fff;
  font-size: 0.68rem;
  font-weight: 700;
  padding: 1px 6px;
  border-radius: 20px;
  min-width: 18px;
  text-align: center;
}

.ss-overlay-tab-content { padding-top: 20px; }

/* ── Admin Comments inside dark viewer ───────────────────────────────── */
.ss-admin-viewer .ss-admin-comment-item {
  background: rgba(255,255,255,0.05);
  border-color: rgba(255,255,255,0.08);
}

.ss-admin-viewer .ss-admin-comment-item.ss-admin-comment-is-admin {
  background: rgba(32,160,185,0.1);
  border-color: rgba(32,160,185,0.3);
}

.ss-admin-viewer .ss-admin-comment-author { color: rgba(255,255,255,0.85); }
.ss-admin-viewer .ss-admin-comment-time   { color: rgba(255,255,255,0.35); }
.ss-admin-viewer .ss-admin-comment-text   { color: rgba(255,255,255,0.75); }
.ss-admin-viewer .ss-admin-comment-reply-btn,
.ss-admin-viewer .ss-admin-comment-edit-btn,
.ss-admin-viewer .ss-admin-comment-delete-btn { color: rgba(255,255,255,0.3); }
.ss-admin-viewer .ss-admin-comment-reply-btn:hover  { color: var(--accent); background: rgba(32,160,185,0.15); }
.ss-admin-viewer .ss-admin-comment-edit-btn:hover   { color: rgba(255,255,255,0.8); background: rgba(255,255,255,0.08); }
.ss-admin-viewer .ss-admin-comment-delete-btn:hover { color: var(--red); background: rgba(239,68,68,0.12); }

.ss-admin-viewer .ss-admin-comment-reply-form .ss-kicker { color: rgba(255,255,255,0.4); }
.ss-admin-viewer .ss-admin-comment-reply-form .ss-text-input {
  background: rgba(255,255,255,0.07);
  border-color: rgba(255,255,255,0.12);
  color: #fff;
}
.ss-admin-viewer .ss-admin-comment-reply-form .ss-text-input::placeholder { color: rgba(255,255,255,0.25); }
.ss-admin-viewer .ss-admin-comment-reply-form .ss-text-input:focus { border-color: var(--accent); }

/* ── Admin Comments Panel ─────────────────────────────────────────────── */
.ss-admin-comments-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 16px;
  max-height: 340px;
  overflow-y: auto;
}

.ss-admin-comment-item {
  padding: 10px 12px;
  background: var(--panel-strong);
  border-radius: 8px;
  border: 1px solid var(--line);
}

.ss-admin-comment-item.ss-admin-comment-reply {
  margin-left: 16px;
  border-left: 2px solid var(--accent);
}

.ss-admin-comment-item.ss-admin-comment-is-admin {
  border-color: rgba(32,160,185,0.35);
  background: rgba(32,160,185,0.08);
}

.ss-admin-comment-header {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 6px;
  flex-wrap: wrap;
}

.ss-admin-comment-badge {
  background: var(--accent);
  color: #fff;
  font-size: 0.65rem;
  font-weight: 700;
  padding: 1px 6px;
  border-radius: 20px;
  text-transform: uppercase;
}

.ss-admin-comment-author { font-size: 0.82rem; font-weight: 600; color: var(--text); }
.ss-admin-comment-time   { font-size: 0.76rem; color: var(--muted); }

.ss-admin-comment-actions {
  margin-left: auto;
  display: flex;
  gap: 4px;
}

.ss-admin-comment-reply-btn,
.ss-admin-comment-edit-btn,
.ss-admin-comment-delete-btn {
  padding: 4px 6px;
  border: none;
  border-radius: 5px;
  background: transparent;
  color: var(--muted);
  cursor: pointer;
  display: flex;
  align-items: center;
  transition: color 120ms, background 120ms;
}

.ss-admin-comment-reply-btn:hover  { color: var(--accent); background: rgba(32,160,185,0.1); }
.ss-admin-comment-edit-btn:hover   { color: var(--text); background: var(--panel); }
.ss-admin-comment-delete-btn:hover { color: var(--red); background: rgba(239,68,68,0.1); }

.ss-admin-comment-text {
  font-size: 0.87rem;
  color: var(--text);
  line-height: 1.5;
  margin: 0;
  white-space: pre-wrap;
}

.ss-admin-comment-reply-form .ss-text-input {
  width: 100%;
}

.ss-events-panel {
  padding: 24px;
}

/* ── Galerie-Statistiken ─────────────────────────────────────────────────── */
.ss-gallery-stats {
  display: grid;
  gap: 14px;
  padding: 14px 16px;
}
.ss-gallery-stats-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 8px;
}
.ss-gallery-stats-header strong {
  font-size: .8rem;
  color: var(--muted);
}
.ss-stats-kpis {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}
.ss-stats-kpi {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  padding: 8px 4px;
  background: var(--bg-soft);
  border-radius: 8px;
}
.ss-stats-kpi-value {
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--text);
}
.ss-stats-kpi-label {
  font-size: .7rem;
  color: var(--muted);
}
.ss-stats-chart {
  display: grid;
  gap: 6px;
}
.ss-stats-bars {
  display: flex;
  align-items: flex-end;
  gap: 2px;
  height: 48px;
}
.ss-stats-bar-col {
  flex: 1;
  display: flex;
  align-items: flex-end;
  height: 100%;
}
.ss-stats-bar {
  width: 100%;
  min-height: 2px;
  height: var(--h, 0%);
  border-radius: 2px 2px 0 0;
  transition: height .3s;
}
.ss-stats-bar--visits { background: var(--accent); opacity: .75; }
.ss-stats-chart-legend {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: .72rem;
  color: var(--muted);
}
.ss-stats-legend-dot {
  width: 8px;
  height: 8px;
  border-radius: 2px;
  flex-shrink: 0;
}
.ss-stats-legend-dot--visits { background: var(--accent); }
.ss-stats-feedback {
  display: grid;
  gap: 6px;
}
.ss-stats-flag-row {
  display: grid;
  grid-template-columns: 10px 44px 1fr 24px;
  align-items: center;
  gap: 6px;
  font-size: .75rem;
  color: var(--muted);
}
.ss-stats-flag-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
}
.ss-stats-flag-bar {
  height: 6px;
  border-radius: 3px;
  background: rgba(255,255,255,.07);
  overflow: hidden;
}
.ss-stats-flag-fill {
  height: 100%;
  border-radius: inherit;
  transition: width .3s;
}
.ss-stats-flag-count {
  text-align: right;
  color: var(--text);
  font-weight: 600;
}

.ss-gallery-events-accordion {
  padding: 0;
  overflow: hidden;
}

.ss-gallery-events-toggle {
  width: 100%;
  border: 0;
  background: transparent;
  color: var(--text);
  padding: 16px 20px;
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: center;
  text-align: left;
  cursor: pointer;
}

.ss-gallery-events-toggle.has-unread .ss-gallery-events-toggle-copy strong::after {
  content: "";
  display: inline-block;
  width: 10px;
  height: 10px;
  margin-left: 10px;
  border-radius: var(--radius-md);
  background: var(--accent-strong);
  vertical-align: middle;
}

.ss-gallery-events-toggle-copy {
  display: grid;
  gap: 2px;
}

.ss-gallery-events-toggle-copy strong {
  font-size: 1.2rem;
}

.ss-gallery-events-toggle-meta {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  color: var(--muted);
}

.ss-gallery-events-chevron {
  font-size: 1.1rem;
  transition: transform 140ms ease;
}

.ss-gallery-events-toggle[aria-expanded="true"] .ss-gallery-events-chevron {
  transform: rotate(180deg);
}

.ss-gallery-events-panel {
  padding: 0 24px 24px;
  border-top: 1px solid var(--line);
}

.ss-gallery-media-panel {
  position: relative;
  transition: border-color 140ms ease, background 140ms ease, transform 140ms ease;
  overflow: visible;
}

.ss-gallery-media-panel .ss-admin-card-head {
  flex-wrap: wrap;
}

.ss-gallery-media-panel.is-dragover {
  border-color: color-mix(in srgb, var(--accent-strong) 78%, transparent);
  background: color-mix(in srgb, var(--accent) 10%, var(--panel));
  transform: translateY(-1px);
}

.ss-gallery-empty-state {
  display: grid;
  gap: 34px;
  min-height: 980px;
  align-content: start;
}

.ss-gallery-empty-brand {
  padding-top: 18px;
}

.ss-gallery-empty-brand img {
  max-width: min(100%, 380px);
  max-height: 128px;
  object-fit: contain;
  display: block;
}

.ss-gallery-empty-copy {
  display: grid;
  gap: 4px;
  max-width: 620px;
}

.ss-gallery-empty-copy p {
  margin: 0;
}

.ss-gallery-empty-note {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  width: fit-content;
  min-height: 44px;
  padding: 0 14px;
  border-radius: 14px;
  background: color-mix(in srgb, var(--bg-soft) 88%, white 12%);
  color: var(--text);
}

.ss-gallery-empty-note-icon {
  display: inline-grid;
  place-items: center;
  width: 18px;
  height: 18px;
  color: var(--accent-strong);
}

.ss-gallery-empty-dropzone {
  display: grid;
  place-items: center;
  gap: 12px;
  min-height: 210px;
  padding: 28px;
  border-radius: 28px;
  border: 2px dashed var(--line-strong);
  background: transparent;
  color: var(--text);
  text-align: center;
}

.ss-gallery-empty-dropzone strong {
  font-size: clamp(1.8rem, 2.4vw, 2.6rem);
  line-height: 1;
}

.ss-gallery-empty-dropzone span {
  color: var(--muted);
}

.ss-gallery-empty-dropzone em {
  font-style: normal;
  min-height: 42px;
  padding: 0 18px;
  border-radius: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(180deg, var(--accent), var(--accent-strong));
  color: #ffffff;
  font-weight: 700;
}

.ss-gallery-empty-dropzone.is-dragover {
  border-color: color-mix(in srgb, var(--accent-strong) 88%, transparent);
  background: color-mix(in srgb, var(--accent) 10%, var(--panel));
}

.ss-subgallery-placeholder {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: end;
  padding-top: 6px;
}

.ss-subgallery-placeholder h2 {
  margin: 0 0 12px;
  font-size: clamp(2rem, 2.7vw, 3.1rem);
}

.ss-subgallery-placeholder p {
  margin: 0;
  max-width: 720px;
}

.ss-gallery-empty-footer {
  margin-top: auto;
  padding-top: 28px;
  border-top: 1px solid var(--line);
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: end;
}

.ss-gallery-empty-footer strong,
.ss-gallery-empty-footer span {
  display: block;
}

.ss-gallery-empty-footer span {
  color: var(--muted);
  margin-top: 4px;
}

.ss-gallery-empty-socials {
  display: flex;
  gap: 12px;
}

.ss-gallery-empty-socials span {
  display: inline-grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border-radius: var(--radius-md);
  border: 1px solid var(--line-strong);
  color: var(--text);
  font-weight: 700;
}

.ss-events-toolbar {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: end;
  margin-bottom: 18px;
  padding: 18px;
  border-radius: 20px;
  background: color-mix(in srgb, var(--panel) 84%, transparent);
  border: 1px solid var(--line);
}

.ss-events-filter-box {
  display: grid;
  gap: 12px;
}

.ss-events-label {
  margin: 0;
  font-weight: 700;
  color: var(--text);
}

.ss-events-checks {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
}

.ss-events-checks label,
.ss-events-toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--text);
}

.ss-event-list {
  display: grid;
  gap: 12px;
}

.ss-event-item {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  gap: 12px;
  align-items: start;
  padding: 10px 0;
  border-top: 1px solid var(--line);
}

.ss-event-item[hidden] {
  display: none;
}

.ss-event-item.is-unread {
  position: relative;
}

.ss-event-item.is-unread::before {
  content: "";
  position: absolute;
  left: -14px;
  top: 18px;
  width: 8px;
  height: 8px;
  border-radius: var(--radius-md);
  background: var(--accent-strong);
}

.ss-event-item:first-child {
  border-top: 0;
  padding-top: 0;
}

.ss-event-icon {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: var(--radius-md);
  border: 1px solid var(--line-strong);
  background: var(--bg-soft);
  color: var(--accent-strong);
  font-size: 1.1rem;
}

.ss-event-copy {
  display: grid;
  gap: 4px;
}

.ss-event-copy strong {
  line-height: 1.45;
}

.ss-event-copy span {
  color: var(--muted);
  font-size: 0.92rem;
}

.ss-overlay {
  position: fixed;
  inset: 0;
  z-index: 20000;
  display: grid;
  align-items: center;
  justify-items: center;
  padding: 24px 16px;
  overflow-y: auto;
  overscroll-behavior: contain;
}

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

.ss-overlay-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(10, 8, 6, 0.78);
  backdrop-filter: blur(6px);
}

.ss-overlay-panel {
  position: relative;
  width: min(920px, calc(100% - 24px));
  max-height: min(calc(100vh - 48px), 980px);
  margin: 0;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding: 26px;
  background: var(--panel-strong);
  border: 1px solid var(--line);
  border-radius: 24px;
  box-shadow: var(--shadow);
}

.ss-overlay-header {
  display: flex;
  justify-content: space-between;
  align-items: start;
  gap: 16px;
  margin-bottom: 16px;
}

.ss-overlay-close {
  width: 44px;
  height: 44px;
  border-radius: var(--radius-md);
  border: 1px solid var(--line-strong);
  background: transparent;
  color: var(--text);
  font-size: 1.6rem;
  cursor: pointer;
}

.ss-gallery-settings-panel {
  width: min(1180px, calc(100% - 24px));
}

.ss-settings-mode-switch {
  display: grid;
  gap: 12px;
  margin: 10px 0 20px;
}

.ss-segmented {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px;
  padding: 6px;
  border-radius: var(--radius-md);
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--bg-soft) 88%, white 12%);
}

.ss-segmented button {
  min-height: 52px;
  border: 0;
  border-radius: var(--radius-md);
  background: transparent;
  color: var(--text);
  cursor: pointer;
  font-weight: 600;
}

.ss-segmented button.is-active {
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent) 94%, white 6%), var(--accent-strong));
  color: #18140f;
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.12);
}

.ss-segmented-tight {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.ss-settings-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 6px;
  background: var(--bg-soft);
  border-radius: 12px;
  border-bottom: 0;
  margin-bottom: 24px;
}

.ss-settings-tabs button {
  flex: 1;
  min-height: 40px;
  border: 0;
  background: transparent;
  color: var(--muted);
  font-weight: 600;
  font-size: 0.95rem;
  cursor: pointer;
  padding: 0 14px;
  border-radius: 8px;
  transition: all 0.2s ease;
}

.ss-settings-tabs button.is-active {
  color: var(--text);
  background: var(--panel);
  box-shadow: 0 1px 6px rgba(0,0,0,0.06);
}

.ss-settings-tab-panel {
  display: none;
}

.ss-settings-tab-panel.is-active {
  display: block;
}

.ss-settings-row {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 24px;
  margin-bottom: 20px;
  background: color-mix(in srgb, var(--panel) 90%, transparent);
  border: 1px solid var(--line);
  border-radius: 16px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.02);
}

.ss-settings-row:first-child {
  border-top: 1px solid var(--line);
}

.ss-settings-row h3 {
  margin: 0;
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--text);
  padding-bottom: 12px;
  border-bottom: 1px solid var(--line);
}

.ss-settings-row-body {
  display: grid;
  gap: 16px;
  min-width: 0;
}

.ss-settings-stack {
  display: grid;
  gap: 10px;
}

.ss-settings-double {
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

/* ── New 2-column settings rows ── */
.ss-settings-top {
  padding: 0 0 18px 0;
}

.ss-settings-top-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 6px;
}

.ss-settings-top-head h2 {
  font-size: 1.35rem;
  font-weight: 800;
  margin: 0;
}

.ss-settings-desc {
  color: var(--muted);
  font-size: 0.88rem;
  line-height: 1.5;
  margin: 0 0 14px 0;
}

.ss-settings-mode-label {
  font-size: 0.8rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--muted);
  margin: 0 0 8px 0;
}

.ss-settings-panels-wrap {
  flex: 1 1 auto;
  overflow-y: auto;
  padding-bottom: 8px;
}

.ss-settings-row2 {
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: 0;
  border-bottom: 1px solid var(--line);
  padding: 18px 0;
  align-items: start;
}

.ss-settings-row2:last-child {
  border-bottom: none;
}

.ss-settings-row2-label {
  padding-top: 2px;
  padding-right: 16px;
}

.ss-settings-row2-label > span {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--text);
  line-height: 1.4;
}

.ss-settings-row2-body {
  display: grid;
  gap: 12px;
  min-width: 0;
}

/* Classic square checkbox labels for "Dateiinfo" section */
.ss-check-label {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.9rem;
  cursor: pointer;
  line-height: 1.4;
}

.ss-check-label input[type="checkbox"] {
  width: 16px;
  height: 16px;
  accent-color: var(--accent);
  flex-shrink: 0;
  cursor: pointer;
}

/* Field sub-labels */
.ss-settings-field-label {
  display: block;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--muted);
  margin-bottom: 6px;
}

/* Small hint text under inputs */
.ss-input-hint {
  font-size: 0.78rem;
  color: var(--muted);
  line-height: 1.5;
  margin: 0;
}

/* Extern URL display row */
.ss-public-url-display {
  display: flex;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 10px;
  overflow: hidden;
  background: var(--panel);
}

.ss-public-url-prefix {
  padding: 8px 10px;
  background: var(--panel-strong);
  color: var(--muted);
  font-size: 0.8rem;
  white-space: nowrap;
  border-right: 1px solid var(--line);
  flex-shrink: 0;
}

.ss-public-url-display input[type="text"] {
  border: none;
  background: transparent;
  flex: 1;
  font-size: 0.9rem;
  padding: 8px 10px;
  outline: none;
  min-width: 0;
}

.ss-public-url-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

/* Settings footer (save + apply checkbox) */
.ss-settings-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 0 0 0;
  border-top: 1px solid var(--line);
  margin-top: 4px;
  flex-shrink: 0;
}

.ss-settings-footer-apply {
  font-size: 0.85rem;
  color: var(--muted);
}

.ss-settings-save-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 20px;
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: 10px;
  font-weight: 700;
  font-size: 0.9rem;
  cursor: pointer;
  transition: opacity 0.15s;
}

.ss-settings-save-btn:hover {
  opacity: 0.88;
}

/* Mode-switch in settings-top */
.ss-settings-mode-switch .ss-segmented {
  background: var(--panel-strong);
  border-radius: 12px;
  padding: 3px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ss-settings-mode-switch .ss-segmented button {
  border-radius: 9px;
  font-weight: 600;
  font-size: 0.88rem;
  padding: 8px 16px;
  text-align: center;
}

.ss-settings-mode-switch .ss-segmented button.is-active {
  background: var(--accent);
  color: #fff;
  box-shadow: 0 2px 6px rgba(0,0,0,0.15);
}

/* Tab icons */
.ss-tab-icon {
  font-style: normal;
  margin-right: 4px;
  opacity: 0.7;
}


.ss-settings-inline {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

.ss-settings-inline input[type="number"] {
  width: 86px;
  min-height: 48px;
  border-radius: 14px;
  border: 1px solid var(--line);
  background: var(--bg-soft);
  color: var(--text);
  padding: 10px 12px;
}

.ss-switch-row {
  display: flex;
  align-items: center;
  gap: 14px;
  cursor: pointer;
  padding: 6px 0;
}

.ss-switch-row input[type="checkbox"] {
  appearance: none;
  -webkit-appearance: none;
  width: 44px;
  height: 24px;
  border-radius: 12px;
  background: var(--line-strong);
  position: relative;
  cursor: pointer;
  flex-shrink: 0;
  margin: 0;
  transition: background-color 0.2s ease;
}

.ss-switch-row input[type="checkbox"]::after {
  content: "";
  position: absolute;
  top: 2px;
  left: 2px;
  width: 20px;
  height: 20px;
  background: #fff;
  border-radius: 50%;
  box-shadow: 0 1px 3px rgba(0,0,0,0.15);
  transition: transform 0.25s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.ss-switch-row input[type="checkbox"]:checked {
  background: var(--accent);
}

.ss-switch-row input[type="checkbox"]:checked::after {
  transform: translateX(20px);
}

.ss-switch-row span {
  flex-grow: 1;
  font-size: 0.95rem;
  line-height: 1.4;
  color: var(--text);
}

.ss-layout-choice-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0;
  padding: 4px;
  border-radius: 18px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--bg-soft) 86%, white 14%);
}

.ss-layout-choice-grid-two {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ss-layout-choice {
  min-height: 96px;
  border-radius: 14px;
  border: 1px solid transparent;
  background: transparent;
  color: var(--text);
  cursor: pointer;
  padding: 12px 10px;
  display: grid;
  justify-items: center;
  align-content: center;
  gap: 10px;
  box-shadow: none;
}

.ss-layout-choice.is-active {
  border-color: color-mix(in srgb, var(--accent-strong) 45%, transparent);
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent) 16%, white 84%), color-mix(in srgb, var(--panel) 92%, white 8%));
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.08);
}

.ss-layout-choice strong {
  font-size: 0.98rem;
  font-weight: 500;
}

.ss-layout-choice-icon {
  display: grid;
  place-items: center;
  color: currentColor;
}

.ss-layout-choice-icon i {
  display: block;
  background: currentColor;
}

.ss-layout-choice-icon--grid {
  grid-template-columns: repeat(4, 8px);
  gap: 3px;
}

.ss-layout-choice-icon--grid i {
  width: 8px;
  height: 8px;
  border-radius: 1px;
}

.ss-layout-choice-icon--tiles {
  grid-template-columns: repeat(4, 8px);
  grid-auto-rows: 8px;
  gap: 3px;
  place-items: stretch;
}

.ss-layout-choice-icon--tiles i {
  width: auto;
  height: 8px;
  border-radius: 1px;
  min-width: 8px;
  justify-self: stretch;
}

.ss-layout-choice-icon--list {
  grid-template-columns: 1fr;
  gap: 4px;
}

.ss-layout-choice-icon--list i {
  width: 42px;
  height: 4px;
  border-radius: var(--radius-md);
}

.ss-presentation-editor {
  grid-template-columns: minmax(0, 1fr) minmax(260px, 0.8fr);
  gap: 18px;
}

.ss-presentation-preview,
.ss-presentation-controls {
  display: grid;
  gap: 14px;
}

.ss-presentation-cover {
  position: relative;
  min-height: 280px;
  border-radius: 20px;
  overflow: hidden;
  border: 1px solid var(--line);
}

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

.ss-presentation-thumbs {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(54px, 1fr));
  gap: 8px;
}

.ss-presentation-thumbs img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  border-radius: 12px;
  border: 1px solid var(--line);
}

.ss-settings-segment-block {
  display: grid;
  gap: 8px;
}

.ss-gallery-copy {
  display: grid;
  gap: 10px;
}

.ss-gallery-opener {
  position: absolute;
  max-width: calc(100% - 28px);
  font-weight: 700;
  line-height: 1.08;
  text-wrap: balance;
  text-shadow: 0 3px 18px rgba(0, 0, 0, 0.35);
}

.ss-gallery-opener.is-small {
  font-size: clamp(1rem, 2vw, 1.45rem);
}

.ss-gallery-opener.is-medium {
  font-size: clamp(1.35rem, 2.8vw, 2.2rem);
}

.ss-gallery-opener.is-large {
  font-size: clamp(1.8rem, 3.3vw, 2.9rem);
}

.ss-gallery-opener.is-light {
  color: #fff8ef;
}

.ss-gallery-opener.is-dark {
  color: #17130f;
  text-shadow: 0 4px 20px rgba(255, 255, 255, 0.18);
}

.ss-gallery-opener.pos-top-left {
  top: 18px;
  left: 18px;
}

.ss-gallery-opener.pos-top-center {
  top: 18px;
  left: 50%;
  transform: translateX(-50%);
  text-align: center;
}

.ss-gallery-opener.pos-top-right {
  top: 18px;
  right: 18px;
  text-align: right;
}

.ss-gallery-opener.pos-middle-left {
  top: 50%;
  left: 18px;
  transform: translateY(-50%);
}

.ss-gallery-opener.pos-center {
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
}

.ss-gallery-opener.pos-middle-right {
  top: 50%;
  right: 18px;
  transform: translateY(-50%);
  text-align: right;
}

.ss-gallery-opener.pos-bottom-left {
  left: 18px;
  bottom: 18px;
}

.ss-gallery-opener.pos-bottom-center {
  left: 50%;
  bottom: 18px;
  transform: translateX(-50%);
  text-align: center;
}

.ss-gallery-opener.pos-bottom-right {
  right: 18px;
  bottom: 18px;
  text-align: right;
}

body.is-overlay-open {
  overflow: hidden;
}

.ss-stat-stack {
  display: grid;
  gap: 8px;
  color: var(--text);
}

.ss-admin-help,
.ss-error {
  margin-top: 14px;
}

.ss-error {
  color: #ff9d8d;
}

body[data-theme="light"] .ss-error {
  color: #000;
}

.ss-gallery-app {
  padding: 28px 0 40px;
}

.ss-gallery-welcome {
  display: none;
  width: min(920px, 100%);
  margin: 0 auto 24px;
  padding: 0 4px;
}

.ss-gallery-welcome .ss-copy {
  font-size: clamp(1rem, 1.5vw, 1.15rem);
  text-align: center;
}

.ss-gallery-toolbar,
.ss-summary-panel {
  display: grid;
  gap: 16px;
  margin-bottom: 20px;
}

.ss-mode-note {
  margin: 0;
  color: var(--muted);
}

.ss-filter-group button,
.ss-mode-switch button,
.ss-rating-group button {
  min-height: 42px;
  border-radius: var(--radius-md);
  border: 1px solid var(--line);
  background: var(--panel-strong);
  color: var(--text);
  padding: 0 14px;
  cursor: pointer;
}

.ss-filter-group button.is-active,
.ss-mode-switch button.is-active {
  background: var(--accent);
  color: #ffffff;
  border-color: rgba(32, 160, 185, 0.45);
}

.ss-summary-panel {
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.ss-summary-card {
  padding: 20px 22px;
}

.ss-gallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 260px), 1fr));
  gap: 14px;
}

.ss-card {
  position: relative;
  background: transparent;
  border: none;
  border-radius: var(--radius-lg);
  overflow: hidden;
  cursor: pointer;
}

.ss-card[data-rating="green"] {
  box-shadow: inset 0 0 0 4px var(--green);
}

.ss-card[data-rating="orange"] {
  box-shadow: inset 0 0 0 4px var(--orange);
}

.ss-card[data-rating="black"] {
  box-shadow: inset 0 0 0 4px var(--black-flag);
}

.ss-card[data-rating="red"] {
  box-shadow: inset 0 0 0 4px var(--red);
}

.ss-gallery-app[data-mode="presentation"] .ss-summary-panel,
.ss-gallery-app[data-mode="presentation"] .ss-filter-group,
.ss-gallery-app[data-mode="presentation"] .ss-gallery-toolbar .ss-stat-row,
.ss-gallery-app[data-mode="presentation"] .ss-gallery-toolbar .ss-mode-note,
.ss-gallery-app[data-mode="presentation"] .ss-gallery-copy .ss-copy,
.ss-gallery-app[data-mode="presentation"] .ss-vote,
.ss-gallery-app[data-mode="presentation"] .ss-file-meta,
.ss-gallery-app[data-mode="presentation"] .ss-rating-group,
.ss-gallery-app[data-mode="presentation"] textarea[data-comment] {
  display: none;
}

.ss-gallery-app[data-mode="presentation"] .ss-gallery-grid {
  display: block;
  position: relative;
  /* Höhe + Karten-Positionen werden per JS-Masonry gesetzt */
}

.ss-gallery-app[data-mode="presentation"] .ss-gallery-header {
  display: grid;
  grid-template-columns: 1fr;
  align-items: stretch;
  gap: 16px;
}

.ss-gallery-app[data-mode="presentation"] .ss-gallery-copy {
  display: none;
}

.ss-gallery-app[data-mode="presentation"] .ss-card {
  display: block;
  background: transparent;
  box-shadow: none;
  margin: 0;
}

.ss-gallery-app[data-mode="presentation"] .ss-card[data-rating] {
  border-color: var(--line);
}

/* ── Voting mode: header (cover thumbnail + opener) hidden ──────────────────
   The cover is shown in presentation mode only. In voting mode the sidebar
   navigation already shows the gallery name.                                 */
.ss-gallery-app[data-mode="voting"] .ss-gallery-header {
  display: none;
}

/* ── Voting mode: overflow:visible so flag dropdown isn't clipped by card bounds;
   rounding applied to thumb + vote overlay instead of card directly.         */
.ss-gallery-app[data-mode="voting"] .ss-card {
  overflow: visible;
}
.ss-gallery-app[data-mode="voting"] .ss-thumb {
  border-radius: var(--radius-lg);
}
.ss-gallery-app[data-mode="voting"] .ss-vote {
  border-radius: var(--radius-lg);
}
/* When a dropdown is open, raise that card above its masonry neighbours
   (all cards are position:absolute z-index:auto → later DOM = painted on top) */
.ss-gallery-app[data-mode="voting"] .ss-card:has(.ss-vote.is-open) {
  z-index: 100;
}

/* ── Voting mode: rated cards — only flag badge stays visible on non-hover ──
   Matches admin view: + and download buttons appear only on hover,
   the flag icon in the top-right corner remains as a permanent indicator.    */
@media (hover: hover) and (pointer: fine) {
  .ss-gallery-app[data-mode="voting"] .ss-card[data-rating]:not(:hover) .ss-vote-add-btn,
  .ss-gallery-app[data-mode="voting"] .ss-card[data-rating]:not(:hover) .ss-vote-bottom {
    opacity: 0 !important;
    pointer-events: none;
  }
}

.ss-gallery-app[data-mode="presentation"] .ss-thumb {
  width: 100%;
  height: 100%;
  aspect-ratio: auto;
  overflow: hidden;
}

.ss-gallery-app[data-mode="presentation"] .ss-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover; /* Karte hat exakte Seitenverhältnis-Höhe aus JS → kein Beschnitt */
  display: block;
}

.ss-gallery-app[data-mode="presentation"] .ss-gallery-cover {
  width: 100%;
  max-width: none;
  aspect-ratio: 16 / 8;
  position: relative;
  border-radius: 28px;
}

.ss-gallery-app[data-mode="presentation"] .ss-gallery-welcome {
  display: block;
}

.ss-gallery-app[data-mode="presentation"] .ss-mode-switch {
  justify-content: center;
}

.ss-gallery-app[data-mode="voting"] .ss-summary-panel {
  display: grid;
}

.ss-gallery-app[data-mode="voting"] .ss-gallery-grid {
  display: block;
  position: relative;
  /* Höhe + Karten-Positionen werden per JS-Masonry gesetzt */
}

.ss-gallery-app[data-mode="voting"] .ss-card {
  display: block;
  background: transparent;
  box-shadow: none;
  margin: 0;
  cursor: pointer;
}
/* Restore color border for rated cards (overrides box-shadow:none above) */
.ss-gallery-app[data-mode="voting"] .ss-card[data-rating="green"]  { box-shadow: inset 0 0 0 4px var(--green); }
.ss-gallery-app[data-mode="voting"] .ss-card[data-rating="orange"] { box-shadow: inset 0 0 0 4px var(--orange); }
.ss-gallery-app[data-mode="voting"] .ss-card[data-rating="red"]    { box-shadow: inset 0 0 0 4px var(--red); }
.ss-gallery-app[data-mode="voting"] .ss-card[data-rating="black"]  { box-shadow: inset 0 0 0 4px var(--black-flag); }

.ss-gallery-app[data-mode="voting"] .ss-thumb {
  width: 100%;
  height: 100%;
  aspect-ratio: auto;
  overflow: hidden;
}

.ss-gallery-app[data-mode="voting"] .ss-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Dateiname-Label im Voting-Modus ausblenden – steht im Vote-Overlay */
.ss-gallery-app[data-mode="voting"] .ss-card-label {
  display: none;
}

.ss-card[hidden] {
  display: none !important; /* beats .ss-gallery-app[data-mode="voting"] .ss-card { display: block } */
}

.ss-thumb {
  position: relative;
  aspect-ratio: auto;
}

.ss-thumb img {
  width: 100%;
  height: auto;
  display: block;
}

.ss-upload-dropzone {
  padding: 18px;
  border: 1px dashed var(--line-strong);
  border-radius: 20px;
  background: color-mix(in srgb, var(--bg-soft) 90%, white 10%);
  transition: border-color 140ms ease, background 140ms ease, transform 140ms ease;
}

.ss-upload-dropzone small {
  color: var(--muted);
}

.ss-upload-dropzone.is-dragover {
  border-color: color-mix(in srgb, var(--accent-strong) 78%, transparent);
  background: color-mix(in srgb, var(--accent) 18%, var(--bg-soft));
  transform: translateY(-1px);
}

.ss-upload-overlay-panel {
  width: min(420px, calc(100% - 24px));
  max-height: min(86vh, 820px);
  overflow-y: auto;
  padding: 24px 28px 28px;
}

/* ── Panel-Titel (während Upload läuft) ── */
.ss-upload-panel-title {
  font-size: 1rem;
  font-weight: 600;
  margin: 0 0 18px;
  color: var(--text);
}

.ss-upload-progress-list {
  display: grid;
  gap: 12px;
}

.ss-upload-progress-item {
  display: grid;
  gap: 8px;
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid var(--line);
  background: color-mix(in srgb, var(--panel) 84%, transparent);
}

.ss-upload-progress-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.ss-upload-filename {
  flex: 1;
  overflow-wrap: anywhere;
  min-width: 0;
}

.ss-upload-pct {
  font-size: .75rem;
  color: var(--muted);
  flex-shrink: 0;
  min-width: 30px;
  text-align: right;
}

.ss-upload-status-icon {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  flex-shrink: 0;
  display: inline-block;
  background: rgba(255,255,255,.1);
  position: relative;
}
[data-upload-status="uploading"] .ss-upload-status-icon {
  background: var(--accent);
  animation: ss-upload-pulse 1s ease-in-out infinite;
}
[data-upload-status="done"] .ss-upload-status-icon {
  background: var(--green);
}
[data-upload-status="error"] .ss-upload-status-icon {
  background: var(--red);
}
[data-upload-status="done"] .ss-upload-pct,
[data-upload-status="done"] .ss-upload-filename {
  color: var(--muted);
}
[data-upload-status="done"] .ss-upload-progress-bar span {
  background: var(--green);
}
[data-upload-status="error"] .ss-upload-progress-bar span {
  background: var(--red);
}
@keyframes ss-upload-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: .4; }
}

.ss-upload-progress-head strong {
  overflow-wrap: anywhere;
}

.ss-upload-progress-bar {
  width: 100%;
  height: 10px;
  border-radius: var(--radius-md);
  background: color-mix(in srgb, var(--bg-soft) 82%, white 18%);
  overflow: hidden;
}

.ss-upload-progress-bar span {
  display: block;
  width: 0;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--accent), var(--accent-strong));
  transition: width 140ms ease;
}

.ss-upload-progress-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid var(--line);
}

.ss-upload-remaining-text {
  font-size: 0.82rem;
  color: var(--muted);
}

.ss-upload-abort-btn {
  padding: 7px 16px;
  border-radius: var(--radius-md);
  border: 1px solid var(--line-strong);
  background: var(--danger);
  color: #fff;
  font-size: 0.82rem;
  font-weight: 500;
  cursor: pointer;
  font-family: inherit;
  transition: opacity 120ms;
}

.ss-upload-abort-btn:hover {
  opacity: 0.85;
}

/* ── Done-State ── */
.ss-upload-done-head {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px 18px;
  border-radius: var(--radius-lg);
  background: rgba(34, 197, 94, 0.1);
  border: 1px solid rgba(34, 197, 94, 0.25);
  margin-bottom: 20px;
}

.ss-upload-done-icon {
  width: 44px;
  height: 44px;
  flex-shrink: 0;
  border-radius: 50%;
  background: rgba(34, 197, 94, 0.18);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #22c55e;
}

.ss-upload-done-title {
  font-size: 1rem;
  font-weight: 600;
  margin: 0 0 2px;
  color: var(--text);
}

.ss-upload-done-sub {
  font-size: 0.82rem;
  color: var(--muted);
  margin: 0;
}

.ss-upload-done-actions {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.ss-upload-done-action {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 13px 16px;
  border-radius: var(--radius-md);
  border: 1px solid var(--line);
  background: var(--panel-strong);
  color: var(--text);
  font-size: 0.88rem;
  font-weight: 400;
  cursor: pointer;
  font-family: inherit;
  text-align: left;
  transition: background 120ms, border-color 120ms, color 120ms;
}

.ss-upload-done-action:hover {
  background: var(--panel);
  border-color: var(--accent);
  color: var(--accent);
}

.ss-upload-duplicate-panel {
  width: min(940px, calc(100% - 24px));
}

.ss-upload-duplicate-compare {
  display: grid;
  gap: 16px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ss-upload-duplicate-card {
  display: grid;
  gap: 10px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: color-mix(in srgb, var(--panel) 90%, transparent);
}

.ss-upload-duplicate-card h3 {
  margin: 0;
  font-size: 0.95rem;
}

.ss-upload-duplicate-card img {
  width: 100%;
  max-height: 220px;
  object-fit: cover;
  border-radius: 12px;
  border: 1px solid var(--line);
  background: var(--bg-soft);
}

.ss-upload-duplicate-card dl {
  margin: 0;
  display: grid;
  gap: 8px;
}

.ss-upload-duplicate-card dl div {
  display: grid;
  gap: 2px;
}

.ss-upload-duplicate-card dt {
  font-size: 0.74rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
}

.ss-upload-duplicate-card dd {
  margin: 0;
  overflow-wrap: anywhere;
}

.ss-upload-duplicate-remember {
  display: inline-flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 0.92rem;
  color: var(--muted);
}

.ss-upload-duplicate-remember input {
  margin-top: 2px;
}

.ss-upload-duplicate-actions {
  margin-top: 18px;
}

.ss-upload-duplicate-actions + .ss-watermark-editor-actions {
  margin-top: 16px;
}

.ss-button-danger {
  background: #b42318;
  color: #fff;
  border-color: #b42318;
}

.ss-button-danger:hover,
.ss-button-danger:focus-visible {
  background: #951a12;
  border-color: #951a12;
}

@media (max-width: 860px) {
  .ss-upload-duplicate-compare {
    grid-template-columns: 1fr;
  }
}

.ss-gallery-app[data-mode="voting"][data-voting-layout="list"] .ss-thumb img {
  height: 100%;
}

.ss-watermark {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: rgba(255, 255, 255, 0.22);
  background-image: repeating-linear-gradient(-32deg, transparent, transparent 14px, rgba(255, 255, 255, 0.05) 14px, rgba(255, 255, 255, 0.05) 28px);
  pointer-events: none;
}

/* ── Vote overlay: compact PicDrop-style icon corners ─────────────────────── */
.ss-vote {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 8px;
  background:
    linear-gradient(180deg, rgba(0,0,0,0.55) 0%, transparent 38%),
    linear-gradient(0deg,   rgba(0,0,0,0.65) 0%, transparent 38%);
  opacity: 0;
  transition: opacity 180ms ease;
  z-index: 10;
  pointer-events: none; /* allow the thumb to receive clicks by default */
}

/* Enable pointer events only on the interactive rows */
.ss-vote-top,
.ss-vote-bottom {
  pointer-events: auto;
}

@media (hover: hover) and (pointer: fine) {
  .ss-card:hover .ss-vote { opacity: 1; }
}

/* Touch devices (iPad, phone): show vote overlay on first tap (is-touch-active) */
@media (hover: none) {
  .ss-gallery-app[data-mode="voting"] .ss-card.is-touch-active .ss-vote {
    opacity: 1;
  }
}

.ss-card[data-rating="green"] .ss-vote,
.ss-card[data-rating="orange"] .ss-vote,
.ss-card[data-rating="red"] .ss-vote,
.ss-card[data-rating="black"] .ss-vote,
.ss-card[data-selected="1"] .ss-vote,
.ss-card:focus-within .ss-vote,
.ss-vote.is-open {
  opacity: 1;
}

/* Top row: + (left) and flag (right) */
.ss-vote-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

/* Bottom row: download (left) and filename (right) */
.ss-vote-bottom {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 6px;
}

/* Circle icon buttons (+ and flag) */
.ss-vote-add-btn,
.ss-vote-flag-btn {
  width: 30px;
  height: 30px;
  flex-shrink: 0;
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.52);
  backdrop-filter: blur(4px);
  border: 0;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 140ms, color 140ms;
}

.ss-vote-add-btn:hover,
.ss-vote-flag-btn:hover {
  background: var(--accent);
}

/* + turns solid when card is selected */
.ss-card[data-selected="1"] .ss-vote-add-btn {
  background: var(--accent);
}

/* ── Flag label spans: hidden by default, one shows when card is rated ── */
.ss-vote-flag-label {
  display: none;
  font-size: 0.8rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.01em;
}
.ss-card[data-rating="green"]  .ss-vote-flag-label[data-for-rating="green"]  { display: inline; }
.ss-card[data-rating="orange"] .ss-vote-flag-label[data-for-rating="orange"] { display: inline; }
.ss-card[data-rating="red"]    .ss-vote-flag-label[data-for-rating="red"]    { display: inline; }
.ss-card[data-rating="black"]  .ss-vote-flag-label[data-for-rating="black"]  { display: inline; }

/* ── Rated card: flag button becomes admin-style pill badge ── */
.ss-card[data-rating] .ss-vote-flag-btn {
  width: auto;
  height: auto;
  min-width: 0;
  border-radius: 11px;
  padding: 5px 9px;
  gap: 5px;
  border: none;
  box-shadow: 0 4px 18px rgba(0,0,0,0.35);
  cursor: pointer;
}
.ss-card[data-rating="green"]  .ss-vote-flag-btn { background: #a8d85b; color: #1b2905; }
.ss-card[data-rating="orange"] .ss-vote-flag-btn { background: #ff8f1f; color: #fff8ef; }
.ss-card[data-rating="red"]    .ss-vote-flag-btn { background: #ea3200; color: #fff8f6; }
.ss-card[data-rating="black"]  .ss-vote-flag-btn { background: #3a3a3a; color: #f0f0f0; }
/* Hide flag icon when a label is visible; show icon again when no rating set */
.ss-card[data-rating] .ss-vote-flag-icon { display: none; }

/* Download pill button */
.ss-vote-dl-btn {
  display: flex;
  align-items: center;
  gap: 5px;
  height: 26px;
  padding: 0 10px;
  background: rgba(0, 0, 0, 0.52);
  backdrop-filter: blur(4px);
  border: 0;
  border-radius: 13px;
  color: #fff;
  font-size: 0.78rem;
  cursor: pointer;
  white-space: nowrap;
  transition: background 140ms;
  flex-shrink: 0;
}

.ss-vote-dl-btn:hover {
  background: rgba(0, 0, 0, 0.82);
}

/* Filename label (bottom right) */
.ss-vote-title {
  flex: 1;
  text-align: right;
  color: rgba(255, 255, 255, 0.82);
  font-size: 0.74rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
}

/* ── Flag dropdown ──────────────────────────────────────────────────────────── */
.ss-flag-dropdown {
  position: absolute;
  top: 44px;
  right: 8px;
  z-index: 200;
  background: var(--panel-strong, #161616);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 10px;
  padding: 4px;
  min-width: 128px;
  box-shadow: 0 8px 28px rgba(0,0,0,0.6);
  pointer-events: auto;
}

.ss-flag-dropdown:not([hidden]) {
  display: flex;
  flex-direction: column;
}

.ss-flag-opt {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 8px 10px;
  border: 0;
  background: transparent;
  color: var(--text, #f2f2f2);
  border-radius: 7px;
  cursor: pointer;
  font-size: 0.88rem;
  text-align: left;
  white-space: nowrap;
  transition: background 120ms;
}

.ss-flag-opt:hover {
  background: rgba(255,255,255,0.07);
}

.ss-flag-opt.is-selected {
  background: rgba(255,255,255,0.1);
  font-weight: 600;
}

.ss-flag-color-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
  display: inline-block;
}

/* ── Selection bar (fixed bottom, appears when "+" cards are selected) ─────── */
/* [hidden] attribute must beat the display:flex rule above */
.ss-selection-bar[hidden] {
  display: none !important;
}

.ss-selection-bar {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  height: 70px;
  background: var(--panel-strong, #161616);
  border-top: 1px solid rgba(255,255,255,0.1);
  display: flex;
  align-items: center;
  padding: 0 18px;
  gap: 14px;
  z-index: 300;
  box-shadow: 0 -4px 28px rgba(0,0,0,0.55);
}

.ss-selection-bar-left {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 1;
  min-width: 0;
  overflow: hidden;
}

.ss-selection-bar-count {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--text, #f2f2f2);
  min-width: 28px;
  line-height: 1;
  flex-shrink: 0;
}

.ss-selection-bar-thumbs {
  display: flex;
  gap: 5px;
  overflow-x: auto;
  scrollbar-width: none;
  flex: 1;
  align-items: center;
}

.ss-selection-bar-thumbs::-webkit-scrollbar { display: none; }

.ss-selection-bar-thumbs img {
  width: 48px;
  height: 48px;
  object-fit: cover;
  border-radius: 5px;
  flex-shrink: 0;
}

.ss-selection-bar-right {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

.ss-bar-flags {
  display: flex;
  gap: 6px;
  align-items: center;
  padding: 0 4px;
  border-left: 1px solid rgba(255,255,255,0.1);
  border-right: 1px solid rgba(255,255,255,0.1);
  margin: 0 2px;
}

.ss-bar-flag-btn {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 2px solid transparent;
  background: transparent;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: transform 150ms, border-color 150ms;
  padding: 0;
}

.ss-bar-flag-btn:hover {
  transform: scale(1.2);
  border-color: rgba(255,255,255,0.25);
}

.ss-bar-flag-dot {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  display: block;
}

.ss-bar-close-btn {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 0;
  background: rgba(255,255,255,0.08);
  color: var(--muted, #7a7a7a);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  flex-shrink: 0;
  transition: background 140ms, color 140ms;
}

.ss-bar-close-btn:hover {
  background: rgba(255,255,255,0.14);
  color: var(--text, #f2f2f2);
}

/* Keep old .ss-vote .ss-file-meta for admin form compatibility */
.ss-vote .ss-file-meta strong { color: #fff; }
.ss-vote .ss-file-meta span { color: #a1a1aa; }

.ss-file-meta {
  display: grid;
  gap: 4px;
}

.ss-file-meta strong {
  font-size: 0.96rem;
  font-weight: 600;
}

.ss-file-meta span {
  color: var(--muted);
  font-size: 0.88rem;
  overflow-wrap: anywhere;
}

.ss-rating-group {
  display: flex;
  gap: 8px;
  align-items: end;
}

.ss-flag {
  position: relative;
  width: auto;
  min-width: 42px;
  height: 36px;
  min-height: 36px;
  padding: 0 10px;
  border: 0;
  border-radius: var(--radius-md);
  background: transparent;
  transform-origin: bottom center;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.ss-flag::before {
  display: none;
}

.ss-flag span {
  position: static;
  width: auto;
  height: auto;
  padding: 0;
  margin: 0;
  overflow: visible;
  clip: auto;
  white-space: nowrap;
  border: 0;
  font-size: 1.2rem;
  line-height: 1;
}

.ss-flag em {
  font-style: normal;
  color: var(--muted);
  font-size: 0.86rem;
}

.ss-flag[data-rate="green"] span {
  color: var(--green);
}

.ss-flag[data-rate="orange"] span {
  color: var(--orange);
}

.ss-flag[data-rate="black"] span {
  color: #aaaaaa;
}

.ss-flag[data-rate="red"] span {
  color: var(--red);
}

.ss-flag:hover,
.ss-flag:focus-visible {
  transform: translateY(-1px);
  background: rgba(255, 255, 255, 0.04);
}

.ss-flag.is-selected em,
.ss-flag:focus-visible em {
  color: var(--text);
}

.ss-flag.is-selected[data-rate="green"] {
  box-shadow: inset 0 0 0 1px rgba(122, 144, 112, 0.34);
}

.ss-flag.is-selected[data-rate="orange"] {
  box-shadow: inset 0 0 0 1px rgba(255, 143, 31, 0.34);
}

.ss-flag.is-selected[data-rate="black"] {
  box-shadow: inset 0 0 0 1px rgba(170, 170, 170, 0.34);
}

.ss-flag.is-selected[data-rate="red"] {
  box-shadow: inset 0 0 0 1px rgba(168, 107, 98, 0.34);
}

.ss-flag.is-saving {
  opacity: 0.74;
}

.ss-flag.is-error {
  box-shadow: inset 0 0 0 1px rgba(180, 107, 96, 0.48);
}


.ss-grid-footer {
  display: grid;
  place-items: center;
  gap: 10px;
  padding: 24px 0 8px;
}

.ss-grid-footer p {
  margin: 0;
  color: var(--muted);
}

/* ═══════════════════════════════════════
   LIGHTBOX / VIEWER (neu: Panel + Main)
═══════════════════════════════════════ */

.ss-viewer {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.96);
  display: flex;
  z-index: 9999;
}

.ss-viewer[hidden] {
  display: none;
}

/* Left info/comment panel */
.ss-viewer-panel {
  width: 260px;
  flex: 0 0 260px;
  height: 100vh;
  overflow-y: auto;
  background: rgba(12, 12, 12, 0.96);
  border-right: 1px solid rgba(255,255,255,0.08);
  display: flex;
  flex-direction: column;
  transition: transform 220ms ease, opacity 220ms ease;
}

.ss-viewer-panel[hidden] {
  display: none;
}

.ss-viewer-panel-tabs {
  display: flex;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  flex-shrink: 0;
}

.ss-viewer-tab {
  flex: 1;
  padding: 12px 8px;
  background: none;
  border: none;
  color: rgba(255,255,255,0.45);
  font-size: 0.82rem;
  font-weight: 600;
  cursor: pointer;
  letter-spacing: 0.03em;
  border-bottom: 2px solid transparent;
  transition: color 140ms, border-color 140ms;
}

.ss-viewer-comment-badge {
  background: var(--accent);
  color: #fff;
  font-size: 0.65rem;
  font-weight: 700;
  padding: 1px 6px;
  border-radius: 20px;
  min-width: 16px;
  text-align: center;
  display: inline-block;
  margin-left: 4px;
}

.ss-viewer-tab.is-active {
  color: #fff;
  border-bottom-color: var(--accent);
}

.ss-viewer-tab:hover { color: rgba(255,255,255,0.75); }

.ss-viewer-tab-content {
  padding: 16px 18px;
  flex: 1;
  overflow-y: auto;
}

.ss-viewer-panel-filename {
  font-size: 0.85rem;
  font-weight: 600;
  color: rgba(255,255,255,0.85);
  margin: 0 0 14px;
  word-break: break-all;
}

/* Main viewer area */
.ss-viewer-main {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-width: 0;
  position: relative;
}

/* Top bar: counter + buttons */
.ss-viewer-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 16px;
  flex-shrink: 0;
}

.ss-viewer-counter {
  font-size: 0.8rem;
  color: rgba(255,255,255,0.45);
  font-variant-numeric: tabular-nums;
}

.ss-viewer-topbar-actions {
  display: flex;
  align-items: center;
  gap: 6px;
}

.ss-viewer-icon-btn {
  width: 34px;
  height: 34px;
  border-radius: 6px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  color: rgba(255,255,255,0.7);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  text-decoration: none;
  transition: background 140ms, color 140ms;
}

.ss-viewer-icon-btn:hover { background: rgba(255,255,255,0.12); color: #fff; }

.ss-viewer-close {
  width: 34px;
  height: 34px;
  border-radius: 6px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  color: rgba(255,255,255,0.7);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 1.4rem;
  line-height: 1;
  padding: 0;
  transition: background 140ms, color 140ms;
}
.ss-viewer-close:hover { background: rgba(200,40,40,0.3); color: #fff; }

/* Stage: image + nav buttons */
.ss-viewer-stage {
  position: relative;
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 0;
  overflow: hidden;
  touch-action: pan-y;
}

.ss-viewer-stage img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  display: block;
  transition: opacity 150ms;
}
.ss-viewer-stage img.is-loading {
  opacity: 0;
}

/* Loading spinner */
.ss-viewer-spinner {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  z-index: 5;
}
.ss-viewer-spinner[hidden] { display: none; }
.ss-viewer-spinner svg {
  color: rgba(255,255,255,0.6);
  animation: ss-spin 0.9s linear infinite;
}
@keyframes ss-spin {
  to { transform: rotate(360deg); }
}

.ss-viewer-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px;
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,0.3);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 8px;
  color: rgba(255,255,255,0.7);
  font-size: 2rem;
  cursor: pointer;
  z-index: 10;
  transition: background 140ms, color 140ms;
  line-height: 1;
  padding: 0;
}

.ss-viewer-nav:hover { background: rgba(0,0,0,0.6); color: #fff; }
.ss-viewer-nav[data-step="-1"] { left: 12px; }
.ss-viewer-nav[data-step="1"]  { right: 12px; }
/* Touch devices: full-height translucent tap strips left/right */
@media (hover: none) {
  .ss-viewer-nav {
    width: 72px;
    height: 90%;
    top: 0;
    transform: none;
    background: rgba(255,255,255,0.06);
    border-color: rgba(255,255,255,0.04);
    color: rgba(255,255,255,0.35);
    font-size: 1.2rem;
    border-radius: 0 6px 6px 0;
  }
  .ss-viewer-nav[data-step="1"] {
    border-radius: 6px 0 0 6px;
  }
  .ss-viewer-nav[data-step="-1"] { left: 0; }
  .ss-viewer-nav[data-step="1"]  { right: 0; }
}

/* Slideshow button active state */
#ss-slideshow-btn[aria-pressed="true"] {
  background: var(--accent);
  color: #fff;
}

/* Bottom action bar (rating flags) */
.ss-viewer-action-bar {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 10px 16px;
  border-top: 1px solid rgba(255,255,255,0.06);
  flex-shrink: 0;
}
.ss-viewer-action-bar[hidden] { display: none; }

.ss-viewer-flag-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  border-radius: 20px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.04);
  color: rgba(255,255,255,0.65);
  font-size: 0.8rem;
  cursor: pointer;
  transition: background 140ms, border-color 140ms, color 140ms;
}

.ss-viewer-flag-btn:hover { background: rgba(255,255,255,0.1); color: #fff; }
.ss-viewer-flag-btn.is-selected { border-color: rgba(255,255,255,0.35); color: #fff; background: rgba(255,255,255,0.1); }

/* Download link (hidden when not available) */
.ss-download-link {
  display: flex;
  align-items: center;
  justify-content: center;
}

@media (max-width: 980px) {
  .ss-hero,
  .ss-admin-form-layout {
    grid-template-columns: 1fr;
  }

  .ss-admin-form-layout.is-gallery-workbench {
    grid-template-columns: 1fr;
  }

  .ss-admin-form-layout.is-gallery-workbench .ss-admin-side {
    order: 0;
    position: static;
  }

  .ss-gallery-settings-hero,
  .ss-gallery-settings-summary,
  .ss-settings-row,
  .ss-presentation-editor {
    grid-template-columns: 1fr;
  }

  .ss-gallery-cover {
    width: min(320px, 100%);
  }

  .ss-subgallery-placeholder,
  .ss-gallery-empty-footer {
    flex-direction: column;
    align-items: start;
  }

  /* Presentation-Grid: Spalten werden per JS-Masonry gesteuert, kein CSS nötig */
}

@media (max-width: 780px) {
  .ss-home-page,
  .ss-gallery-app,
  .ss-admin-shell {
    width: min(calc(100% - 16px), 1760px);
  }

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

  .ss-settings-grid {
    grid-template-columns: 1fr;
  }

  .ss-watermark-editor-layout {
    grid-template-columns: 1fr;
  }

  .ss-layout-choice-grid,
  .ss-layout-choice-grid-two {
    grid-template-columns: 1fr;
  }

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

  .ss-gallery-empty-state {
    min-height: auto;
  }

  .ss-admin-gallery-menu-trigger {
    opacity: 1;
    transform: translateY(0);
  }

  .ss-search-form {
    width: 100%;
  }

  .ss-search-field {
    flex: 1 1 220px;
  }

  .ss-search-field input {
    width: 100%;
  }

  .ss-overlay-panel {
    width: min(100% - 16px, 920px);
    margin: 12px auto;
    padding: 18px;
    max-height: calc(100vh - 24px);
  }

  .ss-watermark-editor-panel {
    width: min(100% - 16px, 1120px);
  }

  .ss-watermark-stage-scene {
    min-height: 260px;
  }

  .ss-watermark-position-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .ss-watermark-pos {
    width: 100%;
  }

  .ss-gallery-grid {
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  }

  .ss-gallery-app[data-mode="voting"][data-voting-layout="list"] .ss-card {
    grid-template-columns: 1fr;
  }

  .ss-gallery-app[data-mode="presentation"] .ss-gallery-grid { column-count: 2; }

  .ss-gallery-app[data-mode="voting"] .ss-gallery-grid {
    grid-template-columns: 1fr;
  }

  .ss-gallery-cover,
  .ss-card-cover {
    width: 100%;
  }

  .ss-card-cover {
    aspect-ratio: 16 / 10;
  }

  .ss-site-footer-wrap {
    width: calc(100% - 32px);
    margin: 24px auto 20px;
  }

  .ss-site-footer {
    padding: 22px 18px 18px;
    border-radius: 22px;
  }

  .ss-cookie-banner {
    left: 12px;
    right: 12px;
    bottom: 12px;
    padding: 18px;
  }

  .ss-hero,
  .ss-password-card,
  .ss-admin-card,
  .ss-summary-card,
  .ss-home-card,
  .ss-admin-form {
    padding: 22px;
  }
}

@media (max-width: 560px) {
  .ss-gallery-app[data-mode="presentation"] .ss-gallery-grid { column-count: 1; }
}

/* ---- Gallery Breadcrumb ---- */
.ss-gallery-breadcrumb {
  padding: 16px 0 0;
  margin-bottom: -8px;
}

.ss-gallery-breadcrumb a {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--muted);
  text-decoration: none;
  font-size: 0.9rem;
  transition: color 140ms ease;
}

.ss-gallery-breadcrumb a:hover {
  color: var(--text);
}

/* ---- Sub-Galerie Grid (öffentliche Ansicht) ---- */
.ss-subgallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 16px;
  padding: 20px 0 8px;
}

.ss-subgallery-grid .ss-kicker {
  grid-column: 1 / -1;
  margin-bottom: 0;
}

.ss-subgallery-tile {
  display: block;
  text-decoration: none;
  color: var(--text);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: var(--panel);
  overflow: hidden;
  transition: transform 140ms ease, border-color 140ms ease;
}

.ss-subgallery-tile:hover {
  transform: translateY(-2px);
  border-color: var(--line-strong);
}

.ss-subgallery-tile-thumb {
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: var(--panel-strong);
  display: flex;
  align-items: center;
  justify-content: center;
}

.ss-subgallery-tile-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.ss-subgallery-tile-placeholder {
  color: var(--muted);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}

.ss-subgallery-tile-copy {
  padding: 10px 14px 14px;
}

.ss-subgallery-tile-copy strong {
  display: block;
  font-size: 0.95rem;
  font-weight: 600;
  margin-bottom: 2px;
}

.ss-subgallery-tile-copy span {
  font-size: 0.82rem;
  color: var(--muted);
}

/* ---- Admin: Sub-Galerie Panel ---- */
.ss-admin-subgalleries-panel .ss-admin-card-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 12px;
  margin-bottom: 16px;
}

.ss-subgallery-admin-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 8px;
}

.ss-subgallery-admin-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  border-radius: var(--radius-md);
  border: 1px solid var(--line);
  background: var(--panel-strong);
}

.ss-subgallery-admin-item .ss-inline-link {
  flex: 1;
  font-weight: 600;
  text-decoration: none;
  color: var(--text);
}

.ss-subgallery-admin-item .ss-inline-link:hover {
  color: var(--accent);
}

/* ---- Admin Dashboard: Parent-Badge ---- */
.ss-admin-gallery-parent-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 0.72rem;
  color: var(--muted);
  margin-bottom: 4px;
  line-height: 1.4;
}

.ss-admin-gallery-parent-badge svg {
  flex-shrink: 0;
  opacity: 0.7;
}

/* ---- Admin Breadcrumb (Gallery Form Header) ---- */
.ss-admin-breadcrumb {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.85rem;
  color: var(--muted);
  flex-wrap: wrap;
}

.ss-admin-breadcrumb a {
  color: var(--muted);
  text-decoration: none;
  transition: color 140ms;
}

.ss-admin-breadcrumb a:hover {
  color: var(--accent);
}

.ss-admin-breadcrumb span:last-child {
  color: var(--text);
  font-weight: 600;
}

/* ---- Admin Sub-Galerie Karten-Grid ---- */
.ss-admin-subgalleries-panel {
  margin-top: 4px;
}

.ss-admin-subgalleries-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 12px;
  margin-bottom: 18px;
}

.ss-subgallery-admin-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 14px;
}

.ss-subgallery-admin-card {
  position: relative;
  display: block;
  text-decoration: none;
  color: var(--text);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: var(--panel-strong);
  overflow: hidden;
  transition: transform 140ms ease, border-color 140ms ease;
}

.ss-subgallery-admin-card:hover {
  transform: translateY(-2px);
  border-color: var(--line-strong);
}

.ss-subgallery-admin-thumb {
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: var(--bg-soft);
  display: flex;
  align-items: center;
  justify-content: center;
}

.ss-subgallery-admin-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.ss-subgallery-admin-placeholder {
  color: var(--muted);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}

.ss-subgallery-admin-copy {
  padding: 10px 12px 12px;
}

.ss-subgallery-admin-copy strong {
  display: block;
  font-size: 0.9rem;
  font-weight: 600;
  margin-bottom: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.ss-subgallery-admin-copy span {
  font-size: 0.78rem;
  color: var(--muted);
}

.ss-subgallery-admin-preview-link {
  position: absolute;
  top: 8px;
  right: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: var(--radius-md);
  background: rgba(0, 0, 0, 0.55);
  color: #fff;
  text-decoration: none;
  opacity: 0;
  transition: opacity 140ms;
}

.ss-subgallery-admin-card:hover .ss-subgallery-admin-preview-link {
  opacity: 1;
}

/* ── Share Modal ── */
.ss-share-panel {
  max-width: 520px;
  width: calc(100vw - 40px);
}

.ss-share-tabs {
  display: flex;
  gap: 2px;
  background: var(--bg-soft);
  border-radius: 10px;
  padding: 4px;
  margin: 0 0 20px;
}

.ss-share-tab {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 9px 10px;
  border-radius: 8px;
  border: 0;
  background: transparent;
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 600;
  cursor: pointer;
  transition: background 120ms, color 120ms;
  white-space: nowrap;
}

.ss-share-tab.is-active {
  background: var(--panel-strong);
  color: var(--text);
  box-shadow: 0 1px 3px rgba(0,0,0,0.12);
}

.ss-share-tab:not(.is-active):hover {
  color: var(--text);
}

.ss-share-body {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.ss-share-body[hidden] { display: none; }

.ss-share-info {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 12px 14px;
  background: var(--accent-muted);
  border: 1px solid color-mix(in srgb, var(--accent) 30%, transparent);
  border-radius: var(--radius-lg);
  font-size: 0.88rem;
  color: var(--text);
  line-height: 1.5;
}

.ss-share-url-label {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.ss-share-url-row {
  display: flex;
  gap: 8px;
  align-items: stretch;
}

.ss-share-url-input {
  flex: 1;
  min-width: 0;
  padding: 10px 14px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--line-strong);
  background: var(--bg-soft);
  color: var(--muted);
  font-size: 0.88rem;
  cursor: text;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ss-share-copy-feedback {
  font-size: 0.85rem;
  color: var(--green);
  font-weight: 600;
  margin: 0;
}

.ss-share-copy-feedback[hidden] { display: none; }

.ss-share-qr-wrap {
  display: flex;
  justify-content: center;
  padding: 20px;
  background: #ffffff;
  border-radius: var(--radius-xl);
  border: 1px solid var(--line);
}

.ss-share-qr-wrap canvas {
  display: block;
  image-rendering: pixelated;
}

.ss-share-qr-url {
  text-align: center;
  font-size: 0.78rem;
  color: var(--muted);
  word-break: break-all;
  margin: 0;
}

.ss-share-pw-embed-label {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.82rem;
  color: var(--text);
  cursor: pointer;
  user-select: none;
}

/* Viewer Info Panel */
.ss-viewer-info-toggle {
  position: absolute;
  bottom: 20px;
  right: 20px;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.2);
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(8px);
  color: rgba(255,255,255,0.8);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 140ms, color 140ms;
  z-index: 5;
}
.ss-viewer-info-toggle:hover { background: rgba(0,0,0,0.8); color: #fff; }

.ss-viewer-info {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 260px;
  max-height: 100%;
  overflow-y: auto;
  background: rgba(10,10,10,0.9);
  backdrop-filter: blur(12px);
  border-left: 1px solid rgba(255,255,255,0.1);
  padding: 20px 18px 24px;
  z-index: 10;
}
.ss-viewer-info-close {
  position: absolute;
  top: 12px;
  right: 14px;
  background: none;
  border: none;
  color: rgba(255,255,255,0.5);
  font-size: 1.2rem;
  cursor: pointer;
  line-height: 1;
  padding: 2px 6px;
}
.ss-viewer-info-close:hover { color: #fff; }
.ss-viewer-info-list {
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 6px 12px;
  align-items: baseline;
  margin-top: 24px;
}
.ss-viewer-info-list dt {
  font-size: 0.72rem;
  color: rgba(255,255,255,0.45);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  white-space: nowrap;
}
.ss-viewer-info-list dd {
  margin: 0;
  font-size: 0.82rem;
  color: rgba(255,255,255,0.85);
  word-break: break-word;
}

/* Selection Sets */
.ss-sets-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 12px;
}
.ss-sets-load-btn {
  background: none;
  border: none;
  color: var(--accent);
  font-size: 0.85rem;
  cursor: pointer;
  padding: 4px 0;
  text-decoration: underline;
  text-underline-offset: 2px;
}
.ss-sets-load-btn:hover { color: var(--accent-strong); }

.ss-sets-panel { max-width: 520px; }

.ss-sets-list { display: grid; gap: 10px; }

.ss-set-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 16px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: var(--panel-strong);
}
.ss-set-item-info strong { display: block; font-size: 0.9rem; font-weight: 600; }
.ss-set-item-info span { font-size: 0.78rem; color: var(--muted); }
.ss-set-item-actions { display: flex; gap: 10px; align-items: center; flex-shrink: 0; }
.ss-muted { color: var(--muted); font-size: 0.9rem; }

/* New gallery CTA bar */
.ss-admin-new-gallery-bar {
  margin-bottom: 20px;
}

.ss-admin-new-gallery-cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 44px;
  padding: 0 20px;
  border-radius: var(--radius-md);
  border: 1px solid rgba(32, 160, 185, 0.3);
  background: linear-gradient(180deg, var(--accent), var(--accent-strong));
  color: #ffffff;
  font-size: 0.95rem;
  font-weight: 700;
  cursor: pointer;
  transition: transform 140ms ease, opacity 140ms ease;
}

.ss-admin-new-gallery-cta:hover {
  transform: translateY(-1px);
}

/* Admin stats bar */
.ss-admin-stats-bar {
  display: flex;
  gap: 2px;
  margin-bottom: 20px;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  overflow: hidden;
}
.ss-admin-stat {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 14px 12px;
  border-right: 1px solid var(--line);
  gap: 2px;
}
.ss-admin-stat:last-child { border-right: none; }
.ss-admin-stat-value {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--text);
  line-height: 1;
}
.ss-admin-stat-label {
  font-size: 0.72rem;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* Settings footer presets */
.ss-settings-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.ss-settings-footer-presets {
  display: flex;
  gap: 8px;
  align-items: center;
}
.ss-settings-footer-right {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
}
.ss-presets-load-wrap { position: relative; }
.ss-presets-dropdown {
  position: absolute;
  bottom: calc(100% + 6px);
  left: 0;
  min-width: 200px;
  background: var(--panel-strong);
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow);
  z-index: 50;
  overflow: hidden;
}
.ss-presets-dropdown-row {
  display: flex;
  align-items: center;
  border-bottom: 1px solid var(--line);
}
.ss-presets-dropdown-row:last-child { border-bottom: none; }
.ss-presets-dropdown-item {
  flex: 1;
  background: none;
  border: none;
  text-align: left;
  padding: 9px 14px;
  font-size: 0.85rem;
  color: var(--text);
  cursor: pointer;
}
.ss-presets-dropdown-item:hover { background: var(--panel); }
.ss-presets-dropdown-delete {
  background: none;
  border: none;
  color: var(--muted);
  padding: 9px 10px;
  cursor: pointer;
  font-size: 1rem;
}
.ss-presets-dropdown-delete:hover { color: var(--danger); }

/* Client Accesses */
.ss-admin-clients-card h3 { font-size: 0.9rem; margin: 0; }
.ss-clients-list { list-style: none; margin: 12px 0 0; padding: 0; display: grid; gap: 6px; }
.ss-client-item {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: var(--panel-strong);
}
.ss-client-info { flex: 1; min-width: 0; }
.ss-client-info strong { display: block; font-size: 0.85rem; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ss-client-info small { display: block; font-size: 0.75rem; color: var(--muted); }
.ss-client-info span { display: block; font-size: 0.72rem; color: var(--muted); margin-top: 1px; }
.ss-client-actions { display: flex; gap: 4px; flex-shrink: 0; align-items: center; }
.ss-client-actions button { padding: 4px; }

/* Admin sets card ──────────────────────────────────────────────────────────── */
.ss-admin-sets-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 6px;
}

.ss-admin-set-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: var(--panel-strong);
}

.ss-admin-set-meta {
  flex: 1;
  min-width: 0;
}
.ss-admin-set-meta strong {
  display: block;
  font-size: 0.85rem;
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ss-admin-set-meta span {
  display: block;
  font-size: 0.75rem;
  color: var(--muted);
}

/* Eye button active state */
.ss-admin-set-eye-btn.is-active {
  color: var(--accent);
  border-color: var(--accent);
}

/* Asset hidden by set filter */
.ss-asset-admin-item[data-set-hidden] {
  display: none !important;
}

/* Set info overlay – compact */
.ss-admin-set-info-panel {
  width: min(380px, calc(100% - 24px));
}
.ss-admin-set-info-title {
  font-size: 1.1rem;
  margin: 0;
}

/* Detail list inside info panel (Autor / Letzte Änderung rows) */
.ss-set-detail-list {
  display: grid;
  gap: 0;
  margin: 0;
  padding: 0;
}
.ss-set-detail-row {
  display: grid;
  grid-template-columns: 130px 1fr;
  gap: 8px;
  align-items: start;
  padding: 10px 0;
  border-bottom: 1px solid var(--line);
}
.ss-set-detail-row:last-child {
  border-bottom: none;
}
.ss-set-detail-row dt {
  font-size: 0.82rem;
  color: var(--muted);
  font-weight: 600;
}
.ss-set-detail-row dd {
  margin: 0;
  font-size: 0.85rem;
  word-break: break-word;
}

/* Set delete overlay – compact */
.ss-admin-set-delete-panel {
  width: min(340px, calc(100% - 24px));
}
.ss-admin-set-delete-msg {
  font-size: 0.9rem;
  margin: 0 0 20px;
  color: var(--text);
}
.ss-admin-set-delete-actions {
  display: flex;
  gap: 10px;
  justify-content: flex-end;
}
.ss-admin-set-delete-actions .ss-secondary-button {
  min-height: 38px;
  padding: 0 14px;
  font-size: 0.88rem;
}
.ss-admin-set-delete-confirm-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 0 16px;
  border-radius: var(--radius-md);
  border: none;
  background: var(--danger);
  color: #fff;
  font-size: 0.88rem;
  font-weight: 600;
  cursor: pointer;
  transition: opacity 140ms;
}
.ss-admin-set-delete-confirm-btn:hover { opacity: 0.88; }

/* E-Mail form in share modal */
.ss-email-form { display: grid; gap: 12px; }
.ss-email-label { display: grid; gap: 4px; font-size: 0.85rem; }
.ss-email-label span { color: var(--muted); font-size: 0.8rem; }
.ss-email-label input, .ss-email-label textarea { background: var(--panel-strong); border: 1px solid var(--line); border-radius: var(--radius-md); color: var(--text); padding: 8px 10px; font-size: 0.88rem; font-family: inherit; resize: vertical; }
.ss-email-label input:focus, .ss-email-label textarea:focus { outline: none; border-color: var(--accent); }
.ss-email-actions { display: flex; align-items: center; gap: 12px; margin-top: 4px; }
.ss-email-feedback { font-size: 0.85rem; font-weight: 600; }

/* ═══════════════════════════════════════
   GALLERY LAYOUT: Sidebar + Content
═══════════════════════════════════════ */

/* Gallery body: no top padding needed */
.ss-gallery-body .ss-gallery-app {
  max-width: 100%;
  width: 100%;
  padding: 0;
  margin: 0;
}

.ss-gallery-layout {
  display: flex;
  align-items: flex-start;
  min-height: calc(100vh - 240px);
}

/* ── Sidebar ── */
.ss-gallery-sidebar {
  width: 220px;
  flex: 0 0 220px;
  position: sticky;
  top: 0;
  max-height: 100vh;
  overflow-y: auto;
  padding: 20px 0;
  border-right: 1px solid var(--line);
  background: var(--bg);
}

.ss-sidebar-inner {
  padding: 0 16px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.ss-sidebar-title {
  font-family: var(--font-display);
  font-size: 1.15rem;
  font-weight: 300;
  color: var(--text);
  margin: 0 0 2px;
  line-height: 1.3;
  word-break: break-word;
}

.ss-sidebar-meta {
  font-size: 0.78rem;
  color: var(--muted);
  margin: 0 0 10px;
}

.ss-sidebar-action-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 7px 12px;
  border-radius: var(--radius-md);
  border: 1px solid var(--line-strong);
  background: var(--panel-strong);
  color: var(--text);
  font-size: 0.82rem;
  cursor: pointer;
  text-decoration: none;
  transition: background 140ms, border-color 140ms;
  margin-bottom: 4px;
}

.ss-sidebar-action-btn:hover {
  background: var(--panel);
  border-color: var(--accent);
  color: var(--accent);
}

.ss-sidebar-download-btn {
  color: var(--accent);
  border-color: rgba(32, 160, 185, 0.35);
  background: rgba(32, 160, 185, 0.07);
}

.ss-sidebar-download-btn:hover {
  background: rgba(32, 160, 185, 0.14);
}

.ss-sidebar-mode-switch {
  display: flex;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  overflow: hidden;
  margin: 6px 0;
}

.ss-sidebar-mode-switch button {
  flex: 1;
  padding: 7px 6px;
  font-size: 0.76rem;
  font-weight: 600;
  border: none;
  background: transparent;
  color: var(--muted);
  cursor: pointer;
  transition: background 140ms, color 140ms;
}

.ss-sidebar-mode-switch button.is-active {
  background: var(--accent);
  color: #fff;
}

.ss-sidebar-section {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid var(--line);
}

.ss-sidebar-section-label {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--muted);
  margin: 0 0 8px;
}

.ss-sidebar-filters {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.ss-sidebar-filters button {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  border-radius: var(--radius-md);
  border: none;
  background: transparent;
  color: var(--muted);
  font-size: 0.83rem;
  cursor: pointer;
  text-align: left;
  transition: background 140ms, color 140ms;
}

.ss-sidebar-filters button:hover { background: var(--panel-strong); color: var(--text); }
.ss-sidebar-filters button.is-active { background: var(--panel-strong); color: var(--text); font-weight: 600; }

.ss-sidebar-summary-stats {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.ss-sidebar-stat {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 0.83rem;
  color: var(--text);
}

.ss-sidebar-ghost-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  width: 100%;
  padding: 6px 10px;
  border-radius: var(--radius-md);
  border: 1px solid var(--line);
  background: transparent;
  color: var(--muted);
  font-size: 0.82rem;
  cursor: pointer;
  transition: background 140ms, color 140ms, border-color 140ms;
  margin-bottom: 4px;
  text-align: left;
}

.ss-sidebar-ghost-btn:hover {
  background: var(--panel-strong);
  color: var(--text);
  border-color: var(--line-strong);
}

.ss-sidebar-mode-note {
  font-size: 0.76rem;
  color: var(--muted);
  margin: 8px 0 0;
  line-height: 1.5;
}

/* ── Voting / Presentation visibility switching ──────────────────────────── */
.ss-gallery-app[data-mode="presentation"] .ss-voting-only  { display: none !important; }
.ss-gallery-app[data-mode="voting"]       .ss-presentation-only { display: none !important; }

/* ── Big sidebar buttons (Herunterladen, Neues Set, Alle auswählen) ───────── */
.ss-sidebar-big-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  padding: 9px 12px;
  border-radius: var(--radius-md);
  border: 0;
  font-size: 0.88rem;
  font-weight: 600;
  cursor: pointer;
  transition: background 140ms, opacity 140ms;
  margin-bottom: 6px;
  text-align: center;
  text-decoration: none;
}

.ss-sidebar-big-btn--accent {
  background: var(--accent);
  color: #fff;
}
.ss-sidebar-big-btn--accent:hover { background: var(--accent-strong); }

.ss-sidebar-big-btn--soft {
  background: var(--panel-strong);
  color: var(--text);
  border: 1px solid var(--line-strong);
}
.ss-sidebar-big-btn--soft:hover { background: var(--panel); border-color: var(--accent); }

/* ── Sidebar subsection label ──────────────────────────────────────────────── */
.ss-sidebar-subsection-label {
  font-size: 0.75rem;
  color: var(--muted);
  margin: 10px 0 4px;
}

/* ── Sidebar select row (select + dir button) ──────────────────────────────── */
.ss-sidebar-select-row {
  display: flex;
  gap: 5px;
  align-items: center;
  margin-bottom: 4px;
}

.ss-sidebar-select-row .ss-sort-select {
  flex: 1;
}

.ss-select-dir-btn {
  flex-shrink: 0;
  width: 30px;
  height: 30px;
  border-radius: var(--radius-md);
  border: 1px solid var(--line);
  background: transparent;
  color: var(--muted);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 140ms, color 140ms;
  padding: 0;
}
.ss-select-dir-btn:hover { background: var(--panel-strong); color: var(--text); }

/* ── Sidebar navigation ─────────────────────────────────────────────────────── */
.ss-sidebar-nav {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.ss-nav-item {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 6px 8px;
  border-radius: var(--radius-md);
  font-size: 0.84rem;
  color: var(--muted);
  text-decoration: none;
  cursor: default;
  transition: background 140ms, color 140ms;
  min-width: 0;
}

a.ss-nav-item {
  cursor: pointer;
}

a.ss-nav-item:hover {
  background: var(--panel-strong);
  color: var(--text);
}

.ss-nav-item.is-active {
  background: var(--panel-strong);
  color: var(--text);
  font-weight: 600;
}

.ss-nav-item--sub {
  padding-left: 22px;
}

.ss-nav-label {
  flex: 1;
  min-width: 0;
  overflow-wrap: break-word;
  word-break: break-word;
}

.ss-nav-count {
  flex-shrink: 0;
  font-size: 0.75rem;
  color: var(--muted);
  background: var(--bg-soft);
  border-radius: 10px;
  padding: 1px 6px;
  min-width: 22px;
  text-align: center;
}

/* ── Sidebar sets list ─────────────────────────────────────────────────────── */
.ss-sidebar-sets-list {
  display: flex;
  flex-direction: column;
  gap: 2px;
  margin-top: 4px;
}

.ss-sidebar-set-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 8px;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: background 140ms;
}

.ss-sidebar-set-item:hover {
  background: var(--panel-strong);
}

.ss-sidebar-set-item.is-active {
  background: var(--panel-strong);
  outline: 1px solid var(--accent);
  outline-offset: -1px;
}

.ss-sidebar-set-name {
  flex: 1;
  min-width: 0;
  font-size: 0.83rem;
  color: var(--text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ss-sidebar-set-eye {
  flex-shrink: 0;
  width: 26px;
  height: 26px;
  border-radius: var(--radius-md);
  border: 0;
  background: transparent;
  color: var(--muted);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: color 140ms, background 140ms;
  padding: 0;
}

.ss-sidebar-set-eye:hover,
.ss-sidebar-set-item.is-active .ss-sidebar-set-eye {
  color: var(--accent);
  background: var(--accent-muted);
}

.ss-sidebar-sets-empty {
  font-size: 0.8rem;
  color: var(--muted);
  padding: 4px 8px;
}

/* ── Voting mode top bar ─────────────────────────────────────────────────────
   Bar is position:fixed (always at top of viewport).
   A sibling .ss-voting-top-spacer in the body flex-column reserves the 44px
   in the document flow so <main> is never hidden underneath the bar.         */

/* Spacer: hidden by default; shown as a 44px block when in voting mode       */
.ss-voting-top-spacer {
  display: none;
  height: 64px;
  flex-shrink: 0;
  pointer-events: none;
}
body.ss-mode-voting .ss-voting-top-spacer {
  display: block;
}

.ss-admin-preview-banner {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 16px;
  background: var(--accent);
  color: #fff;
  font-size: 13px;
  font-family: inherit;
}
body[data-theme="light"] .ss-admin-preview-banner { color: #18130F; }
.ss-admin-preview-banner strong { font-weight: 700; }
.ss-admin-preview-banner-link {
  margin-left: auto;
  color: #fff;
  text-decoration: underline;
  font-weight: 600;
  white-space: nowrap;
}
body[data-theme="light"] .ss-admin-preview-banner-link { color: #18130F; }
.ss-admin-preview-banner-link:hover { opacity: 0.8; }
body.ss-has-admin-banner .ss-voting-top-spacer { display: block; height: 37px; }
body.ss-has-admin-banner.ss-mode-voting .ss-voting-top-spacer { height: 101px; } /* 37 + 64 */
body.ss-has-admin-banner .ss-voting-bottom-bar { top: 37px; }

.ss-voting-bottom-bar {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: 64px;
  background: var(--panel-strong);
  border-bottom: 1px solid var(--line);
  display: flex;
  align-items: center;
  padding: 0 16px;
  gap: 8px;
  z-index: 290; /* below selection bar (300) */
}

/* Hidden unless body carries ss-mode-voting class (set by setMode() in app.js) */
body:not(.ss-mode-voting) .ss-voting-bottom-bar {
  display: none !important;
}

.ss-voting-bottom-bar[hidden] {
  display: none !important;
}

/* Old spacer replaced by left/center/right layout */
.ss-voting-bar-spacer { flex: 1; }

/* Three-section bar layout */
.ss-voting-bar-left,
.ss-voting-bar-right {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 1;
}
.ss-voting-bar-right {
  justify-content: flex-end;
}
.ss-voting-bar-center {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  padding: 0 12px;
}
.ss-voting-bar-logo {
  max-height: 56px;
  width: auto;
  object-fit: contain;
  display: block;
}

.ss-voting-bar-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border-radius: var(--radius-md);
  border: 1px solid var(--accent);
  background: var(--accent);
  color: #fff;
  font-size: 0.82rem;
  cursor: pointer;
  text-decoration: none;
  transition: background 140ms, color 140ms, border-color 140ms;
  white-space: nowrap;
}

.ss-voting-bar-btn:hover {
  background: var(--accent-strong);
  color: #fff;
  border-color: var(--accent-strong);
}


/* ── Voting mode layout: match admin backend proportions ─────────────────────
   Admin sidebar = 300px, gap = 18px, container = calc(100% - 100px)
   Public gallery matches exactly in voting mode                              */

/* Sidebar: widen to 300px (= admin) and clear the 64px top bar */
.ss-gallery-app[data-mode="voting"] .ss-gallery-sidebar {
  width: 300px;
  flex: 0 0 300px;
  top: 64px;
  max-height: calc(100vh - 64px);
}

/* No body padding-top needed: .ss-voting-top-spacer reserves the 44px in the flow */

/* ── Main gallery content area ── */
.ss-gallery-content {
  flex: 1;
  min-width: 0;
  padding: 20px 24px 40px;
}

.ss-gallery-welcome-box {
  max-width: 760px;
  margin: 0 auto 24px;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.ss-gallery-welcome-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 10px 16px;
  background: none;
  border: none;
  color: var(--muted);
  font-size: 0.78rem;
  font-family: var(--font-body);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  cursor: pointer;
  gap: 8px;
}

.ss-gallery-welcome-toggle:hover {
  color: var(--text);
}

.ss-welcome-chevron {
  flex-shrink: 0;
  transition: transform 200ms;
}

.ss-gallery-welcome-box.is-collapsed .ss-welcome-chevron {
  transform: rotate(180deg);
}

.ss-gallery-welcome-content {
  padding: 0 16px 16px;
  font-size: 0.95rem;
  color: var(--muted);
  line-height: 1.7;
  display: block;
}

.ss-gallery-welcome-box.is-collapsed .ss-gallery-welcome-content {
  display: none;
}

/* ── Color filter dots ── */
.ss-filter-dot {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}

.ss-filter-dot--green  { background: var(--green); }
.ss-filter-dot--orange { background: var(--orange); }
.ss-filter-dot--red    { background: var(--red); }
.ss-filter-dot--black  { background: #888; border: 1px solid rgba(255,255,255,0.25); }

/* ── Card filename label ── */
.ss-card-label {
  padding: 5px 6px 4px;
  font-size: 0.74rem;
  color: var(--muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.3;
  background: var(--bg);
}

/* In presentation mode: hide label (clean square-grid like PicDrop) */
.ss-gallery-app[data-mode="presentation"] .ss-card-label { display: none; }
/* In voting mode: hide label (meta is inside vote area) */
.ss-gallery-app[data-mode="voting"] .ss-card-label { display: none; }

/* ── Card rating dot (top-right corner badge) ── */
.ss-card-rating-dot {
  display: none;
  position: absolute;
  top: 8px;
  right: 8px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  box-shadow: 0 0 0 2px rgba(0,0,0,0.6);
  z-index: 2;
}

.ss-card[data-rating="green"]  .ss-card-rating-dot { display: block; background: var(--green); }
.ss-card[data-rating="orange"] .ss-card-rating-dot { display: block; background: var(--orange); }
.ss-card[data-rating="red"]    .ss-card-rating-dot { display: block; background: var(--red); }
.ss-card[data-rating="black"]  .ss-card-rating-dot { display: block; background: #888; }

/* ── Viewer Comments ── */
.ss-viewer-comments-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 16px;
}

.ss-viewer-comment-item {
  padding: 10px 12px;
  background: rgba(255,255,255,0.05);
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,0.07);
}

.ss-viewer-comment-item.ss-viewer-comment-reply {
  margin-left: 16px;
  border-left: 2px solid var(--accent);
}

.ss-viewer-comment-item.ss-viewer-comment-admin {
  border-color: rgba(32,160,185,0.3);
  background: rgba(32,160,185,0.08);
}

.ss-viewer-comment-meta {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.73rem;
  color: rgba(255,255,255,0.35);
  margin-bottom: 4px;
  flex-wrap: wrap;
}

.ss-viewer-comment-admin-badge {
  background: var(--accent);
  color: #fff;
  font-size: 0.65rem;
  font-weight: 700;
  padding: 1px 6px;
  border-radius: 20px;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.ss-viewer-comment-author { color: rgba(255,255,255,0.6); font-weight: 600; }
.ss-viewer-comment-time   { color: rgba(255,255,255,0.3); }

.ss-viewer-comment-item .ss-viewer-comment-text {
  font-size: 0.84rem;
  color: rgba(255,255,255,0.8);
  line-height: 1.5;
  margin: 0;
}

.ss-viewer-comment-form {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding-top: 12px;
  border-top: 1px solid rgba(255,255,255,0.07);
}

.ss-viewer-comment-form .ss-text-input {
  width: 100%;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 8px;
  color: #fff;
  font-size: 0.84rem;
  padding: 8px 10px;
  font-family: inherit;
}

.ss-viewer-comment-form .ss-text-input::placeholder { color: rgba(255,255,255,0.3); }
.ss-viewer-comment-form .ss-text-input:focus { outline: none; border-color: var(--accent); }

.ss-viewer-comment-form textarea {
  width: 100%;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 8px;
  color: #fff;
  font-size: 0.84rem;
  padding: 10px;
  resize: vertical;
  font-family: inherit;
}

.ss-viewer-comment-form textarea::placeholder { color: rgba(255,255,255,0.3); }
.ss-viewer-comment-form textarea:focus { outline: none; border-color: var(--accent); }

.ss-viewer-comment-submit {
  align-self: flex-end;
  padding: 7px 16px;
  border-radius: var(--radius-md);
  border: none;
  background: var(--accent);
  color: #fff;
  font-size: 0.82rem;
  font-weight: 600;
  cursor: pointer;
  transition: background 140ms;
}

.ss-viewer-comment-submit:hover { background: var(--accent-strong); }

/* ── Viewer info list (in panel) ── */
.ss-viewer-info-list {
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 6px 12px;
  align-items: baseline;
}

.ss-viewer-info-list dt {
  font-size: 0.7rem;
  color: rgba(255,255,255,0.35);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  white-space: nowrap;
}

.ss-viewer-info-list dd {
  margin: 0;
  font-size: 0.82rem;
  color: rgba(255,255,255,0.8);
  word-break: break-word;
}

/* Watermark in viewer */
.ss-viewer-watermark {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  pointer-events: none;
  z-index: 5;
  font-size: clamp(14px, 2vw, 28px);
  font-weight: 700;
  color: rgba(255, 255, 255, 0.22);
  letter-spacing: 0.08em;
  text-shadow: 0 1px 3px rgba(0,0,0,0.5);
  white-space: nowrap;
  user-select: none;
}

/* Viewer info toggle (no longer floating, now in topbar) */
.ss-viewer-info-toggle {
  /* Handled by .ss-viewer-icon-btn */
}

/* ── Presentation mode: completely clean, no sidebar, no panel ── */
/* Sidebar only visible in voting mode */
.ss-gallery-app[data-mode="presentation"] .ss-gallery-sidebar { display: none; }
/* Viewer panel (info + comments) only in voting mode */
.ss-gallery-app[data-mode="presentation"] .ss-viewer-panel { display: none; }
/* Action bar with rating buttons only in voting mode */
.ss-gallery-app[data-mode="presentation"] .ss-viewer-action-bar { display: none; }
/* Info-toggle button irrelevant in presentation mode */
.ss-gallery-app[data-mode="presentation"] #ss-viewer-info-toggle { display: none; }
/* Hide presentation action bar in voting mode */
.ss-gallery-app[data-mode="voting"] .ss-presentation-actions { display: none; }

/* When sidebar hidden: content fills full width automatically (flex: 1) */
.ss-gallery-app[data-mode="presentation"] .ss-gallery-content {
  padding: 20px 32px 40px;
}

/* ── Presentation action buttons ── */
.ss-presentation-actions {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  margin: 0 0 28px;
  flex-wrap: wrap;
}

.ss-presentation-action-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 20px;
  border-radius: var(--radius-md);
  border: 1px solid var(--line-strong);
  background: var(--panel-strong);
  color: var(--muted);
  font-size: 0.85rem;
  font-weight: 500;
  cursor: pointer;
  text-decoration: none;
  transition: background 140ms, border-color 140ms, color 140ms;
  font-family: inherit;
}

.ss-presentation-action-btn:hover {
  background: var(--panel);
  border-color: var(--accent);
  color: var(--accent);
}

.ss-presentation-download-btn {
  color: var(--accent);
  border-color: rgba(32, 160, 185, 0.4);
  background: rgba(32, 160, 185, 0.07);
}

.ss-presentation-download-btn:hover {
  background: rgba(32, 160, 185, 0.14);
  border-color: var(--accent);
}

/* ── Responsive: sidebar collapses on small screens ── */
@media (max-width: 860px) {
  .ss-gallery-sidebar {
    display: none;
  }
}

@media (max-width: 780px) {
  /* Viewer panel becomes a bottom sheet on mobile */
  .ss-viewer-panel {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    flex: none;
    height: auto;
    max-height: 55vh;
    border-right: none;
    border-top: 1px solid rgba(255,255,255,0.12);
    border-radius: 12px 12px 0 0;
    z-index: 20;
  }
  /* Info toggle stays visible in voting mode */
  .ss-gallery-app[data-mode="voting"] #ss-viewer-info-toggle {
    display: flex;
  }
  .ss-gallery-content {
    padding: 16px 12px 32px;
  }
}

/* Gallery body: old toolbar/summary no longer rendered in gallery.php */

/* ═══════════════════════════════════════
   PRESENTATION SETTINGS: Bildgröße / Bildabstand / Kanten
   Spaltenanzahl + Abstände werden per JS-Masonry gesteuert (masonryLayout()).
   Die data-presentation-size / data-presentation-gap Attribute werden im JS
   ausgewertet. Hier nur noch die Kanten-Einstellung.
═══════════════════════════════════════ */

/* ── Kanten (presentation_image_corners) ── */
.ss-gallery-app[data-mode="presentation"][data-presentation-corners="round"] .ss-thumb img,
.ss-gallery-app[data-mode="presentation"][data-presentation-corners="round"] .ss-thumb {
  border-radius: var(--radius-lg);
}
.ss-gallery-app[data-mode="presentation"][data-presentation-corners="square"] .ss-thumb img,
.ss-gallery-app[data-mode="presentation"][data-presentation-corners="square"] .ss-thumb {
  border-radius: 0;
}

/* ═══════════════════════════════════════════════════════════════════
   SETTINGS PAGE – Left-nav layout
   ═══════════════════════════════════════════════════════════════════ */

.ss-settings-shell {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}
/* Settings overrides the narrow .ss-admin-shell width */
.ss-admin-shell.ss-settings-shell {
  width: 100%;
  padding-left: 32px;
  padding-right: 32px;
}

.ss-settings-layout {
  display: flex;
  flex: 1;
  align-items: flex-start;
  gap: 0;
  /* Nav panel background via gradient so it fills full height */
  background: linear-gradient(to right, var(--panel) 256px, transparent 256px);
}

/* Left nav */
.ss-settings-nav {
  width: 256px;
  min-width: 256px;
  border-right: 1px solid var(--line);
  padding: 28px 0 48px;
  position: sticky;
  top: 0;
  max-height: 100vh;
  overflow-y: auto;
}

.ss-settings-nav-group {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--muted);
  padding: 24px 20px 6px;
  margin: 0;
}
.ss-settings-nav-group:first-child {
  padding-top: 4px;
}

.ss-settings-nav-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 20px;
  font-size: 13.5px;
  color: var(--text);
  text-decoration: none;
  border-left: 2px solid transparent;
  transition: background .15s, color .15s, border-color .15s;
  cursor: pointer;
}
.ss-settings-nav-item:hover {
  background: var(--panel-strong);
  color: var(--accent);
}
.ss-settings-nav-item.is-active {
  background: var(--panel-strong);
  color: var(--accent);
  border-left-color: var(--accent);
  font-weight: 600;
}
.ss-settings-nav-item svg {
  opacity: .6;
  flex-shrink: 0;
  width: 16px;
  height: 16px;
}
.ss-settings-nav-item.is-active svg { opacity: 1; }

/* Content area */
.ss-settings-content {
  flex: 1;
  padding: 40px 52px 80px;
  max-width: none;
  min-width: 0;
}

/* Section */
.ss-settings-section {
  display: none;
}
.ss-settings-section.is-active {
  display: block;
}

.ss-settings-section-head {
  margin-bottom: 32px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--line);
}
.ss-settings-section-head h2 {
  font-size: 22px;
  font-weight: 700;
  margin: 0 0 6px;
}
.ss-settings-section-head .ss-copy {
  margin: 0;
  font-size: 14px;
}

/* Cards in settings: flex column so fields stack with gap */
.ss-settings-content .ss-admin-card {
  display: flex;
  flex-direction: column;
  gap: 20px;
  padding: 28px 32px;
}
.ss-settings-content .ss-admin-card + .ss-admin-card {
  margin-top: 20px;
}

/* Settings field labels and inputs – scoped to sections because nested
   <form> elements cause the browser to move content outside .ss-admin-form */
.ss-settings-section label {
  display: grid;
  gap: 8px;
}
.ss-settings-section label > span {
  font-size: 13px;
  color: var(--muted);
}
.ss-settings-section input[type="text"],
.ss-settings-section input[type="url"],
.ss-settings-section input[type="email"],
.ss-settings-section input[type="number"],
.ss-settings-section input[type="password"],
.ss-settings-section select,
.ss-settings-section textarea {
  width: 100%;
  min-height: 44px;
  border-radius: var(--radius-md);
  border: 1px solid var(--line);
  background: var(--bg-soft);
  color: var(--text);
  padding: 10px 14px;
  font-size: 14px;
  font-family: inherit;
  box-sizing: border-box;
}
.ss-settings-section textarea {
  min-height: 130px;
  resize: vertical;
}

.ss-settings-section-footer {
  margin-top: 32px;
  padding-top: 24px;
  border-top: 1px solid var(--line);
  display: flex;
  align-items: center;
  gap: 16px;
}

/* Save button in sections */
.ss-settings-section-footer .ss-primary-button,
.ss-settings-section-footer button[type="submit"] {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 0 28px;
  min-height: 44px;
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: var(--radius-md);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: background .15s, transform .1s;
}
.ss-settings-section-footer .ss-primary-button:hover,
.ss-settings-section-footer button[type="submit"]:hover {
  background: var(--accent-strong);
  transform: translateY(-1px);
}

/* ── User Management Cards ───────────────────────────────────────────────── */
.ss-user-card {
  gap: 0 !important;
}
.ss-user-card--new {
  border-style: dashed;
  opacity: .85;
}
.ss-user-card--new:focus-within {
  opacity: 1;
}

.ss-user-card-head {
  display: flex;
  align-items: center;
  gap: 14px;
  padding-bottom: 20px;
  margin-bottom: 20px;
  border-bottom: 1px solid var(--line);
}
.ss-user-card-head strong {
  display: block;
  font-size: 15px;
}
.ss-user-card-head span {
  font-size: 12.5px;
  color: var(--muted);
}
.ss-user-card-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--accent-muted);
  color: var(--accent);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.ss-user-card-avatar svg { width: 22px; height: 22px; }
.ss-user-card-avatar--new { background: var(--panel-strong); color: var(--muted); }
.ss-user-card-head > form { margin-left: auto; }

.ss-user-fields {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.ss-user-fields label {
  display: grid;
  gap: 8px;
}
.ss-user-fields label span { font-size: 13px; color: var(--muted); }

.ss-user-card-footer {
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px solid var(--line);
}

.ss-icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: var(--radius-md);
  border: 1px solid var(--line);
  background: transparent;
  color: var(--muted);
  cursor: pointer;
  transition: background .15s, color .15s, border-color .15s;
}
.ss-icon-btn:hover { background: var(--panel-strong); color: var(--text); }
.ss-icon-btn--danger { color: var(--red); border-color: rgba(239,68,68,.3); }
.ss-icon-btn--danger:hover { background: rgba(239,68,68,.12); color: var(--red); border-color: rgba(239,68,68,.5); }

/* ── Password Requirements ───────────────────────────────────────────────── */
.ss-pw-requirements {
  background: var(--panel-strong);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  padding: 14px 16px;
  font-size: 13px;
}
.ss-pw-requirements .ss-pw-req-title {
  font-weight: 600;
  margin: 0 0 8px;
  color: var(--text);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.ss-pw-requirements ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.ss-pw-requirements li {
  color: var(--muted);
  display: flex;
  align-items: center;
  gap: 8px;
}
.ss-pw-requirements li::before {
  content: '○';
  font-size: 11px;
  flex-shrink: 0;
  transition: color .15s;
}
.ss-pw-requirements li.is-met {
  color: var(--green);
}
.ss-pw-requirements li.is-met::before { content: '●'; color: var(--green); }

.ss-pw-requirements--inline {
  margin-top: 8px;
}
.ss-pw-requirements--inline ul {
  flex-direction: row;
  flex-wrap: wrap;
  gap: 4px 14px;
}

/* Login page forgot-password link */
.ss-client-login-forgot {
  font-size: 13px;
  color: var(--muted);
  text-decoration: none;
  transition: color .15s;
}
.ss-client-login-forgot:hover { color: var(--accent); }

/* Flag label rows */
.ss-flag-label-row {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
}
.ss-flag-dot {
  display: inline-block;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  flex-shrink: 0;
}
.ss-flag-label-row input {
  flex: 1;
  max-width: 200px;
}

/* ═══════════════════════════════════════════════════════════════════
   GALLERY – Search & Sort in sidebar
   ═══════════════════════════════════════════════════════════════════ */

.ss-sidebar-search-wrap {
  margin: 8px 0 4px;
}

.ss-sidebar-search {
  display: flex;
  align-items: center;
  gap: 6px;
  background: var(--panel-strong);
  border-radius: var(--radius);
  padding: 6px 10px;
  border: 1px solid transparent;
  transition: border-color .15s;
}
.ss-sidebar-search:focus-within {
  border-color: var(--accent);
}
.ss-sidebar-search svg {
  color: var(--muted);
  flex-shrink: 0;
}
.ss-search-input {
  flex: 1;
  background: transparent;
  border: none;
  outline: none;
  font-size: 12px;
  color: var(--text);
  min-width: 0;
}
.ss-search-input::placeholder { color: var(--muted); }

.ss-search-clear {
  background: none;
  border: none;
  color: var(--muted);
  font-size: 16px;
  cursor: pointer;
  padding: 0 2px;
  line-height: 1;
  transition: color .15s;
}
.ss-search-clear:hover { color: var(--text); }

.ss-sidebar-sort-wrap {
  margin: 6px 0 8px;
}
.ss-sort-select {
  width: 100%;
  background: var(--panel-strong);
  border: 1px solid transparent;
  border-radius: var(--radius);
  color: var(--text);
  font-size: 12px;
  padding: 6px 10px;
  cursor: pointer;
  transition: border-color .15s;
}
.ss-sort-select:focus {
  outline: none;
  border-color: var(--accent);
}

/* ═══════════════════════════════════════════════════════════════════
   GALLERY – Mobile sidebar
   ═══════════════════════════════════════════════════════════════════ */

.ss-sidebar-mobile-toggle {
  display: none;
  position: fixed;
  bottom: 20px;
  right: 20px;
  z-index: 200;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--accent);
  color: #fff;
  border: none;
  cursor: pointer;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 16px rgba(0,0,0,.4);
  transition: background .15s, transform .15s;
}
.ss-sidebar-mobile-toggle:hover {
  background: var(--accent-strong);
  transform: scale(1.05);
}

.ss-sidebar-backdrop {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.5);
  z-index: 149;
  opacity: 0;
  pointer-events: none;
  transition: opacity .25s;
}
.ss-sidebar-backdrop.is-visible {
  opacity: 1;
  pointer-events: auto;
}

@media (max-width: 768px) {
  .ss-sidebar-mobile-toggle {
    display: flex;
  }
  .ss-sidebar-backdrop {
    display: block;
  }
  .ss-gallery-sidebar {
    position: fixed;
    top: 0;
    left: 0;
    height: 100vh;
    z-index: 150;
    transform: translateX(-100%);
    transition: transform .25s ease;
    overflow-y: auto;
    width: 280px;
    max-width: 85vw;
    box-shadow: 4px 0 20px rgba(0,0,0,.5);
  }
  .ss-gallery-sidebar.is-open {
    transform: translateX(0);
  }
  .ss-gallery-layout {
    display: block;
  }
  .ss-gallery-content {
    width: 100%;
  }
  .ss-settings-nav {
    display: none;
  }
  .ss-settings-layout {
    background: none;
  }
  .ss-settings-content {
    padding: 24px 20px 64px;
  }
  .ss-settings-content .ss-admin-card {
    padding: 20px 20px;
    gap: 16px;
  }
  .ss-settings-section-head {
    margin-bottom: 24px;
    padding-bottom: 16px;
  }
}

/* ── Save-Set Modal ──────────────────────────────────────────────────────── */
.ss-save-set-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.72);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2000;
  padding: 20px;
}

.ss-save-set-overlay[hidden] {
  display: none !important;
}

.ss-save-set-panel {
  background: var(--panel-strong, #161616);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--radius-xl, 12px);
  padding: 28px 28px 24px;
  width: 100%;
  max-width: 440px;
  box-shadow: var(--shadow-lg, 0 20px 60px rgba(0,0,0,0.7));
}

.ss-save-set-panel h3 {
  margin: 0 0 20px;
  font-family: var(--font-display);
  font-size: 1.35rem;
  font-weight: 400;
  color: var(--text);
}

.ss-save-set-form {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.ss-save-set-form label {
  display: flex;
  flex-direction: column;
  gap: 5px;
  font-size: 0.82rem;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .04em;
}

.ss-save-set-form input,
.ss-save-set-form textarea {
  background: var(--bg-soft, #0a0a0a);
  border: 1px solid var(--line-strong, rgba(255,255,255,0.13));
  border-radius: var(--radius-md, 6px);
  color: var(--text);
  padding: 9px 12px;
  font-size: 0.95rem;
  outline: none;
  transition: border-color 140ms;
  resize: vertical;
}

.ss-save-set-form input:focus,
.ss-save-set-form textarea:focus {
  border-color: var(--accent, #20a0b9);
}

.ss-save-set-actions {
  display: flex;
  gap: 10px;
  justify-content: flex-end;
  margin-top: 8px;
}

.ss-save-set-actions .btn-ghost {
  background: transparent;
  border: 1px solid rgba(255,255,255,0.15);
  color: var(--muted);
  padding: 9px 18px;
  border-radius: var(--radius-md, 6px);
  cursor: pointer;
  font-size: 0.9rem;
  transition: border-color 140ms, color 140ms;
}

.ss-save-set-actions .btn-ghost:hover {
  border-color: rgba(255,255,255,0.3);
  color: var(--text);
}

.ss-save-set-actions .btn-primary {
  background: var(--accent, #20a0b9);
  border: 0;
  color: #fff;
  padding: 9px 22px;
  border-radius: var(--radius-md, 6px);
  cursor: pointer;
  font-size: 0.9rem;
  font-weight: 600;
  transition: background 140ms, opacity 140ms;
}

.ss-save-set-actions .btn-primary:hover {
  background: var(--accent-strong, #1a8fa6);
}

.ss-save-set-actions .btn-primary:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}


/* ══════════════════════════════════════════════════════════════════════════
   PAPIERKORB – admin_trash.php
   ══════════════════════════════════════════════════════════════════════════ */

.ss-danger-button {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 6px 12px;
  border-radius: var(--radius-md);
  border: 1px solid #c0392b;
  background: #c0392b;
  color: #fff;
  font-size: 0.82rem;
  cursor: pointer;
  text-decoration: none;
  transition: background 140ms, border-color 140ms;
  white-space: nowrap;
}
.ss-danger-button:hover { background: #a93226; border-color: #a93226; }
.ss-danger-button:disabled { opacity: .5; cursor: not-allowed; }

.ss-accent-button {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 6px 12px;
  border-radius: var(--radius-md);
  border: 1px solid var(--accent);
  background: var(--accent);
  color: #fff;
  font-size: 0.82rem;
  cursor: pointer;
  text-decoration: none;
  transition: background 140ms, border-color 140ms;
  white-space: nowrap;
}
.ss-accent-button:hover { background: var(--accent-strong); border-color: var(--accent-strong); }
.ss-accent-button:disabled { opacity: .5; cursor: not-allowed; }

.ss-trash-page {
  padding: 28px 32px 60px;
  max-width: 1280px;
  margin: 0 auto;
}

.ss-trash-info {
  color: var(--muted);
  font-size: 0.88rem;
  margin: 0 0 24px;
}

.ss-trash-empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 16px;
  padding: 80px 20px;
  color: var(--muted);
  text-align: center;
}
.ss-trash-empty-state svg { opacity: .35; }
.ss-trash-empty-state p { font-size: 1rem; margin: 0; }

.ss-trash-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 20px;
}

.ss-trash-card {
  background: var(--panel);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: var(--radius-lg, 10px);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: box-shadow .15s;
}
.ss-trash-card:hover {
  box-shadow: 0 4px 20px rgba(0,0,0,.35);
}

.ss-trash-thumb {
  aspect-ratio: 4 / 3;
  background: var(--bg-soft);
  overflow: hidden;
}
.ss-trash-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  opacity: .65;
}
.ss-trash-thumb-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--muted);
}

.ss-trash-meta {
  padding: 10px 12px 6px;
  flex: 1;
}
.ss-trash-filename {
  font-size: 0.82rem;
  color: var(--text);
  margin: 0 0 4px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ss-trash-gallery,
.ss-trash-date {
  font-size: 0.75rem;
  color: var(--muted);
  margin: 0 0 2px;
}
.ss-trash-gallery span { color: var(--text); }

.ss-trash-actions {
  padding: 8px 12px 12px;
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.ss-trash-actions .ss-accent-button,
.ss-trash-actions .ss-danger-button {
  flex: 1;
  justify-content: center;
  font-size: 0.78rem;
  padding: 5px 8px;
}

/* ══════════════════════════════════════════════════════════════════════════
   KUNDEN-LOGIN – gallery_client_login.php
   ══════════════════════════════════════════════════════════════════════════ */

/* ── Seiten-Grundgerüst ── */
.ss-client-login-body {
  min-height: 100dvh;
  margin: 0;
  display: flex;
  flex-direction: column;
  position: relative;
  overflow-x: hidden;
}

.ss-home-admin-link {
  position: fixed;
  top: 16px;
  right: 20px;
  z-index: 10;
  font-size: 11px;
  font-family: var(--font-body);
  color: var(--muted);
  text-decoration: none;
  letter-spacing: .04em;
  padding: 4px 8px;
  border-radius: 4px;
  transition: color .15s, background .15s;
}
.ss-home-admin-link:hover {
  color: var(--text);
  background: rgba(255,255,255,.06);
}

/* ── Collage-Hintergrund: Pseudo-Masonry via CSS Grid ──
   object-fit: cover garantiert lückenlose Abdeckung bei jeder Auflösung.
   grid-auto-rows in vh skaliert Zellhöhen bevor Spalten abgebaut werden. ── */
.ss-client-login-bg {
  position: fixed;
  inset: 0;
  z-index: 0;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  grid-auto-rows: clamp(90px, 17vh, 260px);
  grid-auto-flow: dense;
  gap: 4px;
  overflow: hidden;
}
.ss-client-login-bg-tile {
  overflow: hidden;
  border-radius: 2px;
}
/* Abwechselnde Höhen für Masonry-Feeling */
.ss-client-login-bg-tile:nth-child(4n+1) { grid-row: span 2; }
.ss-client-login-bg-tile:nth-child(7n+3) { grid-row: span 3; }
.ss-client-login-bg-tile img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  filter: saturate(0.72) brightness(0.85);
}
/* Responsive: erst skalieren (via vh-basierte row-height), dann Spalten abbauen */
@media (max-width: 1100px) {
  .ss-client-login-bg { grid-template-columns: repeat(4, 1fr); }
}
@media (max-width: 750px) {
  .ss-client-login-bg { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 480px) {
  .ss-client-login-bg { grid-template-columns: repeat(2, 1fr); }
}
.ss-client-login-bg-overlay {
  position: fixed;
  inset: 0;
  z-index: 1;
  background: rgba(0,0,0,0.42);
}
body[data-theme="light"] .ss-client-login-bg-overlay {
  background: rgba(250,250,248,0.48);
}
body[data-theme="light"] .ss-client-login-bg-tile img {
  filter: saturate(0.68) brightness(1.0);
}

/* ── Layout-Wrapper (über dem Hintergrund) ── */
.ss-client-login-layout {
  position: relative;
  z-index: 2;
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
}

/* ── Main: zentriertes Login-Card ── */
.ss-client-login-main {
  flex: 1;
  display: grid;
  place-items: center;
  padding: 24px 16px;
}

/* ── Card ── */
.ss-client-login-card {
  width: min(460px, 100%);
  padding: 32px 36px 36px;
  border-radius: 18px;
  background: color-mix(in srgb, var(--panel) 92%, transparent);
  backdrop-filter: blur(28px) saturate(1.4);
  -webkit-backdrop-filter: blur(28px) saturate(1.4);
  border: 1px solid var(--line-strong);
  box-shadow: 0 24px 64px rgba(0,0,0,0.45), 0 2px 8px rgba(0,0,0,0.2);
}
body[data-theme="light"] .ss-client-login-card {
  background: rgba(255,255,255,0.91);
  box-shadow: 0 16px 48px rgba(20,12,4,0.18), 0 2px 8px rgba(20,12,4,0.08);
}

/* ── Branding oben in der Card (als <a> verlinkt) ── */
.ss-client-login-brand {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
  align-items: center;
  gap: 8px;
  margin-bottom: 4px;
  text-align: center;
}
.ss-client-login-brand:hover { opacity: 0.82; }
.ss-client-login-brand-logo {
  max-height: 60px;
  max-width: 180px;
  width: auto;
  object-fit: contain;
  display: block;
}
.ss-client-login-brand-name {
  font-family: var(--font-display);
  font-size: 1.45rem;
  font-weight: 400;
  letter-spacing: 0.05em;
  color: var(--text);
  line-height: 1.1;
}
.ss-client-login-divider {
  border: none;
  border-top: 1px solid var(--line-strong);
  margin: 20px 0 22px;
}

/* ── Card Inhalt ── */
.ss-client-login-card h1 {
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 3vw, 2.6rem);
  font-weight: 400;
  line-height: 1;
  margin: 4px 0 14px;
  color: var(--text);
}
.ss-client-login-hint {
  font-size: 0.88rem;
  color: var(--muted);
  margin: 0 0 22px;
  line-height: 1.6;
}
.ss-client-login-form {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.ss-client-login-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.ss-client-login-field label {
  font-size: 0.78rem;
  color: var(--muted);
  font-weight: 600;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.ss-client-login-field input {
  background: var(--bg-soft);
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-md);
  color: var(--text);
  font-size: 0.95rem;
  padding: 11px 14px;
  outline: none;
  transition: border-color .15s, box-shadow .15s;
  width: 100%;
  box-sizing: border-box;
  font-family: var(--font-body);
}
.ss-client-login-field input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-muted);
}
.ss-client-login-submit {
  margin-top: 6px;
  padding: 13px 20px;
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: var(--radius-md);
  font-size: 0.95rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  cursor: pointer;
  transition: background .15s, transform .1s;
  width: 100%;
  font-family: var(--font-body);
}
.ss-client-login-submit:hover { background: var(--accent-strong); }
.ss-client-login-submit:active { transform: scale(0.99); }
body[data-theme="light"] .ss-client-login-submit { color: #18130F; }

/* ── Footer ── */
.ss-client-login-footer .ss-site-footer-wrap { margin-top: 0; }
.has-wallpaper .ss-client-login-footer .ss-site-footer-wrap {
  background: rgba(0,0,0,0.35);
  backdrop-filter: blur(8px);
  border-top: 1px solid rgba(255,255,255,0.08);
}
.has-wallpaper .ss-client-login-footer .ss-site-footer { color: rgba(255,255,255,0.75); }
.has-wallpaper .ss-client-login-footer a { color: rgba(255,255,255,0.75); }
.has-wallpaper .ss-client-login-footer a:hover { color: #fff; }
body[data-theme="light"].has-wallpaper .ss-client-login-footer .ss-site-footer-wrap {
  background: rgba(250,250,248,0.7);
}
body[data-theme="light"].has-wallpaper .ss-client-login-footer .ss-site-footer { color: var(--muted); }
body[data-theme="light"].has-wallpaper .ss-client-login-footer a { color: var(--muted); }

/* ── Kein Wallpaper: normaler Look ── */
.ss-client-login-body:not(.has-wallpaper) .ss-client-login-main { padding: 40px 16px; }

/* ── Responsive: Tablet (≤768px) ── */
@media (max-width: 768px) {
  .ss-client-login-card {
    padding: 28px 24px 32px;
  }
}

/* ── Responsive: Mobil (≤480px) ── */
@media (max-width: 480px) {
  .ss-client-login-card {
    padding: 24px 20px 28px;
    border-radius: 14px;
  }
  .ss-client-login-brand-logo { max-height: 48px; }
  .ss-client-login-brand-name { font-size: 1.2rem; }
}

/* Kunden-Zugang PIN-Anzeige */
.ss-client-pin-display {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 0.78rem;
  color: var(--muted);
}
.ss-client-pin-display code {
  background: var(--panel-strong);
  border-radius: 3px;
  padding: 1px 5px;
  color: var(--accent);
  font-family: monospace;
  font-size: 0.82rem;
}
.ss-client-pin-display .ss-client-set-pin {
  padding: 2px 4px;
  opacity: .6;
}
.ss-client-pin-display .ss-client-set-pin:hover { opacity: 1; }

/* ── Aktuelles Passwort-Anzeige (Sicherheits-Tab) ──────────────────────── */
.ss-current-password-row {
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--bg-soft);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--radius-md);
  padding: 7px 10px;
  font-size: 0.84rem;
}
.ss-current-password-label {
  color: var(--muted);
  white-space: nowrap;
  flex-shrink: 0;
}
.ss-current-password-value {
  color: var(--text);
  font-family: monospace;
  font-size: 0.9rem;
  letter-spacing: .04em;
  flex: 1;
  user-select: all;
}
.ss-pw-eye-btn {
  flex-shrink: 0;
  background: transparent;
  border: none;
  cursor: pointer;
  color: var(--muted);
  padding: 3px 4px;
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  transition: color .15s;
}
.ss-pw-eye-btn:hover { color: var(--text); }

/* ── Mobile Admin Navigation ─────────────────────────────────────────────── */
.ss-admin-nav-toggle {
  display: none;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  min-height: 40px;
  border-radius: var(--radius-md);
  border: 1px solid var(--line-strong);
  background: transparent;
  color: var(--text);
  cursor: pointer;
  flex-shrink: 0;
  padding: 0;
  transition: background .15s;
}
.ss-admin-nav-toggle:hover { background: var(--panel-strong); }

/* Settings page mobile section select */
.ss-settings-mobile-select-wrap {
  display: none;
  padding: 16px 0 4px;
}
.ss-settings-mobile-select {
  width: 100%;
  background: var(--panel);
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-md);
  color: var(--text);
  padding: 12px 16px;
  font: inherit;
  font-size: 0.95rem;
  cursor: pointer;
  appearance: auto;
  min-height: 48px;
}

/* Workbench sidebar toggle (mobile only) */
.ss-admin-side-toggle {
  display: none;
  width: 100%;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 12px 16px;
  background: var(--panel-strong);
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-lg);
  color: var(--text);
  font: inherit;
  font-size: 0.9rem;
  font-weight: 600;
  cursor: pointer;
  transition: background .15s;
}
.ss-admin-side-toggle:hover { background: var(--panel); }
.ss-admin-side-toggle svg { transition: transform .2s ease; }
.ss-admin-side-toggle[aria-expanded="true"] svg { transform: rotate(180deg); }

@media (max-width: 768px) {
  /* Show hamburger */
  .ss-admin-nav-toggle {
    display: flex;
    margin-left: auto;
  }

  /* Header stays as a row with toggle, no stacking */
  .ss-admin-header {
    flex-direction: row;
    align-items: center;
    flex-wrap: nowrap;
    padding: 10px 14px;
    position: relative;
  }
  .ss-admin-header .ss-admin-brand-block h1 {
    font-size: clamp(1rem, 4vw, 1.5rem);
    line-height: 1.1;
    margin-bottom: 4px;
  }
  .ss-admin-header .ss-kicker { font-size: 0.6rem; }
  .ss-admin-brand-logo {
    max-height: 40px;
    max-width: min(120px, 22vw);
  }

  /* Actions: hidden by default, dropdown when open */
  .ss-admin-actions {
    display: none;
    position: absolute;
    top: calc(100% + 6px);
    left: 0;
    right: 0;
    z-index: 300;
    flex-direction: column;
    align-items: stretch;
    gap: 6px;
    background: var(--panel-strong);
    border: 1px solid var(--line-strong);
    border-radius: var(--radius-xl);
    padding: 12px;
    box-shadow: var(--shadow-lg);
  }
  .ss-admin-header.is-nav-open .ss-admin-actions { display: flex; }
  .ss-admin-actions .ss-primary-link,
  .ss-admin-actions .ss-primary-button,
  .ss-admin-actions .ss-secondary-link,
  .ss-admin-actions .ss-secondary-button { width: 100%; }
  .ss-admin-actions .ss-sort-menu,
  .ss-admin-actions .ss-search-form,
  .ss-admin-actions form { width: 100%; }
  .ss-admin-actions form button { width: 100%; }
  .ss-admin-actions .ss-admin-breadcrumb { font-size: 0.78rem; }

  /* Settings mobile nav */
  .ss-settings-mobile-select-wrap { display: block; }

  /* Workbench sidebar: collapsible */
  .ss-admin-side-toggle {
    display: flex;
    order: -2; /* float above form-stack on mobile */
  }
  .ss-admin-form-layout.is-gallery-workbench .ss-admin-side {
    display: none;
    order: -1; /* sidebar appears after toggle, before form */
  }
  .ss-admin-form-layout.is-gallery-workbench .ss-admin-side.is-open {
    display: grid;
  }
}

/* ═══════════════════════════════════════════════════════════════════════════
   PWA INSTALL OVERLAY
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Animations ─────────────────────────────────────────────────────────── */
@keyframes pwa-tap {
  0%, 100% { transform: scale(1); opacity: 1; }
  40%       { transform: scale(0.82); opacity: 0.7; }
  70%       { transform: scale(1.08); opacity: 0.9; }
}
@keyframes pwa-ring-pulse {
  0%, 100% { opacity: 0.12; r: 9; }
  50%       { opacity: 0.35; r: 13; }
}
@keyframes pwa-slide-up {
  0%   { transform: translateY(30px); opacity: 0; }
  100% { transform: translateY(0);    opacity: 1; }
}
@keyframes pwa-slide-down {
  0%   { transform: translateY(-20px); opacity: 0; }
  100% { transform: translateY(0);     opacity: 1; }
}
@keyframes pwa-bounce-y {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(-5px); }
}

.ss-pwa-anim-tap   { animation: pwa-tap 1.6s ease-in-out infinite; }
.ss-pwa-tap-ring   { animation: pwa-ring-pulse 1.6s ease-in-out infinite; }
.ss-pwa-anim-slide-up   { animation: pwa-slide-up   0.8s ease-out forwards,
                                      pwa-bounce-y   2s   ease-in-out 0.8s infinite; }
.ss-pwa-anim-slide-down { animation: pwa-slide-down 0.8s ease-out forwards,
                                      pwa-bounce-y   2s   ease-in-out 0.8s infinite; }

/* ── Shortcut-Overlay ───────────────────────────────────────────────────── */
.ss-shortcuts-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.7);
  z-index: 900;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}
.ss-shortcuts-overlay[hidden] { display: none; }
.ss-shortcuts-modal {
  background: var(--panel-strong);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 28px 32px;
  max-width: 480px;
  width: 100%;
}
.ss-shortcuts-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
}
.ss-shortcuts-header h2 {
  font-size: 1rem;
  font-weight: 600;
  margin: 0;
}
.ss-shortcuts-close {
  background: none;
  border: none;
  color: var(--muted);
  font-size: 1.4rem;
  cursor: pointer;
  line-height: 1;
  padding: 0;
}
.ss-shortcuts-close:hover { color: var(--text); }
.ss-shortcuts-grid {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.ss-shortcuts-section h3 {
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--muted);
  margin: 0 0 10px;
}
.ss-shortcuts-section dl {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 6px 16px;
  margin: 0;
}
.ss-shortcuts-section dt {
  display: flex;
  align-items: center;
}
.ss-shortcuts-section dd {
  margin: 0;
  color: var(--text);
  font-size: 0.875rem;
  display: flex;
  align-items: center;
}
kbd {
  display: inline-block;
  padding: 2px 7px;
  font-size: 0.75rem;
  font-family: inherit;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 4px;
  color: var(--text);
  white-space: nowrap;
}

/* ── Overlay backdrop ───────────────────────────────────────────────────── */
.ss-pwa-overlay {
  position: fixed;
  inset: 0;
  z-index: 26000;
  background: rgba(0,0,0,0.78);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  /* No backdrop-filter: causes click-through bugs on iOS Safari */
}
.ss-pwa-overlay[hidden] { display: none; }

/* ── Modal card ─────────────────────────────────────────────────────────── */
.ss-pwa-modal {
  background: var(--panel-strong, #161616);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 20px;
  padding: 1.5rem 1.25rem 2rem;
  width: 100%;
  max-width: 580px;
  max-height: 90dvh;
  overflow-y: auto;
  position: relative;
}

/* ── Close button ───────────────────────────────────────────────────────── */
.ss-pwa-close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  background: rgba(255,255,255,0.07);
  border: none;
  border-radius: 50%;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text);
  cursor: pointer;
}
.ss-pwa-close:hover { background: rgba(255,255,255,0.14); }

/* ── App header ─────────────────────────────────────────────────────────── */
.ss-pwa-header {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1.25rem;
  padding-right: 2.5rem;
}
.ss-pwa-app-icon {
  width: 60px;
  height: 60px;
  border-radius: 14px;
  object-fit: cover;
  flex-shrink: 0;
  border: 1px solid rgba(255,255,255,0.1);
}
.ss-pwa-app-icon--placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--panel, #0e0e0e);
  color: var(--muted);
}
.ss-pwa-app-name {
  font-size: 1rem;
  font-weight: 700;
  color: var(--text);
  margin: 0 0 0.15rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ss-pwa-app-sub {
  font-size: 0.78rem;
  color: var(--muted);
  margin: 0;
}

/* ── Platform tabs ──────────────────────────────────────────────────────── */
.ss-pwa-tabs {
  display: flex;
  gap: 0.5rem;
  margin-bottom: 1.25rem;
  border-bottom: 1px solid rgba(255,255,255,0.07);
  padding-bottom: 0.75rem;
}
.ss-pwa-tab {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.45rem 0.85rem;
  border-radius: 20px;
  border: 1px solid rgba(255,255,255,0.1);
  background: transparent;
  color: var(--muted);
  font-size: 0.8rem;
  cursor: pointer;
  transition: all 0.15s;
}
.ss-pwa-tab.is-active {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}
.ss-pwa-tab:not(.is-active):hover {
  border-color: rgba(255,255,255,0.2);
  color: var(--text);
}

/* ── Steps row ──────────────────────────────────────────────────────────── */
/* !important needed: author display:grid overrides UA display:none from [hidden] attribute */
.ss-pwa-steps[hidden] { display: none !important; }
.ss-pwa-steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.75rem;
}
.ss-pwa-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.6rem;
  text-align: center;
}
.ss-pwa-step-num {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--accent);
  color: #fff;
  font-size: 0.75rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.ss-pwa-phone-mock {
  width: 100%;
}
.ss-pwa-phone-svg {
  width: 100%;
  height: auto;
  border-radius: 8px;
  display: block;
}
.ss-pwa-step-label {
  font-size: 0.72rem;
  color: var(--muted);
  line-height: 1.4;
  margin: 0;
}
.ss-pwa-step-label strong { color: var(--text); }
.ss-pwa-inline-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  border: 1px solid var(--accent);
  border-radius: 4px;
  font-size: 0.65rem;
  color: var(--accent);
  vertical-align: middle;
}

/* ── Native install button (Android) ───────────────────────────────────── */
.ss-pwa-native-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.65rem 1.5rem;
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: 24px;
  font-size: 0.9rem;
  font-weight: 600;
  cursor: pointer;
  margin-top: 1rem;
}
.ss-pwa-native-btn:hover { background: var(--accent-strong); }

/* ── Trigger button (next to voting-mode button) ────────────────────────── */
.ss-pwa-install-btn { /* inherits ss-presentation-action-btn */ }

/* On desktop (mouse/trackpad) hide the install button — feature targets touch devices.
   hover:hover + pointer:fine = true mouse, excludes iPad/iPhone */
@media (hover: hover) and (pointer: fine) {
  .ss-pwa-install-btn { display: none; }
}

/* Very small screens: stack steps vertically */
@media (max-width: 380px) {
  .ss-pwa-steps { grid-template-columns: 1fr; }
}


/* ── Admin Inline Upload Dropzone (below media, above subgalleries) ─────── */
.ss-admin-inline-dropzone {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.9rem 1.25rem;
  border: 1.5px dashed var(--panel-strong);
  border-radius: 8px;
  cursor: pointer;
  color: var(--muted);
  font-size: 0.85rem;
  transition: border-color 0.15s, color 0.15s, background 0.15s;
  margin-bottom: 0.5rem;
}
.ss-admin-inline-dropzone small {
  margin-left: auto;
  font-size: 0.75rem;
  opacity: 0.6;
}
.ss-admin-inline-dropzone:hover,
.ss-admin-inline-dropzone:focus-visible,
.ss-admin-inline-dropzone.is-dragover {
  border-color: var(--accent);
  color: var(--accent);
  background: color-mix(in srgb, var(--accent) 5%, transparent);
  outline: none;
}

/* ── Customer Upload Inline Dropzone (gallery view, below media grid) ───── */
.ss-customer-dropzone {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1.25rem 1.5rem;
  margin: 1rem 0;
  border: 2px dashed var(--panel-strong);
  border-radius: 10px;
  cursor: pointer;
  color: var(--muted);
  transition: border-color 0.15s, color 0.15s, background 0.15s;
}
.ss-customer-dropzone-text {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}
.ss-customer-dropzone-text strong {
  font-size: 0.95rem;
  color: var(--text);
}
.ss-customer-dropzone-text span {
  font-size: 0.8rem;
}
.ss-customer-dropzone:hover,
.ss-customer-dropzone:focus-visible,
.ss-customer-dropzone.is-dragover {
  border-color: var(--accent);
  color: var(--accent);
  background: color-mix(in srgb, var(--accent) 6%, transparent);
  outline: none;
}
.ss-customer-dropzone.is-uploading {
  pointer-events: none;
  opacity: 0.7;
}
.ss-customer-dropzone-status {
  font-size: 0.82rem;
  margin-top: 0.5rem;
  padding: 0.4rem 0.75rem;
  border-radius: 6px;
}
.ss-cu-status--progress { color: var(--muted); }
.ss-cu-status--ok       { color: var(--green); }
.ss-cu-status--warn     { color: var(--orange); }
.ss-cu-status--error    { color: var(--red); }
