/* backecke – detail styles (aus art_detail_app2.php extrahiert)
   Scope: #maincontent & .recipe-sheet
   HINWEIS: Globales body-Override wurde bewusst entfernt, um das Hauptlayout (backecke_main_styles.css) nicht zu überschreiben.
*/
body { background:#fff !important; }

#maincontent .quicklinks-scroll{ font-family: 'Inter'; }

#maincontent .recipe-sheet .recipe-head,
#maincontent .recipe-sheet .section-card,
#maincontent .recipe-sheet .stat-variant{
  background: transparent;
  border: 0;
  box-shadow: none;
  padding-left: clamp(.2rem, .6vw, .75rem);
  padding-right: clamp(.2rem, .6vw, .75rem);
}
#maincontent .recipe-sheet .vote-card,
#maincontent .recipe-sheet .metric-box{ background: none; border:none; }
#maincontent .recipe-sheet .section-card .border-top{ border-top:1px dashed rgba(0,0,0,.08) !important; }

#maincontent .recipe-head {
  background: transparent;
  border-radius:1.25rem;
  padding:1.25rem 1.25rem .75rem;
  box-shadow:none;
  border: 0;
}
#maincontent .recipe-head .display-title{
  font-weight:900; letter-spacing:.2px;
  font-size: clamp(2rem, 2.6vw + 1rem, 3.2rem);
  margin: .15rem 0 .65rem 0; line-height:1.05;
}
#maincontent .recipe-breadcrumb .breadcrumb{ --bs-breadcrumb-divider: "›"; margin:0; }
#maincontent .meta-badges{ display:flex; flex-wrap:wrap; gap:.5rem .6rem; }
#maincontent .meta-badges .badge{
  display:inline-flex; align-items:center; gap:.45rem;
  background:rgba(255,255,255,.8);
  color:#444; font-weight:700;
  border:1px solid rgba(0,0,0,.06);
  padding:.6rem .9rem; border-radius:999px; font-size:0.85rem;
  box-shadow: 0 4px 10px rgba(0,0,0,.04);
  backdrop-filter: blur(2px);
}
#maincontent .meta-badges .bi{ color: var(--bs-primary); }

#maincontent .media-wrap{
  position:relative; border-radius:0.6rem;
  overflow:hidden; margin-top: .75rem;
  box-shadow: 3px 3px 14px rgba(0,0,0,0.24);
  border: 1px solid rgb(0 0 0 / 13%);
}
#maincontent .media-kenburns{ position: relative; width:100%; height: clamp(280px, 44vh, 620px); overflow:hidden; }
#maincontent .media-kenburns img{
  position:absolute; inset:-3%;
  width:106%; height:106%; object-fit:cover;
  transform: scale(1.06);
  animation: kb-slow 22s ease-in-out infinite alternate; will-change: transform;
}
@keyframes kb-slow {
  0%   { transform: scale(1.06) translate3d(0,0,0); }
  50%  { transform: scale(1.10) translate3d(-1.5%, -1%, 0); }
  100% { transform: scale(1.08) translate3d(1.5%, 1%, 0); }
}
#maincontent .media-gradient{
  position:absolute; inset:0; pointer-events:none;
  background: radial-gradient(1200px 50% at 50% -10%, rgba(0,0,0,.35), transparent 60%),
              linear-gradient(180deg, rgba(0,0,0,0) 45%, rgba(0,0,0,.35) 100%);
}
#maincontent .zoom-fab{
  position:absolute; right:.85rem; bottom:.85rem; z-index:2;
  display:inline-flex; align-items:center; gap:.5rem;
  border-radius:999px; padding:.5rem .85rem; font-weight:700;
  border:1px solid rgba(255,255,255,.55);
  background: rgba(255,255,255,.85);
  backdrop-filter: blur(4px);
}
#maincontent .photo-credit{
  position:absolute; left:.95rem; bottom:.9rem; z-index:2;
  color:#fff; text-shadow: 0 1px 3px rgba(0,0,0,.6);
  font-weight:600; letter-spacing:.2px;
}

#maincontent .quick-actions{
  display:flex; flex-wrap:wrap; gap:.6rem .6rem;
  padding: .85rem 1rem 1.1rem;
}
#maincontent .quick-actions .btn{
  border-radius: 999px !important;
  padding: .55rem 1rem;
  font-weight: 700;
  line-height: 1;
  transition: transform .12s ease, box-shadow .15s ease, background-color .15s ease;
  will-change: transform;
}
#maincontent .quick-actions .btn-outline-secondary{
  background:#fff;
  border-color: rgba(0,0,0,.12);
}
#maincontent .quick-actions .btn:hover{ transform: translateY(-1px); box-shadow: 0 6px 16px rgba(0,0,0,.06); }

