/* ASM 4.0 — sdilene komponenty pro klientskou zonu TS3-hosting.cz
   Reference: spec/00-design-manual.html
   Pouziva se spolu s Tailwind CDN + inline tailwind.config (primary/secondary/accent) */

/* === Form inputs ============================================== */

.form-label {
  display: block;
  font-size: 0.875rem;
  font-weight: 500;
  color: #374151;
  margin-bottom: 0.375rem;
}

.form-input {
  display: block;
  width: 100%;
  padding: 0.5rem 0.75rem;
  font-size: 0.875rem;
  line-height: 1.5;
  color: #111827;
  background-color: #fff;
  border: 1px solid #d1d5db;
  border-radius: 0.5rem;
  transition: border-color 0.15s, box-shadow 0.15s;
  -webkit-appearance: none;
  appearance: none;
}
.form-input::placeholder { color: #9ca3af; }
.form-input:hover { border-color: #a5b4fc; }
.form-input:focus {
  outline: none;
  border-color: #818cf8;
  box-shadow: 0 0 0 3px rgba(129, 140, 248, 0.18);
}

.form-input-error {
  border-color: #ef4444;
}
.form-input-error:focus {
  border-color: #ef4444;
  box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.18);
}

.form-input-success {
  border-color: #22c55e;
}
.form-input-success:focus {
  border-color: #22c55e;
  box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.18);
}

.form-hint {
  font-size: 0.75rem;
  color: #6b7280;
  margin-top: 0.25rem;
}

.form-error {
  font-size: 0.75rem;
  color: #dc2626;
  margin-top: 0.25rem;
}

/* === Chipy / badges =========================================== */

.chip {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.125rem 0.625rem;
  border-radius: 9999px;
  font-size: 0.75rem;
  font-weight: 600;
  line-height: 1.25;
  white-space: nowrap;
}
.chip-active   { background-color: #dcfce7; color: #166534; }
.chip-warning  { background-color: #fef3c7; color: #92400e; }
.chip-danger   { background-color: #fee2e2; color: #991b1b; }
.chip-info     { background-color: #dbeafe; color: #1e40af; }
.chip-inactive { background-color: #f3f4f6; color: #4b5563; }

/* === Buttony (kdyz nechces psat utility v markup) ============= */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  font-size: 0.875rem;
  font-weight: 500;
  border-radius: 0.5rem;
  border: 1px solid transparent;
  transition: background-color 0.15s, border-color 0.15s, color 0.15s, box-shadow 0.15s;
  cursor: pointer;
  text-decoration: none;
  white-space: nowrap;
}
.btn:focus { outline: none; box-shadow: 0 0 0 3px rgba(129, 140, 248, 0.25); }
.btn:disabled { opacity: 0.5; cursor: not-allowed; }

.btn-primary       { background-color: #293196; color: #fff; }
.btn-primary:hover { background-color: #22287d; }

.btn-secondary       { background-color: #c50a87; color: #fff; }
.btn-secondary:hover { background-color: #a7076f; }

.btn-outline       { background-color: transparent; border-color: #d1d5db; color: #374151; }
.btn-outline:hover { background-color: #f9fafb; }

.btn-danger        { background-color: #dc2626; color: #fff; }
.btn-danger:hover  { background-color: #b91c1c; }

.btn-ghost        { background-color: transparent; color: #6b7280; }
.btn-ghost:hover  { color: #111827; background-color: #f3f4f6; }

.btn-sm { padding: 0.375rem 0.75rem; font-size: 0.75rem; }
.btn-lg { padding: 0.625rem 1.25rem; font-size: 0.875rem; }

/* === Alerty (pageNotice) ====================================== */

.alert {
  display: flex;
  align-items: flex-start;
  gap: 0.625rem;
  padding: 0.75rem 1rem;
  border-radius: 0.625rem;
  border: 1px solid transparent;
  font-size: 0.875rem;
  line-height: 1.4;
}
.alert-ok      { background-color: #f0fdf4; border-color: #bbf7d0; color: #166534; }
.alert-chyba   { background-color: #fef2f2; border-color: #fecaca; color: #991b1b; }
.alert-warning { background-color: #fffbeb; border-color: #fde68a; color: #92400e; }
.alert-info    { background-color: #eff6ff; border-color: #bfdbfe; color: #1e40af; }

/* === Karty / panely =========================================== */

.card {
  background-color: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 0.75rem;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.03);
}
.card-padded { padding: 1.5rem; }

/* === Drobnosti ================================================ */

a.link {
  color: #293196;
  text-decoration: none;
  font-weight: 500;
}
a.link:hover { color: #22287d; text-decoration: underline; }
