/* ═══════════════════════════════════════════════════
   GastroLogic Dashboard — dashboard.css
   Aesthetic: Professional Kitchen / Industrial Warmth
   Fonts: DM Mono (data) + DM Sans (UI)
═══════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=DM+Mono:wght@400;500&family=DM+Sans:wght@400;500;600;700&display=swap');

/* ── Tokens ────────────────────────────────────────── */
:root {
  --gl-bg:           #F7F5F2;
  --gl-surface:      #FFFFFF;
  --gl-border:       #E2DDD8;
  --gl-border-dark:  #C8C0B8;

  --gl-text:         #1A1714;
  --gl-text-muted:   #7A7068;
  --gl-text-light:   #B0A898;

  --gl-amber:        #D4820A;
  --gl-amber-light:  #FFF3DC;
  --gl-amber-dark:   #A86208;

  --gl-green:        #1E7A4A;
  --gl-green-light:  #E6F5EC;

  --gl-red:          #C0392B;
  --gl-red-light:    #FDECEA;

  --gl-blue:         #2563EB;
  --gl-blue-light:   #EEF3FD;

  --gl-locked:       #9B8EA0;
  --gl-locked-bg:    #F4F0F7;

  --gl-radius:       6px;
  --gl-radius-lg:    10px;
  --gl-shadow:       0 1px 3px rgba(26,23,20,.08), 0 4px 12px rgba(26,23,20,.06);
  --gl-shadow-lg:    0 2px 8px rgba(26,23,20,.10), 0 12px 32px rgba(26,23,20,.10);

  --gl-font-ui:      'DM Sans', system-ui, sans-serif;
  --gl-font-mono:    'DM Mono', 'Courier New', monospace;

  --gl-transition:   150ms ease;
}

/* ── Base ──────────────────────────────────────────── */
.gl-upload-app,
.gl-results-app,
.gl-mapping-app,
.gl-stammdaten-app,
.gl-zutaten-app,
.gl-gerichte-app,
.gl-speisekarte-app {
  font-family: var(--gl-font-ui);
  color: var(--gl-text);
  background: var(--gl-bg);
  padding: 32px 0;
  max-width: 780px;
  margin: 0 auto;
}

/* ── Spacing Utilities ─────────────────────────────── */
.gl-mb  { margin-bottom: 16px; }
.gl-mt  { margin-top: 16px; }
.gl-mb2 { margin-bottom: 32px; }
.gl-text-center { text-align: center; }

/* ── Card ──────────────────────────────────────────── */
.gl-card {
  background: var(--gl-surface);
  border: 1px solid var(--gl-border);
  border-radius: var(--gl-radius-lg);
  padding: 24px;
  box-shadow: var(--gl-shadow);
}

/* ── Section Header ────────────────────────────────── */
.gl-section-title {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .10em;
  text-transform: uppercase;
  color: var(--gl-text-muted);
  margin: 0 0 16px;
}

/* ── Buttons ───────────────────────────────────────── */
.gl-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--gl-font-ui);
  font-size: 14px;
  font-weight: 600;
  padding: 10px 20px;
  border-radius: var(--gl-radius);
  border: 1.5px solid transparent;
  cursor: pointer;
  transition: all var(--gl-transition);
  text-decoration: none;
  white-space: nowrap;
}

.gl-btn:disabled {
  opacity: .45;
  cursor: not-allowed;
}

.gl-btn--primary {
  background: var(--gl-amber);
  color: #fff;
  border-color: var(--gl-amber);
}
.gl-btn--primary:hover:not(:disabled) {
  background: var(--gl-amber-dark);
  border-color: var(--gl-amber-dark);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(212,130,10,.30);
}

.gl-btn--success {
  background: var(--gl-green);
  color: #fff;
  border-color: var(--gl-green);
}
.gl-btn--success:hover:not(:disabled) {
  background: #175c38;
  transform: translateY(-1px);
}

.gl-btn--ghost {
  background: transparent;
  color: var(--gl-text-muted);
  border-color: var(--gl-border-dark);
}
.gl-btn--ghost:hover:not(:disabled) {
  background: var(--gl-bg);
  color: var(--gl-text);
  border-color: var(--gl-text-muted);
}

.gl-btn--danger {
  background: transparent;
  color: var(--gl-red);
  border-color: var(--gl-red);
}
.gl-btn--danger:hover:not(:disabled) {
  background: var(--gl-red-light);
}

/* ── Form ──────────────────────────────────────────── */
.gl-form-row {
  margin-bottom: 20px;
}

.gl-form-row label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: var(--gl-text);
  margin-bottom: 6px;
}

.gl-form-row input[type="text"],
.gl-form-row input[type="email"],
.gl-form-row input[type="url"],
.gl-form-row input[type="tel"],
.gl-form-row input[type="number"],
.gl-form-row select,
.gl-form-row textarea {
  width: 100%;
  font-family: var(--gl-font-ui);
  font-size: 14px;
  color: var(--gl-text);
  background: var(--gl-surface);
  border: 1.5px solid var(--gl-border);
  border-radius: var(--gl-radius);
  padding: 9px 12px;
  box-sizing: border-box;
  transition: border-color var(--gl-transition), box-shadow var(--gl-transition);
  appearance: none;
  -webkit-appearance: none;
}

