/* FindEdition Recipes Enterprise Design System — Platform 22.2.3 */
:root {
  /* Canonical tokens — use --recipes-* only in new rules */
  --recipes-primary: #ea580c;
  --recipes-primary-hover: #c2410c;
  --recipes-primary-dark: #9a3412;
  --recipes-primary-light: #fb923c;
  --recipes-accent: #f59e0b;
  --recipes-accent-soft: #fbbf24;
  --recipes-star: #d97706;
  --recipes-success: #16a34a;
  --recipes-danger: #dc2626;
  --recipes-danger-soft: #b91c1c;
  --recipes-info: #2563eb;
  --recipes-surface: #ffffff;
  --recipes-surface-2: #f8fafc;
  --recipes-surface-3: #f1f5f9;
  --recipes-card: #ffffff;
  --recipes-text: #0f172a;
  --recipes-text-secondary: #334155;
  --recipes-muted: #64748b;
  --recipes-border: #e2e8f0;
  --recipes-border-strong: #cbd5e1;
  --recipes-on-primary: #ffffff;
  --recipes-radius: 1rem;
  --recipes-radius-sm: 0.5rem;
  --recipes-radius-lg: 1.25rem;
  --recipes-shadow: 0 4px 24px rgba(15, 23, 42, 0.08);
  --recipes-shadow-hover: 0 12px 40px rgba(234, 88, 12, 0.15);
  --recipes-shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.04);
  --recipes-primary-tint: rgba(234, 88, 12, 0.1);
  --recipes-primary-tint-strong: rgba(234, 88, 12, 0.15);
  --recipes-primary-border: rgba(234, 88, 12, 0.25);
  --recipes-primary-border-strong: rgba(234, 88, 12, 0.35);
  --recipes-primary-glow: rgba(234, 88, 12, 0.12);
  --recipes-success-tint: rgba(22, 163, 74, 0.12);
  --recipes-danger-tint: rgba(239, 68, 68, 0.12);
  --recipes-danger-border: rgba(239, 68, 68, 0.25);
  --recipes-info-tint: rgba(37, 99, 235, 0.08);
  --recipes-info-border: rgba(37, 99, 235, 0.2);
  --recipes-prep-tint: rgba(59, 130, 246, 0.15);
  --recipes-cook-tint: rgba(234, 88, 12, 0.15);
  --recipes-total-tint: rgba(16, 185, 129, 0.15);
  --recipes-badge-featured-bg: #fef3c7;
  --recipes-badge-featured-text: #92400e;
  --recipes-badge-brand-bg: #fff7ed;
  --recipes-badge-brand-text: #9a3412;
  --recipes-hero-nav-bg: rgba(255, 255, 255, 0.14);
  --recipes-hero-nav-border: rgba(255, 255, 255, 0.4);
  --recipes-font: system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  --recipes-fs-xs: 0.75rem;
  --recipes-fs-sm: 0.875rem;
  --recipes-fs-base: 1rem;
  --recipes-fs-lg: 1.125rem;
  --recipes-fs-xl: 1.75rem;
  --recipes-transition: 0.2s ease;
  --recipes-scroll-offset: 5rem;

  /* Legacy aliases — existing rp-/rdisc-/rc- rules */
  --rp-primary: var(--recipes-primary);
  --rp-primary-dark: var(--recipes-primary-dark);
  --rp-accent: var(--recipes-accent);
  --rp-surface: var(--recipes-surface);
  --rp-surface-2: var(--recipes-surface-2);
  --rp-border: var(--recipes-border);
  --rp-text: var(--recipes-text);
  --rp-muted: var(--recipes-muted);
  --rp-radius: var(--recipes-radius);
  --rp-shadow: var(--recipes-shadow);
  --rp-shadow-hover: var(--recipes-shadow-hover);
}

.recipes-theme {
  color: var(--recipes-text);
  background: var(--recipes-surface-2);
  font-family: var(--recipes-font);
  -webkit-font-smoothing: antialiased;
  overflow-x: clip;
  max-width: 100%;
}

