/* =========================================================
   KPI Dashboard — Full CSS (clean + consolidated)
   ========================================================= */

/* ---------- Variables ---------- */
:root{
  /* Layout */
  --header-h: 80px;
  --cb-h: 56px;
  --sidebar-w: 210px;

  /* Dialog sizing 280*/
  --dialog-max: 520px;      /* maximale Breite für Modal-Panel */
  --dialog-gutter: 16px;    /* seitlicher Rand auf kleinen Screens */

  /* Card styling */
  --kpi-bar-width: 8px;
  --kpi-radius: 14px;
  --kpi-shadow: 0 8px 24px rgba(0,0,0,.08);

  /* Palette */
  --kpi-bg: #fff;
  --kpi-text: #111;
  --kpi-sub: #5d6470;

  --kpi-good: #1a9e3f;
  --kpi-warn: #f7a400;
  --kpi-bad:  #d32f2f;
  --kpi-neutral: #5b6b7a;

  /* Surfaces / borders */
  --surface: #fff;
  --border:  #e6e8ee;

  /* Misc */
  --text:   #111;
  --muted:  #5d6470;
  --accent: #3b82f6;

  /*Controlbar*/
  --cb-icon-size: 22px;  /* Icon size zentral */
  --cb-gutter: 12px;     /* Innenabstand links/rechts */
}


/* ---------- Base / Typography ---------- */
html, body{
  margin:0;
  background:#f6f7fb;
  color:var(--kpi-text);
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
}

.wrap{ max-width:1100px; margin:0 auto; padding:20px; }
.spacer{ flex:1 1 auto; }

/* ---------- Header (sticky) ---------- */
.app-header{
  position: sticky;
  top: 0;
  z-index: 1000;
  height: var(--header-h);
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 0 14px;
  background: var(--surface);
  border-bottom: 1px solid var(--border);
}

.brand{ display:flex; align-items:center; gap:10px; text-decoration:none; color:inherit; }
.brand-logo{ width:75px; height:75px; object-fit:contain; }
.brand-name{ font-weight:700; letter-spacing:.2px; }

/* ---------- Controlbar ---------- */

/* gleichmäßig über die volle Breite, von der Mitte bis zum Rand verteilt */
.controlbar{
  position: sticky;
  top: var(--header-h);
  z-index: 999;
  height: var(--cb-h);
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(64px, 1fr); /* gleiche Spaltenbreite, min. Klickfläche */
  align-items: center;
  padding: 0 var(--cb-gutter);
  background: #fff;
  border-bottom: 1px solid var(--border);
  gap: 0; /* gleichmäßige Verteilung ohne Zusatzabstände */
}

.cb-btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 40px;
  min-width: 40px;
  padding: 0;                      /* nur Icon, keine Text-Polster nötig */
  border: 1px solid #d6d9e0;
  border-radius: 10px;
  background: #fff;
  font: inherit;
  color: inherit;
  text-decoration: none;
  cursor: pointer;
  justify-self: center;            /* Button in seiner Spalte zentrieren */
}