.gl-form-row select {
  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='%237A7068' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  padding-right: 36px;
  cursor: pointer;
}

.gl-form-row input:focus,
.gl-form-row select:focus,
.gl-form-row textarea:focus {
  outline: none;
  border-color: var(--gl-amber);
  box-shadow: 0 0 0 3px rgba(212,130,10,.12);
}

.gl-form-row .description {
  font-size: 12px;
  color: var(--gl-text-muted);
  margin-top: 5px;
}

.gl-form-row code {
  font-family: var(--gl-font-mono);
  font-size: 11px;
  background: var(--gl-bg);
  border: 1px solid var(--gl-border);
  border-radius: 3px;
  padding: 1px 5px;
}

.gl-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0 20px;
}

@media (max-width: 600px) {
  .gl-form-grid { grid-template-columns: 1fr; }
}

/* ── Dropzone ──────────────────────────────────────── */
.gl-dropzone {
  border: 2px dashed var(--gl-border-dark);
  border-radius: var(--gl-radius-lg);
  padding: 48px 24px;
  text-align: center;
  cursor: pointer;
  background: var(--gl-surface);
  transition: all var(--gl-transition);
  position: relative;
}

.gl-dropzone:hover,
.gl-dropzone.is-hover {
  border-color: var(--gl-amber);
  background: var(--gl-amber-light);
}

.gl-dropzone.is-hover .gl-dropzone__icon { transform: scale(1.1); }

.gl-dropzone__icon {
  font-size: 40px;
  display: block;
  margin-bottom: 12px;
  transition: transform var(--gl-transition);
}

.gl-dropzone__text {
  font-size: 15px;
  color: var(--gl-text-muted);
  margin: 0;
  line-height: 1.6;
}

.gl-dropzone__text strong {
  color: var(--gl-amber);
}

/* ── File Info ─────────────────────────────────────── */
.gl-file-info {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  background: var(--gl-green-light);
  border: 1.5px solid var(--gl-green);
  border-radius: var(--gl-radius);
  font-size: 14px;
  color: var(--gl-green);
  font-weight: 500;
}

.gl-file-info__icon { font-size: 20px; }
.gl-file-info__name { flex: 1; font-family: var(--gl-font-mono); font-size: 13px; }

.gl-file-info__remove {
  background: none;
  border: none;
  cursor: pointer;
  color: var(--gl-green);
  font-size: 18px;
  line-height: 1;
  padding: 0;
  opacity: .7;
}
.gl-file-info__remove:hover { opacity: 1; }

/* ── Status Steps ──────────────────────────────────── */
.gl-status {
  margin-top: 24px;
  padding: 20px 24px;
  background: var(--gl-surface);
  border: 1px solid var(--gl-border);
  border-radius: var(--gl-radius-lg);
}

.gl-steps {
  display: flex;
  gap: 0;
  margin-bottom: 16px;
}

.gl-step {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 500;
  color: var(--gl-text-light);
  padding-bottom: 12px;
  border-bottom: 2px solid var(--gl-border);
  transition: all var(--gl-transition);
}

.gl-step.is-active {
  color: var(--gl-amber);
  border-bottom-color: var(--gl-amber);
}

.gl-step.is-done {
  color: var(--gl-green);
  border-bottom-color: var(--gl-green);
}

.gl-step__icon { font-size: 16px; }

.gl-status__msg {
  font-size: 14px;
  color: var(--gl-text-muted);
  margin: 0 0 12px;
  font-family: var(--gl-font-mono);
  font-size: 13px;
}

/* ── Loading ───────────────────────────────────────── */
.gl-loading {
  padding: 48px 24px;
  text-align: center;
  color: var(--gl-text-muted);
  font-size: 14px;
}

.gl-loading::before {
  content: '';
  display: block;
  width: 32px;
  height: 32px;
  border: 3px solid var(--gl-border);
  border-top-color: var(--gl-amber);
  border-radius: 50%;
  animation: gl-spin .7s linear infinite;
  margin: 0 auto 16px;
}

@keyframes gl-spin {
  to { transform: rotate(360deg); }
}

/* ── Error / Banner ────────────────────────────────── */
.gl-error {
  padding: 14px 16px;
  background: var(--gl-red-light);
  border: 1.5px solid var(--gl-red);
  border-radius: var(--gl-radius);
  font-size: 14px;
  color: var(--gl-red);
}

.gl-banner {
  padding: 14px 16px;
  border-radius: var(--gl-radius);
  font-size: 14px;
  margin-bottom: 16px;
}

.gl-banner--warning {
  background: var(--gl-amber-light);
  border: 1.5px solid var(--gl-amber);
  color: var(--gl-amber-dark);
}

.gl-banner--info {
  background: var(--gl-blue-light);
  border: 1.5px solid var(--gl-blue);
  color: var(--gl-blue);
}

/* ── Table ─────────────────────────────────────────── */
.gl-table-wrap {
  overflow-x: auto;
  border-radius: var(--gl-radius-lg);
  border: 1px solid var(--gl-border);
}

.gl-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
}

.gl-table thead th {
  background: var(--gl-bg);
  padding: 10px 14px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--gl-text-muted);
  text-align: left;
  border-bottom: 1px solid var(--gl-border);
  white-space: nowrap;
}

.gl-table tbody td {
  padding: 11px 14px;
  border-bottom: 1px solid var(--gl-border);
  vertical-align: middle;
}