#maincontent .section-card{ background:transparent; border-radius:1rem; border:0; box-shadow:none; padding: 1.2rem 1.2rem 1rem; }

#maincontent .ingredients-head{
  display:grid; grid-template-columns:auto 1fr; align-items:center; gap:.75rem;
}
@media (min-width: 1200px){ #maincontent .ingredients-head .servings-tools{ justify-self:center; } }
@media (max-width: 991.98px){
  #maincontent .ingredients-head{ grid-template-columns:1fr auto; }
  #maincontent .ingredients-head .servings-tools{ justify-self:end; }
}

#maincontent .ingredients-table.table{
  --bs-table-border-color: transparent;
  --bs-table-striped-bg: transparent;
  --bs-table-striped-color: inherit;
  margin-bottom:.25rem;
  font-size: clamp(1rem, 0.94rem + 0.35vw, 1.15rem);
}
#maincontent .ingredients-table :is(th, td){ border:0 !important; }
#maincontent .ingredients-table thead th{ color:#666; font-weight:700; }
#maincontent .ingredients-table td, #maincontent .ingredients-table th{ vertical-align: middle; }
#maincontent .ingredients-table td.qty{ width: 92px; font-weight:800; }
#maincontent .ingredients-table td.unit{ width: 80px; color:#666; }
#maincontent .ingredients-table tbody tr{ transition: background-color .15s ease; }
#maincontent .ingredients-table tbody tr:hover{ background: rgba(0,0,0,.025); }

#maincontent .servings-tools{
  --h: 36px;
  display:inline-flex; align-items:center; gap:.35rem;
  border:1px solid rgba(0,0,0,.08);
  background:#fff; border-radius:999px;
  padding: .15rem .35rem;
  box-shadow: 0 2px 8px rgba(0,0,0,.06);
}
#maincontent .servings-tools .input-group-text{ border:0; padding:.1rem .5rem; background:transparent; font-weight:800; color:#555; }
#maincontent .servings-tools .btn{
  height:var(--h); width:var(--h); display:inline-flex; align-items:center; justify-content:center;
  border:0; background:#f7f7f7; border-radius:999px;
}
#maincontent .servings-tools .btn:active{ transform: translateY(1px); }
#maincontent .servings-tools .form-control{
  height:var(--h); width:68px; text-align:center; border:0; box-shadow:none; font-weight:900; padding:0 .25rem;
}
#maincontent .servings-tools .form-control:focus{ outline:none; box-shadow:none; }
#maincontent .servings-tools .unit-tail{ border:0; background:transparent; font-weight:800; color:#555; padding:.1rem .6rem; }