.cb-btn:hover{ background:#f8fafc; }
.cb-btn:active{ transform: translateY(1px); }

/* Einheitliche Icon-Größe – gilt für <img class="icon"> und inline <svg class="icon"> */
.controlbar .cb-btn .icon{
  width: var(--cb-icon-size);
  height: var(--cb-icon-size);
  display: block;
  object-fit: contain;
}

/* Falls du inline-SVG ohne .icon-Klasse hast */
.controlbar .cb-btn svg{
  width: var(--cb-icon-size);
  height: var(--cb-icon-size);
  display: block;
}

/* ---------- Sidebar (unter Header) ---------- */
.app-sidebar{
  position: fixed;
  top: var(--header-h);
  left: calc(-1 * var(--sidebar-w));
  width: var(--sidebar-w);
  height: calc(100vh - var(--header-h));
  background: #fff;
  box-shadow: 0 10px 30px rgba(0,0,0,.18);
  border-right:1px solid var(--border);
  transition: left .25s ease;
  z-index: 1200;
  overflow: auto;
}
body.sidebar-open .app-sidebar{ left: 0; }

.app-overlay{
  position: fixed;
  left: 0; right: 0;
  top: var(--header-h);
  height: calc(100vh - var(--header-h));
  background: rgba(0,0,0,.35);
  z-index: 1100;
}
.app-overlay[hidden]{ display:none; }

.side-nav{ display:flex; flex-direction:column; gap:6px; padding:12px; }
.side-row{
  display:flex; align-items:center; justify-content:space-between;
  gap:8px; padding:6px 0 10px; border-bottom:1px solid var(--border); margin-bottom:6px;
}
.side-title{ font-weight:700; font-size:15px; color:#111; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.side-link{ display:block; padding:8px 10px; border-radius:8px; color:inherit; text-decoration:none; }
.side-link:hover{ background:#f6f7fb; }
.side-link.active{ background:#eef2ff; color:#334155; font-weight:600; }
.side-close{
  display:inline-flex; align-items:center; justify-content:center;
  width:36px; height:36px; border:1px solid #e1e4ea; border-radius:10px; background:#fff; cursor:pointer;
}
.side-close:hover{ background:#f8fafc; }

/*Controlbar all svg icons size*/
:root{
  --cb-icon-size: 30px; /* hier zentral anpassen */
}

.controlbar .cb-btn .icon{
  width: var(--cb-icon-size);
  height: var(--cb-icon-size);
  display: block;
  object-fit: contain;
}


/* ---------- Main spacing ---------- */
.app-main{ padding-top: calc(var(--cb-h) + 12px); }
@media (min-width:900px){ .app-main{ padding-top: calc(var(--cb-h) + 16px); } }

/* ---------- Section headers ---------- */
.section{
  margin:18px 0 8px;
  font-size:12px; color:var(--kpi-sub);
  text-transform:uppercase; letter-spacing:.35px;
  scroll-margin-top: calc(var(--header-h) + var(--cb-h) + 12px);
}

/* ---------- Current stock title ---------- */
.stock-heading{ font-size:clamp(20px,4vw,28px); font-weight:800; margin:8px 0 4px; }
.stock-sub{ color:var(--muted); font-size:12px; margin-bottom:8px; }

/* ---------- KPI grid ---------- */
.kpi-grid{ display:grid; gap:16px; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
@media (max-width: 560px){
  .kpi-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
  .kpi-card { padding:14px 14px 14px calc(14px + var(--kpi-bar-width)); }
  .kpi-value { font-size:22px; }
  .chip { font-size:10px; padding:3px 6px; }
}
@media (max-width: 340px){ .kpi-grid { grid-template-columns: 1fr; } }

/* ---------- KPI card ---------- */
.kpi-card{
  position:relative; display:flex; flex-direction:column; gap:8px;
  padding:16px 18px 16px calc(18px + var(--kpi-bar-width));
  border-radius: var(--kpi-radius); background: var(--kpi-bg); box-shadow: var(--kpi-shadow);
  min-height: 112px;
}
.kpi-card::before{
  content:""; position:absolute; left:0; top:0; bottom:0; width:var(--kpi-bar-width);
  border-top-left-radius:var(--kpi-radius); border-bottom-left-radius:var(--kpi-radius);
  background: linear-gradient(to bottom, var(--bar-color, var(--kpi-neutral)), transparent);
  pointer-events: none;
}
.kpi-title{font-size:12px; letter-spacing:.3px; color:var(--kpi-sub); text-transform:uppercase; margin-top:2px;}
.kpi-main{display:flex; align-items:baseline; gap:10px; flex-wrap:wrap;}
.kpi-value{font-size:26px; font-weight:700; line-height:1.2;}
.kpi-badge{ font-size:12px; font-weight:700; line-height:1; padding:6px 8px; border-radius:999px; background: rgba(0,0,0,.05); }
.kpi-badge.good{color:var(--kpi-good);} .kpi-badge.warn{color:var(--kpi-warn);}
.kpi-badge.bad{color:var(--kpi-bad);} .kpi-badge.neutral{color:var(--kpi-neutral);}
.kpi-foot{ display:flex; flex-wrap:wrap; gap:10px; align-items:center; margin-top:0; color:var(--kpi-sub); font-size:12px; }

/* ---------- Threshold chips ---------- */
.kpi-chips { display:flex; gap:6px; flex-wrap:wrap; align-items:center; }
.kpi-label { font-size:11px; color: var(--kpi-sub); margin-right:6px; }
.chip{ font-size:11px; font-weight:600; line-height:1; padding:4px 6px; border-radius:999px; border:1px solid transparent; background: rgba(0,0,0,.05); }
.chip.green  { color: var(--kpi-good);   border-color: rgba(26,158,63,.25);  background: rgba(26,158,63,.10); }
.chip.yellow { color: var(--kpi-warn);   border-color: rgba(247,164,0,.25);  background: rgba(247,164,0,.10); }
.chip.red    { color: var(--kpi-bad);    border-color: rgba(211,47,47,.25);  background: rgba(211,47,47,.10); }
.chip.neutral{ color: var(--kpi-neutral);border-color: rgba(91,107,122,.20); background: rgba(91,107,122,.08); }
.chip.band   { border-style: dashed; }

/* ---------- Responsive overlay helper ---------- */
@media (max-width: 900px){
  body.sidebar-open .app-overlay{ display:block; }
}

/* ---------- LIST/ITEM/BADGE (für beide Modals) ---------- */
.list{ max-height:280px; overflow:auto; border:1px solid #eef0f3; border-radius:10px; }
.item{ display:flex; align-items:center; justify-content:space-between; gap:8px; padding:10px 12px; cursor:pointer; }
.item:hover, .item[aria-selected="true"]{ background:#f6f7fb; }
.badge{ font-size:11px; color:#334155; background:#eef2ff; border-radius:999px; padding:4px 8px; border:1px solid #dbe3ff; }

/* ---------- MODAL (gemeinsam für Add & Picker) ---------- */
.modal{ position:fixed; inset:0; z-index:1500; display:none; }
.modal.open{ display:block; }
.modal .scrim{ position:absolute; inset:0; background:rgba(0,0,0,.35); }
.modal .panel{
  position:absolute; left:50%; top:50%; transform:translate(-50%,-50%);
  width: clamp(280px, calc(100vw - (2 * var(--dialog-gutter))), var(--dialog-max));
  background:#fff; border:1px solid var(--border);
  border-radius:14px; box-shadow:0 10px 30px rgba(0,0,0,.18); padding:16px;
}

.dialog-head{ display:flex; align-items:center; justify-content:space-between; gap:8px; margin-bottom:10px; }
.dialog-title{ margin:0; font-size:16px; font-weight:700; line-height:1.2; }
.dialog-close{
  display:inline-flex; align-items:center; justify-content:center;
  width:32px; height:32px; border:1px solid #e1e4ea; border-radius:10px; background:#fff; cursor:pointer;
}
.dialog-close:hover{ background:#f8fafc; }
.dialog-body{ display:block; }
.dialog-search{
  width:100%; max-width:100%; box-sizing:border-box; display:block;
  padding:10px 12px; border:1px solid #d6d9e0; border-radius:10px; margin-bottom:8px;
}

/* ---------- Buttons ---------- */
.btn{ padding:10px 12px; border-radius:10px; border:1px solid #d6d9e0; background:#fff; cursor:pointer; }
.btn.primary{ background:var(--accent); border-color:var(--accent); color:#fff; }

/* ---------- Loader ---------- */
.loader{ display:flex; align-items:center; gap:10px; font-size:14px; color:var(--kpi-sub); margin-top:8px; }
.spinner{
  width:18px; height:18px; border:3px solid #e5e7eb; border-top-color: var(--accent);
  border-radius:50%; animation: spin .9s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
.loader[hidden]{ display: none !important; }

/* ---------- Toast ---------- */
.toast{
  position:fixed; left:50%; bottom:18px; transform:translateX(-50%); z-index:2000;
  background:#111; color:#fff; padding:10px 14px; border-radius:999px;
  box-shadow:0 10px 30px rgba(0,0,0,.2); display:none;
}
.toast.show{ display:block; }

/* ---------- Hidden adapter ---------- */
#symbolSel{ display:none !important; }

/* === Modal: immer mit Seitenrand, inkl. Padding/Border einkalkuliert === */
:root{
  --dialog-max: 520px;    /* max. Breite der Modals (anpassen nach Wunsch) */
  --dialog-gutter: 16px;  /* Rand links/rechts zum Bildschirm */
}

.modal .panel{
  box-sizing: border-box; /* <- wichtig: Padding & Border in Breite einrechnen */
  width: clamp(280px, calc(100vw - (2 * var(--dialog-gutter))), var(--dialog-max)) !important;
  /* Rest (padding, border, etc.) bleibt wie gehabt */
}

/* === Add-Dialog: Feld & Button sauber ausrichten === */
.modal .dialog-body{
  display: grid;
  gap: 12px;
}

.modal .field{
  display: grid;
  grid-template-columns: 1fr auto; /* Input füllt, Button so breit wie nötig */
  gap: 8px;
  width: 100%;
}

.modal .field input[type="text"]{
  min-width: 0;      /* erlaubt echtes Schrumpfen im Grid/Flex-Layout */
  height: 44px;      /* einheitliche Höhe */
  box-sizing: border-box;
}

.modal .field .btn{
  height: 44px;      /* gleiche Höhe wie Input */
  line-height: 1;    /* keine zusätzliche Vertikalexpansion */
  align-self: stretch;
}

/* Sehr kleine Screens: untereinander & Button volle Breite */
@media (max-width: 420px){
  .modal .field{
    grid-template-columns: 1fr;
  }
  .modal .field .btn{
    width: 100%;
  }
}

/* === Einheitliche Form & Typo für Inputs + Buttons in Modals === */
:root{
  --control-radius: 10px;  /* gleiche Rundung wie Buttons */
  --control-h:      44px;  /* Touch-freundliche Höhe */
  --control-font:   16px;  /* >=16px verhindert Mobile-Zoom */
}

/* Panel: Rand einkalkulieren (falls noch nicht gesetzt) */
.modal .panel{
  box-sizing: border-box;
}

/* Eingabefeld im ADD und Suchfeld im PICK (Modal) */
.modal .field input[type="text"],
.modal .dialog-search,
.modal select,
.modal textarea{
  height: var(--control-h);
  box-sizing: border-box;
  width: 100%;
  border: 1px solid #d6d9e0;
  border-radius: var(--control-radius) !important;
  padding: 10px 12px;
  font-size: var(--control-font);
  line-height: 1.25;
  color: var(--kpi-text);
  background: #fff;

  /* gleiche Optik auf iOS/Safari & Co. */
  -webkit-appearance: none;
          appearance: none;
}

/* Platzhalter-Typo angleichen */
.modal .field input[type="text"]::placeholder,
.modal .dialog-search::placeholder{
  font-size: inherit;
  line-height: inherit;
  color: var(--kpi-sub);
  opacity: 1; /* manche Browser machen Placeholder sonst zu blass/klein */
}

/* Fokus-Style konsistent */
.modal .field input[type="text"]:focus,
.modal .dialog-search:focus{
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(59,130,246,.18); /* weiches Focus-Ring */
}

/* Button im ADD: gleiche Höhe & Rundung wie Input */
.modal .field .btn{
  height: var(--control-h);
  border-radius: var(--control-radius);
  font-size: var(--control-font);
  line-height: 1;          /* verhindert vertikales „Aufblähen“ */
  align-self: stretch;      /* füllt die Zeile vertikal wie das Input */
}

/* Layout der Zeile (falls noch nicht aktiv) */
.modal .field{
  display: grid;
  grid-template-columns: 1fr auto; /* Input füllt, Button so breit wie nötig */
  gap: 8px;
  width: 100%;
}

/* sehr schmale Screens: untereinander anordnen */
@media (max-width: 420px){
  .modal .field{
    grid-template-columns: 1fr;
  }
  .modal .field .btn{
    width: 100%;
  }
}