.rp-container,
.rdisc-container,
.rc-container { max-width: 1280px; margin: 0 auto; padding: 0 1rem; }

.rdisc-lead { color: var(--recipes-text-secondary); margin-bottom: 2rem; }
.rdisc-muted,
.rdisc-empty { color: var(--recipes-muted); }

/* Navigation */
.rp-nav { display: flex; flex-wrap: wrap; gap: .375rem .5rem; margin-bottom: 1.5rem; }
.rp-nav a {
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  padding: .5rem 1rem;
  border-radius: 999px;
  font-size: .8125rem;
  font-weight: 600;
  color: var(--recipes-muted);
  border: 1px solid var(--recipes-border);
  background: var(--recipes-surface);
  text-decoration: none;
  transition: color var(--recipes-transition), border-color var(--recipes-transition), background var(--recipes-transition);
  white-space: nowrap;
}
.rp-nav a:hover {
  color: var(--recipes-primary-dark);
  border-color: var(--recipes-primary);
  background: color-mix(in srgb, var(--recipes-primary) 10%, var(--recipes-surface));
}
.rp-nav a.is-active {
  color: var(--recipes-on-primary);
  border-color: var(--recipes-primary);
  background: var(--recipes-primary);
}
.rp-nav a:focus-visible { outline: 2px solid var(--recipes-primary); outline-offset: 2px; }
.rp-nav-end { justify-content: flex-end; margin-left: auto; }

.rp-page-toolbar {
  display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between;
  gap: .75rem 1.25rem; padding: .75rem 0 .5rem; width: 100%;
}
.rp-page-toolbar-start { flex: 1 1 auto; min-width: 0; }
.rp-page-toolbar-start .rp-breadcrumb-bar { padding: 0; }
.rp-page-toolbar-end { flex: 0 1 auto; margin-left: auto; }
.rp-page-toolbar-end .rp-nav { margin-bottom: 0; }
@media (min-width: 768px) {
  .rp-nav a { font-size: .875rem; padding: .5rem 1.125rem; }
}
@media (max-width: 767px) {
  .rp-page-toolbar { flex-direction: column; align-items: stretch; }
  .rp-page-toolbar-end { margin-left: 0; width: 100%; }
  .rp-page-toolbar-end .rp-nav { justify-content: flex-end; overflow-x: auto; flex-wrap: nowrap; padding-bottom: .25rem; -webkit-overflow-scrolling: touch; }
}

.rp-nav-hero {
  justify-content: center;
  margin-bottom: 1.25rem;
  gap: 0.5rem 0.625rem;
  width: 100%;
}
.rp-nav-hero a {
  font-size: 0.9375rem;
  font-weight: 600;
  padding: 0.625rem 1.125rem;
  color: var(--recipes-on-primary);
  border: 1px solid var(--recipes-hero-nav-border);
  background: var(--recipes-hero-nav-bg);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.rp-nav-hero a:hover {
  color: var(--recipes-on-primary);
  border-color: rgba(255, 255, 255, 0.75);
  background: rgba(255, 255, 255, 0.24);
}
.rp-nav-hero a.is-active {
  color: var(--recipes-primary-dark);
  background: var(--recipes-on-primary);
  border-color: var(--recipes-on-primary);
  box-shadow: var(--recipes-shadow-sm);
}
@media (min-width: 768px) {
  .rp-nav-hero { gap: 0.625rem 0.875rem; margin-bottom: 1.5rem; }
  .rp-nav-hero a { font-size: 1rem; padding: 0.75rem 1.375rem; }
}

/* Cards */
.rp-recipe-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 1.25rem; }
.rp-recipe-card {
  background: var(--recipes-card);
  border: 1px solid var(--recipes-border);
  border-radius: var(--recipes-radius);
  overflow: hidden;
  box-shadow: var(--recipes-shadow);
  transition: transform var(--recipes-transition), box-shadow var(--recipes-transition);
  text-decoration: none;
  color: inherit;
  display: block;
}
.rp-recipe-card:hover { transform: translateY(-4px); box-shadow: var(--recipes-shadow-hover); }
.rp-recipe-card-image { position: relative; aspect-ratio: 16/10; background: var(--recipes-surface-2); overflow: hidden; }
.rp-recipe-card-image img { width: 100%; height: 100%; object-fit: cover; }
.rp-recipe-card-body { padding: 1rem; }
.rp-recipe-title { font-weight: 700; font-size: 1rem; margin: 0 0 .25rem; overflow-wrap: anywhere; }
.rp-recipe-subtitle { font-size: .8125rem; color: var(--recipes-muted); margin: 0 0 .75rem; }
.rp-recipe-meta { display: flex; justify-content: space-between; align-items: center; gap: .5rem; }
.rp-price { font-weight: 700; color: var(--recipes-primary); font-size: .9375rem; }
.rp-price-na { color: var(--recipes-muted); font-weight: 500; }
.rp-rating { color: var(--recipes-star); font-size: .8125rem; font-weight: 600; }