.gl-table tbody tr:last-child td { border-bottom: none; }

.gl-table tbody tr:hover td { background: var(--gl-bg); }

.gl-table .gl-mono {
  font-family: var(--gl-font-mono);
  font-size: 13px;
}

/* ── Badge ─────────────────────────────────────────── */
.gl-badge {
  display: inline-flex;
  align-items: center;
  font-size: 11px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 99px;
}

.gl-badge--neutral  { background: var(--gl-bg); color: var(--gl-text-muted); border: 1px solid var(--gl-border); }
.gl-badge--success  { background: var(--gl-green-light); color: var(--gl-green); }
.gl-badge--info     { background: #e0f0ff; color: #0070c0; }
.gl-badge--warning  { background: var(--gl-amber-light); color: var(--gl-amber-dark); }
.gl-badge--error    { background: var(--gl-red-light); color: var(--gl-red); }
.gl-badge--locked   { background: var(--gl-locked-bg); color: var(--gl-locked); }

/* ── Locked Feature ────────────────────────────────── */
.gl-locked-cell {
  position: relative;
  user-select: none;
}

.gl-locked-cell__blur {
  filter: blur(4px);
  pointer-events: none;
  opacity: .6;
}

.gl-locked-cell__icon {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  color: var(--gl-locked);
  font-weight: 600;
}

/* ── Invoice Header Card ───────────────────────────── */
.gl-invoice-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
}

.gl-invoice-meta__item {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.gl-invoice-meta__label {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--gl-text-muted);
}

.gl-invoice-meta__value {
  font-size: 15px;
  font-weight: 600;
  font-family: var(--gl-font-mono);
  color: var(--gl-text);
}

/* ── Mapping Card ──────────────────────────────────── */
.gl-mapping-header {
  margin-bottom: 24px;
}

.gl-mapping-header h3 {
  font-size: 18px;
  font-weight: 700;
  margin: 0 0 12px;
}

.gl-progress-bar {
  height: 6px;
  background: var(--gl-border);
  border-radius: 99px;
  overflow: hidden;
  margin-bottom: 8px;
}

.gl-progress-bar__fill {
  height: 100%;
  background: var(--gl-amber);
  border-radius: 99px;
  transition: width .4s ease;
}

.gl-mapping-counter {
  font-size: 13px;
  color: var(--gl-text-muted);
  margin: 0;
  font-family: var(--gl-font-mono);
}

.gl-mapping-card { margin-top: 0; }

.gl-mapping-product {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
}

.gl-prod-title {
  font-size: 18px;
  font-weight: 700;
  color: var(--gl-text);
}

.gl-mapping-meta {
  display: flex;
  gap: 16px;
  font-size: 13px;
  font-family: var(--gl-font-mono);
  color: var(--gl-text-muted);
  margin-bottom: 20px;
}

.gl-mapping-actions {
  display: flex;
  gap: 10px;
  margin-top: 20px;
}

/* ── Success State ─────────────────────────────────── */
.gl-success-icon {
  font-size: 48px;
  margin-bottom: 8px;
  color: var(--gl-green);
}

/* ── Allergen Matrix ───────────────────────────────── */
.gl-allergen-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
  gap: 8px;
  margin-top: 12px;
}

.gl-allergen-chip {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: var(--gl-radius);
  font-size: 13px;
  font-weight: 500;
  border: 1px solid var(--gl-border);
  background: var(--gl-surface);
}

.gl-allergen-chip.is-present {
  background: var(--gl-red-light);
  border-color: var(--gl-red);
  color: var(--gl-red);
}

.gl-allergen-chip.is-absent {
  background: var(--gl-bg);
  color: var(--gl-text-muted);
}

/* ── Stammdaten ────────────────────────────────────── */
.gl-email-row {
  display: flex;
  align-items: center;
  gap: 8px;
}

.gl-email-row input[type="email"] {
  flex: 1;
}

.gl-btn--sm {
  font-size: 12px;
  padding: 5px 12px;
}

.gl-sd-actions {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-top: 8px;
}

.gl-sd-msg {
  font-size: 14px;
  font-weight: 500;
}

.gl-sd-msg--success { color: var(--gl-green); }
.gl-sd-msg--error   { color: var(--gl-red); }

/* ── Mobile ────────────────────────────────────────── */
@media (max-width: 640px) {
  .gl-upload-app,
  .gl-results-app,
  .gl-mapping-app {
    padding: 16px;
  }

  .gl-card { padding: 16px; }

  .gl-steps { flex-direction: column; gap: 8px; }
  .gl-step { border-bottom: none; border-left: 2px solid var(--gl-border); padding: 4px 12px; }
  .gl-step.is-active { border-left-color: var(--gl-amber); }
  .gl-step.is-done   { border-left-color: var(--gl-green); }

  .gl-mapping-actions { flex-direction: column; }
  .gl-btn { justify-content: center; }
}

/* ═══════════════════════════════════════════════════
   Rezept-Editor (rezept-editor.js)
═══════════════════════════════════════════════════ */

.gl-rezept-app {
  font-family: var(--gl-font-ui);
  color: var(--gl-text);
  background: var(--gl-bg);
  padding: 32px 0;
  max-width: 780px;
  margin: 0 auto;
}

