/* Demo Modal — Self-contained styles for pages that don't load draft.css.
   Uses tokens.css variable names (--color-*) with hardcoded fallbacks.
   Include AFTER tokens.css or standalone. */

@keyframes demo-spin {
  to { transform: rotate(360deg); }
}

#demo-request-modal {
  position: fixed;
  inset: 0;
  z-index: 2147483647;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 1;
  transition: opacity 0.12s ease;
}
#demo-request-modal.demo-modal-closing {
  opacity: 0;
  pointer-events: none;
}
#demo-request-modal.hidden {
  display: none !important;
}

/* Backdrop */
#demo-request-modal > div:first-child {
  position: absolute;
  inset: 0;
  background: rgba(10, 15, 30, 0.85) !important;
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
}

/* Centering wrapper */
#demo-request-modal > div:nth-child(2) {
  position: relative;
  z-index: 10;
  display: flex;
  min-height: 100%;
  width: 100%;
  align-items: center;
  justify-content: center;
  padding: 2.5rem 1rem;
}

/* Card */
#demo-request-modal .w-full { width: 100% !important; }
#demo-request-modal .max-w-xl { max-width: 36rem; }
#demo-request-modal .rounded-3xl { border-radius: 1.5rem !important; }
#demo-request-modal .bg-white { background-color: var(--color-white, #fff) !important; }
#demo-request-modal .shadow-2xl { box-shadow: 0 25px 50px -12px rgba(0,0,0,0.25); }
#demo-request-modal .ring-1,
#demo-request-modal .ring-slate-900\/10 { box-shadow: 0 0 0 1px rgba(15,23,42,0.1); }
#demo-request-modal .overflow-hidden { overflow: visible !important; }

/* Layout utilities */
#demo-request-modal .flex { display: flex !important; }
#demo-request-modal .min-h-full { min-height: 100% !important; }
#demo-request-modal .items-center { align-items: center !important; }
#demo-request-modal .items-start { align-items: flex-start !important; }
#demo-request-modal .justify-center { justify-content: center !important; }
#demo-request-modal .justify-between { justify-content: space-between !important; }
#demo-request-modal .gap-3 { gap: 0.75rem !important; }
#demo-request-modal .gap-4 { gap: 1rem !important; }
#demo-request-modal .inline-flex { display: inline-flex !important; }

/* Spacing utilities */
#demo-request-modal .px-4 { padding-left: 1rem !important; padding-right: 1rem !important; }
#demo-request-modal .px-6 { padding-left: 1.5rem !important; padding-right: 1.5rem !important; }
#demo-request-modal .py-5 { padding-top: 1.25rem !important; padding-bottom: 1.25rem !important; }
#demo-request-modal .py-10 { padding-top: 2.5rem !important; padding-bottom: 2.5rem !important; }
#demo-request-modal .pt-4 { padding-top: 1rem !important; }
#demo-request-modal .pb-6 { padding-bottom: 1.5rem !important; }
#demo-request-modal .mt-1 { margin-top: 0.25rem !important; }
#demo-request-modal .mt-2 { margin-top: 0.5rem !important; }
#demo-request-modal .p-2 { padding: 0.5rem !important; }

/* Text utilities */
#demo-request-modal .text-xs { font-size: 0.75rem !important; line-height: 1rem !important; }
#demo-request-modal .text-sm { font-size: 0.875rem !important; line-height: 1.25rem !important; }
#demo-request-modal .text-xl { font-size: 1.25rem !important; line-height: 1.75rem !important; }
#demo-request-modal .font-bold { font-weight: 700 !important; }
#demo-request-modal .font-semibold { font-weight: 600 !important; }
#demo-request-modal .font-medium { font-weight: 500 !important; }
#demo-request-modal .uppercase { text-transform: uppercase !important; }

/* Color utilities */
#demo-request-modal .text-primary { color: var(--color-blue-500, #4a6fe8) !important; }
#demo-request-modal .bg-primary { background-color: var(--color-blue-500, #4a6fe8) !important; }
#demo-request-modal .text-slate-500 { color: var(--text-muted, #6B7280) !important; }
#demo-request-modal .text-slate-700 { color: var(--text-secondary, #4B5563) !important; }
#demo-request-modal .text-slate-900,
#demo-request-modal .text-slate-800 { color: var(--text-primary, #111) !important; }
#demo-request-modal .border-slate-200 { border-color: var(--border-default, #E5E7EB) !important; }
#demo-request-modal .border-b { border-bottom-width: 1px !important; border-bottom-style: solid !important; }

/* Shape utilities */
#demo-request-modal .rounded-full { border-radius: 9999px !important; }
#demo-request-modal .rounded-xl { border-radius: 0.75rem; }
#demo-request-modal .h-4 { height: 1rem !important; }
#demo-request-modal .w-4 { width: 1rem !important; }