.rp-compare-btn {
  position: absolute; top: .5rem; right: .5rem; z-index: 2;
  width: 2rem; height: 2rem; border-radius: 50%; border: none; cursor: pointer;
  background: rgba(255, 255, 255, 0.92); color: var(--recipes-primary);
  box-shadow: var(--recipes-shadow-sm);
  display: flex; align-items: center; justify-content: center;
}
.rp-compare-btn.is-added { background: var(--recipes-primary); color: var(--recipes-on-primary); }

.rp-badge { display: inline-block; padding: .2rem .6rem; border-radius: 999px; font-size: .6875rem; font-weight: 700; text-transform: uppercase; }
.rp-badge-featured { background: var(--recipes-badge-featured-bg); color: var(--recipes-badge-featured-text); }
.rp-badge-brand { background: var(--recipes-badge-brand-bg); color: var(--recipes-badge-brand-text); }
.rp-badge-success { background: var(--recipes-success-tint); color: var(--recipes-success); }

.rp-page-header { margin-bottom: 1.5rem; }
.rp-page-header h1 { font-size: var(--recipes-fs-xl); font-weight: 800; margin: 0 0 .35rem; color: var(--recipes-text); }
.rp-page-header p { margin: 0; color: var(--recipes-muted); }

.rp-questions-page .rp-question-title { font-size: 1.05rem; font-weight: 700; margin: 0 0 .35rem; }
.rp-questions-page .rp-question-title a { color: var(--recipes-text); text-decoration: none; }
.rp-questions-page .rp-question-title a:hover { color: var(--recipes-primary); }
.rp-questions-page .rp-question-excerpt { font-size: .875rem; color: var(--recipes-muted); margin: 0 0 .5rem; }
.rp-questions-page .rp-question-meta { display: flex; flex-wrap: wrap; gap: .5rem; align-items: center; font-size: .75rem; color: var(--recipes-muted); }
.rp-questions-page .rp-question-meta a { color: var(--recipes-primary); text-decoration: none; }

/* Search autocomplete (parity with api.recipes.suggest) */
.rp-suggest-dropdown {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: var(--recipes-card);
  border: 1px solid var(--recipes-border);
  border-radius: 12px;
  box-shadow: var(--recipes-shadow);
  z-index: 50;
  margin-top: 4px;
  max-height: 320px;
  overflow-y: auto;
}
.rp-suggest-item {
  display: flex;
  gap: 0.75rem;
  align-items: center;
  padding: 0.75rem 1rem;
  text-decoration: none;
  color: var(--recipes-text);
  border-bottom: 1px solid var(--recipes-border);
  min-height: 44px;
}
.rp-suggest-item:last-child { border-bottom: none; }
.rp-suggest-item:hover,
.rp-suggest-item:focus-visible {
  background: var(--recipes-primary-tint);
  outline: none;
}
.rp-suggest-item img { border-radius: 8px; object-fit: cover; flex-shrink: 0; }
.rp-suggest-item div { display: flex; flex-direction: column; min-width: 0; }
.rp-suggest-item strong { font-size: 0.9375rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.rp-suggest-item span { font-size: 0.75rem; color: var(--recipes-muted); }
.rp-suggest-icon {
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--recipes-surface-2);
  border-radius: 8px;
  color: var(--recipes-muted);
  flex-shrink: 0;
}

