/**
 * Directorist Stripe Connect — Dashboard Styles
 * Aesthetic: Refined Financial / Luxe Minimal
 * Font pairing: DM Serif Display + DM Sans
 */

@import url('https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,300&display=swap');

/* ─── Design Tokens ──────────────────────────────────────────────────── */
:root {
  --dsc-bg:            #0d0f14;
  --dsc-surface:       #151820;
  --dsc-surface-2:     #1c1f2b;
  --dsc-border:        rgba(255,255,255,0.07);
  --dsc-border-focus:  rgba(99,179,237,0.45);

  --dsc-stripe:        #635bff;
  --dsc-stripe-light:  #8b85ff;
  --dsc-stripe-glow:   rgba(99,91,255,0.22);

  --dsc-live:          #00d68f;
  --dsc-live-bg:       rgba(0,214,143,0.10);
  --dsc-test:          #f6a623;
  --dsc-test-bg:       rgba(246,166,35,0.10);

  --dsc-text:          #e8eaf0;
  --dsc-text-muted:    #7b8198;
  --dsc-text-faint:    #4a4f65;

  --dsc-success-bg:    rgba(0,214,143,0.08);
  --dsc-success-border:rgba(0,214,143,0.25);

  --dsc-radius:        14px;
  --dsc-radius-sm:     8px;
  --dsc-transition:    0.22s cubic-bezier(0.4, 0, 0.2, 1);
}

/* ─── Wrapper ────────────────────────────────────────────────────────── */
.dsc-stripe-connect-wrapper {
  font-family: 'DM Sans', sans-serif;
  max-width: 660px;
  margin: 0 auto;
  padding: 48px 40px 56px;
  background: var(--dsc-surface);
  border: 1px solid var(--dsc-border);
  border-radius: var(--dsc-radius);
  box-shadow:
    0 0 0 1px rgba(255,255,255,0.03),
    0 24px 64px rgba(0,0,0,0.55),
    0 0 80px var(--dsc-stripe-glow);
  position: relative;
  overflow: hidden;
  float: left;
}

/* Decorative top accent bar */
.dsc-stripe-connect-wrapper::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--dsc-stripe) 0%, var(--dsc-stripe-light) 50%, transparent 100%);
}

/* Subtle grain texture overlay */
.dsc-stripe-connect-wrapper::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.035'/%3E%3C/svg%3E");
  border-radius: var(--dsc-radius);
  opacity: 0.5;

}

/* ─── Section Title ──────────────────────────────────────────────────── */
.dsc-section-title {
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: 1.9rem;
  font-weight: 400;
  letter-spacing: -0.02em;
  color: var(--dsc-text);
  margin: 0 0 10px;
  line-height: 1.2;
}

.dsc-section-description {
  font-size: 0.875rem;
  color: var(--dsc-text-muted);
  line-height: 1.65;
  margin: 0 0 32px;
  font-weight: 300;
}

/* ─── Success Alert ──────────────────────────────────────────────────── */
.dsc-connection-success {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 16px 20px;
  border-radius: var(--dsc-radius-sm);
  border: 1px solid var(--dsc-success-border);
  background: var(--dsc-success-bg);
  margin-bottom: 28px;
}

.dsc-connection-success strong {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--dsc-live);
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.dsc-connection-success p {
  margin: 0;
  font-size: 0.83rem;
  color: var(--dsc-text-muted);
  line-height: 1.55;
}

/* ─── Form ───────────────────────────────────────────────────────────── */
.dsc-stripe-form {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.dsc-form-group {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 22px;
}

.dsc-form-group label {
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--dsc-text-muted);
  letter-spacing: 0.07em;
  text-transform: uppercase;
}