/* ── Gerichte-Grid ──────────────────────────────── */
.gl-rezept-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: 16px;
}

.gl-rezept-card {
  display: flex;
  flex-direction: column;
  gap: 12px;
  cursor: default;
}

.gl-rezept-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.gl-rezept-card__name {
  font-size: 17px;
  font-weight: 700;
}

.gl-rezept-card__price {
  font-size: 18px;
  font-weight: 700;
  font-family: var(--gl-font-mono);
  color: var(--gl-amber-dark);
}

.gl-rezept-card__meta {
  display: flex;
  align-items: center;
  gap: 12px;
}

.gl-rezept-card__status {
  margin-top: auto;
}

/* ── Detail-Ansicht ─────────────────────────────── */
.gl-rezept-detail-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

.gl-rezept-detail-title {
  font-size: 22px;
  font-weight: 700;
  margin: 0 0 4px;
}

.gl-rezept-detail-price {
  text-align: right;
  flex-shrink: 0;
}

/* ── Komponenten ────────────────────────────────── */
.gl-rezept-component {
  border-left: 3px solid var(--gl-amber);
}

.gl-rezept-component__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--gl-border);
  margin-bottom: 12px;
  user-select: none;
}

.gl-rezept-toggle-icon {
  font-size: 12px;
  color: var(--gl-text-muted);
  width: 16px;
  text-align: center;
  flex-shrink: 0;
}

/* ── Zutaten-Grid ───────────────────────────────── */
.gl-rezept-ingredient-header {
  display: grid;
  grid-template-columns: 2fr 70px 72px 1fr 80px 36px;
  gap: 8px;
  align-items: center;
  padding: 0 0 6px;
  border-bottom: 1px solid var(--gl-border);
  margin-bottom: 8px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--gl-text-muted);
}

.gl-rezept-ingredient-row {
  display: grid;
  grid-template-columns: 2fr 70px 72px 1fr 80px 36px;
  gap: 8px;
  align-items: center;
  margin-bottom: 8px;
}

/* ── Autocomplete-Dropdown ──────────────────────── */
.gl-rezept-ing-dropdown {
  position: absolute;
  top: calc(100% + 2px);
  left: 0;
  right: 0;
  background: var(--gl-surface);
  border: 1.5px solid var(--gl-amber);
  border-radius: var(--gl-radius);
  box-shadow: 0 4px 16px rgba(0,0,0,.12);
  z-index: 300;
  max-height: 220px;
  overflow-y: auto;
}

.gl-rezept-ac-item {
  padding: 8px 12px;
  cursor: pointer;
  border-bottom: 1px solid var(--gl-border);
  transition: background .1s;
}

.gl-rezept-ac-item:hover {
  background: var(--gl-bg);
}

.gl-rezept-ac-item:last-child {
  border-bottom: none;
}

/* ── Kosten-Bar ─────────────────────────────────── */
.gl-rezept-cost-summary {
  display: flex;
  align-items: center;
  gap: 24px;
}

.gl-cost-bar-container {
  flex: 1;
}

.gl-cost-bar {
  height: 8px;
  background: var(--gl-border);
  border-radius: 99px;
  overflow: visible;
  position: relative;
}

.gl-cost-bar__fill {
  height: 100%;
  background: linear-gradient(to right, var(--gl-green), var(--gl-amber), var(--gl-red));
  border-radius: 99px;
  transition: width .4s ease;
}

.gl-cost-bar__marker {
  position: absolute;
  top: -4px;
  width: 2px;
  height: 16px;
  background: var(--gl-text-muted);
  border-radius: 1px;
}

/* ── Zurueck-Button ─────────────────────────────── */
#gl-rezept-back {
  margin-bottom: 16px;
}

/* ═══════════════════════════════════════════════════
   Allergen-Badges (allergen-badge.js)
═══════════════════════════════════════════════════ */

.gl-allergen-section {
  margin-bottom: 12px;
}

.gl-allergen-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.gl-allergen {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  border-radius: 12px;
  font-size: 13px;
  font-weight: 500;
  font-family: var(--gl-font-ui);
  transition: all var(--gl-transition);
  white-space: nowrap;
}

.gl-allergen__icon {
  font-size: 14px;
}

.gl-allergen__label {
  font-size: 12px;
}

.gl-allergen__code {
  font-family: var(--gl-font-mono);
  font-size: 11px;
  font-weight: 700;
  min-width: 16px;
  text-align: center;
}

.gl-allergen__confidence {
  font-size: 8px;
  margin-left: 2px;
}

.gl-allergen--active {
  background: #FEE2E2;
  color: #991B1B;
  border: 1px solid #FECACA;
}

.gl-allergen--inactive {
  background: #F3F4F6;
  color: #9CA3AF;
  border: 1px solid #E5E7EB;
}

.gl-allergen--compact {
  padding: 2px 8px;
  font-size: 12px;
}

.gl-allergen--additive {
  background: var(--gl-surface);
  color: var(--gl-text-muted);
  border: 1px solid var(--gl-border);
}

/* ── Confidence-Bar ─────────────────────────────── */
.gl-confidence-bar {
  flex: 1;
  height: 6px;
  background: var(--gl-border);
  border-radius: 99px;
  overflow: hidden;
}

.gl-confidence-bar__fill {
  height: 100%;
  border-radius: 99px;
  transition: width .4s ease;
}

