:root{--bg:#f7f3ec;--panel:#fffaf3;--ink:#2f2a24;--muted:#7c7065;--line:#e3d7c8;--accent:#8d5d36;--soft:#eee2d1;--danger:#9a3a2f}*{box-sizing:border-box}body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,sans-serif;background:var(--bg);color:var(--ink);display:flex;min-height:100vh}.sidebar{width:270px;background:#2d251f;color:#fff;padding:28px 22px;position:sticky;top:0;height:100vh}.brand{display:flex;gap:12px;align-items:center;margin-bottom:34px}.brandmark{display:grid;place-items:center;width:42px;height:42px;border-radius:14px;background:#c89563;color:#241c17;font-weight:900}.brand small{display:block;color:#cbbdad;margin-top:3px}.nav{width:100%;display:block;text-align:left;margin:8px 0;padding:13px 14px;border:0;border-radius:14px;background:transparent;color:#e9dfd4;cursor:pointer;font-size:15px}.nav.active,.nav:hover{background:#46382e}.stats{margin-top:32px;padding:16px;border:1px solid #604f43;border-radius:18px;color:#d8cabd;font-size:14px}main{flex:1;padding:34px;min-width:0}.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.eyebrow{text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-size:12px;margin:0 0 6px}h1{margin:0;font-size:36px}h2{margin-top:0}.view{display:none}.view.active{display:block}.card{background:var(--panel);border:1px solid var(--line);border-radius:24px;padding:22px;box-shadow:0 18px 40px rgba(68,45,26,.06)}.filters{display:grid;grid-template-columns:1fr 220px 140px;gap:12px;margin-bottom:18px}.layout{display:grid;grid-template-columns:minmax(280px,1fr) 440px;gap:18px}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}.recipe-card{background:#fff;border:1px solid var(--line);border-radius:22px;overflow:hidden;cursor:pointer;transition:.15s}.recipe-card:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(68,45,26,.08)}.thumb{height:145px;background:linear-gradient(135deg,#dcc6a7,#f8e8d1);display:grid;place-items:center;color:#7b604a;font-size:42px;font-weight:800}.thumb img{width:100%;height:100%;object-fit:cover}.recipe-card .body{padding:16px}.meta,.chips{display:flex;gap:7px;flex-wrap:wrap;color:var(--muted);font-size:13px}.chip{background:var(--soft);border-radius:999px;padding:5px 9px;color:#6d5745}.detail{position:sticky;top:24px;max-height:calc(100vh - 48px);overflow:auto}.detail.empty{display:grid;place-items:center;color:var(--muted);min-height:250px}.hero{height:210px;border-radius:18px;background:linear-gradient(135deg,#d8bb91,#fff1dc);overflow:hidden;margin-bottom:16px}.hero img{width:100%;height:100%;object-fit:cover}.detail h2{margin-bottom:8px}.ingredients{padding-left:18px}.steps{counter-reset:step;list-style:none;padding:0}.steps li{counter-increment:step;margin:12px 0;padding-left:44px;position:relative}.steps li:before{content:counter(step);position:absolute;left:0;top:-2px;width:30px;height:30px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center}.form{max-width:1100px}.form-head,.actions{display:flex;justify-content:space-between;align-items:center;gap:12px}.two{display:grid;grid-template-columns:1fr 1fr;gap:14px}.four{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}label{display:block;color:var(--muted);font-size:13px;margin:10px 0}input,select,textarea{width:100%;padding:12px 13px;border:1px solid var(--line);border-radius:13px;background:#fff;color:var(--ink);font:inherit;margin-top:6px}textarea{min-height:92px;resize:vertical}.row{display:grid;grid-template-columns:1.4fr .6fr .6fr 1fr 40px;gap:10px;align-items:end}.step-row{display:grid;grid-template-columns:1fr 120px 40px;gap:10px;align-items:end}button,.button{border:0;border-radius:14px;padding:12px 16px;font-weight:700;cursor:pointer;text-decoration:none;display:inline-block}.primary{background:var(--accent);color:#fff}.ghost{background:var(--soft);color:#604832}.danger{background:#f1d8d3;color:var(--danger)}.check{display:flex;gap:8px;align-items:center}.check input{width:auto;margin:0}.shopping-group{border-top:1px solid var(--line);padding-top:12px;margin-top:12px}@media(max-width:1000px){body{display:block}.sidebar{position:relative;width:auto;height:auto}.layout,.filters,.two,.four{grid-template-columns:1fr}.detail{position:static}.row,.step-row{grid-template-columns:1fr}}@media print{.sidebar,.topbar,.filters,.nav,button,.button{display:none!important}main{padding:0}.card{box-shadow:none;border:0}.view{display:block}.view:not(.active){display:none}}
.image-upload{display:grid;grid-template-columns:1fr 260px;gap:14px;align-items:end}.image-preview{min-height:118px;border:1px dashed var(--line);border-radius:16px;background:#fff;display:grid;place-items:center;color:var(--muted);overflow:hidden;text-align:center;padding:8px}.image-preview img{width:100%;height:120px;object-fit:cover;border-radius:12px}.image-preview span{display:block;margin-top:6px;font-size:12px}.hero-placeholder{height:100%;display:grid;place-items:center;font-size:64px;font-weight:900;color:#8d5d36}.planner-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:14px;margin:18px 0}.planner-day{background:#fff;border:1px solid var(--line);border-radius:18px;padding:14px}.planner-day h3{margin-top:0}.planned-item{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--soft);border-radius:12px;padding:9px 10px;margin:8px 0}.planned-item button{padding:6px 10px}.muted{color:var(--muted)}@media(max-width:1000px){.image-upload{grid-template-columns:1fr}}

.pdf-text {
  min-height: 340px;
  font-family: Consolas, 'Courier New', monospace;
  white-space: pre-wrap;
}
.import-preview {
  border: 1px dashed var(--line);
  border-radius: 18px;
  padding: 16px;
  background: #fffaf2;
}
.muted { color: var(--muted); }


.pdf-dropzone{border:2px dashed var(--line);border-radius:20px;background:#fff;padding:18px;margin:12px 0;transition:.15s}.pdf-dropzone strong{display:block;font-size:18px}.pdf-dropzone span{display:block;color:var(--muted);margin:4px 0 10px}.pdf-dropzone.dragover{background:#fff3df;border-color:var(--accent);box-shadow:0 0 0 4px rgba(141,93,54,.12)}
.row.ingredient-row{grid-template-columns:90px 1.4fr .55fr .55fr .9fr 40px}.step-row{grid-template-columns:90px 1fr 120px 40px}.heading-check{align-self:center;margin-bottom:14px}.marked-heading{background:#fff6e8;border:1px dashed var(--accent);border-radius:16px;padding:8px}.ingredient-heading{list-style:none;margin:22px 0 10px -18px;padding-top:8px;font-weight:800;font-size:1.05rem;color:var(--accent);border-top:1px solid var(--line)}.steps .step-heading{counter-increment:none;list-style:none;margin:28px 0 12px;padding-left:0;font-weight:800;font-size:1.08rem;color:var(--accent);border-top:1px solid var(--line);padding-top:14px}.steps .step-heading:before{display:none}.import-preview .ingredient-heading,.import-preview .step-heading{margin-left:0}
@media(max-width:1000px){.row.ingredient-row,.step-row{grid-template-columns:1fr}.heading-check{margin-bottom:0}}

/* V7: bessere Kartenbilder und Rezeptarchiv Professional */
.recipe-card{display:flex;flex-direction:column;min-height:0}.recipe-card .body{background:#fff;position:relative;z-index:2;min-height:130px}.thumb{height:132px;min-height:132px;max-height:132px;overflow:hidden;flex:0 0 132px}.thumb img{display:block;width:100%;height:100%;object-fit:cover;object-position:center}.recipe-card h3{margin:.7rem 0 .8rem;line-height:1.18}.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:-6px 0 16px}.gallery img{width:100%;height:82px;object-fit:cover;border-radius:12px;border:1px solid var(--line)}.image-upload{grid-template-columns:1fr 1fr 260px}.row-actions{display:flex;gap:4px;align-items:center}.row-actions button{padding:8px 9px;border-radius:10px}.row.ingredient-row{grid-template-columns:90px 1.4fr .55fr .55fr .9fr 116px}.step-row{grid-template-columns:90px 1fr 120px 116px}.ingredient-row,.step-row{transition:.12s}.ingredient-row:hover,.step-row:hover{box-shadow:0 0 0 2px rgba(141,93,54,.08);border-radius:16px}.trash-note{color:var(--muted)}@media(max-width:1000px){.image-upload,.row.ingredient-row,.step-row{grid-template-columns:1fr}.row-actions{justify-content:flex-start}.gallery{grid-template-columns:repeat(2,1fr)}}


/* V8 PDF/OCR Professional */
.ocr-panel { border: 1px dashed var(--line); border-radius: 18px; padding: 1rem; background: rgba(255,255,255,.55); margin: 1rem 0; }
.import-log { margin-top: 1rem; padding-top: 1rem; border-top: 1px solid var(--line); }
.log-item { padding: .65rem .8rem; border: 1px solid var(--line); border-radius: 12px; margin: .45rem 0; background: #fffaf2; }
.multi-import-card { border: 1px solid var(--line); border-radius: 14px; padding: .85rem; margin: .7rem 0; background: #fff; }
.progressbar { height: 8px; border-radius: 999px; background: #efe3d1; overflow: hidden; margin: .5rem 0; }
.progressbar span { display: block; height: 100%; width: var(--p,0%); background: var(--accent); transition: width .2s; }

/* V9 Kochmodus Professional */
.cookmode{max-width:none;min-height:calc(100vh - 120px)}
.cook-header{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:18px}
.cook-header h2{font-size:34px;margin-bottom:10px}.cook-header-actions{display:flex;gap:8px;flex-wrap:wrap}.cook-layout{display:grid;grid-template-columns:290px minmax(360px,1fr) 270px;gap:18px}.cook-ingredients,.cook-steps,.cook-current{background:#fff;border:1px solid var(--line);border-radius:22px;padding:18px}.cook-ingredients{max-height:calc(100vh - 210px);overflow:auto}.cook-current{display:flex;flex-direction:column;gap:16px;min-height:560px}.cook-counter{color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-size:12px}.cook-step-card{flex:1;display:flex;flex-direction:column;justify-content:center;border-radius:24px;background:#fff8ed;border:1px solid var(--line);padding:32px}.cook-step-card.section-title{background:#f4e2c8}.cook-instruction{font-size:clamp(28px,4vw,56px);line-height:1.18;font-weight:800}.cook-timer{font-size:52px;font-weight:900;text-align:center;background:#2d251f;color:#fff;border-radius:22px;padding:18px}.cook-timer-start{align-self:flex-start;margin-top:22px}.cook-controls{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}.cook-controls button{font-size:18px;padding:16px}.cook-step-index{width:100%;display:flex;gap:10px;align-items:flex-start;text-align:left;margin:8px 0;background:#f7f0e8;color:var(--ink);border:1px solid transparent}.cook-step-index span{flex:0 0 28px;height:28px;border-radius:50%;display:grid;place-items:center;background:var(--soft);font-weight:900}.cook-step-index.active{border-color:var(--accent);background:#fff2df}.cook-step-index.done{opacity:.58;text-decoration:line-through}.cook-empty{display:grid;place-items:center;text-align:center;min-height:420px}.cookmode .progressbar span{width:var(--p)}
body:has(#cookmode.active) .topbar{display:none}body:has(#cookmode.active) main{padding:18px}body:has(#cookmode.active) .sidebar{display:none}body:has(#cookmode.active){display:block}
@media(max-width:1100px){.cook-layout{grid-template-columns:1fr}.cook-ingredients{max-height:none}.cook-header{display:block}.cook-header-actions{margin-top:12px}.cook-controls{grid-template-columns:1fr}.cook-instruction{font-size:32px}}
@media print{.cookmode{display:none!important}}

/* V11 – Intelligente Zutaten & KI-Assistent */
.catalog-list{display:grid;gap:.7rem;margin-top:1rem}.catalog-item,.suggestion{display:grid;grid-template-columns:1fr auto;gap:.25rem .75rem;align-items:center;padding:.8rem;border:1px solid var(--border);border-radius:14px;background:#fffaf3}.catalog-item strong,.suggestion strong{font-size:1rem}.catalog-item span,.suggestion span{color:var(--muted)}.catalog-item small,.suggestion small{grid-column:1 / -1;color:var(--muted)}.assistant-result{margin-top:1rem;padding:1rem;border:1px dashed var(--border);border-radius:16px;background:#fffaf3}.assistant-result h3{margin-top:0}.assistant-result .suggestion button{justify-self:end}.shopping-group small{display:block;margin-left:1.6rem;color:var(--muted);font-size:.8rem}

.bulk-import-panel{border:1px solid var(--line);border-radius:18px;padding:1rem;margin:1rem 0;background:#fffaf4}
.bulk-result{margin-top:1rem}.table-wrap{overflow:auto;max-height:420px;border:1px solid var(--line);border-radius:14px;background:white}.bulk-table{width:100%;border-collapse:collapse;font-size:.9rem}.bulk-table th,.bulk-table td{padding:.65rem;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}.bulk-table th{position:sticky;top:0;background:#fff7ef}.status-badge{display:inline-block;border-radius:999px;padding:.15rem .5rem;background:#eee;font-size:.8rem}.status-badge.imported{background:#d9f7df}.status-badge.recognized{background:#e3f0ff}.status-badge.uncertain{background:#fff0c2}.status-badge.needs_ocr,.status-badge.error,.status-badge.skipped{background:#ffd7d7}
.three{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;margin:12px 0 16px}
.stat-card{border:1px solid var(--border);border-radius:14px;padding:12px;background:#fff7ed}
.stat-card strong{display:block;font-size:1.6rem;color:var(--accent)}
.stat-card span{font-size:.85rem;color:var(--muted)}
.migration-panel{border-color:#d9b68c;background:#fffaf2}
.status-badge.duplicate{background:#fee2e2;color:#991b1b}
.status-badge.imported{background:#dcfce7;color:#166534}
.status-badge.recognized{background:#dbeafe;color:#1d4ed8}
.status-badge.uncertain{background:#fef3c7;color:#92400e}
.status-badge.needs_ocr{background:#f3e8ff;color:#6b21a8}
@media (max-width: 900px){.three{grid-template-columns:1fr}}
.mini-thumb{width:44px;height:34px;object-fit:cover;border-radius:8px;vertical-align:middle;margin-right:8px;border:1px solid var(--line)}
.assistant-result.compact { margin: 1rem 0; padding: .8rem; }
.suggestion small { display:block; color: var(--muted); margin-top:.25rem; }

.dashboard-grid { display:grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap:12px; margin: 16px 0; }
.dashboard-grid > div { background:#fff7ec; border:1px solid #ead8c0; border-radius:16px; padding:14px; }
.dashboard-grid strong { display:block; font-size:1.8rem; color:#9a6234; }
.dashboard-grid span { color:#7c6d61; font-size:.9rem; }
.image-candidates { margin-top:18px; }
.image-group { margin:18px 0; }
.image-grid { display:grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap:14px; }
.image-candidate { background:#fff; border:1px solid #e7d8c8; border-radius:18px; padding:10px; display:flex; flex-direction:column; gap:8px; }
.image-candidate img { width:100%; height:130px; object-fit:cover; border-radius:14px; background:#ead6b8; }
.image-candidate strong { font-size:.92rem; line-height:1.2; }
.image-candidate small { color:#776a60; }

/* V16d Admin-/Lesemodus */
.auth-box { display:flex; gap:.6rem; align-items:center; flex-wrap:wrap; justify-content:flex-end; }
.auth-status { font-size:.85rem; padding:.35rem .7rem; border-radius:999px; background:#f1e6d8; color:#6b4a2f; font-weight:700; }
.admin-active .auth-status { background:#dff3df; color:#266b2c; }
.nav.locked { opacity:.45; }
.nav.locked::after { content:' 🔒'; font-size:.8em; }
.readonly-active #newRecipeTop { display:none; }
.readonly-active .admin-only { display:none !important; }

/* V16c Kochbuch-Auswahl */
.recipe-card { position: relative; }
.cookbook-select {
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: 3;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 8px;
  border-radius: 999px;
  background: rgba(255, 248, 238, 0.92);
  border: 1px solid rgba(154, 106, 58, 0.25);
  color: #6e4a2e;
  font-size: 12px;
  box-shadow: 0 2px 10px rgba(43, 33, 26, 0.08);
}
.cookbook-select input { width: auto; margin: 0; }

/* V16c: Kochbuch-Toolbar direkt im Verzeichnis */
.cookbook-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
}
.cookbook-toolbar .actions {
  margin: 0;
  flex-wrap: wrap;
}
.cookbook-select {
  position: absolute;
  z-index: 2;
  top: .75rem;
  left: .75rem;
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(160,120,80,.25);
  border-radius: 999px;
  padding: .25rem .55rem;
  font-size: .78rem;
  backdrop-filter: blur(4px);
}
.recipe-card { position: relative; }
@media (max-width: 900px) {
  .cookbook-toolbar { align-items: flex-start; flex-direction: column; }
}

/* V18.1 – Bildmanagement Professional */
.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.image-management{display:grid;grid-template-columns:minmax(280px,1.2fr) minmax(280px,1fr);gap:16px;margin:14px 0 18px}.image-dropzone{border:1.5px dashed var(--line);border-radius:22px;background:#fffaf4;padding:16px;cursor:pointer;transition:.16s;min-height:230px;display:flex;flex-direction:column;gap:12px}.image-dropzone:hover,.image-dropzone:focus,.image-dropzone.dragover{border-color:#9a6a3a;background:#fff4e6;box-shadow:0 0 0 4px rgba(154,106,58,.10);outline:none}.dropzone-copy{display:flex;flex-direction:column;gap:4px;color:#7a6a5e}.dropzone-copy strong{font-size:16px;color:#2b211a}.dropzone-copy small{font-size:12px;color:var(--muted)}.compact-actions{margin-top:auto}.compact-actions button{padding:8px 12px}.image-dropzone .image-preview{min-height:150px;height:150px;border:1px solid var(--line);border-radius:18px;background:#fff;display:grid;place-items:center;overflow:hidden;text-align:center;padding:8px}.image-dropzone .image-preview img{width:100%;height:100%;object-fit:cover;border-radius:14px}.gallery-preview{min-height:150px;border:1px solid var(--line);border-radius:18px;background:#fff;display:grid;grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:8px;align-content:start;padding:8px;color:var(--muted)}.gallery-preview img{width:100%;height:72px;object-fit:cover;border-radius:12px;border:1px solid var(--line)}.gallery-preview>span:first-child:last-child{grid-column:1/-1;align-self:center;justify-self:center}.gallery-preview-item{display:flex;align-items:center;justify-content:center;min-height:72px;background:var(--soft);border:1px solid var(--line);border-radius:12px;font-size:11px;text-align:center;padding:6px;color:#6f4b2f;overflow:hidden}.detail-image-drop{position:relative}.detail-image-drop .detail-drop-hint{position:absolute;left:12px;right:12px;bottom:12px;background:rgba(43,33,26,.72);color:#fff;padding:8px 10px;border-radius:12px;font-size:12px;text-align:center;opacity:0;transform:translateY(4px);transition:.15s;pointer-events:none}.detail-image-drop:hover .detail-drop-hint,.detail-image-drop.dragover .detail-drop-hint{opacity:1;transform:translateY(0)}.detail-image-drop.dragover{outline:4px solid rgba(154,106,58,.25);outline-offset:-6px}@media(max-width:1000px){.image-management{grid-template-columns:1fr}.image-dropzone{min-height:200px}}