.dsc-form-group .directorist-input,
.dsc-form-group input[type="text"],
.dsc-form-group input[type="password"] {
  font-family: 'DM Sans', sans-serif;
  width: 100%;
  padding: 13px 16px;
  background: var(--dsc-surface-2);
  border: 1px solid var(--dsc-border);
  border-radius: var(--dsc-radius-sm);
  color: var(--dsc-text);
  font-size: 0.9rem;
  font-weight: 400;
  letter-spacing: 0.01em;
  outline: none;
  transition: border-color var(--dsc-transition), box-shadow var(--dsc-transition), background var(--dsc-transition);
  box-sizing: border-box;
  -webkit-appearance: none;
}

.dsc-form-group .directorist-input::placeholder,
.dsc-form-group input::placeholder {
  color: var(--dsc-text-faint);
  font-family: 'DM Sans', monospace;
  letter-spacing: 0.03em;
}

.dsc-form-group .directorist-input:hover,
.dsc-form-group input:hover {
  border-color: rgba(255,255,255,0.14);
  background: #202336;
}

.dsc-form-group .directorist-input:focus,
.dsc-form-group input:focus {
  border-color: var(--dsc-border-focus);
  box-shadow: 0 0 0 3px rgba(99,91,255,0.12);
  background: #202336;
}

.dsc-field-description {
  font-size: 0.75rem !important;
  color: var(--dsc-text-faint) !important;
  line-height: 1.5;
  font-style: italic;
  margin-top: 2px !important;
}

/* ─── Keys Section Card ──────────────────────────────────────────────── */
.dsc-keys-section {
  background: var(--dsc-surface-2);
  border: 1px solid var(--dsc-border);
  border-radius: var(--dsc-radius);
  padding: 24px 24px 8px;
  margin-bottom: 24px;
  transition: border-color var(--dsc-transition);
}

.dsc-keys-section:hover {
  border-color: rgba(255,255,255,0.12);
}

.dsc-keys-section-title {
  font-size: 0.82rem;
  font-weight: 500;
  color: var(--dsc-text-muted);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin: 0 0 20px;
  display: flex;
  align-items: center;
  gap: 10px;
}

/* ─── Badges ─────────────────────────────────────────────────────────── */
.dsc-badge {
  display: inline-flex;
  align-items: center;
  padding: 3px 9px;
  border-radius: 4px;
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.1em;
}

.dsc-badge-live {
  background: var(--dsc-live-bg);
  color: var(--dsc-live);
  border: 1px solid rgba(0,214,143,0.2);
}

.dsc-badge-test {
  background: var(--dsc-test-bg);
  color: var(--dsc-test);
  border: 1px solid rgba(246,166,35,0.2);
}

/* ─── Test Mode Toggle ───────────────────────────────────────────────── */
.dsc-test-mode-group {
  background: var(--dsc-surface-2);
  border: 1px solid var(--dsc-border);
  border-radius: var(--dsc-radius);
  padding: 18px 22px;
  margin-bottom: 20px !important;
}

.dsc-toggle-label {
  display: flex;
  align-items: center;
  gap: 14px;
  cursor: pointer;
  user-select: none;
}

.dsc-toggle-checkbox {
  display: none;
}

.dsc-toggle-slider {
  position: relative;
  width: 44px;
  height: 24px;
  background: var(--dsc-text-faint);
  border-radius: 100px;
  flex-shrink: 0;
  transition: background var(--dsc-transition);
}

.dsc-toggle-slider::after {
  content: '';
  position: absolute;
  top: 3px;
  left: 3px;
  width: 18px;
  height: 18px;
  background: #fff;
  border-radius: 50%;
  box-shadow: 0 1px 4px rgba(0,0,0,0.35);
  transition: transform var(--dsc-transition);
}

.dsc-toggle-checkbox:checked + .dsc-toggle-slider {
  background: var(--dsc-test);
}

.dsc-toggle-checkbox:checked + .dsc-toggle-slider::after {
  transform: translateX(20px);
}

.dsc-toggle-text {
  font-size: 0.88rem;
  font-weight: 500;
  color: var(--dsc-text);
}