/* ═══════════════════════════════════════════════════
   Bulk-Mapping (mapping-bulk.js)
═══════════════════════════════════════════════════ */

.gl-bulk-section {
  margin-top: 32px;
}

.gl-bulk-group {
  padding: 16px;
  border: 1px solid var(--gl-border);
  border-radius: var(--gl-radius-lg);
  background: var(--gl-surface);
  transition: opacity .3s ease;
}

.gl-bulk-group__header {
  margin-bottom: 12px;
}

.gl-bulk-group__items {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 16px;
}

.gl-bulk-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  border-radius: var(--gl-radius);
  border: 1px solid var(--gl-border);
  cursor: pointer;
  transition: background var(--gl-transition);
  font-size: 14px;
}

.gl-bulk-item:hover {
  background: var(--gl-bg);
}

.gl-bulk-item input[type="checkbox"] {
  width: 16px;
  height: 16px;
  accent-color: var(--gl-amber);
  flex-shrink: 0;
}

.gl-bulk-item__info {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.gl-bulk-item__title {
  font-weight: 500;
  font-family: var(--gl-font-mono);
  font-size: 13px;
}

.gl-bulk-item__supplier {
  font-size: 12px;
  color: var(--gl-text-muted);
}

.gl-bulk-group__actions {
  display: flex;
  align-items: center;
  gap: 10px;
}

.gl-bulk-group__msg {
  margin-top: 10px;
  font-size: 13px;
  font-weight: 500;
  padding: 8px 12px;
  border-radius: var(--gl-radius);
}

.gl-bulk-msg--success {
  background: var(--gl-green-light);
  color: var(--gl-green);
}

.gl-bulk-msg--error {
  background: var(--gl-red-light);
  color: var(--gl-red);
}

/* ── Bulk Mobile ────────────────────────────────── */
@media (max-width: 640px) {
  .gl-rezept-app { padding: 16px; }
  .gl-rezept-grid { grid-template-columns: 1fr; }

  .gl-rezept-detail-header { flex-direction: column; }

  .gl-rezept-ingredient-header,
  .gl-rezept-ingredient-row {
    grid-template-columns: 1fr;
    gap: 4px;
  }

  .gl-rezept-ingredient-header { display: none; }

  .gl-rezept-ingredient-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    padding: 8px 0;
    border-bottom: 1px solid var(--gl-border);
  }

  .gl-rezept-ing-search-wrap { width: 100%; }

  .gl-rezept-cost-summary {
    flex-direction: column;
    align-items: flex-start;
  }

  .gl-cost-bar-container { width: 100%; }

  .gl-bulk-group__actions {
    flex-direction: column;
    align-items: stretch;
  }
}

/* ═══════════════════════════════════════════════════
   Legal Onboarding — gl-lo__*
═══════════════════════════════════════════════════ */

.gl-legal-onboarding-app {
  font-family: var(--gl-font-ui);
  color: var(--gl-text);
  max-width: 640px;
  margin: 0 auto;
  padding: 32px 16px;
}

.gl-lo__loading {
  text-align: center;
  padding: 64px 0;
  color: var(--gl-text-muted);
}

.gl-lo__spinner {
  width: 32px;
  height: 32px;
  border: 3px solid var(--gl-border);
  border-top-color: var(--gl-amber);
  border-radius: 50%;
  margin: 0 auto 16px;
  animation: gl-lo-spin 0.8s linear infinite;
}

@keyframes gl-lo-spin {
  to { transform: rotate(360deg); }
}

.gl-lo__card {
  background: var(--gl-surface);
  border: 1px solid var(--gl-border);
  border-radius: var(--gl-radius-lg);
  padding: 32px;
  box-shadow: var(--gl-shadow);
}

.gl-lo__card--center {
  text-align: center;
}

.gl-lo__header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
}

.gl-lo__step-badge {
  width: 32px;
  height: 32px;
  background: var(--gl-amber);
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 14px;
  flex-shrink: 0;
}

.gl-lo__title {
  font-size: 20px;
  font-weight: 700;
  margin: 0;
}

.gl-lo__desc {
  color: var(--gl-text-muted);
  font-size: 14px;
  line-height: 1.6;
  margin: 8px 0 16px;
}

.gl-lo__desc--muted {
  color: var(--gl-text-light);
  font-size: 13px;
}

.gl-lo__error {
  background: var(--gl-red-light);
  color: var(--gl-red);
  padding: 10px 14px;
  border-radius: var(--gl-radius);
  font-size: 13px;
  margin-bottom: 16px;
}

