/* Admin-Oberfläche Händlerbereich */
.admin-main {
  padding: calc(80px + 2rem) 1.5rem 4rem;
  min-height: 100vh;
  background: var(--bg);
}

.admin-login-wrap,
.admin-forbidden,
.admin-dashboard {
  max-width: 960px;
  margin: 0 auto;
}

.admin-login-wrap {
  padding: 3rem 0;
}

.admin-login-box {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 12px;
  padding: 2.5rem;
  max-width: 400px;
}

.admin-login-box h1 {
  font-family: var(--font-heading);
  font-size: 1.5rem;
  margin: 0 0 0.5rem;
  color: var(--text);
}

.admin-login-hint {
  font-size: 0.9rem;
  color: var(--text-muted);
  margin: 0 0 1.5rem;
  line-height: 1.5;
}

.admin-login-box label {
  display: block;
  font-size: 0.8rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 0.35rem;
  color: var(--text-muted);
}

.admin-login-box input {
  width: 100%;
  padding: 0.75rem 1rem;
  margin-bottom: 1rem;
  font: inherit;
  font-size: 1rem;
  color: var(--text);
  background: rgba(0,0,0,0.35);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 8px;
}

.admin-login-box input:focus {
  outline: none;
  border-color: var(--accent);
}

.admin-forbidden {
  text-align: center;
  padding: 4rem 1rem;
}

.admin-forbidden p {
  color: var(--text-muted);
  margin-bottom: 1.5rem;
}

.admin-dashboard-header {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1rem;
  margin-bottom: 2rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}

.admin-dashboard-header h1 {
  font-family: var(--font-heading);
  font-size: 1.5rem;
  margin: 0;
  flex: 1;
}

.admin-user {
  margin: 0;
  font-size: 0.9rem;
  color: var(--text-muted);
}

.admin-user strong { color: var(--accent); }

.admin-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 1.5rem;
}

.admin-tab {
  padding: 0.6rem 1.2rem;
  font: inherit;
  font-size: 0.9rem;
  color: var(--text-muted);
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 8px;
  cursor: pointer;
  transition: border-color 0.2s, color 0.2s;
}

.admin-tab:hover {
  color: var(--text);
  border-color: rgba(255,255,255,0.2);
}

.admin-tab.active {
  color: var(--accent);
  border-color: var(--accent);
  background: rgba(139,195,74,0.08);
}

.admin-tab-panel {
  display: none;
}

.admin-tab-panel.active {
  display: block;
}

.admin-tab-panel h2 {
  font-family: var(--font-heading);
  font-size: 1.1rem;
  margin: 0 0 1rem;
  color: var(--accent);
}

.admin-hint {
  font-size: 0.85rem;
  color: var(--text-muted);
  margin: 0 0 1rem;
}

.admin-table-wrap {
  overflow-x: auto;
  margin-bottom: 1.5rem;
}

.admin-table-wrap table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
}

.admin-table-wrap th,
.admin-table-wrap td {
  text-align: left;
  padding: 0.6rem 0.75rem;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}

.admin-table-wrap th {
  color: var(--text-muted);
  font-weight: 600;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.admin-table-wrap tr:hover td {
  background: rgba(255,255,255,0.02);
}

.admin-link {
  color: var(--accent);
  text-decoration: none;
}

.admin-link:hover { text-decoration: underline; }

.admin-error {
  color: #ef5350;
  font-size: 0.9rem;
  margin: 0 0 1rem;
}

.admin-form-wrap {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 10px;
  padding: 1.5rem;
  margin-bottom: 1.5rem;
  max-width: 400px;
}

.admin-form-wrap h3 {
  font-size: 1rem;
  margin: 0 0 1rem;
  color: var(--accent);
}

.admin-form-wrap label {
  display: block;
  margin-bottom: 0.75rem;
  font-size: 0.85rem;
  color: var(--text-muted);
}

.admin-form-wrap input,
.admin-form-wrap select {
  display: block;
  width: 100%;
  margin-top: 0.25rem;
  padding: 0.5rem 0.75rem;
  font: inherit;
  color: var(--text);
  background: rgba(0,0,0,0.3);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 6px;
}

.admin-users-actions { margin-bottom: 1rem; }

.admin-settings-form label {
  display: block;
  margin-bottom: 1rem;
  font-size: 0.85rem;
  color: var(--text-muted);
}

.admin-settings-form input,
.admin-settings-form textarea {
  display: block;
  width: 100%;
  max-width: 600px;
  margin-top: 0.35rem;
  padding: 0.6rem 0.75rem;
  font: inherit;
  font-size: 0.9rem;
  color: var(--text);
  background: rgba(0,0,0,0.3);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 6px;
}

.admin-settings-form textarea {
  min-height: 80px;
  font-family: monospace;
}

.admin-empty {
  color: var(--text-muted);
  font-style: italic;
  padding: 1.5rem;
}

.btn-small {
  padding: 0.4rem 0.75rem;
  font-size: 0.8rem;
}

.admin-badge {
  display: inline-block;
  padding: 0.25rem 0.6rem;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  border-radius: 6px;
}

.admin-badge-ok {
  background: rgba(139,195,74,0.2);
  color: var(--accent);
  border: 1px solid rgba(139,195,74,0.4);
}

.admin-modal-wrap {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.6);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  padding: 1rem;
}

.admin-modal {
  background: var(--bg);
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 12px;
  padding: 1.5rem;
  max-width: 480px;
  width: 100%;
  max-height: 90vh;
  overflow-y: auto;
}

.admin-modal h3 {
  margin: 0 0 1rem;
  font-family: var(--font-heading);
  font-size: 1.25rem;
}

.admin-modal label {
  display: block;
  margin-bottom: 0.5rem;
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--text-muted);
}

.admin-modal input {
  width: 100%;
  padding: 0.5rem 0.75rem;
  margin-bottom: 0.75rem;
  font: inherit;
  color: var(--text);
  background: rgba(0,0,0,0.3);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 6px;
}

.admin-hint-inline {
  font-size: 0.75rem;
  font-weight: normal;
  color: var(--text-muted);
  margin-left: 0.5rem;
}

.admin-custom-prices-wrap {
  margin: 1.25rem 0;
  padding-top: 1rem;
  border-top: 1px solid rgba(255,255,255,0.1);
}

.admin-custom-prices-wrap h4 {
  font-size: 0.9rem;
  margin: 0 0 0.35rem;
  color: var(--text);
}

.admin-custom-prices-list {
  max-height: 220px;
  overflow-y: auto;
  margin-top: 0.5rem;
}

.admin-custom-prices-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.85rem;
}

.admin-custom-prices-table th,
.admin-custom-prices-table td {
  text-align: left;
  padding: 0.4rem 0.5rem;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}

.admin-custom-prices-table .custom-price-input {
  width: 100%;
  max-width: 90px;
  padding: 0.35rem 0.5rem;
  font: inherit;
  font-size: 0.85rem;
  color: var(--text);
  background: rgba(0,0,0,0.3);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 4px;
}