/* ─── Save Button ────────────────────────────────────────────────────── */
.dsc-form-actions {
  padding-top: 4px;
}

.dsc-form-actions .directorist-btn-primary,
#dsc-save-keys {
  font-family: 'DM Sans', sans-serif;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 14px 36px;
  background: var(--dsc-stripe);
  color: #fff;
  border: none;
  border-radius: var(--dsc-radius-sm);
  font-size: 0.9rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  cursor: pointer;
  outline: none;
  transition:
    background var(--dsc-transition),
    transform var(--dsc-transition),
    box-shadow var(--dsc-transition);
  box-shadow: 0 4px 20px rgba(99,91,255,0.35);
  position: relative;
  overflow: hidden;
}

.dsc-form-actions .directorist-btn-primary::before,
#dsc-save-keys::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,0.12), transparent 60%);
  pointer-events: none;
}

.dsc-form-actions .directorist-btn-primary:hover,
#dsc-save-keys:hover {
  background: var(--dsc-stripe-light);
  box-shadow: 0 6px 28px rgba(99,91,255,0.50);
  transform: translateY(-1px);
}

.dsc-form-actions .directorist-btn-primary:active,
#dsc-save-keys:active {
  transform: translateY(0);
  box-shadow: 0 2px 10px rgba(99,91,255,0.3);
}

.dsc-form-actions .directorist-btn-primary:disabled,
#dsc-save-keys:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  transform: none;
}

/* ─── Status Message ─────────────────────────────────────────────────── */
#dsc-connection-status {
  margin-top: 16px;
  font-size: 0.83rem;
  padding: 0;
  border-radius: var(--dsc-radius-sm);
  transition: all var(--dsc-transition);
}

#dsc-connection-status:not(:empty) {
  padding: 12px 16px;
}

#dsc-connection-status.dsc-status-success {
  background: var(--dsc-success-bg);
  border: 1px solid var(--dsc-success-border);
  color: var(--dsc-live);
}

#dsc-connection-status.dsc-status-error {
  background: rgba(255,80,80,0.08);
  border: 1px solid rgba(255,80,80,0.22);
  color: #ff6b6b;
}

/* ─── Animate in ─────────────────────────────────────────────────────── */
.dsc-stripe-connect-wrapper {
  animation: dsc-reveal 0.45s cubic-bezier(0.16, 1, 0.3, 1) both;
}

@keyframes dsc-reveal {
  from {
    opacity: 0;
    transform: translateY(16px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.dsc-keys-section,
.dsc-test-mode-group {
  animation: dsc-fade 0.4s ease both;
}

@keyframes dsc-fade {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ─── Light theme override (optional) ───────────────────────────────── */
@media (prefers-color-scheme: light) {
  .dsc-stripe-connect-wrapper {
    --dsc-bg:          #f7f8fc;
    --dsc-surface:     #ffffff;
    --dsc-surface-2:   #f3f4f9;
    --dsc-border:      rgba(0,0,0,0.08);
    --dsc-border-focus:rgba(99,91,255,0.4);
    --dsc-text:        #1a1d2e;
    --dsc-text-muted:  #6b7194;
    --dsc-text-faint:  #b0b5cc;
    --dsc-stripe-glow: rgba(99,91,255,0.10);
    box-shadow:
      0 0 0 1px rgba(0,0,0,0.04),
      0 20px 48px rgba(0,0,0,0.10),
      0 0 60px var(--dsc-stripe-glow);
  }

  .dsc-form-group .directorist-input:hover,
  .dsc-form-group input:hover {
    background: #eef0f8;
  }

  .dsc-form-group .directorist-input:focus,
  .dsc-form-group input:focus {
    background: #eef0f8;
  }
}

/* ─── Responsive ─────────────────────────────────────────────────────── */
@media (max-width: 600px) {
  .dsc-stripe-connect-wrapper {
    padding: 32px 22px 40px;
  }

  .dsc-section-title {
    font-size: 1.5rem;
  }
}