/* Form */
.gl-lo__form {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.gl-lo__label {
  font-size: 13px;
  font-weight: 600;
  color: var(--gl-text);
}

.gl-lo__input {
  padding: 10px 14px;
  border: 1px solid var(--gl-border);
  border-radius: var(--gl-radius);
  font-family: var(--gl-font-ui);
  font-size: 14px;
  transition: border-color var(--gl-transition);
}

.gl-lo__input:focus {
  outline: none;
  border-color: var(--gl-amber);
  box-shadow: 0 0 0 3px var(--gl-amber-light);
}

/* Buttons */
.gl-lo__btn {
  padding: 12px 24px;
  border: none;
  border-radius: var(--gl-radius);
  font-family: var(--gl-font-ui);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: all var(--gl-transition);
}

.gl-lo__btn--primary {
  background: var(--gl-amber);
  color: #fff;
}

.gl-lo__btn--primary:hover:not(:disabled) {
  background: var(--gl-amber-dark);
}

.gl-lo__btn--primary:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.gl-lo__btn--full {
  width: 100%;
  margin-top: 16px;
}

.gl-lo__btn--ghost {
  background: transparent;
  color: var(--gl-text-muted);
  border: 1.5px solid var(--gl-border-dark);
}

.gl-lo__btn--ghost:hover:not(:disabled) {
  background: var(--gl-bg);
  color: var(--gl-text);
  border-color: var(--gl-text-muted);
}

/* Icon circles */
.gl-lo__icon-circle {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 16px;
}

.gl-lo__icon-circle--amber {
  background: var(--gl-amber-light);
  color: var(--gl-amber);
}

.gl-lo__icon-circle--green {
  background: var(--gl-green-light);
  color: var(--gl-green);
}

/* Document cards */
.gl-lo__doc {
  border: 1px solid var(--gl-border);
  border-radius: var(--gl-radius);
  margin: 16px 0;
  overflow: hidden;
}

.gl-lo__doc-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  background: var(--gl-bg);
  border-bottom: 1px solid var(--gl-border);
}

.gl-lo__doc-status {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--gl-border);
  color: var(--gl-text-muted);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 700;
  flex-shrink: 0;
}

.gl-lo__doc-status--done {
  background: var(--gl-green);
  color: #fff;
}

.gl-lo__doc-title {
  font-size: 14px;
  font-weight: 600;
  margin: 0;
  flex: 1;
}

.gl-lo__doc-version {
  font-family: var(--gl-font-mono);
  font-size: 12px;
  color: var(--gl-text-light);
}

.gl-lo__doc-content {
  max-height: 300px;
  overflow-y: auto;
  padding: 16px;
  font-size: 13px;
  line-height: 1.7;
  color: var(--gl-text);
  border-bottom: 1px solid var(--gl-border);
  background: #fafaf8;
}

.gl-lo__doc-scroll-hint {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 8px 16px;
  background: var(--gl-amber-light);
  color: var(--gl-amber-dark);
  font-size: 12px;
  font-weight: 500;
  transition: all .3s ease;
}

.gl-lo__doc-scroll-hint--done {
  background: var(--gl-green-light);
  color: var(--gl-green);
}

.gl-lo__doc-checkbox {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  background: var(--gl-bg);
  font-size: 13px;
  font-weight: 500;
  color: var(--gl-text);
  cursor: pointer;
  user-select: none;
}

.gl-lo__doc-checkbox input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: var(--gl-green);
  flex-shrink: 0;
  cursor: pointer;
}

.gl-lo__doc-checkbox input[type="checkbox"]:disabled {
  cursor: not-allowed;
  opacity: 0.4;
}

.gl-lo__doc-checkbox--disabled {
  color: var(--gl-text-light);
  cursor: not-allowed;
}

.gl-lo__submit-area {
  margin-top: 24px;
  padding: 16px;
  border-top: 2px solid var(--gl-amber, #D4820A);
  text-align: center;
}


/* LMIV Modal Overlay */
.gl-lo__overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(26, 23, 20, 0.6);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10000;
  padding: 16px;
}

.gl-lo__modal {
  background: var(--gl-surface);
  border-radius: var(--gl-radius-lg);
  padding: 32px;
  max-width: 480px;
  width: 100%;
  box-shadow: var(--gl-shadow-lg);
  text-align: center;
}

.gl-lo__modal-icon {
  margin-bottom: 16px;
}

.gl-lo__modal-title {
  font-size: 18px;
  font-weight: 700;
  margin: 0 0 12px;
}

.gl-lo__modal-text {
  font-size: 14px;
  line-height: 1.6;
  color: var(--gl-text);
  margin: 0 0 12px;
}

.gl-lo__modal-text--muted {
  color: var(--gl-text-muted);
  font-size: 13px;
}

