/* components.css */

/* Inputs */
.field {
  display: grid;
  gap: 8px;
}

.field label {
  color: var(--text-soft);
  font-size: 13px;
  font-weight: 600;
}

.input,
.select,
.textarea {
  width: 100%;
  min-height: 46px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: rgba(17,24,39,.72);
  color: var(--text);
  padding: 12px 14px;
  outline: none;
  transition:
    border-color var(--transition-fast),
    box-shadow var(--transition-fast),
    background var(--transition-fast);
  box-shadow: var(--shadow-xs);
}

.input::placeholder,
.textarea::placeholder {
  color: var(--muted);
}

.input:hover,
.select:hover,
.textarea:hover {
  border-color: var(--line-strong);
}

.input:focus,
.select:focus,
.textarea:focus {
  border-color: rgba(96,165,250,.38);
  box-shadow:
    0 0 0 4px rgba(59,130,246,.14),
    var(--shadow-xs);
  background: rgba(17,24,39,.84);
}

.textarea {
  min-height: 110px;
  resize: vertical;
}

/* Buttons */
.btn {
  --btn-bg: linear-gradient(180deg, rgba(59,130,246,.22), rgba(59,130,246,.12));
  --btn-border: rgba(96,165,250,.24);
  --btn-color: var(--text);
  --btn-shadow: 0 14px 32px rgba(37,99,235,.18);

  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 46px;
  padding: 0 18px;
  border: 1px solid var(--btn-border);
  border-radius: var(--radius-sm);
  background: var(--btn-bg);
  color: var(--btn-color);
  cursor: pointer;
  font-weight: 700;
  letter-spacing: -.01em;
  transition:
    transform var(--transition-fast),
    border-color var(--transition-fast),
    box-shadow var(--transition-fast),
    filter var(--transition-fast),
    background var(--transition-fast);
  box-shadow: var(--btn-shadow);
  user-select: none;
  text-align: center;
  white-space: nowrap;
}

.btn:hover {
  transform: translateY(-1px);
  filter: saturate(1.08);
  border-color: rgba(147,197,253,.34);
}

.btn:active {
  transform: translateY(0);
}

.btn:disabled,
.btn.is-disabled {
  opacity: .55;
  cursor: not-allowed;
  transform: none;
  filter: none;
}

.btn-sm {
  min-height: 40px;
  padding: 0 14px;
  border-radius: 14px;
  font-size: 13px;
}

.btn-lg {
  min-height: 52px;
  padding: 0 22px;
  border-radius: 18px;
  font-size: 15px;
}

.btn-block {
  width: 100%;
}

.btn-primary {
  --btn-bg: linear-gradient(180deg, rgba(59,130,246,.26), rgba(37,99,235,.14));
  --btn-border: rgba(96,165,250,.30);
}

.btn-secondary {
  --btn-bg: rgba(17,24,39,.72);
  --btn-border: var(--line);
  --btn-shadow: var(--shadow-sm);
}

.btn-success {
  --btn-bg: linear-gradient(180deg, rgba(34,197,94,.24), rgba(34,197,94,.12));
  --btn-border: rgba(134,239,172,.28);
  --btn-shadow: 0 14px 32px rgba(34,197,94,.14);
}

.btn-warning {
  --btn-bg: linear-gradient(180deg, rgba(245,158,11,.26), rgba(245,158,11,.12));
  --btn-border: rgba(252,211,77,.28);
  --btn-shadow: 0 14px 32px rgba(245,158,11,.14);
}

.btn-danger {
  --btn-bg: linear-gradient(180deg, rgba(239,68,68,.24), rgba(239,68,68,.12));
  --btn-border: rgba(252,165,165,.24);
  --btn-shadow: 0 14px 32px rgba(239,68,68,.16);
}

.btn-ghost {
  --btn-bg: transparent;
  --btn-border: transparent;
  --btn-shadow: none;
  color: var(--text-soft);
}

.btn-ghost:hover {
  background: rgba(255,255,255,.04);
}