/* Tracking */
#demo-request-modal .tracking-\[0\.2em\] { letter-spacing: 0.2em !important; }

/* Responsive */
@media (min-width: 640px) {
  #demo-request-modal > div:nth-child(2) { padding: 4rem 1rem; }
}
@media (min-width: 768px) {
  #demo-request-modal form .grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
  }
}

/* ---- Dismiss button ---- */
#demo-request-modal button[data-demo-dismiss] {
  background: var(--color-navy-800, #111d33) !important;
  border: none !important;
  color: var(--color-white, #fff) !important;
  cursor: pointer;
  transition: background 0.15s ease;
}
#demo-request-modal button[data-demo-dismiss]:hover {
  background: var(--color-navy-700, #1a2f5e) !important;
}
#demo-request-modal button[data-demo-dismiss]:focus {
  outline: none !important;
  box-shadow: 0 0 0 2px rgba(74,111,232,0.4) !important;
}
#demo-request-modal button[data-demo-dismiss] svg {
  width: 14px;
  height: 14px;
  display: block;
}

/* ---- Submit button ---- */
#demo-request-modal button[data-demo-submit] {
  background-color: var(--color-blue-500, #4a6fe8) !important;
  color: var(--color-white, #fff) !important;
  border: none;
  border-radius: 9999px !important;
  padding: 0.75rem 1.5rem !important;
  font-weight: 600 !important;
  font-size: 14px;
  cursor: pointer;
  transition: background-color 0.15s ease;
  width: 100%;
}
#demo-request-modal button[data-demo-submit]:hover {
  background-color: var(--color-blue-600, #3658d4) !important;
}
#demo-request-modal button[data-demo-submit].demo-submit-loading {
  cursor: wait;
  min-height: 2.75rem;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
}

/* ---- Spinner ---- */
#demo-request-modal .demo-submit-spinner,
#demo-chili-loading-bridge .demo-submit-spinner {
  width: 1rem;
  height: 1rem;
  border: 2px solid rgba(255, 255, 255, 0.35);
  border-top-color: var(--color-white, #fff);
  border-radius: 50%;
  animation: demo-spin 0.7s linear infinite;
}

/* ---- Form fields ---- */
#demo-request-modal .input-demo {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  max-width: 100%;
}
#demo-request-modal .input-field {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
#demo-request-modal .input-label {
  font-size: 12px;
  font-weight: 600;
  color: var(--color-navy-900, #0a1628);
}
#demo-request-modal .input-el {
  font-family: var(--font-sans, 'Inter', -apple-system, sans-serif);
  font-size: 14px;
  color: var(--color-navy-900, #0a1628);
  background: var(--color-white, #fff);
  border: 1px solid var(--border-default, #E5E7EB);
  border-radius: 0.5rem;
  padding: 10px 14px;
  outline: none;
  transition: border-color 0.15s ease;
  width: 100%;
  box-sizing: border-box;
}
#demo-request-modal .input-el::placeholder {
  color: var(--text-muted, #9CA3AF);
}
#demo-request-modal .input-el:focus {
  border-color: var(--color-blue-500, #4a6fe8);
  box-shadow: 0 0 0 2px rgba(74,111,232,0.15);
}
#demo-request-modal .input-el.error {
  border-color: #ef4444;
}
#demo-request-modal .input-hint {
  font-size: 11px;
  color: var(--text-muted, #9CA3AF);
}
#demo-request-modal .input-hint.error {
  color: #ef4444;
}
#demo-request-modal .input-row-two {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}
@media (max-width: 480px) {
  #demo-request-modal .input-row-two {
    grid-template-columns: 1fr;
  }
}

/* Peer checkbox (for multi-step modal) */
#demo-request-modal .sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border-width: 0;
}
#demo-request-modal .block { display: block; }
#demo-request-modal .hidden { display: none !important; }
#demo-request-modal label .peer:checked ~ span {
  border-color: var(--color-blue-500, #4a6fe8) !important;
  background-color: rgba(74,111,232,0.05) !important;
  color: var(--color-blue-500, #4a6fe8) !important;
}
#demo-request-modal label .peer:checked ~ span svg {
  opacity: 1 !important;
}
#demo-request-modal .opacity-0 { opacity: 0; }
#demo-request-modal .transition-colors { transition: color 0.15s, background-color 0.15s, border-color 0.15s; }

/* Pill previews */
#demo-request-modal .bg-primary\/10 { background-color: rgba(74,111,232,0.1); }
#demo-request-modal .bg-slate-200 { background-color: var(--border-default, #E5E7EB); }
#demo-request-modal .text-slate-600 { color: var(--text-secondary, #4B5563); }

/* ---- Chili loading bridge ---- */
#demo-chili-loading-bridge {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  background: rgba(15,23,42,0.9);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  color: #fff;
  font-family: var(--font-sans, 'Inter', system-ui, sans-serif);
}
