/* ============================================================
   LUMIZED — Design System
   Dark Luxury · Editorial · Gold / Teal / Pink
   ============================================================ */

/* ── Google Fonts ─────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500&display=swap');

/* ── Tokens ───────────────────────────────────────────────── */
:root {
  /* Hintergründe */
  --black:       #060606;
  --bg:          #060606;
  --surface:     #111111;
  --surface-2:   #1a1a1a;
  --border:      #2a2a2a;
  --border-2:    #1f1f1f;

  /* Gold */
  --gold:        #a97c10;
  --gold-light:  #c49520;
  --gold-dark:   #7a590b;
  --gold-dim:    #3d2c05;

  /* Teal */
  --teal:        #087e7f;
  --teal-light:  #0aa6a7;
  --teal-dark:   #055859;
  --teal-dim:    #022c2c;

  /* Pink */
  --pink:        #9d1278;
  --pink-light:  #c41893;
  --pink-dark:   #6e0d54;
  --pink-dim:    #380628;

  /* Status */
  --green:       #0aa6a7;
  --green-dim:   #022c2c;
  --red:         #9d1278;
  --red-dim:     #380628;
  --orange:      #e07a20;
  --orange-dim:  #2a1f00;

  /* Schrift */
  --white:       #dcdcdc;
  --white-mid:   #777777;
  --white-dim:   #666666;
  --white-faint: #4c4c4b;
  --text:        #dcdcdc;
  --text-sec:    #666666;
  --text-muted:  #4c4c4b;

  /* Typografie — Schriften */
  --font-main: 'Inter', system-ui, -apple-system, sans-serif;
  --font-ui:   'Inter', system-ui, -apple-system, sans-serif;
  --font-mono: 'SF Mono', 'JetBrains Mono', 'Fira Code', monospace;

  /* Typografie — Größen-Skala */
  --text-xs:   0.68rem;   /* Codes, Micro-Labels */
  --text-sm:   0.75rem;   /* Captions, Meta, Hints */
  --text-ui:   0.78rem;   /* Tabs, Buttons, Nav */
  --text-base: 0.88rem;   /* Card-Namen, Body */
  --text-lg:   1.1rem;    /* Subheadlines */
  --text-xl:   1.3rem;    /* Page-Titel, Display */

  /* Radius & Spacing */
  --radius:      2px;   /* Buttons, Inputs, Chips */
  --radius-card: 12px;  /* Cards: grid-card, surface-card, info-card, promo-card */
  --t:          0.15s ease;
  --transition: 0.15s ease;

  /* Builder-spezifisch */
  --header-h: 96px;
  --tabs-h:   44px;
}

/* ------------------------------------------------------------
   Reset & Base
   ------------------------------------------------------------ */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  scrollbar-gutter: stable;
}

