:root{
  --bg:#000;
  --surface:#111214;
  --surface-2:#1c1d1f;
  --surface-3:#2a2b2e;
  --line:#2c2d30;
  --text:#f3f4f6;
  --muted:#8a8d93;
  --teal:#2bb6c4;
  --teal-deep:#1f8f9b;
  --tile:#2bafbd;
  --accent:#3a99ff;
  --danger:#e0524a;
  --radius:16px;
  --tabbar-h:84px;
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0;height:100%}
body{
  background:#0a0a0a;
  color:var(--text);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  display:flex;justify-content:center;align-items:stretch;
}

/* Phone frame */
#phone{
  position:relative;
  width:100%;max-width:440px;
  background:var(--bg);
  display:flex;flex-direction:column;
  height:100vh;height:100dvh;
  overflow:hidden;
}
@media(min-width:480px){
  body{align-items:center;padding:16px;background:#161616}
  #phone{height:min(900px,96vh);border-radius:40px;box-shadow:0 0 0 10px #1d1d1f,0 30px 80px rgba(0,0,0,.6);border:1px solid #222}
}

#app{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding-bottom:8px}
#app::-webkit-scrollbar{width:0}

/* ---------- Top bar ---------- */
.topbar{
  position:sticky;top:0;z-index:20;
  background:rgba(0,0,0,.82);backdrop-filter:blur(12px);
  display:flex;align-items:center;gap:10px;
  padding:14px 16px 12px;min-height:60px;
}
.topbar .title{font-size:20px;font-weight:700;flex:1;display:flex;align-items:center;gap:8px}
.topbar .title.center{justify-content:center;text-align:center}
.brand{display:flex;align-items:center;gap:9px;justify-content:center;flex:1;color:var(--teal);font-weight:700;font-size:20px}
.brand svg{width:26px;height:26px}

.round-btn{
  width:42px;height:42px;border-radius:50%;
  background:var(--surface-3);border:none;color:var(--teal);
  display:flex;align-items:center;justify-content:center;cursor:pointer;flex:0 0 auto;
}
.round-btn svg{width:22px;height:22px}
.round-btn:active{background:#3a3b3e}

.back-pill{
  display:inline-flex;align-items:center;gap:4px;
  background:var(--surface-3);color:var(--teal);
  border:none;border-radius:22px;padding:9px 16px 9px 10px;
  font-size:16px;cursor:pointer;font-weight:500;
}
.back-pill svg{width:20px;height:20px}
.pill-btn{
  background:var(--surface-3);color:var(--text);border:none;
  border-radius:22px;padding:10px 20px;font-size:16px;cursor:pointer;font-weight:600;
}
.pill-btn.teal{color:var(--teal)}

/* ---------- Tabs (Rezeptarten / Kategorien ...) ---------- */
.seg{
  display:flex;gap:4px;margin:6px 12px 14px;
  background:var(--surface-2);border-radius:24px;padding:5px;overflow-x:auto;
}
.seg::-webkit-scrollbar{height:0}
.seg button{
  flex:1 0 auto;white-space:nowrap;border:none;background:transparent;color:var(--muted);
  padding:9px 16px;border-radius:20px;font-size:15px;cursor:pointer;font-weight:500;
}
.seg button.active{background:var(--teal);color:#04313a;font-weight:700}

.count-head{
  display:flex;justify-content:center;align-items:center;gap:6px;
  font-size:17px;font-weight:600;margin:2px 0 4px;color:var(--text);cursor:pointer;
}
.count-head svg{width:16px;height:16px;color:var(--muted)}

/* ---------- Tile grid ---------- */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:4px 12px 20px}
.tile{
  position:relative;aspect-ratio:1/1;border-radius:12px;overflow:hidden;
  background:var(--tile);cursor:pointer;border:none;padding:0;color:#fff;text-align:left;
  display:block;
}
.tile img{width:100%;height:100%;object-fit:cover;display:block}
.tile .ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--tile)}
.tile .ph svg{width:46px;height:46px;opacity:.55;color:#0c4a52}
.tile .label{
  position:absolute;left:0;right:0;bottom:0;
  background:var(--teal-deep);color:#fff;
  display:flex;justify-content:space-between;align-items:center;gap:4px;
  padding:7px 9px;font-size:14px;font-weight:600;
}
.tile .label .nm{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tile .label .ct{opacity:.95;font-weight:700}
.tile.solid .label{position:static;height:100%;justify-content:space-between;flex-direction:row;align-items:flex-end}
.tile.solid{background:var(--tile)}
.tile.solid .label{background:transparent;padding:10px;height:100%;align-items:flex-end}

/* recipe list rows */
.rlist{padding:4px 0 12px}
.rrow{
  display:flex;align-items:center;gap:14px;padding:10px 16px;cursor:pointer;border-bottom:1px solid var(--line);
}
.rrow img,.rrow .thumb{width:64px;height:64px;border-radius:10px;object-fit:cover;flex:0 0 auto;background:var(--tile);display:flex;align-items:center;justify-content:center}
.rrow .thumb svg{width:30px;height:30px;color:#0c4a52;opacity:.6}
.rrow .meta{flex:1;min-width:0}
.rrow .meta .t{font-size:16px;font-weight:600}
.rrow .meta .s{font-size:13px;color:var(--muted);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rrow .fav{color:var(--teal);width:22px;height:22px;flex:0 0 auto}

/* ---------- Recipe detail ---------- */
.hero{position:relative;width:100%;aspect-ratio:1/1;max-height:420px;background:var(--tile);overflow:hidden}
.hero img{width:100%;height:100%;object-fit:cover}
.hero .ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center}
.hero .ph svg{width:90px;height:90px;color:#0c4a52;opacity:.5}
.hero .titlewrap{
  position:absolute;left:0;right:0;bottom:0;padding:16px;
  background:linear-gradient(transparent,rgba(0,0,0,.85));
}
.hero h1{margin:0;font-size:24px;font-weight:800;line-height:1.15}
.hero .tags{font-size:14px;color:#cfd2d6;margin-top:4px}

.detail{padding:16px}
.facts{display:grid;grid-template-columns:auto 1fr;gap:10px 16px;margin-bottom:8px}
.facts .k{color:var(--muted);font-size:16px}
.facts .v{font-size:16px}
.facts .v a{color:var(--accent);text-decoration:none;word-break:break-all}
.facts .link{color:var(--accent);cursor:pointer}

/* Portionsgröße: +/- Stepper */
.serv-step{display:inline-flex;align-items:center;gap:10px;vertical-align:middle}
.serv-step button{
  width:30px;height:30px;border-radius:50%;border:1px solid var(--line);
  background:var(--surface-3);color:var(--teal);font-size:20px;line-height:1;
  cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0;flex:0 0 auto;
}
.serv-step button:active{background:#3a3b3e}
.serv-step b{min-width:20px;text-align:center;font-weight:800;font-size:17px}

/* Suche: Icon-Größe, Schnell-Filter, Zeit im Treffer */
.ipt-ico{display:inline-flex;align-items:center;color:var(--muted);flex:0 0 auto}
.ipt-ico svg{width:20px;height:20px}
.search-filters{display:flex;gap:8px;padding:0 16px 8px;flex-wrap:wrap}
.search-filters .chip{display:inline-flex;align-items:center}
.search-filters .chip svg{width:15px;height:15px;margin-right:6px}
.rrow .row-time{color:var(--teal);font-weight:600}
.rrow .row-time svg{width:13px;height:13px;vertical-align:-2px;margin-right:1px}

.section-h{color:var(--teal);font-size:22px;font-weight:800;margin:22px 0 12px}
.ing{font-size:17px;line-height:1.55;padding:3px 0}
.ing .amt{font-weight:800}
.steps{counter-reset:s}
.step{font-size:17px;line-height:1.5;margin:0 0 16px}

/* bottom action toolbar inside detail */
.toolbar{
  position:sticky;bottom:8px;margin:18px auto 6px;width:max-content;max-width:94%;
  background:var(--surface-2);border-radius:30px;padding:12px 20px;
  display:flex;gap:26px;align-items:center;box-shadow:0 8px 24px rgba(0,0,0,.5);
}
.toolbar button{background:none;border:none;color:var(--teal);cursor:pointer;padding:0}
.toolbar button.active{color:#ffd24a}
.toolbar svg{width:24px;height:24px;display:block}

/* ---------- Forms ---------- */
.form{padding:4px 0}
.frow{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border-bottom:1px solid var(--line)}
.frow .lab{color:var(--muted);font-size:16px;width:120px;flex:0 0 auto;padding-top:9px}
.frow .ctl{flex:1;min-width:0}
.frow input,.frow textarea,.frow select{
  width:100%;background:transparent;border:none;color:var(--text);font-size:16px;
  font-family:inherit;outline:none;padding:9px 0;
}
.frow textarea{resize:vertical;min-height:44px;line-height:1.4}
.frow input::placeholder,.frow textarea::placeholder{color:#5c5f65}
/* Select: dunkles Feld + lesbare Dropdown-Optionen (sonst weiß auf weiß) */
.frow select{
  background:var(--surface-2);border:1px solid var(--line);border-radius:10px;
  padding:11px 12px;cursor:pointer;
}
.frow select option{background:var(--surface-2);color:var(--text)}
.field-block{padding:14px 16px;border-bottom:1px solid var(--line)}
.field-block .lab{color:var(--teal);font-size:15px;font-weight:700;margin-bottom:8px;display:block}
.boxinput{
  width:100%;background:var(--surface-2);border:1px solid var(--line);border-radius:10px;
  color:var(--text);font-size:16px;font-family:inherit;padding:12px;outline:none;
}
textarea.boxinput{min-height:120px;line-height:1.5;resize:vertical}

.chiprow{display:flex;flex-wrap:wrap;gap:8px}
.chip{
  background:var(--surface-3);border:1px solid var(--line);color:var(--text);
  border-radius:18px;padding:8px 14px;font-size:14px;cursor:pointer;
}
.chip.on{background:var(--teal);color:#04313a;border-color:var(--teal);font-weight:700}

.ing-editor .ing-line{display:flex;gap:8px;margin-bottom:8px;align-items:center}
.ing-editor .ing-line input{flex:1}
.ing-editor .amt-in{flex:0 0 90px !important}
.icon-x{background:var(--surface-3);border:none;color:var(--muted);width:36px;height:36px;border-radius:8px;cursor:pointer;flex:0 0 auto;font-size:18px}
.add-line{background:none;border:none;color:var(--teal);font-size:15px;cursor:pointer;padding:6px 0;font-weight:600}

.primary-btn{
  display:block;width:calc(100% - 32px);margin:20px auto;
  background:var(--teal);color:#04313a;border:none;border-radius:14px;
  padding:16px;font-size:17px;font-weight:800;cursor:pointer;
}
.ghost-btn{
  display:block;width:calc(100% - 32px);margin:10px auto;
  background:var(--surface-3);color:var(--text);border:none;border-radius:14px;
  padding:15px;font-size:16px;font-weight:600;cursor:pointer;
}
.ghost-btn.danger{color:var(--danger)}

/* ---------- Popover menu (+) ---------- */
.overlay{position:absolute;inset:0;z-index:60;background:rgba(0,0,0,.35)}
.popover{
  position:absolute;top:62px;right:12px;z-index:61;width:300px;max-width:80%;
  background:#1b1c1f;border:1px solid #303134;border-radius:18px;overflow:hidden;
  box-shadow:0 20px 50px rgba(0,0,0,.6);
}
.popover button{
  display:flex;align-items:center;gap:14px;width:100%;text-align:left;
  background:none;border:none;color:var(--text);font-size:17px;cursor:pointer;
  padding:16px 18px;border-bottom:1px solid #262729;line-height:1.25;
}
.popover button:last-child{border-bottom:none}
.popover button svg{width:22px;height:22px;color:var(--teal);flex:0 0 auto}
.popover button:active{background:#26272a}

/* sheet (modal full) */
.sheet{position:absolute;inset:0;z-index:70;background:var(--bg);display:flex;flex-direction:column}
.sheet .topbar{background:#161719}
.sheet-body{flex:1;overflow-y:auto}

/* ---------- Speiseplan ---------- */
.week-head{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;gap:10px}
.week-head .wlabel{font-size:18px;font-weight:700}
.week-head .navs{display:flex;gap:10px}
.day{border-bottom:1px solid var(--line);padding:14px 16px}
.day .dname{color:var(--muted);font-size:16px;margin-bottom:8px}
.day.today .dname{color:var(--teal)}
.meal{display:flex;align-items:center;gap:10px;padding:8px 0;cursor:pointer}
.meal .dot{width:11px;height:11px;border-radius:50%;background:var(--danger);flex:0 0 auto}
.meal .mlab{color:var(--muted);font-size:16px}
.meal .mname{font-weight:700;font-size:16px}
.add-meal{color:var(--text);font-size:16px;background:none;border:none;cursor:pointer;padding:8px 0;display:block}
.add-meal:before{content:"+ "}
.meal-del{margin-left:auto;color:var(--muted);background:none;border:none;cursor:pointer;display:flex;align-items:center;padding:6px;border-radius:8px;flex:0 0 auto}
.meal-del svg{width:18px;height:18px;display:block}
.meal-del:active{background:var(--surface-3);color:var(--danger)}

/* ---------- Einkaufsliste ---------- */
.addbar{display:flex;gap:10px;align-items:center;padding:10px 16px}
.addbar .ipt{flex:1;display:flex;align-items:center;background:var(--surface-3);border-radius:12px;padding:0 6px 0 14px}
.addbar .ipt input{flex:1;background:none;border:none;color:var(--text);font-size:16px;padding:13px 0;outline:none;font-family:inherit}
.addbar .ipt button{background:none;border:none;color:var(--text);cursor:pointer;padding:8px}
.addbar .ipt button svg{width:24px;height:24px}
/* Einkaufsliste: Lösch-Aktionen */
.list-actions{display:flex;gap:10px;padding:2px 16px 8px}
.list-actions button{
  flex:1;display:flex;align-items:center;justify-content:center;gap:7px;
  background:var(--surface-3);color:var(--text);border:none;border-radius:12px;
  padding:11px;font-size:14px;font-weight:600;cursor:pointer;
}
.list-actions button svg{width:16px;height:16px}
.list-actions button.danger{color:var(--danger)}
.list-actions button:active{background:#3a3b3e}

/* KI-Import: Ladeanzeige + Datei-Auswahl */
.importing{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;padding:70px 24px;text-align:center}
.importing .msg{color:var(--text);font-size:17px;font-weight:600}
.importing .sub{color:var(--muted);font-size:14px;margin-top:-10px}
.spinner{width:48px;height:48px;border-radius:50%;border:4px solid var(--surface-3);border-top-color:var(--teal);animation:spin .9s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.file-drop{
  display:flex;flex-direction:column;align-items:center;gap:10px;
  margin:18px 16px;padding:38px 18px;border:2px dashed #3a3b3e;border-radius:16px;
  text-align:center;color:var(--muted);cursor:pointer;
}
.file-drop:active{background:var(--surface-2)}
.file-drop svg{width:42px;height:42px;color:var(--teal)}
.ai-hint{display:flex;gap:8px;align-items:flex-start;color:var(--teal);font-size:13px;line-height:1.4;padding:6px 16px 10px}
.ai-hint svg{width:16px;height:16px;flex:0 0 auto;margin-top:1px}
.list-sec{padding:6px 16px 2px}
.list-sec h3{color:var(--teal);font-size:19px;font-weight:800;margin:14px 0 6px}
.litem{display:flex;align-items:flex-start;gap:14px;padding:9px 16px;border-bottom:1px solid #1a1b1d}
.litem .cb{
  width:26px;height:26px;border-radius:7px;border:2px solid #6a6d72;flex:0 0 auto;margin-top:2px;
  cursor:pointer;display:flex;align-items:center;justify-content:center;background:transparent;
}
.litem .cb.on{background:var(--teal);border-color:var(--teal)}
.litem .cb svg{width:18px;height:18px;color:#04313a}
.litem .txt{flex:1;min-width:0}
.litem .txt .n{font-size:17px;line-height:1.3}
.litem .txt .src{font-size:13px;color:var(--teal);margin-top:2px}
.litem.done .txt .n{text-decoration:line-through;color:var(--muted)}
.litem .edit{color:var(--muted);background:none;border:none;cursor:pointer;flex:0 0 auto}
.litem .edit svg{width:20px;height:20px}

/* selectable add-to-list */
.sel-sec{padding:8px 16px}
.sel-sec h3{color:var(--teal);font-size:18px;font-weight:800;margin:14px 0 8px}
.sel-item{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.sel-item .cb{width:26px;height:26px;border-radius:7px;border:2px solid #6a6d72;flex:0 0 auto;cursor:pointer;display:flex;align-items:center;justify-content:center}
.sel-item .cb.on{background:var(--teal);border-color:var(--teal)}
.sel-item .cb svg{width:18px;height:18px;color:#04313a}
.sel-item .box{flex:1;background:#000;border:1px solid #2a2b2e;border-radius:8px;padding:13px 14px;font-size:16px}

.bottom-actions{
  display:flex;gap:12px;padding:14px 16px;border-top:1px solid var(--line);background:var(--bg);
  position:sticky;bottom:0;
}
.bottom-actions button{flex:1;background:var(--surface-3);border:none;color:var(--teal);border-radius:24px;padding:15px;font-size:16px;font-weight:600;cursor:pointer}

/* autocomplete */
.ac{position:relative}
.ac-list{background:transparent;margin-top:6px}
.ac-list button{display:block;width:100%;text-align:left;background:none;border:none;color:var(--text);font-size:16px;padding:12px 0;cursor:pointer;border-bottom:1px solid var(--line)}

/* empty / misc */
.empty{text-align:center;color:var(--muted);padding:60px 30px;font-size:16px;line-height:1.5}
.empty svg{width:60px;height:60px;opacity:.4;margin-bottom:14px;color:var(--teal)}

.help-fab{
  position:absolute;right:14px;bottom:calc(var(--tabbar-h) + 12px);z-index:15;
  background:var(--teal);color:#063;border:none;border-radius:24px;padding:11px 18px;
  font-size:16px;font-weight:600;display:flex;align-items:center;gap:7px;cursor:pointer;color:#04313a;
}
.help-fab svg{width:20px;height:20px}

.settings .srow{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--line);font-size:16px}
.settings .srow .sub{color:var(--muted);font-size:13px;margin-top:3px}
.settings .group-h{color:var(--muted);font-size:13px;text-transform:uppercase;letter-spacing:.5px;padding:18px 16px 6px}

/* ---------- Tabbar ---------- */
#tabbar{
  height:var(--tabbar-h);flex:0 0 auto;
  background:rgba(20,21,23,.96);backdrop-filter:blur(12px);
  border-top:1px solid #202124;
  display:flex;align-items:flex-start;padding:10px 6px 0;
}
#tabbar button{
  flex:1;background:none;border:none;color:var(--muted);cursor:pointer;
  display:flex;flex-direction:column;align-items:center;gap:4px;font-size:11px;position:relative;
}
#tabbar button svg{width:24px;height:24px}
#tabbar button.active{color:var(--teal)}
#tabbar .badge{
  position:absolute;top:-6px;right:50%;transform:translateX(22px);
  background:var(--teal);color:#04313a;border-radius:11px;min-width:20px;height:20px;
  font-size:11px;font-weight:800;display:flex;align-items:center;justify-content:center;padding:0 5px;
}

.hidden{display:none !important}

/* toast */
#toast{
  position:absolute;left:50%;bottom:calc(var(--tabbar-h) + 20px);transform:translateX(-50%);
  background:var(--surface-3);color:var(--text);border:1px solid var(--line);
  padding:13px 20px;border-radius:14px;font-size:15px;max-width:84%;text-align:center;
  box-shadow:0 10px 30px rgba(0,0,0,.5);z-index:200;opacity:0;pointer-events:none;
  transition:opacity .2s, transform .2s;
}
#toast.show{opacity:1;transform:translateX(-50%) translateY(-4px)}

/* login */
.login{min-height:100%;display:flex;align-items:center;justify-content:center;padding:24px}
.login-card{width:100%;max-width:340px;text-align:center}
.login-brand{display:flex;align-items:center;justify-content:center;gap:10px;color:var(--teal);font-size:24px;font-weight:800;margin-bottom:6px}
.login-brand svg{width:34px;height:34px}
.login-sub{color:var(--muted);font-size:15px;margin:0 0 22px}
.login-input{
  width:100%;background:var(--surface-2);border:1px solid var(--line);border-radius:12px;
  color:var(--text);font-size:17px;font-family:inherit;padding:15px;outline:none;text-align:center;letter-spacing:.5px;
}
.login-input:focus{border-color:var(--teal)}
.login-err{color:var(--danger);font-size:14px;margin-top:12px}
.login-admin{display:inline-block;margin-top:18px;color:var(--muted);font-size:14px;text-decoration:none}
.login-admin:hover{color:var(--teal)}

/* ============================================================
   Drucken – nur das aktuell geöffnete Rezept, ohne App-Rahmen
   ============================================================ */
@media print{
  *{ -webkit-print-color-adjust:exact !important; print-color-adjust:exact !important; }
  html,body{background:#fff !important;height:auto !important}
  body{display:block !important}
  #phone{
    position:static !important;max-width:none !important;width:auto !important;
    height:auto !important;border:0 !important;border-radius:0 !important;box-shadow:none !important;
    overflow:visible !important;background:#fff !important;display:block !important;
  }
  #app{height:auto !important;overflow:visible !important;padding:0 !important;background:#fff !important}
  /* App-Chrome ausblenden */
  #tabbar,.topbar,.toolbar,.help-fab,#toast,.seg,.count-head{display:none !important}
  /* Rezept in Schwarz auf Weiß */
  .hero{position:static !important;aspect-ratio:auto !important;max-height:none !important;background:#fff !important;overflow:visible !important}
  .hero .ph{display:none !important}
  .hero img{max-height:260px !important;width:auto !important;max-width:60% !important;display:block !important;margin:0 0 6px}
  .hero .titlewrap{position:static !important;background:none !important;padding:0 16px 4px !important}
  .hero h1{color:#000 !important;font-size:22pt !important}
  .hero .tags{color:#333 !important}
  .detail{padding:0 16px 16px !important}
  .facts .k{color:#333 !important}
  .facts .v,.facts .v b{color:#000 !important}
  .facts .v a{color:#000 !important}
  .serv-step button{display:none !important}      /* +/- nicht mitdrucken */
  .section-h{color:#000 !important;font-size:15pt !important;margin:14px 0 8px !important}
  .ing,.step{color:#000 !important;break-inside:avoid}
  .ing .amt{color:#000 !important}
}