/* Badges */
.badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-height: 28px;
  padding: 0 10px;
  border-radius: var(--radius-pill);
  border: 1px solid transparent;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .01em;
  white-space: nowrap;
  max-width: 100%;
}

.badge-neutral {
  color: var(--text-soft);
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.06);
}

.badge-primary {
  color: #bfdbfe;
  background: rgba(59,130,246,.12);
  border-color: rgba(59,130,246,.18);
}

.badge-success {
  color: #86efac;
  background: var(--success-soft);
  border-color: rgba(134,239,172,.14);
}

.badge-warning {
  color: #fcd34d;
  background: var(--warning-soft);
  border-color: rgba(252,211,77,.14);
}

.badge-danger {
  color: #fca5a5;
  background: var(--danger-soft);
  border-color: rgba(252,165,165,.14);
}

.badge-info {
  color: #93c5fd;
  background: rgba(59,130,246,.12);
  border-color: rgba(147,197,253,.14);
}

/* Cards */
.card {
  position: relative;
  background: rgba(17,24,39,.82);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  padding: 20px;
  box-shadow: var(--shadow-md);
  overflow: hidden;
}

.card::before {
  content: "";
  position: absolute;
  inset: 0 auto auto 0;
  width: 100%;
  height: 1px;
  background: linear-gradient(90deg, rgba(96,165,250,.20), transparent 42%);
  pointer-events: none;
}

.card-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 16px;
}

.card-title {
  margin: 0;
  font-size: clamp(16px, 2vw, 18px);
  font-weight: 700;
  letter-spacing: -.02em;
}

.card-subtitle {
  margin: 6px 0 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.55;
}

.card-body {
  display: grid;
  gap: 14px;
}

.card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 18px;
  padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,.06);
  flex-wrap: wrap;
}

.card-soft {
  background: rgba(255,255,255,.04);
}

.card-flat {
  box-shadow: none;
}

.card-login {
  width: min(460px, 100%);
  padding: 28px;
  border-radius: var(--radius-lg);
  background: linear-gradient(180deg, rgba(17,24,39,.94), rgba(15,23,42,.96));
}

/* Modal */
.modal {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 24px;
  z-index: 1000;
}

.modal.is-open,
.modal.show {
  display: flex;
}

.modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(2,6,23,.76);
  backdrop-filter: blur(6px);
}

.modal-dialog {
  position: relative;
  width: min(720px, 100%);
  max-height: min(90vh, 900px);
  overflow: auto;
  background: rgba(15,23,42,.98);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 26px;
  box-shadow: var(--shadow-lg);
  z-index: 1;
}

.modal-dialog.modal-sm {
  width: min(440px, 100%);
}

.modal-dialog.modal-lg {
  width: min(980px, 100%);
}

.modal-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 22px 24px 16px;
  border-bottom: 1px solid rgba(255,255,255,.06);
}

.modal-title {
  margin: 0 0 6px;
  font-size: clamp(20px, 3vw, 22px);
  font-weight: 800;
  letter-spacing: -.03em;
}

.modal-description {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.55;
}

.modal-body {
  padding: 22px 24px 24px;
}

.modal-footer {
  display: flex;
  justify-content: flex-end;
  gap: 12px;
  padding: 0 24px 24px;
  flex-wrap: wrap;
}

.modal-close {
  width: 42px;
  height: 42px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 14px;
  background: rgba(255,255,255,.04);
  color: var(--text);
  display: inline-grid;
  place-items: center;
  cursor: pointer;
  box-shadow: var(--shadow-xs);
  transition: background var(--transition-fast), border-color var(--transition-fast), transform var(--transition-fast);
}

.modal-close:hover {
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.14);
  transform: translateY(-1px);
}

body.modal-open {
  overflow: hidden;
}

@media (max-width: 640px) {
  .btn {
    width: 100%;
  }

  .card,
  .modal-body,
  .modal-header,
  .modal-footer {
    padding-left: 16px;
    padding-right: 16px;
  }

  .modal {
    padding: 12px;
  }

  .modal-dialog,
  .modal-dialog.modal-sm,
  .modal-dialog.modal-lg {
    width: 100%;
    border-radius: 20px;
  }
}
