:root{
  --brand:#007c91;
  --brand2:#009fb3;
  --bg:#f6f9fb;
  --card:#ffffff;
  --text:#1f2937;
  --muted:#6b7280;
  --border:#e5e7eb;
  --danger:#e11d48;
  --shadow: 0 8px 30px rgba(0,0,0,.08);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
    font-family: Arial, sans-serif;

  background:var(--bg);
  color:var(--text);
}
/* Schrift überall fix: auch Inputs/Textarea/Buttons */
input, textarea, select, button, .btn, .input, .textarea, .select{
  font-family: Arial, sans-serif;
}

/* Login immer zentriert – auch nach Logout */
#loginView{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:14px; /* optional: schöner am Handy */
}

/* Topbar */
.topbar{
  position:sticky; top:0; z-index:10;
  display:flex; gap:14px; align-items:center; justify-content:space-between;
  padding:12px 14px;
  background:linear-gradient(180deg, #ffffff, #fbfdff);
  border-bottom:1px solid var(--border);
}
.brand{display:flex; gap:12px; align-items:center}
.logo{
  width:40px;height:40px;border-radius:12px;
  background:linear-gradient(135deg, var(--brand), var(--brand2));
  color:#fff; display:flex; align-items:center; justify-content:center;
  font-weight:800; letter-spacing:.5px;
  box-shadow: 0 10px 25px rgba(0,124,145,.20);
}
.titles .h1{font-weight:800}
.titles .sub{color:var(--muted); font-size:12px; margin-top:2px}

.top-actions{
  display:flex; gap:8px; align-items:center; flex-wrap:wrap;
}
.divider{width:1px;height:26px;background:var(--border); margin:0 4px}

/* Layout */
.layout{
  display:grid;
  grid-template-columns: 320px 1fr;
  gap:14px;
  padding:14px;
  height: calc(100vh - 70px);
}

/* Sidebar */
.sidebar{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:16px;
  box-shadow: var(--shadow);
  display:flex; flex-direction:column;
  overflow:hidden;
}
.sidebar-top{padding:12px 12px 10px; border-bottom:1px solid var(--border);}
.hint{color:var(--muted); font-size:12px; margin-top:8px}
.hint.small{font-size:11px; line-height:1.35}

.product-list{
  overflow:auto;
  padding:8px;
}
.product-item{
  border:1px solid var(--border);
  border-radius:12px;
  padding:10px 10px;
  margin:8px 0;
  cursor:pointer;
  background:#fff;
  transition: transform .08s ease, border-color .12s ease;
}
.product-item:hover{transform: translateY(-1px); border-color:#cde7ed}
.product-item.active{
  border-color: rgba(0,159,179,.55);
  box-shadow: 0 10px 20px rgba(0,159,179,.10);
}
.p-title{font-weight:800; font-size:14px}
.p-meta{display:flex; gap:8px; flex-wrap:wrap; margin-top:6px}
.chip{
  font-size:11px; padding:3px 8px; border-radius:999px;
  border:1px solid var(--border);
  color:var(--muted);
  background:#fbfdff;
}
.chip.important{border-color: rgba(225,29,72,.35); color: #be123c; background:#fff1f2}

/* Content */
.content{display:flex; flex-direction:column; gap:14px}
.card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:16px;
  box-shadow: var(--shadow);
  padding:14px;
}
.card.muted{
  background:linear-gradient(180deg, #ffffff, #fbfdff);
}
.muted-title{font-weight:800; margin-bottom:8px}
.muted-list{margin:0; padding-left:18px; color:var(--muted); font-size:13px}
.muted-list b{color:var(--text)}

.row{display:grid; grid-template-columns: 1fr 320px; gap:12px; margin-bottom:12px}
.row:first-child{grid-template-columns: 1fr 240px}
.col{min-width:0}
.col.small{width:100%}
.label{display:block; font-size:12px; color:var(--muted); margin:0 0 6px}
.input, .textarea, .select{
  width:100%;
  padding:10px 10px;
  border-radius:12px;
  border:1px solid var(--border);
  background:#fff;
  outline:none;
  font-size:14px;
}
.textarea{min-height:52vh; height:calc(100vh - 360px); max-height:calc(100vh - 220px); resize:vertical; line-height:1.45}
.input:focus, .textarea:focus, .select:focus{
  border-color: rgba(0,159,179,.55);
  box-shadow:0 0 0 4px rgba(0,159,179,.12)
}

.toolbar-inline{display:flex; gap:8px; align-items:center; flex-wrap:wrap; margin-top:10px}
.status{color:var(--muted); font-size:12px}

/* Buttons */
.btn{
  border:1px solid transparent;
  background:linear-gradient(135deg, var(--brand), var(--brand2));
  color:#fff;
  padding:9px 12px;
  border-radius:12px;
  font-weight:700;
  cursor:pointer;
  box-shadow: 0 10px 25px rgba(0,124,145,.14);
}
.btn:hover{filter: brightness(1.02)}
.btn:active{transform: translateY(1px)}
.btn.secondary{
  background:#fff;
  color:var(--text);
  border-color: var(--border);
  box-shadow:none;
}
.btn.danger{
  background: #fff;
  color: var(--danger);
  border-color: rgba(225,29,72,.25);
  box-shadow:none;
}
.filelike{position:relative; overflow:hidden}

/* Image */
.imagecol{display:flex; flex-direction:column}
.imagebox{
  border:1px dashed #cfe8ee;
  border-radius:14px;
  height:260px;
  background:#f9feff;
  display:flex; align-items:center; justify-content:center;
  overflow:hidden;
  position:relative;
}
.imagebox img{
  width:100%; height:100%;
  object-fit:contain;
  display:none;
}
.img-empty{
  position:absolute;
  color:var(--muted);
  font-size:12px;
}

/* Responsive */
@media (max-width: 980px){
  .layout{grid-template-columns: 1fr; height:auto}
  .row, .row:first-child{grid-template-columns: 1fr}
  .imagebox{height:220px}
}

/* Toggle (mit/ohne Bild) */
.toggle{
  display:flex; align-items:center; gap:8px;
  padding:6px 8px;
  border:1px solid var(--border);
  border-radius:12px;
  background:#fff;
  cursor:pointer;
  user-select:none;
}
.toggle input{display:none}
.toggle .track{
  width:44px; height:24px;
  border-radius:999px;
  background:#e5e7eb;
  position:relative;
  transition: background .15s ease;
}
.toggle .thumb{
  width:18px; height:18px; border-radius:50%;
  background:#fff;
  position:absolute; top:3px; left:3px;
  box-shadow: 0 6px 12px rgba(0,0,0,.12);
  transition: left .15s ease;
}
.toggle input:checked + .track{ background: rgba(0,159,179,.55); }
.toggle input:checked + .track .thumb{ left:23px; }
.toggle-text{font-size:12px; color:var(--muted); font-weight:700}

/* Print Header (nur im Druck/PDF sichtbar) */
.print-header{
  display:none;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  padding:0 0 10px 0;
  margin:0 0 10px 0;
  border-bottom:1px solid var(--border);
}
.ph-supplier{font-weight:800; font-size:12pt}
.ph-product{font-weight:800; font-size:16pt; margin-top:2px}
.ph-date{color:var(--muted); font-size:11pt; text-align:right}

/* Print-Text: am Bildschirm versteckt (nur Druck/PDF zeigt es) */
.print-text{
  display:none;
  white-space: pre-wrap;      /* Zeilenumbrüche behalten */
  word-break: break-word;     /* lange Wörter umbrechen */
  font-size: 12.5pt;
  line-height: 1.45;
}

@media print{
  /* Seite */
  @page { size: A4 portrait; margin: 12mm; }

  /* Alles was nicht gedruckt werden soll */
  .topbar, .sidebar, .toolbar-inline, .status, .hint, .divider { display:none !important; }

  /* Layout auf 1 Spalte */
  .layout{ display:block !important; height:auto !important; padding:0 !important; }
  .content{ gap:0 !important; }
  .card{ box-shadow:none !important; border:none !important; padding:0 !important; }

  /* Print header sichtbar */
  .print-header{display:flex !important}

  /* Bild optional ausblenden */
  body.no-print-image .imagecol{display:none !important}
  body.no-print-image .row{grid-template-columns: 1fr !important}

  /* wichtig: textarea darf beim Drucken NICHT scrollen */
  textarea{
    height:auto !important;
    overflow:visible !important;
    max-height:none !important;
    resize:none !important;
  }

  /* Beim Drucken: textarea aus, printText an */
  #prodText{ display:none !important; }
  #printText{ display:block !important; }

  /* Bildbox in Druck sauber */
  .imagebox{ border: none !important; background: transparent !important; height:auto !important; }
  .imagebox img{ display:block !important; max-height: 85mm; }
  .img-empty{ display:none !important; }
}
.btn.secondary {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
/* Editor-Textfeld: Schrift garantiert Arial */
#prodText{
  font-family: Arial, sans-serif !important;
  font-size: 14px;
  line-height: 1.5;
}