/* Activation Progress Indicator */
.gl-lo__activation-progress {
  text-align: center;
  padding: 8px 0 4px;
}
.gl-lo__progress-spinner {
  width: 40px; height: 40px;
  margin: 0 auto 16px;
  border: 3px solid var(--gl-border);
  border-top-color: var(--gl-red);
  border-radius: 50%;
  animation: gl-spin 0.8s linear infinite;
}
@keyframes gl-spin { to { transform: rotate(360deg); } }
.gl-lo__progress-title {
  font-size: 15px;
  font-weight: 600;
  color: var(--gl-text);
  margin: 0 0 16px;
}
.gl-lo__progress-steps {
  text-align: left;
  max-width: 280px;
  margin: 0 auto;
}
.gl-lo__progress-step {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 0;
  font-size: 13px;
  color: var(--gl-text-light);
  transition: color 0.3s;
}
.gl-lo__progress-dot {
  display: inline-block;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--gl-border);
  flex-shrink: 0;
  transition: background 0.3s;
}
.gl-lo__progress-step.active {
  color: var(--gl-text);
  font-weight: 500;
}
.gl-lo__progress-step.active .gl-lo__progress-dot {
  background: var(--gl-red);
  box-shadow: 0 0 0 3px rgba(200, 16, 46, 0.15);
}
.gl-lo__progress-step.done {
  color: var(--gl-green, #38A169);
}
.gl-lo__progress-step.done .gl-lo__progress-dot {
  background: var(--gl-green, #38A169);
}

/* Mobile */
@media (max-width: 600px) {
  .gl-legal-onboarding-app {
    padding: 16px 12px;
  }

  .gl-lo__card {
    padding: 20px 16px;
  }

  .gl-lo__modal {
    padding: 24px 16px;
  }

  .gl-lo__doc-content {
    max-height: 200px;
  }
}

/* Google OAuth Button */
.gl-lo__btn--google {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 12px 24px;
  background: #fff;
  border: 1px solid var(--gl-border);
  border-radius: var(--gl-radius);
  font-family: var(--gl-font-ui);
  font-size: 14px;
  font-weight: 600;
  color: var(--gl-text);
  cursor: pointer;
  transition: all var(--gl-transition);
}

.gl-lo__btn--google:hover {
  border-color: var(--gl-border-dark);
  box-shadow: var(--gl-shadow);
}

.gl-lo__divider {
  display: flex;
  align-items: center;
  margin: 20px 0;
  color: var(--gl-text-light);
  font-size: 13px;
}

.gl-lo__divider::before,
.gl-lo__divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--gl-border);
}

.gl-lo__divider span {
  padding: 0 12px;
}

/* Slug Input Row */
.gl-lo__slug-row {
  display: flex;
  align-items: center;
  gap: 0;
  border: 1px solid var(--gl-border);
  border-radius: var(--gl-radius);
  overflow: hidden;
  transition: border-color var(--gl-transition);
}

.gl-lo__slug-row:focus-within {
  border-color: var(--gl-amber);
  box-shadow: 0 0 0 3px var(--gl-amber-light);
}

.gl-lo__input--slug {
  border: none;
  border-radius: 0;
  flex: 1;
  min-width: 0;
}

.gl-lo__input--slug:focus {
  box-shadow: none;
  border-color: transparent;
}

.gl-lo__slug-suffix {
  padding: 10px 14px 10px 0;
  font-size: 14px;
  color: var(--gl-text-light);
  white-space: nowrap;
  background: var(--gl-surface);
  font-family: var(--gl-font-ui);
}

.gl-lo__slug-status {
  font-size: 13px;
  min-height: 20px;
  margin-top: -4px;
  margin-bottom: 4px;
}

/* Set Password App */
.gl-set-password-app {
  font-family: var(--gl-font-ui);
  color: var(--gl-text);
  max-width: 480px;
  margin: 0 auto;
  padding: 32px 16px;
}

@media (max-width: 600px) {
  .gl-lo__slug-suffix {
    font-size: 12px;
    padding-right: 10px;
  }

  .gl-lo__slug-row {
    flex-wrap: nowrap;
  }
}

/* ═══════════════════════════════════════════════════
   Food-Cost / Wareneinsatz
═══════════════════════════════════════════════════ */

.gl-fc-mono {
  font-family: var(--gl-font-mono, 'DM Mono', monospace);
}