body {
  background:  var(--black);
  color:       var(--white);
  font-family: var(--font-main);
  font-size:   15px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

a {
  color: var(--gold);
  text-decoration: none;
  transition: color var(--transition);
}
a:hover { color: var(--white); }

img { display: block; max-width: 100%; }

ul, ol { list-style: none; }

/* ------------------------------------------------------------
   Site Header
   ------------------------------------------------------------ */
.site-header {
  position:        fixed;
  top:             0;
  left:            0;
  right:           0;
  height:          var(--header-h);
  background:      linear-gradient(135deg, #0a1112, #0c1416);
  border-bottom:   1px solid #1a2a2c;
  z-index:         100;
}

.site-header-inner {
  max-width:       1200px;
  margin:          0 auto;
  padding:         0 2rem;
  height:          100%;
  display:         flex;
  align-items:     center;
  justify-content: space-between;
}

.site-header-left {
  display:     flex;
  align-items: flex-end;
  gap:         4rem;
}

.site-logo {
  font-size:      1rem;
  font-weight:    300;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color:          var(--white);
  text-decoration: none;
  user-select:    none;
  flex-shrink:    0;
}
.site-logo img   { height: 40px; width: auto; display: block; }
.site-logo span  { color: var(--gold); font-weight: 400; }

.site-nav {
  display:     flex;
  gap:         2rem;
  align-items: flex-end;
}
.site-nav a {
  color:           #888;
  font-size:       0.95rem;
  font-weight:     300;
  letter-spacing:  0.04em;
  transition:      color var(--transition);
  text-decoration: none;
  white-space:     nowrap;
  line-height:     1;
}
.site-nav a:hover,
.site-nav a.active { color: var(--white); }

.site-header-right {
  display:     flex;
  align-items: center;
  gap:         1rem;
}

/* ------------------------------------------------------------
   Briefing Button (always visible, header right)
   ------------------------------------------------------------ */
.briefing-btn {
  display:         inline-flex;
  align-items:     center;
  gap:             0.5rem;
  border:          1px solid var(--gold-dim);
  color:           var(--gold);
  padding:         0.4rem 1rem;
  font-size:       0.8rem;
  letter-spacing:  0.08em;
  text-transform:  uppercase;
  border-radius:   var(--radius);
  background:      transparent;
  cursor:          pointer;
  text-decoration: none;
  transition:      background var(--transition), color var(--transition), border-color var(--transition);
  white-space:     nowrap;
}
.briefing-btn:hover {
  background: var(--gold);
  color:      var(--black);
  border-color: var(--gold);
}
.briefing-count {
  display:         inline-flex;
  align-items:     center;
  justify-content: center;
  background:      var(--gold);
  color:           var(--black);
  font-size:       0.7rem;
  font-weight:     600;
  min-width:       1.3rem;
  height:          1.3rem;
  border-radius:   999px;
  padding:         0 0.3rem;
  line-height:     1;
}
.briefing-count:empty,
.briefing-count[data-count="0"] {
  display: none;
}

/* ------------------------------------------------------------
   Tabs (below header)
   ------------------------------------------------------------ */
.tabs {
  position:      fixed;
  top:           var(--header-h);
  left:          0;
  right:         0;
  height:        var(--tabs-h);
  background:    #0d0d0d;
  border-bottom: 1px solid var(--border);
  overflow-x:    auto;
  overflow-y:    hidden;
  z-index:       99;
  scrollbar-width: none;
}
.tabs::-webkit-scrollbar { display: none; }

.tabs-inner {
  max-width:  1200px;
  margin:     0 auto;
  padding:    0 0.5rem;
  height:     100%;
  display:    flex;
}

.tab {
  display:        inline-flex;
  align-items:    center;
  padding:        0 1rem;
  height:         100%;
  font-size:      var(--text-ui);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor:         pointer;
  border-bottom:  2px solid transparent;
  white-space:    nowrap;
  transition:     color var(--transition), border-color var(--transition);
  text-decoration: none;
  user-select:    none;
  background:     transparent;
  border-top:     none;
  border-left:    none;
  border-right:   none;
  font-family:    var(--font-main);
  color:          var(--white-mid);
}
.tab:hover { color: var(--white); }
.tab.active {
  color:               var(--white);
  border-bottom-color: var(--gold);
}
.tab.disabled {
  color:   var(--white-dim);
  opacity: 0.45;
  cursor:  not-allowed;
  pointer-events: none;
}
.tab--covered        { color: var(--white-dim); border-color: transparent; opacity: 0.5; }
.tab--covered.active { opacity: 0.75; }
.tab--tscovered      { color: var(--white-dim); border-color: transparent; opacity: 0.35; pointer-events: none; }

/* ------------------------------------------------------------
   Main Content Area
   ------------------------------------------------------------ */
.main-content {
  padding-top: calc(var(--header-h) + var(--tabs-h) + 2rem);
  padding-left:  2rem;
  padding-right: 2rem;
  padding-bottom: 4rem;
  width:         100%;
  max-width:     1200px;
  margin:        0 auto;
}

.main-content--no-tabs {
  padding-top: calc(var(--header-h) + 2rem);
}

.page-title {
  font-size:      2rem;
  font-weight:    300;
  letter-spacing: 0.04em;
  color:          var(--white);
  margin-bottom:  1.75rem;
}
.page-title span { color: var(--gold); }
.page-title__sub {
  font-size:      1rem;
  font-weight:    300;
  color:          var(--text-sec);
  letter-spacing: 0.02em;
}
.page-title--sm { font-size: 1.3rem; }
.page-sub {
  font-size:      var(--text-lg);
  font-weight:    400;
  color:          var(--text-sec);
  margin-bottom:  1.25rem;
  line-height:    1.5;
}
.page-intro {
  font-size:      var(--text-base);
  color:          var(--text-sec);
  line-height:    1.7;
  margin-bottom:  0.75rem;
}
.page-intro:last-of-type { margin-bottom: 2rem; }

/* ------------------------------------------------------------
   Card Grid (catalog view)
   ------------------------------------------------------------ */
.card-grid {
  display:               grid;
  grid-template-columns: repeat(5, 1fr);
  gap:                   1.5rem;
}

.card {
  background:  var(--surface);
  border:      1px solid var(--border);
  overflow:    hidden;
  transition:  border-color var(--transition), box-shadow var(--transition);
  cursor:      pointer;
}
.card:hover {
  border-color: var(--white-faint);
}
.card.picked {
  border-color: var(--gold);
  box-shadow:   0 0 0 1px var(--gold);
}
.card.disabled {
  opacity: 0.3;
  pointer-events: none;
}

.card-img {
  width:           100%;
  aspect-ratio:    3 / 4;
  object-fit:      cover;
  background:      var(--surface-2);
  display:         flex;
  align-items:     center;
  justify-content: center;
}
.card-img.is-placeholder {
  /* when used as a div placeholder */
  width:           100%;
  aspect-ratio:    3 / 4;
  background:      var(--surface-2);
  display:         flex;
  align-items:     center;
  justify-content: center;
}

.no-img {
  color:          var(--white-faint);
  font-size:      0.72rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

/* Thumbnail-Proportionen — global verwendbar */
.ratio-square   { aspect-ratio: 1 / 1; }
.ratio-portrait { aspect-ratio: 3 / 4; }
.ratio-original { aspect-ratio: unset; object-fit: contain; }

.card-body {
  padding: 0.875rem 1rem 1rem;
}

.card-code {
  font-size:      var(--text-xs);
  color:          var(--text-sec);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom:  0.25rem;
}

.card-name {
  font-size:     var(--text-base);
  color:         var(--white);
  margin-bottom: 0.75rem;
  line-height:   1.3;
  min-height:    calc(2 * 1.3 * var(--text-base));
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}

.card-meta {
  font-size:     var(--text-sm);
  color:         var(--white-faint);
  margin-bottom: 0.75rem;
  line-height:   1.4;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}

/* ============================================================
   BUTTONS
   Base: .btn
   Color:   -primary | -outline | -ghost | -danger | -clear
   Size:    -sm | -lg | -block
   Special: -pick | -slot | -live
   ============================================================ */

.btn {
  display:         inline-block;
  padding:         0.5rem 1.25rem;
  border:          none;
  color:           var(--text-sec);
  font-size:       var(--text-ui);
  letter-spacing:  0.02em;
  text-transform:  none;
  cursor:          pointer;
  background:      var(--surface-2);
  transition:      color var(--transition), background var(--transition), opacity var(--transition);
  text-decoration: none;
  border-radius:   20px;
  font-family:     var(--font-main);
  line-height:     1;
  white-space:     nowrap;
}
.btn:hover    { color: var(--white); }
.btn:disabled { opacity: 0.35; cursor: default; }

/* -- Color Modifier ----------------------------------------- */
.btn-primary       { background: var(--border); color: #888; }
.btn-primary:hover { background: var(--gold); color: #000; opacity: 1; }

.btn-outline       { background: var(--border); color: var(--white-dim); }
.btn-outline:hover { color: var(--white); }

.btn-ghost         { background: transparent; color: var(--white-faint); }
.btn-ghost:hover   { background: var(--surface-2); color: var(--white); }

.btn-danger        { background: var(--red); color: var(--white); }
.btn-danger:hover  { opacity: 0.85; color: var(--white); }

.btn-delete        { background: rgba(220,50,50,0.08); color: var(--red); border: 1px solid rgba(220,50,50,0.25); }
.btn-delete:hover  { background: var(--red); color: var(--white); opacity: 1; }

.btn-clear         { background: transparent; color: var(--white-faint); font-size: 0.7rem; padding: 0.3rem 0.6rem; }
.btn-clear:hover   { color: var(--red); }

/* -- Size Modifier ------------------------------------------ */
.btn-sm    { padding: 0.3rem 0.75rem; font-size: 0.72rem; }
.btn-lg    { padding: 0.75rem 2rem;   font-size: 1rem; }
.btn-block { display: block; width: 100%; text-align: center; }

/* -- Special Modifier --------------------------------------- */

/* Pick — flat dunkelgrau inaktiv, gold aktiv */
.btn-pick         { width: 100%; background: var(--border); color: #888; font-size: 0.72rem; padding: 0.4rem 0.5rem; text-align: center; }
.btn-pick:hover   { background: var(--gold); color: #000; }
.btn-pick.active  { background: var(--gold); color: #000; }

.btn-teal  { background: var(--teal);  color: #fff; }
.btn-teal:hover  { opacity: 0.85; color: #fff; }
.btn-hover-teal:hover  { background: var(--teal); color: #fff; opacity: 1; }
.btn-pink  { background: var(--pink);  color: #fff; }
.btn-pink:hover  { opacity: 0.85; color: #fff; }
.btn-green { background: var(--green); color: #000; }
.btn-green:hover { opacity: 0.85; color: #000; }

/* Slot + Live → studio.php entfernt, nicht mehr benötigt */

/* ------------------------------------------------------------
   List View (alternative to card grid)
   ------------------------------------------------------------ */
.list-view {
  display:        flex;
  flex-direction: column;
  gap:            0;
}

.list-item {
  display:     flex;
  align-items: center;
  gap:         1rem;
  padding:     0.75rem 0.5rem;
  border-bottom: 1px solid var(--border);
  cursor:      pointer;
  transition:  background var(--transition), border-left-color var(--transition);
  border-left: 3px solid transparent;
}
.list-item:hover {
  background: rgba(255,255,255,0.02);
}
.list-item.picked {
  border-left-color: var(--gold);
  padding-left:      calc(0.5rem - 0px); /* border already counted in element */
}

.list-thumb {
  width:      60px;
  height:     80px;
  object-fit: cover;
  background: var(--surface-2);
  flex-shrink: 0;
}
.list-thumb.no-img-thumb {
  width:           60px;
  height:          80px;
  background:      var(--surface-2);
  flex-shrink:     0;
  display:         flex;
  align-items:     center;
  justify-content: center;
}

.list-info {
  flex: 1;
  min-width: 0;
}

.list-code {
  font-size:      0.68rem;
  color:          var(--text-sec);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom:  0.2rem;
}

.list-name {
  font-size:  0.88rem;
  color:      var(--white);
  white-space: nowrap;
  overflow:   hidden;
  text-overflow: ellipsis;
}

.list-meta {
  font-size: 0.75rem;
  color:     var(--white-faint);
  margin-top: 0.15rem;
}

.list-pick-btn {
  margin-left: auto;
  flex-shrink: 0;
}

/* View toggle */
.view-toggle {
  display:   flex;
  gap:       0.25rem;
  align-items: center;
}
.view-toggle-btn {
  background:  transparent;
  border:      1px solid var(--border);
  color:       var(--white-faint);
  padding:     0.3rem 0.5rem;
  cursor:      pointer;
  font-size:   0.8rem;
  transition:  all var(--transition);
  border-radius: var(--radius);
}
.view-toggle-btn.active,
.view-toggle-btn:hover {
  border-color: var(--gold-dim);
  color:        var(--gold);
}

/* ------------------------------------------------------------
   Toolbar (above grid/list — search, sort, filters)
   ------------------------------------------------------------ */
.toolbar {
  display:       flex;
  align-items:   center;
  gap:           1rem;
  margin-bottom: 1.5rem;
  flex-wrap:     wrap;
}

.toolbar-left  { display: flex; align-items: center; gap: 0.75rem; flex: 1; min-width: 0; }
.toolbar-right { display: flex; align-items: center; gap: 0.75rem; flex-shrink: 0; }

.search-input {
  background:   var(--surface-2);
  border:       1px solid var(--border);
  color:        var(--white);
  padding:      0.45rem 0.875rem;
  font-size:    0.85rem;
  font-family:  var(--font-main);
  width:        260px;
  border-radius: var(--radius);
  transition:   border-color var(--transition);
}
.search-input:focus {
  outline:      none;
  border-color: var(--gold-dim);
}
.search-input::placeholder { color: var(--white-faint); }

.filter-select {
  background:    var(--surface-2);
  border:        1px solid var(--border);
  color:         var(--white-dim);
  padding:       0.45rem 0.875rem;
  font-size:     0.82rem;
  font-family:   var(--font-main);
  border-radius: var(--radius);
  cursor:        pointer;
  transition:    border-color var(--transition);
}
.filter-select:focus {
  outline:      none;
  border-color: var(--gold-dim);
}

/* ------------------------------------------------------------
   Detail View
   ------------------------------------------------------------ */
.detail-header {
  display:               grid;
  grid-template-columns: 1fr 1fr;
  gap:                   3rem;
  margin-bottom:         3rem;
  align-items:           start;
}

.detail-images {
  display:               grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap:                   1rem;
}

.detail-image-slot {
  position: relative;
}
.detail-image-slot img {
  width:      100%;
  aspect-ratio: 3/4;
  object-fit: cover;
  background: var(--surface-2);
}
.detail-image-slot .slot-label {
  position:  absolute;
  bottom:    0;
  left:      0;
  right:     0;
  background: rgba(0,0,0,0.7);
  color:      var(--white-faint);
  font-size:  0.65rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding:    0.25rem 0.4rem;
}

.detail-info {
  display:        flex;
  flex-direction: column;
  gap:            1.5rem;
}

.detail-label {
  font-size:      0.7rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color:          var(--white-faint);
  margin-bottom:  0.3rem;
}

.detail-value {
  font-size:   0.9rem;
  color:       var(--white);
  line-height: 1.5;
}

.detail-pick-btn {
  padding:    1rem 3rem;
  font-size:  1rem;
  width:      100%;
  text-align: center;
  margin-top: 0.5rem;
}

/* ------------------------------------------------------------
   Snippet Box
   ------------------------------------------------------------ */
.snippet-box {
  background:  var(--surface-2);
  border:      1px solid var(--border);
  padding:     1.25rem;
  font-family: var(--font-mono);
  font-size:   0.8rem;
  line-height: 1.7;
  color:       var(--white-dim);
  white-space: pre-wrap;
  word-break:  break-word;
}

.snippet-copy-btn {
  font-size:   0.7rem;
  margin-top:  0.5rem;
}

/* ------------------------------------------------------------
   Form Elements
   ------------------------------------------------------------ */
.form-group {
  margin-bottom: 1.25rem;
}

.form-label {
  display:        block;
  font-size:      0.72rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color:          var(--white-faint);
  margin-bottom:  0.4rem;
}
.form-label .required {
  color: var(--gold);
  margin-left: 0.25rem;
}

.form-input,
.form-select,
.form-textarea {
  width:        100%;
  background:   var(--surface-2);
  border:       1px solid var(--border);
  color:        var(--white);
  padding:      0.6rem 0.75rem;
  font-size:    0.88rem;
  font-family:  var(--font-main);
  border-radius: var(--radius);
  transition:   border-color var(--transition);
  appearance:   none;
}
.form-input:focus,
.form-select:focus,
.form-textarea:focus {
  outline:      none;
  border-color: var(--gold-dim);
}
.form-input::placeholder,
.form-textarea::placeholder { color: var(--white-faint); }

.form-textarea {
  resize:     vertical;
  min-height: 100px;
}

.form-select {
  cursor:            pointer;
  background-image:  url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23555' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.75rem center;
  padding-right:     2.5rem;
}
.form-select option {
  background: var(--surface-2);
  color:      var(--white);
}

.form-hint {
  font-size:   0.72rem;
  color:       var(--white-faint);
  margin-top:  0.3rem;
  line-height: 1.4;
}

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}
.form-row-3 {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 1rem;
}

/* ------------------------------------------------------------
   Tag Cloud & Tag Chips
   ------------------------------------------------------------ */
.tag-cloud {
  display:       flex;
  flex-wrap:     wrap;
  gap:           0.4rem;
  margin-bottom: 0.5rem;
}

.tag-cloud-label {
  font-size:      0.68rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color:          var(--white-faint);
  margin-bottom:  0.4rem;
}

.tag-chip {
  padding:        0.22rem 0.6rem;
  border:         1px solid var(--border);
  color:          var(--white-faint);
  font-size:      0.72rem;
  cursor:         pointer;
  border-radius:  999px;
  background:     transparent;
  font-family:    var(--font-main);
  transition:     border-color var(--transition), color var(--transition), background var(--transition);
  user-select:    none;
}
.tag-chip:hover {
  border-color: var(--gold-dim);
  color:        var(--gold);
}
.tag-chip.active {
  background:   rgba(201,168,76,0.12);
  border-color: var(--gold-dim);
  color:        var(--gold);
}
.tag-chip--shot { border-color: var(--border); color: var(--white-faint); }
.tag-chip--shot.active { background: var(--gold-dim); border-color: var(--gold-dark); color: var(--gold-light); }

/* ------------------------------------------------------------
   Shot Section (briefing shot types)
   ------------------------------------------------------------ */
.shot-section {
  background:    var(--surface);
  border:        1px solid var(--border);
  padding:       1.25rem;
  margin-bottom: 1rem;
}

.shot-section-header {
  display:       flex;
  align-items:   center;
  gap:           1rem;
  margin-bottom: 0.75rem;
}

.shot-section-title {
  font-size:      0.78rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color:          var(--white-dim);
}

.shot-count-input {
  width:        60px;
  background:   var(--surface-2);
  border:       1px solid var(--border);
  color:        var(--white);
  padding:      0.35rem 0.5rem;
  font-size:    0.88rem;
  font-family:  var(--font-main);
  text-align:   center;
  border-radius: var(--radius);
  transition:   border-color var(--transition);
}
.shot-count-input:focus {
  outline:      none;
  border-color: var(--gold-dim);
}

.shot-detail {
  display: none; /* shown by JS when count > 0 */
  margin-top: 0.75rem;
}
.shot-detail.visible { display: block; }

/* ------------------------------------------------------------
   Recce / Pola Toggle
   ------------------------------------------------------------ */
.recce-toggle {
  display:   flex;
  gap:       0.5rem;
  align-items: center;
}

.toggle-btn {
  padding:        0.35rem 0.875rem;
  border:         1px solid var(--border);
  color:          var(--white-faint);
  font-size:      0.78rem;
  letter-spacing: 0.06em;
  cursor:         pointer;
  background:     transparent;
  font-family:    var(--font-main);
  border-radius:  999px;
  transition:     all var(--transition);
}
.toggle-btn:hover {
  border-color: var(--white-faint);
  color:        var(--white);
}
.toggle-btn.active {
  background:   var(--gold);
  color:        var(--black);
  border-color: var(--gold);
}

/* Segmented Toggle (Look-Filter) */
.lft-btn { padding: 0.3rem 0.85rem; font-size: 0.7rem; letter-spacing: 0.06em; background: var(--border); border: none; border-radius: 999px; color: #888; cursor: pointer; transition: background 0.12s, color 0.12s; white-space: nowrap; }
.lft-btn + .lft-btn { border-left: none; }
.lft-btn.active { background: var(--gold); color: var(--black); font-weight: 500; }
.lft-btn:hover:not(.active) { color: var(--white-dim); }

.recce-context {
  display: none;
  margin-top: 0.75rem;
}
.recce-context.visible { display: block; }

/* ------------------------------------------------------------
   Alerts
   ------------------------------------------------------------ */
.alert {
  padding:       0.75rem 1rem;
  margin-bottom: 1rem;
  font-size:     0.85rem;
  border-radius: var(--radius);
  line-height:   1.5;
}

.alert-success {
  background: #1a2e1a;
  border:     1px solid var(--green);
  color:      #66cc66;
}

.alert-error {
  background: #2e1a1a;
  border:     1px solid var(--red);
  color:      #cc6666;
}

.alert-warning {
  background: #2a2a1a;
  border:     1px solid #666622;
  color:      #aaaa44;
}

.alert-info {
  background: #1a1f2e;
  border:     1px solid #2d4a6a;
  color:      #6699cc;
}

/* ------------------------------------------------------------
   Badge System
   Basis: .badge  ·  Größe: .badge--sm .badge--xs
   Farbe: .badge-gold/teal/pink/orange/green/red/muted
   Overlay (auf Thumbnails): .mas-badge .lora-badge
   ------------------------------------------------------------ */

/* Gemeinsame Basis aller Badge-Typen */
.badge, .status-badge, .sched-badge, .ts-card-typ {
  display:        inline-flex;
  align-items:    center;
  font-weight:    500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border:         1px solid transparent;
  border-radius:  6px;
  white-space:    nowrap;
  vertical-align: middle;
}

/* Größen */
.badge        { font-size: 11px;    padding: 3px 10px; }
.status-badge { font-size: 12px;    padding: 3px 10px; }
.sched-badge  { font-size: 0.62rem; padding: 2px 6px;  font-weight: 700; }
.ts-card-typ  { font-size: 0.58rem; padding: 0.15em 0.5em; }

/* Status-Badge Default + States */
.status-badge                { background: var(--surface);     color: var(--white-dim);    border-color: var(--border); }
.status-badge.processing     { background: var(--orange-dim);  color: var(--orange);       border-color: var(--orange); }
.status-badge.complete       { background: var(--green-dim);   color: var(--green);        border-color: var(--green); }
.status-badge.error          { background: var(--red-dim);     color: var(--red);          border-color: var(--red); }

/* Status-Approved / Draft */
.status-approved { background: var(--teal-dim);   color: var(--teal-light);  border-color: var(--teal-dark); }
.status-draft    { background: #2a2a1a;            color: #aaaa44;            border: 1px solid #666622; }

/* Overlay-Badges (absolut auf Thumbnails) */
.mas-badge, .lora-badge {
  position: absolute; top: 5px; right: 5px;
  display: inline-flex; align-items: center;
  font-size: 0.6rem; font-weight: 700;
  letter-spacing: 0.09em; text-transform: uppercase;
  border-radius: 4px;
  white-space: nowrap;
  font-family: var(--mono);
  cursor: default;
}
.mas-badge  { background: rgba(8,126,127,0.85); backdrop-filter: blur(4px); border: 1px solid rgba(10,166,167,0.5); color: #fff; padding: 2px 6px; }
.lora-badge { background: var(--gold); border: none; color: var(--black); padding: 2px 5px; }
.sitz-badge {
  position: absolute; bottom: 5px; right: 5px;
  display: inline-flex; align-items: center; justify-content: center;
  width: 20px; height: 20px;
  background: rgba(30,18,6,0.82); backdrop-filter: blur(4px);
  border: 1px solid rgba(180,120,40,0.5);
  border-radius: 4px;
  color: #c98a30;
  cursor: default;
}

/* Header ← Builder Link */
.site-header-right a.btn-clear {
  background:   #0a1112;
  color:        #0aa6a7;
  border:       1px solid #055859;
  border-radius: var(--radius);
}
.site-header-right a.btn-clear:hover {
  background:   #0c1a1b;
  border-color: #0aa6a7;
  color:        #0aa6a7;
}

/* ------------------------------------------------------------
   Admin Layout
   ------------------------------------------------------------ */
.admin-wrap {
  max-width:   960px;
  margin:      0 auto;
  padding:     2rem;
  padding-top: calc(var(--header-h) + 2rem);
}

.admin-header {
  display:         flex;
  justify-content: space-between;
  align-items:     center;
  margin-bottom:   2rem;
  padding-bottom:  1rem;
  border-bottom:   1px solid var(--border);
}

.admin-title {
  font-size:      1.4rem;
  font-weight:    300;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color:          var(--white);
}
.admin-title span { color: var(--gold); }

.admin-actions {
  display:     flex;
  align-items: center;
  gap:         0.75rem;
}

/* Admin table */
.admin-table {
  width:           100%;
  border-collapse: collapse;
  font-size:       0.85rem;
}
.admin-table th {
  text-align:     left;
  padding:        0.6rem 1rem;
  font-size:      0.7rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color:          var(--white-faint);
  border-bottom:  1px solid var(--border);
  font-weight:    400;
}
.admin-table td {
  padding:       0.75rem 1rem;
  border-bottom: 1px solid var(--border);
  color:         var(--white-dim);
  vertical-align: middle;
}
.admin-table tr:hover td {
  background: rgba(255,255,255,0.015);
}
.admin-table td:first-child { color: var(--white); }

/* Admin form card */
.admin-form-card {
  background:    var(--surface);
  border:        1px solid var(--border);
  padding:       2rem;
  margin-bottom: 2rem;
}
.admin-form-card + .admin-form-card {
  margin-top: 1.5rem;
}

.admin-section-title {
  font-size:      0.72rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color:          var(--text-sec);
  margin-bottom:  1.25rem;
  padding-bottom: 0.5rem;
  border-bottom:  1px solid var(--border);
}

/* ------------------------------------------------------------
   Briefing Summary (briefing page)
   ------------------------------------------------------------ */
.briefing-summary {
  display:        flex;
  flex-direction: column;
  gap:            2rem;
}

.briefing-section {
  background: var(--surface);
  border:     1px solid var(--border);
  padding:    1.5rem;
}

.briefing-section-title {
  font-size:      0.72rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color:          var(--text-sec);
  margin-bottom:  1rem;
  padding-bottom: 0.5rem;
  border-bottom:  1px solid var(--border);
}

.picked-item-row {
  display:       flex;
  align-items:   center;
  gap:           1rem;
  padding:       0.5rem 0;
  border-bottom: 1px solid var(--border);
}
.picked-item-row:last-child { border-bottom: none; }

.picked-item-thumb {
  width:      48px;
  height:     64px;
  object-fit: cover;
  background: var(--surface-2);
  flex-shrink: 0;
}

.picked-item-info {
  flex: 1;
  min-width: 0;
}
.picked-item-code {
  font-size:      0.65rem;
  color:          var(--text-sec);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.picked-item-name {
  font-size:  0.88rem;
  color:      var(--white);
}

.picked-item-remove {
  margin-left:  auto;
  flex-shrink:  0;
  background:   transparent;
  border:       none;
  color:        var(--white-faint);
  font-size:    1rem;
  cursor:       pointer;
  padding:      0.25rem 0.4rem;
  line-height:  1;
  transition:   color var(--transition);
}
.picked-item-remove:hover { color: var(--red); }

.briefing-empty {
  color:     var(--white-faint);
  font-size: 0.82rem;
  font-style: italic;
}

/* Briefing export / print area */
.briefing-output {
  background:  var(--surface-2);
  border:      1px solid var(--border);
  padding:     2rem;
  font-family: var(--font-mono);
  font-size:   0.8rem;
  line-height: 1.8;
  color:       var(--white-dim);
  white-space: pre-wrap;
  word-break:  break-word;
  margin-top:  1.5rem;
}

/* ------------------------------------------------------------
   Divider
   ------------------------------------------------------------ */
.divider {
  border:        none;
  border-top:    1px solid var(--border);
  margin:        2rem 0;
}

/* ------------------------------------------------------------
   Utilities
   ------------------------------------------------------------ */
.text-gold      { color: var(--gold); }
.text-dim       { color: var(--white-dim); }
.text-faint     { color: var(--white-faint); }
.text-sm        { font-size: 0.82rem; }
.text-xs        { font-size: 0.72rem; }
.text-upper     { text-transform: uppercase; letter-spacing: 0.08em; }
.text-mono      { font-family: var(--font-mono); }
.text-center    { text-align: center; }
.mt-1  { margin-top: 0.5rem; }
.mt-2  { margin-top: 1rem; }
.mt-3  { margin-top: 1.5rem; }
.mt-4  { margin-top: 2rem; }
.mb-1  { margin-bottom: 0.5rem; }
.mb-2  { margin-bottom: 1rem; }
.mb-3  { margin-bottom: 1.5rem; }
.mb-4  { margin-bottom: 2rem; }
.flex  { display: flex; }
.flex-center { display: flex; align-items: center; justify-content: center; }
.gap-1 { gap: 0.5rem; }
.gap-2 { gap: 1rem; }
.gap-3 { gap: 1.5rem; }
.flex-between { display: flex; align-items: center; justify-content: space-between; }
.flex-1 { flex: 1; }
.hidden { display: none !important; }
.sr-only {
  position: absolute;
  width:    1px;
  height:   1px;
  overflow: hidden;
  clip:     rect(0,0,0,0);
}

/* ------------------------------------------------------------
   Scrollbar (webkit)
   ------------------------------------------------------------ */
::-webkit-scrollbar        { width: 6px; height: 6px; }
::-webkit-scrollbar-track  { background: var(--black); }
::-webkit-scrollbar-thumb  { background: var(--border); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--white-faint); }

/* ------------------------------------------------------------
   Hamburger Button (mobile only)
   ------------------------------------------------------------ */
.nav-hamburger {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 6px;
  margin-left: auto;
  flex-shrink: 0;
}
.nav-hamburger span {
  display: block;
  width: 22px;
  height: 2px;
  background: #888;
  border-radius: 1px; /* progress bar — intentionally sharp */
  transition: transform 0.2s, opacity 0.2s, background 0.2s;
}
.nav-hamburger:hover span,
.nav-hamburger.is-open span { background: var(--white); }
.nav-hamburger.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-hamburger.is-open span:nth-child(2) { opacity: 0; }
.nav-hamburger.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ------------------------------------------------------------
   Responsive
   ------------------------------------------------------------ */
@media (max-width: 1024px) {
  .card-grid {
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  }
}

@media (max-width: 768px) {
  .main-content {
    padding-left:  1rem;
    padding-right: 1rem;
  }

  .card-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 0.75rem;
  }

  .detail-header {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }

  .form-row,
  .form-row-3 {
    grid-template-columns: 1fr;
  }

  .site-header {
    padding: 0 1rem;
  }
  .nav-hamburger {
    display: flex;
  }
  .site-header-left {
    flex: 1;
  }

  .site-nav {
    display: none;
    position: fixed;
    top: var(--header-h);
    left: 0; right: 0;
    background: linear-gradient(135deg, #0a1112, #0c1416);
    border-bottom: 1px solid #1a2a2c;
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
    padding: 0.5rem 0 1rem;
    z-index: 99;
  }
  .site-nav.mobile-open {
    display: flex;
  }
  .site-nav a,
  .site-nav .nsfw-toggle {
    padding: 0.75rem 1.5rem !important;
    width: 100%;
    margin-left: 0 !important;
    font-size: 1rem !important;
    line-height: 1.5 !important;
    align-self: auto !important;
    border-bottom: 1px solid rgba(255,255,255,0.05);
  }
  #sys-live-badge {
    padding: 0.75rem 1.5rem !important;
    margin-left: 0 !important;
    align-self: auto !important;
    line-height: 1.5 !important;
  }

  .admin-wrap {
    padding: 1rem;
  }

  .admin-header {
    flex-direction: column;
    align-items:   flex-start;
    gap:           1rem;
  }

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

  .search-input {
    width: 100%;
  }

  .briefing-section {
    padding: 1rem;
  }

  .tabs {
    padding-left: 0.5rem;
  }
}

@media (max-width: 480px) {
  .card-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .detail-images {
    grid-template-columns: 1fr 1fr;
  }
}

/* ------------------------------------------------------------
   Print
   ------------------------------------------------------------ */
@media print {
  .site-header,
  .tabs,
  .toolbar,
  .btn-pick,
  .briefing-btn { display: none !important; }

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

  body {
    background: #fff;
    color:      #000;
  }

  .briefing-output,
  .snippet-box {
    border:     1px solid #ccc;
    background: #f9f9f9;
    color:      #333;
  }
}

/* ============================================================
   LUMIZED — Shared Page Components
   Genutzt von: brief, order, session, job, coins
   ============================================================ */

/* ── Simple-Page Header ───────────────────────────────────── */
.site-header-title { font-size: 14px; font-weight: 400; color: var(--white-dim); letter-spacing: 0.04em; }

/* ── Page Shell ───────────────────────────────────────────── */
.lp-full,
.lp-wide,
.lp-mid,
.lp-editorial,
.page {
  width:   100%;
  margin:  0 auto;
  padding: calc(var(--header-h) + 28px) 2rem 80px;
}
.lp-full { max-width: 100%; }
.lp-wide { max-width: 1200px; }
.lp-mid,
.page    { max-width: 760px; }

/* ── Editorial-Layout: App (links 780px) + Sidebar (rechts) ── */
.lp-editorial {
  max-width:   1200px;
  display:     grid;
  grid-template-columns: 780px 1fr;
  gap:         2rem;
  align-items: start;
}
.lp-editorial__main    { min-width: 0; }
.lp-editorial__sidebar { min-width: 0; padding-top: 13px; }
@media (max-width: 960px) {
  .lp-editorial { grid-template-columns: 1fr; }
  .lp-editorial__sidebar { display: none; }
}

/* ── Page Header (inline, z.B. Kunden-Name in job.php) ───── */
.page-header {
  display:         flex;
  align-items:     flex-start;
  justify-content: space-between;
  padding-bottom:  20px;
  border-bottom:   1px solid var(--border);
  margin-bottom:   28px;
  gap:             16px;
}
.page-header__left h1    { font-size: 20px; font-weight: 600; color: var(--white); margin-bottom: 4px; }
.page-header__left .subtitle { font-size: 12px; color: var(--white-dim); }
.page-header__right      { text-align: right; flex-shrink: 0; }

/* ── Back-Link ────────────────────────────────────────────── */
.back-link { font-size: 13px; color: var(--white-dim); text-decoration: none; transition: color var(--transition); }
.back-link:hover { color: var(--white); }

/* ── System-Status Dot ────────────────────────────────────── */
.sys-status { display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--white-dim); }
.sys-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--border); transition: background 0.3s; flex-shrink: 0; }
.sys-dot.online  { background: var(--green); }
.sys-dot.busy    { background: var(--orange); }
.sys-dot.offline { background: var(--red); }

/* ── Content Card (body.lp scoped) ───────────────────────── */
body.lp .card         { padding: 24px; margin-bottom: 14px; cursor: default; overflow: visible; }
body.lp .card--tight  { padding: 16px 20px; }
body.lp .card--dark   { background: #111; }
.card-label          { font-size: 1rem; font-weight: 500; letter-spacing: 0; text-transform: none; color: var(--white-dim); margin-bottom: 0.9rem; }
.card-label--teal    { color: var(--teal-light); }
.card-title  { font-size: 18px; font-weight: 600; color: var(--white); margin-bottom: 6px; }
.card-sub    { font-size: 13px; color: var(--white-dim); line-height: 1.6; }


/* ── Badge Farb-Modifier (alle Badge-Typen) ───────────────── */
.badge-gold   { background: var(--gold-dim);   color: var(--gold-light);  border-color: var(--gold-dark); }
.badge-teal   { background: var(--teal-dim);   color: var(--teal-light);  border-color: var(--teal-dark); }
.badge-pink   { background: var(--pink-dim);   color: var(--pink-light);  border-color: var(--pink-dark); }
.badge-green  { background: var(--green-dim);  color: var(--green);       border-color: #1a4a2a; }
.badge-red    { background: var(--red-dim);    color: var(--red);         border-color: #4a1010; }
.badge-orange { background: var(--orange-dim); color: var(--orange);      border-color: #4a3010; }
.badge-muted  { background: var(--surface);    color: var(--white-dim);   border-color: var(--border); }

/* ── Chips ────────────────────────────────────────────────── */
.chip { display: inline-block; background: var(--surface); border: 1px solid var(--border); border-radius: 999px; padding: 5px 12px; font-family: var(--font-main); font-size: 12px; color: var(--white-dim); cursor: pointer; transition: color var(--transition), border-color var(--transition), background var(--transition); }
.chip:hover       { color: var(--white); border-color: #444; }
.chip.active      { color: var(--teal-light); border-color: var(--teal); background: var(--teal-dim); }
.chip.active-gold { color: var(--gold-light); border-color: var(--gold); background: var(--gold-dim); }
.chip.active-pink { color: var(--pink-light); border-color: var(--pink); background: var(--pink-dim); }

/* ── Inputs ───────────────────────────────────────────────── */
.input { width: 100%; background: #111; border: 1px solid var(--border); border-radius: var(--radius); color: var(--white); font-family: var(--font-main); font-size: 14px; padding: 10px 12px; outline: none; transition: border-color var(--transition); margin-bottom: 8px; }
.input:focus     { border-color: var(--gold); }
.input.error     { border-color: var(--red); }
.input--mono     { font-family: var(--font-mono); letter-spacing: 1px; text-transform: uppercase; }
.input--textarea { height: 220px; resize: vertical; line-height: 1.6; }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.checkbox-label { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--white-dim); margin-top: 4px; cursor: pointer; }
.checkbox-label input[type="checkbox"] { width: 16px; height: 16px; margin: 0; accent-color: var(--gold); cursor: pointer; }

/* ── Parse Error ──────────────────────────────────────────── */
.parse-error { color: var(--red); font-size: 12px; margin-top: 6px; min-height: 18px; }

/* ── Summary Rows ─────────────────────────────────────────── */
.summary-row { display: flex; justify-content: space-between; align-items: center; padding: 8px 0; border-bottom: 1px solid var(--border); font-size: 13px; }
.summary-row:last-child { border-bottom: none; }
.summary-key   { color: var(--white-dim); }
.summary-value { font-weight: 500; }

/* ── Type-Cards (Job-Typ Auswahl) ─────────────────────────── */
.type-card { flex: 1; background: var(--black); border: 1px solid var(--border); border-radius: var(--radius-card); padding: 16px; cursor: pointer; transition: border-color var(--transition), box-shadow var(--transition); }
.type-card:hover          { border-color: var(--white-dim); }
.type-card.selected       { border-color: var(--gold); }
.type-card.disabled       { opacity: 0.4; cursor: default; pointer-events: none; }
.type-card__title { font-size: 14px; font-weight: 500; margin-bottom: 4px; }
.type-card__sub   { font-size: 12px; color: var(--white-dim); line-height: 1.4; }
.type-card__dur   { font-size: 12px; color: var(--gold); margin-top: 8px; font-weight: 500; }

/* Live — Teal */
.job-type-row .type-card--live.selected {
  background: linear-gradient(135deg, #010e0e, #022c2c) !important;
  border-color: var(--teal-dark) !important;
}
.type-card--live.selected .type-card__dur { color: var(--teal-light); }

/* Slot — Gold */
.job-type-row .type-card--slot.selected {
  background: linear-gradient(135deg, #0a0600, #1a1000) !important;
  border-color: var(--gold) !important;
}
.type-card--slot.selected .type-card__dur { color: var(--gold); }

/* .status-badge → konsolidiert im Badge System Block oben */

/* ── Toggle Switch ────────────────────────────────────────── */
.toggle-switch { position: relative; display: inline-block; width: 46px; height: 26px; flex-shrink: 0; }
.toggle-switch input { display: none; }
.toggle-slider { position: absolute; inset: 0; background: #333; border-radius: 26px; cursor: pointer; transition: background var(--transition); }
.toggle-slider::before { content: ''; position: absolute; width: 20px; height: 20px; left: 3px; top: 3px; background: #fff; border-radius: 50%; transition: transform var(--transition); }
.toggle-switch input:checked + .toggle-slider { background: var(--green); }
.toggle-switch input:checked + .toggle-slider::before { transform: translateX(20px); }

/* ── Settings Card — Blueprint für Einstellungs-Bereiche ─── */
.settings-card        { margin-top: 1rem; }
.settings-card__title { /* deprecated → .card-label */ font-size: 1rem; font-weight: 500; letter-spacing: 0; text-transform: none; color: var(--text-sec); margin-bottom: 0.9rem; }
.chips-simple .tag-chip:not(.active) { display: none; }
.settings-grid        { display: grid; grid-template-columns: 3fr 2fr; gap: 1rem 1.5rem; align-items: start; }
.settings-label       { font-size: var(--text-sm); color: var(--text-sec); margin-bottom: 0.4rem; }
.settings-toggle-row  { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 0.55rem 0; border-bottom: 1px solid var(--border); }
.settings-toggle-row:last-child { border-bottom: none; padding-bottom: 0; }
.settings-toggle-info { flex: 1; }
.settings-hint        { font-size: var(--text-xs); color: var(--text-sec); margin-top: 2px; }
.settings-summary     { font-size: var(--text-sm); color: var(--gold); margin-top: 0.75rem; letter-spacing: 0.02em; }

.format-chips { display: flex; flex-wrap: wrap; gap: 8px; }
.format-chip  { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 3px; padding: 6px 7px; min-width: 42px; background: var(--surface-2); border: 1px solid var(--border); border-radius: var(--radius-card); cursor: pointer; color: var(--text-sec); font-size: 10px; font-weight: 500; letter-spacing: 0.04em; transition: border-color var(--transition), color var(--transition), background var(--transition); }
.format-chip:hover  { border-color: var(--gold-dark); color: var(--white); }
.format-chip.active { border-color: var(--gold); color: var(--gold); background: var(--gold-dim); }
.format-chip svg    { opacity: 0.6; transition: opacity var(--transition); }
.format-chip.active svg, .format-chip:hover svg { opacity: 1; }

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

/* ── Mode-Toggle ──────────────────────────────────────────── */
.mode-toggle { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 20px; }
.mode-btn { background: var(--black); border: 1px solid var(--border); border-radius: 999px; padding: 7px 14px; font-family: var(--font-main); font-size: 13px; color: var(--white-dim); cursor: pointer; transition: color var(--transition), border-color var(--transition); }
.mode-btn:hover:not(:disabled) { color: var(--white); }
.mode-btn.active   { color: var(--gold); border-color: var(--gold); }
.mode-btn:disabled { opacity: 0.35; cursor: default; }

/* ── Coin Section ─────────────────────────────────────────── */
.coin-section { margin-top: 18px; padding-top: 16px; border-top: 1px solid var(--border); }
.coin-input-row { display: flex; gap: 8px; align-items: center; margin-bottom: 0; }
.coin-input-row .input { flex: 1; margin-bottom: 0; }
.coin-info { margin-top: 12px; background: #111; border: 1px solid var(--border); border-radius: var(--radius); padding: 12px 14px; }
.coin-row { display: flex; justify-content: space-between; font-size: 13px; padding: 3px 0; }
.coin-row__label { color: var(--white-dim); }
.coin-row__val   { font-weight: 500; }
.coin-row--total { border-top: 1px solid var(--border); margin-top: 6px; padding-top: 8px; }
.coin-row--total .coin-row__val       { color: var(--gold); }
.coin-row--insufficient .coin-row__val { color: var(--red); }
.coin-shop { margin-top: 14px; }
.coin-shop-hint { font-size: 12px; color: var(--white-dim); margin-bottom: 10px; }
.coin-shop-hint.warn { color: var(--red); }
.coin-packages { display: flex; gap: 8px; }
.coin-pkg { flex: 1; display: block; text-align: center; text-decoration: none; background: #111; border: 1px solid var(--border); border-radius: var(--radius); padding: 10px 8px; transition: border-color var(--transition); }
.coin-pkg:hover         { border-color: var(--gold); color: inherit; }
.coin-pkg__coins { font-size: 13px; font-weight: 600; color: var(--gold); display: block; }
.coin-pkg__price { font-size: 12px; color: var(--white-dim); display: block; margin-top: 2px; }

/* ── Lightbox ─────────────────────────────────────────────── */
.lb-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.92); z-index: 1000; align-items: center; justify-content: center; padding-top: var(--header-h); box-sizing: border-box; }
.lb-overlay.open { display: flex; }
.lb-img  { max-width: min(90vw, 800px); max-height: calc(100vh - var(--header-h) - 2rem); object-fit: contain; border-radius: var(--radius); display: block; }
.lb-close { position: fixed; top: 18px; right: 22px; font-size: 28px; line-height: 1; color: var(--white-dim); cursor: pointer; background: none; border: none; transition: color var(--transition); z-index: 10; }
.lb-close:hover { color: var(--white); }
.lb-nav  { position: fixed; top: 50%; transform: translateY(-50%); font-size: 36px; color: var(--white-dim); cursor: pointer; background: none; border: none; padding: 0 16px; transition: color var(--transition); user-select: none; }
.lb-nav:hover { color: var(--white); }
.lb-prev { left: 8px; }
.lb-next { right: 8px; }
.lb-counter { position: fixed; bottom: 20px; left: 50%; transform: translateX(-50%); font-size: 13px; color: var(--white-dim); }

/* ── Image Grid ───────────────────────────────────────────── */
.img-grid    { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 12px; }
.img-grid--sm { grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 10px; }
.thumb { position: relative; border-radius: var(--radius); overflow: hidden; border: 1px solid var(--border); aspect-ratio: 3/4; background: #111; transition: border-color var(--transition); }
.thumb:hover      { border-color: var(--gold); }
.thumb a          { display: block; width: 100%; height: 100%; }
.thumb img        { width: 100%; height: 100%; object-fit: cover; display: block; }
.thumb.locked img { filter: blur(6px); }
.thumb.unlocked   { cursor: pointer; }

/* ── Info-Box ─────────────────────────────────────────────── */
.info-box         { padding: 10px 14px; border-radius: var(--radius); font-size: 13px; border: 1px solid; }
.info-box--gold   { background: var(--gold-dim);   border-color: var(--gold-dark);  color: var(--gold-light); }
.info-box--teal   { background: var(--teal-dim);   border-color: var(--teal-dark);  color: var(--teal-light); }
.info-box--red    { background: var(--red-dim);    border-color: var(--red);        color: var(--red); }
.info-box--orange { background: var(--orange-dim); border-color: var(--orange);     color: var(--orange); }
.info-box--muted  { background: var(--surface);    border-color: var(--border);     color: var(--white-dim); }

/* ── Utilities ────────────────────────────────────────────── */
.hidden           { display: none !important; }
.mt-xs            { margin-top: 8px; }
.mt-sm            { margin-top: 16px; }
.mb-0             { margin-bottom: 0 !important; }
.ml-auto          { margin-left: auto; }
.empty-state      { text-align: center; padding: 3rem; color: var(--white-faint); }
.flex-chips       { display: flex; gap: 0.35rem; flex-wrap: wrap; }
.flex-row-wrap    { display: flex; gap: 1rem; flex-wrap: wrap; }
.grid-2           { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.grid-3           { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.text-placeholder { color: var(--white-faint); font-style: italic; }
.hint-text        { font-size: var(--text-ui); color: var(--white-faint); line-height: 1.6; margin: 0 0 0.75rem; }
/* .btn-lg → im Button-Block oben definiert */
.lora-label       { color: var(--gold-light); font-weight: 600; font-size: 0.7rem; letter-spacing: 0.04em; vertical-align: middle; }
.modal-eyebrow    { font-size: var(--text-sm); letter-spacing: 0.12em; text-transform: uppercase; color: var(--white-faint); transition: opacity 0.4s; }
.conflict-hint    { color: var(--orange); }
.nsfw-toggle      { font-size: 0.65rem; letter-spacing: 0.06em; color: var(--white-faint); text-decoration: none; }
.nsfw-toggle[data-active="1"] { color: var(--pink); }
.text-white       { color: var(--white); }
.text-pink        { color: var(--pink); }
.text-teal        { color: var(--teal-light); }
.text-orange      { color: var(--orange); }
.fw-600           { font-weight: 600; }
.status-dot       { display: inline-block; width: 8px; height: 8px; border-radius: 50%; margin-right: 6px; vertical-align: middle; }
.status-online    { color: var(--teal-light); font-weight: 600; }
.status-offline   { color: var(--pink); font-weight: 600; }
.status-busy      { color: var(--orange); font-weight: 600; }

/* Info-Bar (schmaler Hinweis-Streifen) */
.info-bar         { padding: 0.5rem 1rem; margin-bottom: 1rem; font-size: 0.78rem; letter-spacing: 0.04em; border: 1px solid; }
.info-bar--gold   { background: rgba(201,168,76,0.06); border-color: var(--gold-dark); color: var(--gold); }

/* Schedule-Rows (JS-generiert in System-Status-Card) */
.sched-row        { margin-bottom: 0.6rem; }
.sched-badge      { font-size: 0.62rem; font-weight: 700; padding: 1px 5px; border-radius: 2px; letter-spacing: 0.05em; }
.sched-date       { color: var(--text-sec); font-weight: 600; font-size: 0.76rem; margin-top: 3px; }
.sched-note       { color: var(--white-faint); font-size: 0.72rem; margin-top: 1px; }

/* ── Composer / Shared Components ────────────────────────── */

/* Info-Panel (flache Card ohne externe Headline) */
.info-panel { background: var(--bg); border: 1px solid var(--border); padding: 0.9rem 1rem; } /* deprecated → .info-card */
.info-panel-label { font-size: 0.9rem; font-weight: 600; color: #ccc; margin-bottom: 0.65rem; } /* deprecated → .info-card-label */

/* Info-Card (System-Status, Schedule — semantische Daten-Cards) */
.info-card       { background: var(--surface); border: 1px solid var(--gold-dim); padding: 0.9rem 1rem; border-radius: 12px; color: var(--text-sec); }
.info-card-label { font-size: var(--text-base); font-weight: 600; color: var(--white); margin-bottom: 0.65rem; }

/* Clear-Button */
/* .btn-clear → im Button-Block oben definiert */

/* Tab-Badge (count) + Tab-Reset-Button */
.tab-badge {
  display: inline-block; background: var(--teal-light); color: var(--black);
  font-size: 0.7rem; font-weight: 700; border-radius: 999px;
  padding: 0.1em 0.45em; margin-left: 0.3em; vertical-align: middle;
  line-height: 1.4; min-width: 1.2em; text-align: center;
}
.tab-badge:empty { display: none; }
.tab-reset-btn {
  display: inline-block; background: var(--pink); color: var(--white);
  font-size: 0.7rem; font-weight: 700; border-radius: 999px;
  padding: 0.1em 0.45em; margin-left: 0.25em; vertical-align: middle;
  line-height: 1.4; min-width: 1.2em; text-align: center;
  border: none; cursor: pointer; font-family: inherit; opacity: 0.85; transition: opacity 0.15s;
}
.tab-reset-btn:hover { opacity: 1; }
.tab-reset-btn:empty { display: none; }

/* Modal-Overlay (generisch) */
/* ── Modal System ─────────────────────────────────────────── */
.modal-overlay          { display: none; position: fixed; inset: 0; z-index: 1000; background: rgba(0,0,0,0.85); overflow-y: auto; }
.modal-overlay.open     { display: block; }
.modal-overlay--center  { overflow-y: unset; align-items: center; justify-content: center; }
.modal-overlay--center.open { display: flex; }

/* Gemeinsamer Glassmorphism-Stil */
.modal-box,
.modal-content {
  background: rgba(20,20,20,0.6); backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 16px;
}

/* Glassmorphism-Box (order, tz) */
.modal-box { padding: 0; margin: 6rem auto 4rem; width: 90%; max-width: 560px; }
.modal-header { display: flex; align-items: center; justify-content: space-between; padding: 1.25rem 1.5rem; border-bottom: 1px solid var(--border); }
.order-modal-close {
  position: absolute; top: 0.9rem; right: 0.9rem; z-index: 2;
  width: 2rem; height: 2rem; border-radius: 50%;
  background: rgba(255,255,255,0.07); border: 1px solid rgba(255,255,255,0.12);
  color: rgba(255,255,255,0.5); font-size: 0.8rem; line-height: 1;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: background 0.15s, color 0.15s;
}
.order-modal-close:hover { background: rgba(255,255,255,0.14); color: var(--white); }

/* Content-Box (fundus, model) */
.modal-content     { position: relative; max-width: 1100px; margin: 2rem auto; padding: 2rem 2rem 1rem; }
.modal-content--sm { max-width: 320px; width: 90%; margin: 0; padding: 2rem; }

/* Close-Button */
.modal-close       { position: absolute; top: 1rem; right: 1rem; background: none; border: none; color: var(--white-faint); font-size: 1.5rem; cursor: pointer; line-height: 1; z-index: 10; transition: color 0.15s; padding: 0; font-family: var(--font-main); }
.modal-close:hover { color: var(--white); }

/* Card-Overlays (Badges auf Fundus-Thumbnails) */
.card-img-wrap { position: relative; display: block; }
.card { cursor: pointer; }

/* ============================================================
   SURFACE-CARD SYSTEM
   Base: .surface-card — Layout-Container, fasst Bereiche zusammen
   Modifier: .surface-card--filter, etc.
   ============================================================ */

.surface-card {
  background:    var(--surface);
  border:        none;
  padding:       1rem 1.25rem;
  border-radius: 12px;
}

/* Filter-Bar Variante (Model-Filter oben im Grid) */
.surface-card--filter {
  display:        flex;
  flex-direction: column;
  gap:            0.75rem;
  margin-bottom:  1.5rem;
  border-radius:  12px;
}

/* Shot-Card Variante (Hero-Shots, Render-Optionen, Alt-Prompts in Synopsis) */
.surface-card--teal  { background: #0a1112; }

.surface-card--shot {
  margin-bottom: 1rem;
}
.surface-card--shot.open .secondary-chevron  { transform: rotate(180deg); }
.surface-card--shot.open .secondary-card-body { display: block; }

/* ============================================================
   PROMO-CARD SYSTEM
   Eigenständiger Typ — werblich, Call-to-Action
   ============================================================ */

.promo-card {
  flex:            1;
  display:         block;
  text-align:      center;
  text-decoration: none;
  background:      var(--surface-2);
  border:          1px solid var(--gold-dim);
  border-radius:   12px;
  padding:         10px 8px;
  transition:      border-color var(--transition), background var(--transition);
  position:        relative;
  overflow:        hidden;
  color:           var(--white);
}
.promo-card:hover {
  border-color: var(--gold-dark);
  background:   rgba(169,124,16,0.08);
}

/* Modifier: Sidebar-Variante (linksbündig, gestapelt) */
.promo-card--sidebar {
  flex:        none;
  text-align:  left;
  padding:     20px 18px;
  margin-bottom: 12px;
}
.promo-card--sidebar:last-child { margin-bottom: 0; }

/* Modifier: Farbe */
.promo-card--teal  { border-color: var(--teal-dark); background: var(--teal-dim); }
.promo-card--teal:hover  { border-color: var(--teal-light); background: rgba(10,166,167,0.06); }
.promo-card--pink  { border-color: var(--pink-dark); background: var(--pink-dim); }
.promo-card--pink:hover  { border-color: var(--pink-light); background: rgba(157,18,120,0.06); }
.promo-card--muted { border-color: var(--border); background: var(--surface); cursor: default; }

/* Child-Klassen */
.promo-card__tag {
  font-size: 9px; font-weight: 700; letter-spacing: 1.2px;
  text-transform: uppercase; margin-bottom: 8px;
  color: var(--gold); opacity: 0.7;
}
.promo-card--teal .promo-card__tag { color: var(--teal-light); }
.promo-card--pink .promo-card__tag { color: var(--pink-light); }

.promo-card__title {
  font-size: 15px; font-weight: 600; line-height: 1.3;
  margin-bottom: 6px; color: var(--white);
}
.promo-card__desc {
  font-size: 12px; line-height: 1.6;
  color: var(--text-sec); margin-bottom: 14px;
}
.promo-card__cta {
  font-size: 11px; font-weight: 600; letter-spacing: 0.5px;
  display: inline-flex; align-items: center; gap: 4px;
  color: var(--gold);
}
.promo-card--teal .promo-card__cta { color: var(--teal-light); }
.promo-card--pink .promo-card__cta { color: var(--pink-light); }
.promo-card--muted .promo-card__cta { color: var(--text-sec); }

/* ── Sidebar Teaser (Gradient-Platzhalter) ──────────────────── */
.sidebar-teaser {
  border-radius: var(--radius-card);
  margin-bottom: 12px;
  flex: none;
}
.sidebar-teaser:last-child { margin-bottom: 0; }
.sidebar-teaser--gold   { height: 130px; background: linear-gradient(135deg, #1c1500 0%, #2e2100 60%, #1a1100 100%); }
.sidebar-teaser--teal   { height: 110px; background: linear-gradient(135deg, #001c1c 0%, #002828 60%, #001515 100%); }
.sidebar-teaser--rose   { height: 150px; background: linear-gradient(135deg, #1a0016 0%, #260022 60%, #180010 100%); }
.sidebar-teaser--slate  { height: 120px; background: linear-gradient(135deg, #08101e 0%, #0d1830 60%, #060c18 100%); }
.sidebar-teaser--ash    { height: 100px; background: linear-gradient(135deg, #111 0%, #181818 60%, #0e0e0e 100%); }

/* ============================================================
   COIN-SHOP — .pkg / .pkg-grid
   Kaufkarten auf /coins — global steuerbar
   ============================================================ */

.shop-section  { margin-top: 16px; }
.shop-header   { margin-bottom: 28px; }
.shop-header h2 { font-size: 28px; font-weight: 300; color: var(--white); margin-bottom: 8px; }
.shop-header p  { font-size: 13px; color: var(--text-sec); line-height: 1.6; }

.pkg-grid { display: flex; flex-direction: column; gap: 12px; }
.pkg {
  display: flex; align-items: center; justify-content: space-between;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-card); padding: 20px 22px;
  text-decoration: none; color: var(--white);
  transition: border-color var(--transition), background var(--transition);
  position: relative; overflow: hidden;
}
.pkg:hover         { border-color: var(--gold); background: var(--surface-2); color: var(--white); }
.pkg.best          { border-color: var(--gold-dark); }
.pkg.best:hover    { border-color: var(--gold); }

.pkg-best-badge {
  position: absolute; top: 0; right: 0;
  background: var(--gold); color: #000;
  font-size: 10px; font-weight: 600; letter-spacing: 0.8px;
  text-transform: uppercase; padding: 4px 12px;
  border-bottom-left-radius: var(--radius-card);
}
.pkg-coins { font-size: 22px; font-weight: 400; color: var(--gold); line-height: 1; }
.pkg-desc  { font-size: 12px; color: var(--text-sec); margin-top: 5px; line-height: 1.4; }
.pkg-right { text-align: right; flex-shrink: 0; }
.pkg-price { font-size: 24px; font-weight: 300; color: var(--white); line-height: 1; }
.pkg-per   { font-size: 11px; color: var(--text-sec); margin-top: 4px; }
.pkg-arrow { font-size: 18px; color: var(--text-sec); margin-left: 16px; flex-shrink: 0; transition: color var(--transition); }
.pkg:hover .pkg-arrow { color: var(--gold); }

.shop-footer { text-align: center; margin-top: 18px; font-size: 12px; color: var(--text-sec); line-height: 1.6; }
.shop-footer strong { color: var(--white); }

/* ============================================================
   GRID-CARD SYSTEM
   Base: .grid-card — ersetzt .card für alle Grid-Kacheln
   Modifier: .grid-card--model, .grid-card--fundus, etc.
   ============================================================ */

.grid-card {
  background:    var(--surface);
  border:        1px solid var(--border);
  border-radius: 12px;
  overflow:      hidden;
  cursor:        pointer;
  transition:    border-color var(--transition), box-shadow var(--transition);
}
.grid-card:hover   { border-color: var(--white-faint); }
.grid-card.picked  { border-color: var(--gold); box-shadow: 0 0 0 1px var(--gold); }
.grid-card.disabled { opacity: 0.3; pointer-events: none; }

/* Model-Grid-Card */
.grid-card--model .card-name { min-height: unset; }

/* Fundus-Grid-Card */
.grid-card--fundus {
  /* Modifier — hier gezielt gestalten */
}
/* .mas-badge, .lora-badge → im Badge System Block oben */
.loc-preset-badge {
  position: absolute; bottom: 5px; left: 5px;
  display: inline-flex; align-items: center; gap: 3px;
  padding: 2px 6px 2px 4px;
  background: rgba(0,0,0,0.65); backdrop-filter: blur(4px);
  border: 1px solid rgba(255,255,255,0.15); border-radius: 3px;
  font-size: 0.6rem; letter-spacing: 0.09em; text-transform: uppercase;
  color: rgba(255,255,255,0.8); font-family: var(--mono); pointer-events: none;
}

/* Fundus-Gruppen (typ-basiert) */
.group-section { margin-bottom: 0.5rem; }
.group-header {
  display: flex; align-items: center; gap: 0.6rem;
  padding: 0.45rem 0.75rem; background: var(--surface); border: 1px solid var(--border); border-radius: 8px;
  cursor: pointer; user-select: none; margin-bottom: 0.5rem; transition: background 0.12s;
}
.group-header:hover { background: var(--surface-2); }
/* ── Global caret (collapsible chevron) ── */
.caret { display: inline-flex; align-items: center; justify-content: center; color: var(--white-dim); flex-shrink: 0; transition: transform 0.2s ease; }
.caret.open { transform: rotate(180deg); }

.group-chevron { color: var(--white-faint); transform: rotate(0deg); }
.group-section.collapsed .group-chevron { transform: rotate(-90deg); }
.group-label { font-size: var(--text-ui); letter-spacing: 0.1em; text-transform: uppercase; color: var(--white); }
.group-count { font-size: var(--text-ui); color: var(--white-faint); margin-left: 0.25rem; }
.group-body { margin-bottom: 1rem; }
.group-section.collapsed .group-body { display: none; }

/* Shooting-Typ Kategorie-Palette */
:root {
  --ts-editorial:   #8ab4e8;
  --ts-nude:        #d4a96a;
  --ts-highfashion: #c9a0e0;
  --ts-swimwear:    #5cc8d0;
  --ts-casualwear:  #72c48a;
  --ts-sportswear:  #64c88c;
}
.ts-typ-EDITORIAL    { background: rgba(100,140,200,0.18); color: var(--ts-editorial);   border: 1px solid rgba(100,140,200,0.3); }
.ts-typ-NUDE         { background: rgba(200,160,100,0.18); color: var(--ts-nude);        border: 1px solid rgba(200,160,100,0.3); }
.ts-typ-HIGH-FASHION { background: rgba(180,150,220,0.18); color: var(--ts-highfashion); border: 1px solid rgba(180,150,220,0.3); }
.ts-typ-LINGERIE     { background: rgba(210,120,140,0.18); color: var(--pink-light);     border: 1px solid rgba(210,120,140,0.3); }
.ts-typ-SWIMWEAR     { background: rgba(80,190,200,0.18);  color: var(--ts-swimwear);    border: 1px solid rgba(80,190,200,0.3); }
.ts-typ-CASUALWEAR   { background: rgba(100,180,120,0.18); color: var(--ts-casualwear);  border: 1px solid rgba(100,180,120,0.3); }
.ts-typ-SPORTSWEAR   { background: rgba(100,200,140,0.18); color: var(--ts-sportswear);  border: 1px solid rgba(100,200,140,0.3); }

/* Testshoot-Karten */
.ts-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 0.75rem; margin-top: 1rem; }
.ts-card { background: var(--surface); border: 1px solid var(--border); padding: 0; cursor: pointer; transition: border-color 0.15s, background 0.15s; position: relative; overflow: hidden; }
.ts-card:hover  { border-color: rgba(255,255,255,0.3); background: rgba(255,255,255,0.03); }
.ts-card.picked { border-color: var(--white); background: rgba(255,255,255,0.06); }
.ts-card-thumb { width: 100%; aspect-ratio: 1/1; object-fit: cover; display: block; background: var(--surface-2); }
.ts-card-thumb-placeholder { width: 100%; aspect-ratio: 1/1; background: var(--surface-2); display: flex; align-items: center; justify-content: center; color: var(--white-faint); font-size: 0.6rem; letter-spacing: 0.08em; text-transform: uppercase; }
.ts-card-body { padding: 0.75rem 0.9rem; }
.ts-card-code  { font-size: 0.62rem; letter-spacing: 0.12em; color: var(--white-faint); margin-bottom: 0.3rem; font-family: var(--mono); }
.ts-card-name  { font-size: 0.82rem; font-weight: 400; line-height: 1.35; margin-bottom: 0.55rem; color: var(--white); }
/* .ts-card-typ → im Badge System Block oben */
.ts-card-check { position: absolute; top: 0.7rem; right: 0.8rem; font-size: 0.75rem; color: var(--white); opacity: 0; transition: opacity 0.15s; }
.ts-card.picked .ts-card-check { opacity: 1; }
.ts-card-info  { display: inline-flex; align-items: center; justify-content: center; margin-left: auto; width: 1.4rem; height: 1.4rem; border-radius: 50%; border: 1px solid var(--border); color: var(--white-faint); font-size: 0.6rem; letter-spacing: 0.03em; text-decoration: none; transition: border-color 0.15s, color 0.15s; flex-shrink: 0; }
.ts-card-info:hover { border-color: var(--white); color: var(--white); }
.ts-card-footer { display: flex; align-items: center; margin-top: 0.55rem; }

/* Synopsis Panel */
.synopsis-section { margin-bottom: 2rem; }
.synopsis-section-title { font-size: 0.78rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--teal-light); border-bottom: 1px solid var(--teal-dark); padding-bottom: 0.4rem; margin-bottom: 1rem; }
.secondary-card-header { display: flex; align-items: center; justify-content: space-between; padding: 0.75rem 1.25rem; cursor: pointer; user-select: none; }
.secondary-chevron { color: var(--white-faint); }
.secondary-card-body { display: none; padding: 0.25rem 1.25rem 1rem; }
.hero-shot-card { background: var(--surface); border: 1px solid var(--border); padding: 1rem 1.25rem; margin-bottom: 1rem; } /* deprecated → .surface-card--shot */
.hero-shot-title { /* → .card-label */ font-size: 1rem; font-weight: 500; letter-spacing: 0; text-transform: none; color: var(--text-sec); margin-bottom: 0.9rem; }
.hero-shot-row { display: flex; align-items: center; gap: 0.75rem; margin-bottom: 0.6rem; }
.hero-shot-label { font-size: 0.68rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--white-faint); min-width: 52px; flex-shrink: 0; }
.hero-shot-chips { display: flex; flex-wrap: wrap; gap: 0.3rem; }

/* Picks-Liste (Synopsis) */
.synopsis-picks-list { display: flex; flex-direction: column; gap: 0.3rem; font-size: 0.82rem; }
.synopsis-picks-row { display: flex; gap: 0.6rem; }
.synopsis-picks-key { color: var(--white-faint); font-size: 0.68rem; letter-spacing: 0.06em; text-transform: uppercase; width: 110px; flex-shrink: 0; padding-top: 0.1rem; }
.synopsis-picks-val { color: var(--white); }
.synopsis-picks-empty { color: var(--white-faint); font-style: italic; font-size: 0.78rem; }
.picks-reset-btn { background: none; border: none; padding: 0; cursor: pointer; font-size: inherit; letter-spacing: inherit; font-family: inherit; font-weight: inherit; color: var(--white-faint); transition: color 0.2s; text-transform: uppercase; }
.picks-reset-btn:hover { color: var(--pink); }

/* Brief-Fehler */
.brief-errors { border: 1px solid var(--red); padding: 0.75rem 1rem; font-size: 0.82rem; }
.brief-errors-title { color: var(--red); font-size: 0.68rem; letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 0.5rem; }
.brief-error-item { color: var(--red); padding: 0.15rem 0; }
.brief-error-item::before { content: '✕  '; }
.input-error { border-color: var(--red) !important; }

/* ── Detail Pages (fundus.php / model.php shared) ─────────── */

/* Layout */
.detail-grid { display: grid; grid-template-columns: 420px 1fr; gap: 3rem; align-items: start; margin-bottom: 2rem; }
@media (max-width: 900px) { .detail-grid { grid-template-columns: 1fr; gap: 2rem; } }

/* Bildgalerie */
.img-gallery-main img  { width: 100%; object-fit: cover; background: var(--surface-2); cursor: zoom-in; margin-bottom: 0.5rem; display: block; }
.img-gallery           { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0.4rem; }
.img-gallery img       { width: 100%; aspect-ratio: 1/1; object-fit: cover; background: var(--surface-2); cursor: zoom-in; transition: opacity 0.12s; }
.img-gallery img:hover { opacity: 0.75; }
.img-placeholder       { width: 100%; background: var(--surface-2); display: flex; align-items: center; justify-content: center; color: var(--white-faint); font-size: 0.75rem; letter-spacing: 0.08em; }

/* Felder */
.field-block            { margin-bottom: 1.5rem; }
.field-label            { display: flex; align-items: center; gap: 0.4rem; font-size: var(--text-base); font-weight: 500; letter-spacing: 0.01em; color: var(--white-mid); margin-bottom: 0.4rem; }
.field-value            { font-size: 0.9rem; color: var(--white); line-height: 1.6; }
.field-value.mono       { font-family: var(--font-mono); font-size: 0.82rem; background: var(--surface-2); border: 1px solid var(--border); padding: 1rem; white-space: pre-wrap; word-break: break-word; color: var(--white-dim); line-height: 1.75; }
.field-mono             { font-size: 0.78rem; color: var(--white-faint); line-height: 1.7; font-family: var(--font-mono); }

/* Affinitäts-Chips */
.aff-chips { display: flex; flex-wrap: wrap; gap: 0.4rem; margin-top: 0.25rem; }
.aff-chip  { display: inline-flex; align-items: center; gap: 0.3rem; font-size: 0.7rem; letter-spacing: 0.04em; padding: 0.2rem 0.55rem; background: var(--surface-2); border: 1px solid rgba(232,184,109,0.25); color: var(--white-dim); border-radius: 999px; white-space: nowrap; }

/* Pick-Bar (sticky bottom) */
.pick-bar       { position: sticky; bottom: 0; background: var(--surface); border-top: 1px solid var(--border); padding: 1rem 2rem; display: flex; align-items: center; gap: 1rem; z-index: 50; }
.pick-bar-name  { font-size: 0.85rem; color: var(--white-dim); flex: 1; }
.pick-bar-name strong { color: var(--white); }

/* Section-Divider */
.section-divider { font-size: 0.68rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-sec); margin: 2rem 0 1rem; padding-bottom: 0.5rem; border-bottom: 1px solid var(--border); }

/* Seiten-Navigation (Prev/Next Item) */
.page-nav         { position: fixed; top: 50%; transform: translateY(-50%); z-index: 100; display: flex; align-items: center; justify-content: center; width: 48px; height: 96px; background: var(--surface); border: 1px solid var(--border); color: var(--white-dim); font-size: 2rem; line-height: 1; text-decoration: none; transition: background 0.15s, color 0.15s, border-color 0.15s; user-select: none; }
.page-nav:hover   { background: var(--surface-2); border-color: var(--white-faint); color: var(--white); }
.page-nav.disabled { opacity: 0.2; pointer-events: none; }
.page-nav--prev   { left: 0.75rem; }
.page-nav--next   { right: 0.75rem; }

/* Modal-Nav-Bar (Prev/Next im Modal) */
.modal-nav-bar  { display: flex; justify-content: center; align-items: center; gap: 3rem; margin-bottom: 1.5rem; padding-bottom: 1rem; border-bottom: 1px solid var(--border); }
.modal-nav-btn  { background: var(--surface-2); white-space: nowrap; } /* → .btn .btn-nav */
.modal-nav-btn:hover    { color: var(--white); border-color: var(--white-faint); }
.modal-nav-btn:disabled { opacity: 0.25; pointer-events: none; }
.btn-nav { background: var(--surface-2); white-space: nowrap; text-transform: none; letter-spacing: 0.02em; }
.modal-nav-name { font-size: 0.82rem; color: var(--white); letter-spacing: 0.04em; white-space: nowrap; }

/* Detail-Lightbox (fundus + model) */
.detail-lightbox      { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.96); z-index: 500; align-items: center; justify-content: center; cursor: zoom-out; padding: var(--header-h) 1rem 2rem; box-sizing: border-box; }
.detail-lightbox.open { display: flex; }
.lb-inner             { display: flex; align-items: center; gap: 0.5rem; max-height: 100%; }
.lb-img-wrap          { position: relative; display: flex; flex-direction: column; align-items: center; gap: 0.75rem; }
.detail-lightbox img  { max-width: min(85vw, 900px); max-height: calc(100vh - var(--header-h) - 4rem); object-fit: contain; display: block; cursor: default; }
.detail-lightbox .lb-nav  { position: static; font-size: 42px; color: rgba(255,255,255,0.3); padding: 0 8px; line-height: 1; flex-shrink: 0; transform: none; }
.detail-lightbox .lb-counter { position: static; transform: none; font-size: 12px; color: var(--white-dim); text-align: center; }

/* ── Exclusive Model Card ── */
.grid-card.exclusive       { background: linear-gradient(160deg, #1c1400 0%, #2a1e00 60%, #1a1200 100%); border-color: var(--gold-dim); }
.grid-card.exclusive:hover { border-color: var(--gold-dark); }
.grid-card.exclusive.picked { border-color: var(--gold); box-shadow: 0 0 0 1px var(--gold); }
.badge-exclusive { background: var(--pink-dim); color: var(--pink-light); border-color: var(--pink-dark); }
.card-badge-corner { position: absolute; top: 0; right: 0; z-index: 2; background: var(--pink-dim); color: var(--pink-light); font-size: 9px; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; padding: 4px 10px; border-bottom-left-radius: var(--radius-card); pointer-events: none; }
.btn-ask       { width: 100%; background: var(--pink-dim); color: var(--pink-light); font-size: 0.72rem; padding: 0.4rem 0.5rem; text-align: center; }
.btn-ask:hover { background: var(--pink); color: #fff; }

/* ── Compat-Ampel (Outfit) ───────────────────────────────── */
.compat-wrap       { margin-bottom: 1.5rem; }
.compat-rows       { width: 200px; border: 1px solid var(--border); border-radius: 10px; overflow: hidden; padding: 0.5rem 1rem; }
.compat-row        { display: flex; align-items: center; justify-content: space-between; padding: 0.15rem 0; border-bottom: 1px solid var(--border-2); }
.compat-footnote   { font-size: var(--text-xs); color: var(--white-faint); margin-top: 0.4rem; line-height: 1.4; }
.compat-approved   { display: inline-flex; align-items: center; gap: 2px; font-size: 0.55rem; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--teal-light); background: var(--teal-dim); border: 1px solid var(--teal-dark); border-radius: 999px; padding: 1px 5px 1px 3px; line-height: 1; }
.compat-row:last-child { border-bottom: none; }
.compat-name { font-size: var(--text-xs); color: var(--white-dim); }
.compat-icon { display: flex; align-items: center; }
.compat-na   { font-size: var(--text-xs); color: var(--white-faint); }

/* ── Promo Card: Image-Variante ──────────────────────────────────────────── */
.promo-card--image {
  padding: 0;
  overflow: hidden;
  border: none !important;
}
.promo-card--image:hover { border: none !important; }
.promo-card--image .promo-card__img,
.promo-card--image .gal-photo {
  width: 100%;
  height: auto;
  display: block;
  transition: transform 0.6s ease;
}
.promo-card--image:hover .promo-card__img,
.promo-card--image:hover .gal-photo { transform: scale(1.03); }
.promo-card--image::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0);
  transition: background 0.3s;
  pointer-events: none;
  border-radius: 12px;
}
.promo-card--image:hover::after { background: rgba(0,0,0,0.12); }

/* Info-Balken über dem Bild (wie in Galerie) */
.promo-card--image .gal-badge-bar {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  background: rgba(0,0,0,0.6);
  padding: 6px 10px;
  font-size: 0.78rem;
  color: rgba(255,255,255,0.8);
  letter-spacing: 0.02em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  pointer-events: none;
  z-index: 3;
  display: flex;
  align-items: center;
  gap: 6px;
}

/* LUMIZED-Wasserzeichen (wie in Galerie) */
.promo-card--image .gal-badge-logo {
  position: absolute;
  bottom: calc(min(25%, 80px) + 6px);
  left: 12px;
  height: 11px;
  width: auto;
  display: block;
  opacity: 0.6;
  pointer-events: none;
  z-index: 3;
}

/* Teaser-Cards: Gradient-Platzhalter wenn kein echtes Bild */
.promo-card--teaser .promo-card__img-placeholder {
  width: 100%;
  height: 140px;
  display: block;
  background: linear-gradient(135deg, #2d1a4a 0%, #5a2d82 45%, #c15a1a 100%);
}

/* Feature-Overlay: 1/4 von unten, Steckbrief */
.promo-card__feature-overlay {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 25%;
  max-height: 80px;
  background: rgba(0,0,0,0.58);
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 4px;
  padding: 8px 12px;
  pointer-events: none;
  z-index: 3;
}
.promo-card__feature-headline {
  font-size: 14px;
  font-weight: 700;
  color: #fff;
  line-height: 1.2;
  letter-spacing: -0.01em;
}
.promo-card__feature-info {
  font-size: 10px;
  font-weight: 400;
  color: rgba(255,255,255,0.6);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  letter-spacing: 0.01em;
}
