*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
  font-family: 'Segoe UI', system-ui, sans-serif;
  background: #f5f5f0;
  color: #1a1a1a;
  min-height: 100vh;
}

/* ── Navbar ── */
nav {
  background: #1a1a1a;
  color: #fff;
  padding: 0 2rem;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
nav .brand { font-weight: 700; font-size: 1.2rem; letter-spacing: 1px; }
nav .nav-right { display: flex; gap: 1rem; align-items: center; }
nav a { color: #ccc; text-decoration: none; font-size: 0.9rem; }
nav a:hover { color: #fff; }
nav button.logout {
  background: none; border: 1px solid #555; color: #ccc;
  padding: 4px 12px; border-radius: 4px; cursor: pointer; font-size: 0.85rem;
}
nav button.logout:hover { border-color: #fff; color: #fff; }

/* ── Container ── */
.container { max-width: 960px; margin: 2rem auto; padding: 0 1.5rem; }

/* ── Cards ── */
.card {
  background: #fff;
  border-radius: 8px;
  padding: 2rem;
  box-shadow: 0 1px 4px rgba(0,0,0,0.08);
  margin-bottom: 1.5rem;
}

/* ── Auth-Seite ── */
.auth-wrapper {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #f5f5f0;
}
.auth-box {
  background: #fff;
  border-radius: 10px;
  padding: 2.5rem;
  width: 100%;
  max-width: 400px;
  box-shadow: 0 2px 12px rgba(0,0,0,0.1);
}
.auth-box h1 { font-size: 1.5rem; margin-bottom: 0.25rem; }
.auth-box .subtitle { color: #666; font-size: 0.9rem; margin-bottom: 1.5rem; }

/* ── Formulare ── */
.form-group { margin-bottom: 1rem; }
label { display: block; font-size: 0.85rem; font-weight: 600; margin-bottom: 0.3rem; color: #444; }
input[type="text"], input[type="email"], input[type="password"], input[type="number"], select, textarea {
  width: 100%; padding: 10px 12px;
  border: 1px solid #ddd; border-radius: 6px;
  font-size: 0.95rem; transition: border-color 0.2s;
}
input:focus, select:focus, textarea:focus {
  outline: none; border-color: #1a1a1a;
}

/* ── Buttons ── */
.btn {
  padding: 10px 20px; border: none; border-radius: 6px;
  font-size: 0.95rem; font-weight: 600; cursor: pointer; transition: opacity 0.2s;
}
.btn:hover { opacity: 0.85; }
.btn-primary { background: #1a1a1a; color: #fff; }
.btn-success { background: #2d8a4e; color: #fff; }
.btn-danger  { background: #c0392b; color: #fff; }
.btn-warning { background: #e67e22; color: #fff; }
.btn-sm { padding: 5px 12px; font-size: 0.82rem; }
.btn-full { width: 100%; }

/* ── Tabs ── */
.tabs { display: flex; gap: 0; border-bottom: 2px solid #e0e0e0; margin-bottom: 1.5rem; }
.tab {
  padding: 10px 20px; cursor: pointer; font-weight: 600;
  font-size: 0.9rem; color: #666; border-bottom: 2px solid transparent;
  margin-bottom: -2px; transition: color 0.2s;
}
.tab.active { color: #1a1a1a; border-bottom-color: #1a1a1a; }

/* ── Tabellen ── */
table { width: 100%; border-collapse: collapse; font-size: 0.9rem; }
th { text-align: left; padding: 10px 12px; background: #f8f8f6; font-size: 0.8rem; color: #666; text-transform: uppercase; letter-spacing: 0.5px; }
td { padding: 12px; border-top: 1px solid #f0f0f0; }
tr:hover td { background: #fafafa; }

/* ── Status-Badges ── */
.badge {
  display: inline-block; padding: 3px 10px; border-radius: 20px;
  font-size: 0.75rem; font-weight: 600; text-transform: uppercase;
}
.badge-pending  { background: #fff3cd; color: #856404; }
.badge-confirmed { background: #d1ecf1; color: #0c5460; }
.badge-delivered { background: #d4edda; color: #155724; }
.badge-cancelled { background: #f8d7da; color: #721c24; }
.badge-approved  { background: #d4edda; color: #155724; }
.badge-waiting   { background: #fff3cd; color: #856404; }

/* ── Alerts ── */
.alert {
  padding: 12px 16px; border-radius: 6px; margin-bottom: 1rem;
  font-size: 0.9rem; display: none;
}
.alert.show { display: block; }
.alert-error   { background: #f8d7da; color: #721c24; border: 1px solid #f5c6cb; }
.alert-success { background: #d4edda; color: #155724; border: 1px solid #c3e6cb; }
.alert-info    { background: #d1ecf1; color: #0c5460; border: 1px solid #bee5eb; }

/* ── Shop-Produktkarten ── */
.products-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 1rem;
}
.product-card {
  background: #fff; border-radius: 8px; padding: 1.25rem;
  box-shadow: 0 1px 4px rgba(0,0,0,0.08); border: 2px solid transparent;
  cursor: pointer; transition: border-color 0.2s;
}
.product-card.selected { border-color: #1a1a1a; }
.product-card h3 { font-size: 0.95rem; margin-bottom: 0.25rem; }
.product-card .price { font-size: 1.1rem; font-weight: 700; color: #2d8a4e; margin: 0.5rem 0; }
.product-card .unit { font-size: 0.8rem; color: #888; }
.qty-input { width: 80px; margin-top: 0.5rem; }

/* ── Warenkorb-Summary ── */
.cart-summary { background: #f8f8f6; border-radius: 8px; padding: 1.25rem; }
.cart-item { display: flex; justify-content: space-between; padding: 6px 0; font-size: 0.9rem; }
.cart-total { font-weight: 700; font-size: 1rem; border-top: 1px solid #ddd; padding-top: 8px; margin-top: 4px; display: flex; justify-content: space-between; }

/* ── Divider ── */
.divider { text-align: center; color: #aaa; font-size: 0.85rem; margin: 1rem 0; }

/* ── Link ── */
.link { color: #1a1a1a; font-weight: 600; cursor: pointer; text-decoration: underline; }
