/**
 * Circloud GUI - Form Styles
 * Login, input groups, form elements
 */

/* Login page body override */
body.login-page {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  background: var(--body-bg, linear-gradient(135deg, #1a1a2e 0%, #16213e 100%));
}

.login,
.login-container {
  background: #1e1e2f;
  padding: 50px 40px;
  border-radius: 20px;
  box-shadow: 0 25px 80px rgba(0,0,0,0.5);
  max-width: 420px;
  border: 1px solid rgba(255,255,255,0.1);
}

/* Error Box */
.error-box {
  background: linear-gradient(135deg, rgba(239, 68, 68, 0.15) 0%, rgba(30, 30, 47, 0.9) 100%);
  border: 1px solid rgba(239, 68, 68, 0.3);
  border-left: 4px solid #ef4444;
  border-radius: 12px;
  padding: 24px;
  text-align: center;
}

.error-box h2 {
  color: #f87171;
  font-size: 24px;
  font-weight: 700;
  margin: 0 0 12px 0;
}

.error-box p {
  color: #fca5a5;
  font-size: 15px;
  margin: 0 0 20px 0;
  line-height: 1.5;
}

.logo {
  text-align: center;
  margin-bottom: 30px;
}

.logo h1 {
  color: #fff;
  font-size: 32px;
  font-weight: 700;
  margin-bottom: 8px;
}

.logo p {
  color: #888;
  font-size: 14px;
}

.error {
  background: #3d1e1e;
  border: 2px solid #e74c3c;
  color: #ff6b6b;
  padding: 15px;
  border-radius: 10px;
  margin-bottom: 20px;
  font-size: 14px;
  text-align: center;
  animation: shake 0.5s;
}

@keyframes shake {
  0%, 100% { transform: translateX(0); }
  25% { transform: translateX(-10px); }
  75% { transform: translateX(10px); }
}

.input-group {
  position: relative;
  margin: 20px 0;
}

.input-group label {
  display: block;
  color: #aaa;
  font-size: 13px;
  margin-bottom: 8px;
  font-weight: 500;
}

.input-group input {
  width: 100%;
  padding: 14px 16px;
  background: #2a2a3e;
  border: 2px solid #3a3a4e;
  border-radius: 10px;
  color: #fff;
  font-size: 15px;
  transition: all 0.3s;
}

.input-group input:focus {
  outline: none;
  border-color: #667eea;
  background: #2e2e42;
}

.password-wrapper {
  position: relative;
}

.password-wrapper input {
  padding-right: 45px;
}

.eye-icon {
  position: absolute;
  right: 15px;
  top: 50%;
  transform: translateY(-50%);
  cursor: pointer;
  color: #888;
  font-size: 20px;
  user-select: none;
  transition: color 0.3s;
}

.eye-icon:hover {
  color: #667eea;
}

/* Form groups for dashboard forms */
.form-group {
  margin-bottom: 10px;
  flex: 1;
}

.form-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 220px));
  gap: 6px 10px;
  margin-bottom: 10px;
  justify-content: start;
}

.form-row .form-group {
  margin-bottom: 0;
  min-width: 0;
}

.form-group label {
  display: block;
  margin-bottom: 4px;
  color: #8b949e;
  font-weight: 500;
  font-size: 11px;
}

.checkbox-label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 0;
  font-size: 11px;
  font-weight: 500;
  color: #8b949e;
}

.checkbox-label input {
  margin: 0;
}

.form-group input[type="text"],
.form-group input[type="password"],
.form-group input[type="number"],
.form-group input[type="email"],
.form-group input[type="url"],
.form-group select,
.form-group textarea {
  width: 100%;
  max-width: 220px;
  padding: 6px 8px;
  background: #0d1117;
  border: 1px solid #30363d;
  border-radius: 4px;
  color: #e6edf3;
  font-size: 11px;
  font-family: inherit;
  transition: border-color 0.15s ease;
}

.pod-replicas,
.pod-service-port,
.pod-tunnel-port {
  width: 90px;
  max-width: 90px;
}

.form-group.form-group-wide,
.form-group.form-group-full {
  max-width: none;
}

.form-group.form-group-wide {
  grid-column: span 2;
}

.form-group.form-group-full {
  grid-column: 1 / -1;
}

.form-group.form-group-wide input,
.form-group.form-group-wide select,
.form-group.form-group-wide textarea,
.form-group.form-group-full input,
.form-group.form-group-full select,
.form-group.form-group-full textarea {
  max-width: 100%;
}

.pod-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(160px, 220px));
  gap: 8px 12px;
  align-items: start;
}

.pod-form-grid .form-group {
  margin-bottom: 0;
}

.pod-form-grid .span-2 {
  grid-column: span 2;
}

.form-group input[type="text"]:focus,
.form-group input[type="password"]:focus {
  outline: none;
  border-color: #8b5cf6;
  background: #161b22;
}

.form-group input::placeholder {
  color: #484f58;
}

.tenant-form.form-disabled .form-group {
  opacity: 0.55;
}

.tenant-form.form-disabled .form-actions .btn-submit {
  opacity: 0.6;
}

.tenant-form.form-disabled input,
.tenant-form.form-disabled select,
.tenant-form.form-disabled textarea {
  cursor: not-allowed;
}

/* Password wrapper with toggle */
.form-group .password-wrapper {
  position: relative;
  display: flex;
  align-items: center;
}

.form-group .password-wrapper input {
  padding-right: 32px;
}

.password-toggle {
  position: absolute;
  right: 6px;
  background: none;
  border: none;
  color: #8b949e;
  cursor: pointer;
  padding: 2px;
  font-size: 12px;
  line-height: 1;
  transition: color 0.15s ease;
}

.password-toggle:hover {
  color: #e6edf3;
}

/* Checkbox styling */
.form-group input[type="checkbox"] {
  width: 14px;
  height: 14px;
  accent-color: #8b5cf6;
  cursor: pointer;
}

.form-group .checkbox-label {
  display: flex;
  align-items: center;
  gap: 6px;
  color: #8b949e;
  font-size: 11px;
  cursor: pointer;
}

.validation-message {
  display: block;
  margin-top: 4px;
  font-size: 10px;
  font-weight: 500;
}

.validation-message.error {
  color: #f87171;
}

.validation-message.success {
  color: #34d399;
}

.form-actions {
  display: flex;
  gap: 8px;
  margin-top: 10px;
}

/* Tenant creation form */
.create-tenant-section {
  margin-bottom: 20px;
}

.tenant-form {
  background: var(--section-container-bg, #161b22);
  border: 1px solid var(--section-container-border, #30363d);
  border-radius: 6px;
  padding: 12px;
  margin-top: 8px;
}

.tenant-form h3, .tenant-form h4 {
  margin: 0 0 10px 0;
  color: #e6edf3;
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