.variant-tag{ display:inline-block; font-weight:800; font-size:.75rem; background:#fff; border:1px solid #eee; padding:.2rem .5rem; border-radius:999px; color:#666; box-shadow: 0 1px 4px rgba(0,0,0,.05); }
.nutr-wrapper{ display:grid; gap:1rem; background: linear-gradient(180deg, #fff, #fbfbfb); width:100%; }
@media (min-width: 1200px){ .nutr-wrapper{ width:66%; } }
@media (min-width: 1400px){ .nutr-wrapper{ width:50%; } }

.nutr-card{ padding:1rem; }
.nutr-grid{ display:grid; grid-template-columns: repeat(4,1fr); gap:.75rem; }
@media (max-width: 575.98px){ .nutr-grid{ grid-template-columns: repeat(2,1fr); } }
.nutr-item{ text-align:center; }
.nutr-item .v{ font-weight:900; font-size:clamp(1.05rem, 0.9rem + 0.6vw, 1.35rem); line-height:1.1; }
.nutr-item .l{ color:#6b7280; font-size:.9rem; }
.nutr-v1 .nutr-item{ padding:.8rem; background:#fff; border-radius:16px; }
.nutr-v1 .nutr-item i{ display:block; font-size:1.2rem; color:var(--bs-primary); margin-bottom:.35rem; }

.prep-steps .prep-list{ list-style:none; padding:0; margin:.35rem 0 0 0; }
.prep-steps .prep-item{ display:block; background:transparent; border:0; padding:.45rem 0; margin:0; }
.prep-steps .prep-text{ margin:0; line-height:1.65; font-size: clamp(1rem, 0.96rem + 0.5vw, 1.2rem); }

.prep-metrics{ display:flex; flex-wrap:wrap; gap:8px; justify-content:flex-start; align-items:stretch; margin-top:.35rem; }
.prep-metrics .metric-box{ background: none; box-shadow: none;  border: none; padding:.6rem .7rem; display:flex; flex-direction:column; justify-content:flex-start; flex: 0 1 300px; max-width:300px; min-height:110px; }
.progress.slim{ height: 10px; }

.vote-row { background: linear-gradient(180deg, #fff, #fbfbfb); position:relative; }
@media (min-width: 992px){
  .vote-row{ --divider-w: 50px; }
  .vote-row::after{
    content:""; position:absolute; top:0; bottom:0; left:50%; transform:translateX(-50%);
    width: var(--divider-w); background:#fff; pointer-events:none;
  }
  .vote-row > [class*="col-"]{ padding-left: calc(var(--bs-gutter-x) + var(--divider-w)/2); padding-right: calc(var(--bs-gutter-x) + var(--divider-w)/2); }
}
.vote-row > [class*="col-"]{ display:flex; }
.vote-card{ display:flex; flex-direction:column; border:1px solid rgba(0,0,0,.08); background:#fff; height:100%; }
.vote-card form{ display:flex; flex-direction:column; height:100%; }
.vote-card .btn-row{ margin-left:auto; }

.rating-picker{ display:inline-flex; align-items:center; gap:.35rem; user-select:none; }
.rating-picker .star{ cursor:pointer; line-height:1; font-size:1.5rem; color:#cbcbcb; transition: transform .08s ease, color .12s ease; }
.rating-picker .star:hover{ transform: scale(1.08); color:#FFDB5A; }
.rating-picker .star.active{ color:#FFC107; }

.rating-summary{ display:grid; grid-template-columns: 130px 1fr; gap:1rem; align-items:center; }
@media (max-width: 575.98px){ .rating-summary{ grid-template-columns: 1fr; } }
.avg-badge{ display:flex; flex-direction:column; align-items:center; justify-content:center; }
.avg-badge .avg-num{ font-size:2.4rem; font-weight:900; line-height:.9; }
.avg-badge .avg-stars{ color:#FFC107; font-size:1.1rem; letter-spacing:.15rem; }
.avg-badge .total{ color:#666; font-size:.85rem; }

.dist-row{ display:flex; align-items:center; gap:.6rem; margin:.15rem 0; }
.dist-row .label{ width:22px; text-align:right; color:#777; font-weight:700; }
.dist-row .bar{ flex:1 1 auto; height:12px; border-radius:999px; background:#eee; overflow:hidden; }
.dist-row .bar > span{ display:block; height:100%; width:0%; background:linear-gradient(90deg, #d8f5d8, #a5d6a7); transition:width .35s ease; }
.dist-row .count{ width:60px; text-align:right; color:#777; font-variant-numeric: tabular-nums; }

.section-divider{ position:relative; height:20px; margin: .25rem 0 1.25rem 0; }
.section-divider::before{
  content:""; position:absolute; left:0; right:0; top:50%; transform: translateY(-50%);
  height:1px; background: linear-gradient(90deg, transparent, rgba(0,0,0,.12), transparent);
}
.section-divider .dot{
  position:absolute; left:50%; top:50%; transform: translate(-50%, -50%);
  width:10px; height:10px; border-radius:50%; background:#fff; border:1px solid rgba(0,0,0,.12);
  box-shadow: 0 2px 6px rgba(0,0,0,.06);
}

:root{
  --st-blue:#5e8ef6;
  --st-blue-weak:#eaf1ff;
  --st-blue-border:#cfe0ff;
  --st-blue-grad-start:#a8c8ff;
}
.survey-block{  border-radius:.9rem; padding:1rem;  }
.survey-head{ display:flex; justify-content:space-between; align-items:center; gap:.75rem; margin-bottom:.5rem; }
.survey-head .variant-tag{ background:#f8f9ff; border-color:#e8edff; }
.survey-B .emoji{ font-size:1.5rem; cursor:pointer; filter: grayscale(1) opacity(.8); transition: transform .08s ease, filter .12s ease; }
.survey-B .emoji.active{ filter:none; transform: scale(1.05); }
.survey-B .picker{ display:flex; gap:.5rem; align-items:center; }
.survey-summary{ margin-top:.6rem; }
.survey-meter{
  position:relative; flex:1 1 auto; height:24px; background:#fff; border:1px solid var(--st-blue-border);
  border-radius:999px; box-shadow: inset 0 1px 2px rgba(0,0,0,.04); overflow:hidden;
}
.survey-meter .fill{
  position:absolute; left:0; top:0; bottom:0; width:0%;
  background:linear-gradient(90deg, var(--st-blue-grad-start), var(--st-blue));
  border-radius:inherit; transition:width .35s ease;
}
.survey-meta{ display:flex; justify-content:space-between; align-items:center; margin-top:.35rem; color:#6b7280; font-size:.9rem; }
.survey-actions{ display:flex; gap:.5rem; align-items:center; margin-left:auto; }
.survey-actions .btn-cta{
  background:#f4f5f7; color:var(--bs-primary); border:1px solid #e6e6e6; box-shadow:none;
  transition: background .15s ease, border-color .15s ease, color .15s ease, transform .12s ease;
  border-radius:999px; padding:.45rem .8rem; font-weight:800;
}
.survey-actions .btn-cta:hover{ background:#fff; border-color: var(--bs-primary); color: var(--bs-primary); transform: translateY(-1px); }

.btn-browse{
  border:2px solid var(--bs-secondary);
  color:var(--bs-secondary);
  background:#fff;
  border-radius:999px;
  padding:.55rem 1rem;
  font-weight:800; 
  transition: transform .12s ease, background .15s ease, color .15s ease, box-shadow .15s ease;
  display:inline-flex; align-items:center; gap:.4rem;
}
.btn-browse .bi{ vertical-align: -2px; }
.btn-browse:hover{ background:var(--bs-secondary); color:#fff; transform: translateY(-1px); text-decoration:none; }
.btn-browse-sm{ padding:.45rem .85rem; font-size:.92rem; }

.btn-browse.is-inverted{ background: var(--bs-secondary); color: #fff; border-color: var(--bs-secondary); }
.btn-browse.is-inverted:hover{ background: #fff; color: var(--bs-secondary); border-color: var(--bs-secondary); }

.nav-inline{ display:flex; align-items:center; justify-content:space-between; gap:.75rem; flex-wrap:wrap; }
.nav-inline .btn-group-inline{ display:flex; gap:.5rem; flex-wrap:wrap; margin-left:auto; }
@media (max-width: 575.98px){
  .nav-inline{ align-items:stretch; }
  .nav-inline .btn-group-inline{
    order:1; width:100%; display:flex; justify-content:space-between; gap:.5rem; flex-wrap:nowrap;
  }
  .nav-inline .btn-group-inline .btn{ flex:1 1 48%; min-width:0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
  .nav-inline > .btn-browse.is-inverted{ order:2; align-self:flex-start; margin-top:.5rem; }
}

.btn-cta{
  --shadow: 0 8px 18px rgba(230,81,0,.22);
  border:0; border-radius:999px; padding:.55rem 1rem; font-weight:800; box-shadow: var(--shadow);
  background: linear-gradient(180deg, #FF9800 0%, #E65100 100%); color:#fff;
}
.btn-cta:hover{ filter:brightness(1.05); transform: translateY(-1px); color:#fff; }
.btn-cta:active{ transform: translateY(0); }
.btn-cta .bi{ vertical-align:-3px; }

.stat-group{ display:grid; gap:1rem; background:linear-gradient(180deg, #fff, #fbfbfb); }
.stat-variant{ background:transparent; border:0; border-radius:1rem; box-shadow:none; }
.kpi-tile{
  border-radius:1.25rem; padding:1rem; height:100%;
  display:flex; flex-direction:column; justify-content:center; text-align:center;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(1px);
}
.kpi-tile .kpi-icon{ font-size:1.4rem; color:var(--bs-primary); }
.kpi-tile .kpi-value{ font-weight:800; font-size:1.6rem; line-height:1; margin-top:.25rem; }
.kpi-tile .kpi-sub{ color:#6b7280; font-size:.9rem; }
.kpi-tile .kpi-badge{ display:inline-block; margin-top:.4rem; padding:.15rem .5rem; border-radius:999px; background:#f8f8f8; border:1px solid #eee; font-weight:700; font-size:.85rem; }

/* Inter Variable Font – lokal geladen */
@font-face{
  font-family: "Inter";
  src: url("/media/fonts/inter/InterVariable.woff2") format("woff2");
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}
@font-face{
  font-family: "Inter";
  src: url("/media/fonts/inter/InterVariable-Italic.woff2") format("woff2");
  font-weight: 100 900;
  font-style: italic;
  font-display: swap;
}

#maincontent{
  --ff-inter: 'Inter', system-ui, -apple-system, "Segoe UI", Roboto, Arial, "Noto Sans", "Liberation Sans", sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
#maincontent .display-title,
#maincontent .section-card h2,
#maincontent .stat-variant h2,
#maincontent .vote-card h3,
#maincontent .survey-block h3,
#maincontent .meta-badges .badge,
#maincontent .ingredients-table,
#maincontent .prep-text,
#maincontent .servings-tools,
#maincontent .quick-actions .btn,
#maincontent .kpi-tile{
  font-family: var(--ff-inter) !important;
  letter-spacing: 0;
}

/* Reveal-on-scroll helper (gleicht main) */
[data-reveal]{ opacity:0; transform: translateY(24px) scale(.99); transition: opacity .7s ease, transform .7s ease; }
.reveal-show{ opacity:1; transform: translateY(0) scale(1); }