/* Empty states */
.rp-empty-state {
  background: var(--recipes-surface-2);
  border: 1px solid var(--recipes-border);
  border-radius: var(--recipes-radius-lg);
  padding: 3rem 1.5rem;
  text-align: center;
}
.rp-empty-state-icon { font-size: 4rem; color: var(--recipes-muted); margin-bottom: 1rem; opacity: 0.5; }
.rp-empty-state-title { font-size: 1.5rem; font-weight: 700; color: var(--recipes-text); margin: 0 0 0.5rem; }
.rp-empty-state-text { color: var(--recipes-muted); margin: 0 0 1.25rem; }
.rp-empty-state-action {
  display: inline-block;
  background: var(--recipes-primary);
  color: var(--recipes-on-primary);
  padding: 0.75rem 1.5rem;
  border-radius: var(--recipes-radius);
  font-weight: 600;
  text-decoration: none;
  min-height: 44px;
  line-height: 1.25;
}
.rp-empty-state-action:hover { background: var(--recipes-primary-dark); color: var(--recipes-on-primary); }
.rp-empty-state-action:focus-visible {
  outline: 2px solid var(--recipes-primary);
  outline-offset: 2px;
}

/* Focus and interaction polish */
.rp-recipe-card:focus-within {
  outline: 2px solid var(--recipes-primary);
  outline-offset: 2px;
}
.rp-compare-btn:focus-visible {
  outline: 2px solid var(--recipes-primary);
  outline-offset: 2px;
}

/* Opt-in dark mode only — matches Mobiles/Autos enterprise pattern */
.recipes-theme.rp-dark,
html.dark .recipes-theme {
  --recipes-surface: #1e293b;
  --recipes-surface-2: #0f172a;
  --recipes-surface-3: #334155;
  --recipes-card: #1e293b;
  --recipes-border: #334155;
  --recipes-border-strong: #475569;
  --recipes-text: #f1f5f9;
  --recipes-text-secondary: #cbd5e1;
  --recipes-muted: #94a3b8;
  --recipes-shadow: 0 4px 24px rgba(0, 0, 0, 0.25);
  --recipes-shadow-hover: 0 12px 40px rgba(234, 88, 12, 0.2);
  --recipes-primary-tint: rgba(234, 88, 12, 0.18);
  --recipes-primary-tint-strong: rgba(234, 88, 12, 0.22);
  --recipes-primary-glow: rgba(234, 88, 12, 0.2);
  --recipes-badge-brand-bg: rgba(234, 88, 12, 0.2);
  --recipes-badge-brand-text: #fdba74;
  --recipes-badge-featured-bg: rgba(251, 191, 36, 0.2);
  --recipes-badge-featured-text: #fcd34d;
}
.recipes-theme.rp-dark .rp-nav a:hover,
html.dark .recipes-theme .rp-nav a:hover {
  background: var(--recipes-primary-tint);
  color: var(--recipes-primary-light);
}
.recipes-theme.rp-dark .rp-recipe-card-image,
html.dark .recipes-theme .rp-recipe-card-image { background: var(--recipes-surface-3); }

@media (prefers-reduced-motion: reduce) {
  .rp-recipe-card,
  .rp-nav a,
  .rdisc-card,
  .rc-widget-card { transition: none; }
}

@media (prefers-contrast: more) {
  .rp-nav a.is-active { outline: 2px solid currentColor; }
  .rp-nav a:focus-visible { outline-width: 3px; }
}