/* Summary Bar */
.gl-fc-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 24px;
  padding: 20px 24px;
  background: var(--gl-surface, #fff);
  border: 1px solid var(--gl-border, #E2DDD8);
  border-radius: 12px;
  margin-bottom: 16px;
  align-items: center;
}

.gl-fc-stat {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.gl-fc-stat__val {
  font-family: var(--gl-font-mono, 'DM Mono', monospace);
  font-size: 24px;
  font-weight: 600;
  color: var(--gl-text, #1A1714);
}

.gl-fc-stat__label {
  font-size: 12px;
  color: var(--gl-text-muted, #7A7068);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.gl-fc-stat--info {
  flex-direction: row;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: var(--gl-text-muted, #7A7068);
}

/* Status Dots */
.gl-fc-dot {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  vertical-align: middle;
}

.gl-fc-dot--green   { background: #38A169; }
.gl-fc-dot--yellow  { background: #D69E2E; }
.gl-fc-dot--red     { background: #E53E3E; }

/* Estimated dots: striped pattern */
.gl-fc-dot--green-est  { background: repeating-linear-gradient(45deg, #38A169, #38A169 2px, #68D391 2px, #68D391 4px); }
.gl-fc-dot--yellow-est { background: repeating-linear-gradient(45deg, #D69E2E, #D69E2E 2px, #ECC94B 2px, #ECC94B 4px); }
.gl-fc-dot--red-est    { background: repeating-linear-gradient(45deg, #E53E3E, #E53E3E 2px, #FC8181 2px, #FC8181 4px); }

/* Estimated badge */
.gl-fc-est-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  font-size: 14px;
  font-weight: 700;
  line-height: 1;
  color: #744210;
  background: #FEFCBF;
  border: 1px solid #ECC94B;
  border-radius: 50%;
}

/* Filter Buttons */
.gl-fc-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 16px;
}

.gl-fc-filters button {
  padding: 6px 16px;
  border: 1px solid var(--gl-border, #E2DDD8);
  border-radius: 8px;
  background: var(--gl-surface, #fff);
  color: var(--gl-text-muted, #7A7068);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.15s;
}

.gl-fc-filters button:hover {
  border-color: var(--gl-amber, #D4820A);
  color: var(--gl-text, #1A1714);
}

.gl-fc-filter--active {
  background: var(--gl-amber, #D4820A) !important;
  color: #fff !important;
  border-color: var(--gl-amber, #D4820A) !important;
}

/* Table */
.gl-fc-table-wrap {
  overflow-x: auto;
  margin-bottom: 16px;
}

.gl-fc-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--gl-surface, #fff);
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid var(--gl-border, #E2DDD8);
}

.gl-fc-table thead th {
  padding: 10px 14px;
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--gl-text-muted, #7A7068);
  background: var(--gl-bg, #F7F5F2);
  border-bottom: 1px solid var(--gl-border, #E2DDD8);
  cursor: pointer;
  user-select: none;
  white-space: nowrap;
}

.gl-fc-table thead th:hover {
  color: var(--gl-text, #1A1714);
}

.gl-fc-sorted-asc::after  { content: ' \u25B2'; font-size: 10px; }
.gl-fc-sorted-desc::after { content: ' \u25BC'; font-size: 10px; }

.gl-fc-table tbody td {
  padding: 10px 14px;
  font-size: 14px;
  border-bottom: 1px solid var(--gl-border, #E2DDD8);
  color: var(--gl-text, #1A1714);
}

.gl-fc-row {
  cursor: pointer;
  transition: background 0.15s;
}

.gl-fc-row:hover {
  background: var(--gl-bg, #F7F5F2);
}

.gl-fc-row--estimated {
  background: #FFFBEB;
}

.gl-fc-row--estimated:hover {
  background: #FEF3C7;
}

/* Coverage labels */
.gl-fc-coverage-low {
  font-family: var(--gl-font-mono, 'DM Mono', monospace);
  font-size: 13px;
  color: #C05621;
}

.gl-fc-coverage-full {
  font-family: var(--gl-font-mono, 'DM Mono', monospace);
  font-size: 13px;
  color: #38A169;
}

/* Drill-down Panel */
.gl-fc-drill {
  background: var(--gl-surface, #fff);
  border: 1px solid var(--gl-border, #E2DDD8);
  border-radius: 12px;
  padding: 24px;
  margin-top: 16px;
}

.gl-fc-drill-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 16px;
}

.gl-fc-drill-header h3 {
  margin: 0;
  font-size: 18px;
  font-weight: 600;
}

.gl-fc-btn-close {
  padding: 6px 16px;
  border: 1px solid var(--gl-border, #E2DDD8);
  border-radius: 8px;
  background: var(--gl-surface, #fff);
  color: var(--gl-text-muted, #7A7068);
  font-size: 13px;
  cursor: pointer;
}

.gl-fc-btn-close:hover {
  border-color: var(--gl-red, #C53030);
  color: var(--gl-red, #C53030);
}

/* Drill-down Table */
.gl-fc-drill-table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 16px;
}

.gl-fc-drill-table thead th {
  padding: 8px 12px;
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--gl-text-muted, #7A7068);
  background: var(--gl-bg, #F7F5F2);
  border-bottom: 1px solid var(--gl-border, #E2DDD8);
}

.gl-fc-drill-table tbody td {
  padding: 8px 12px;
  font-size: 13px;
  border-bottom: 1px solid var(--gl-border, #E2DDD8);
}

.gl-fc-drill-table .gl-fc-row--estimated td {
  background: #FFFBEB;
}

.gl-fc-code {
  font-size: 10px;
  color: var(--gl-text-muted, #7A7068);
}

/* Source labels in drill-down */
.gl-fc-source-real {
  font-size: 11px;
  padding: 2px 8px;
  border-radius: 10px;
  background: #C6F6D5;
  color: #276749;
}

.gl-fc-source-est {
  font-size: 11px;
  padding: 2px 8px;
  border-radius: 10px;
  background: #FEFCBF;
  color: #744210;
}

.gl-fc-source-missing {
  font-size: 11px;
  padding: 2px 8px;
  border-radius: 10px;
  background: #FED7D7;
  color: #9B2C2C;
}

/* Drill-down Summary */
.gl-fc-drill-summary {
  padding: 12px 16px;
  background: var(--gl-bg, #F7F5F2);
  border-radius: 8px;
  font-size: 14px;
  margin-bottom: 8px;
}

.gl-fc-drill-breakdown {
  font-size: 12px;
  color: var(--gl-text-muted, #7A7068);
}

.gl-fc-drill-hint {
  padding: 10px 16px;
  background: #EBF8FF;
  border: 1px solid #BEE3F8;
  border-radius: 8px;
  font-size: 13px;
  color: #2A4365;
  margin-top: 8px;
}

/* Missing price indicators (legacy) */
.gl-fc-missing {
  font-size: 11px;
  padding: 2px 8px;
  border-radius: 10px;
  background: #FED7D7;
  color: #9B2C2C;
  margin-left: 4px;
}

.gl-fc-no-price td {
  color: var(--gl-text-muted, #7A7068);
  font-style: italic;
}

/* Responsive */
@media (max-width: 768px) {
  .gl-fc-summary {
    gap: 16px;
    padding: 16px;
  }
  .gl-fc-stat__val {
    font-size: 20px;
  }
  .gl-fc-table thead th,
  .gl-fc-table tbody td {
    padding: 8px 10px;
    font-size: 13px;
  }
}
