/* ============================================================
   Demodrop — scoped styles, high specificity to survive WP themes
   ============================================================ */

/* ── Reset within scope ────────────────────────────────────── */

.demodrop-wrap,
.demodrop-wrap * {
  box-sizing: border-box !important;
  font-family: 'Oswald', -apple-system, BlinkMacSystemFont, 'Segoe UI', Arial, sans-serif !important;
}

.demodrop-wrap {
  max-width: 680px !important;
  margin: 0 auto !important;
  padding: 0 16px 40px !important;
  color: #171717 !important;
  background: transparent !important;
}

/* ── Card ──────────────────────────────────────────────────── */

.demodrop-wrap .demodrop-card {
  background: #f5f5f5 !important;
  border: 1px solid #e0e0e0 !important;
  border-radius: 10px !important;
  padding: 40px 48px !important;
  box-shadow: 0 2px 12px rgba(0,0,0,0.06) !important;
}

@media (max-width: 600px) {
  .demodrop-wrap .demodrop-card {
    padding: 28px 20px !important;
  }
}

/* ── Header ────────────────────────────────────────────────── */

.demodrop-wrap .demodrop-header {
  text-align: center !important;
  margin-bottom: 32px !important;
  padding: 0 !important;
  background: transparent !important;
  border: none !important;
}

.demodrop-wrap .demodrop-logo {
  width: 64px !important;
  height: 64px !important;
  border-radius: 8px !important;
  display: block !important;
  margin: 0 auto 16px !important;
}

.demodrop-wrap .demodrop-title {
  font-size: 2rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
  color: #171717 !important;
  margin: 0 0 8px !important;
  padding: 0 !important;
  line-height: 1.2 !important;
  background: none !important;
  border: none !important;
}

.demodrop-wrap .demodrop-subtitle {
  font-size: 0.72rem !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: #999 !important;
  margin: 0 !important;
  padding: 0 !important;
  background: none !important;
}

.demodrop-wrap .demodrop-sep {
  color: rgba(255, 184, 51, 0.6) !important;
  margin: 0 6px !important;
}

/* ── Form layout ───────────────────────────────────────────── */

.demodrop-wrap form {
  text-align: left !important;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border: none !important;
}

.demodrop-wrap .demodrop-row {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 16px !important;
  margin-bottom: 16px !important;
}

@media (max-width: 520px) {
  .demodrop-wrap .demodrop-row {
    grid-template-columns: 1fr !important;
  }
}

.demodrop-wrap .demodrop-field {
  display: flex !important;
  flex-direction: column !important;
  margin-bottom: 16px !important;
  padding: 0 !important;
  background: transparent !important;
  border: none !important;
}

.demodrop-wrap .demodrop-row .demodrop-field {
  margin-bottom: 0 !important;
}

.demodrop-wrap .demodrop-field label {
  font-size: 0.72rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color: #555 !important;
  margin-bottom: 6px !important;
  padding: 0 !important;
  display: block !important;
  background: none !important;
  border: none !important;
  line-height: 1.4 !important;
}

.demodrop-wrap .demodrop-field input[type="text"],
.demodrop-wrap .demodrop-field input[type="email"],
.demodrop-wrap .demodrop-field textarea {
  background: #ffffff !important;
  border: 1px solid #d4d4d4 !important;
  border-radius: 6px !important;
  padding: 10px 14px !important;
  font-size: 0.9rem !important;
  color: #171717 !important;
  transition: border-color 0.15s, box-shadow 0.15s !important;
  outline: none !important;
  width: 100% !important;
  margin: 0 !important;
  box-shadow: none !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  line-height: 1.5 !important;
}

.demodrop-wrap .demodrop-field input[type="text"]:focus,
.demodrop-wrap .demodrop-field input[type="email"]:focus,
.demodrop-wrap .demodrop-field textarea:focus {
  border-color: #FFB833 !important;
  box-shadow: 0 0 0 3px rgba(255, 184, 51, 0.18) !important;
  outline: none !important;
}

.demodrop-wrap .demodrop-field textarea {
  resize: vertical !important;
  min-height: 110px !important;
}

/* ── Dropzone (now a <label> element) ──────────────────────── */

.demodrop-wrap .demodrop-dropzone {
  display: block !important;
  position: relative !important;
  border: 2px dashed #cacaca !important;
  border-radius: 8px !important;
  padding: 36px 24px !important;
  text-align: center !important;
  cursor: pointer !important;
  transition: border-color 0.15s, background 0.15s !important;
  background: #ffffff !important;
  /* Reset label default styles */
  font-weight: normal !important;
  color: inherit !important;
  margin: 0 !important;
}

.demodrop-wrap .demodrop-dropzone:hover,
.demodrop-wrap .demodrop-dropzone.is-over {
  border-color: #FFB833 !important;
  background: rgba(255, 184, 51, 0.04) !important;
}

.demodrop-wrap .demodrop-dz-inner {
  pointer-events: none !important;
}

.demodrop-wrap .demodrop-dz-icon {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 48px !important;
  height: 48px !important;
  border-radius: 50% !important;
  background: rgba(26, 115, 232, 0.08) !important;
  color: #1A73E8 !important;
  margin: 0 auto 12px !important;
}

.demodrop-wrap .demodrop-dz-icon-active {
  background: rgba(255, 184, 51, 0.14) !important;
  color: #FFB833 !important;
}

.demodrop-wrap .demodrop-dz-icon svg {
  display: block !important;
  width: 24px !important;
  height: 24px !important;
}

.demodrop-wrap .demodrop-dz-primary {
  font-size: 0.875rem !important;
  font-weight: 500 !important;
  color: #333 !important;
  margin: 0 0 4px !important;
  padding: 0 !important;
}

.demodrop-wrap .demodrop-dz-secondary {
  font-size: 0.75rem !important;
  color: #999 !important;
  margin: 0 0 10px !important;
  padding: 0 !important;
}

.demodrop-wrap .demodrop-badge {
  display: inline-block !important;
  background: #ebebeb !important;
  border: 1px solid #ddd !important;
  border-radius: 4px !important;
  font-size: 0.65rem !important;
  font-family: monospace !important;
  padding: 2px 7px !important;
  color: #666 !important;
  letter-spacing: 0.04em !important;
}

.demodrop-wrap .demodrop-dz-limit {
  font-size: 0.7rem !important;
  color: #bbb !important;
  margin: 8px 0 0 !important;
  padding: 0 !important;
}

/* ── File list — hidden by default, JS adds .demodrop-show ─── */

.demodrop-wrap .demodrop-file-list {
  display: none !important;
  margin-top: 10px !important;
  padding: 0 !important;
  flex-direction: column !important;
  gap: 8px !important;
}

.demodrop-wrap .demodrop-file-list.demodrop-show {
  display: flex !important;
}

.demodrop-wrap .demodrop-file-item {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  background: rgba(0,0,0,0.03) !important;
  border: 1px solid #eaeaea !important;
  border-radius: 6px !important;
  padding: 8px 12px !important;
  margin: 0 !important;
}

.demodrop-wrap .demodrop-file-icon {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 28px !important;
  height: 28px !important;
  min-width: 28px !important;
  border-radius: 50% !important;
  background: rgba(26, 115, 232, 0.08) !important;
  color: #1A73E8 !important;
}

.demodrop-wrap .demodrop-file-info {
  flex: 1 !important;
  min-width: 0 !important;
}

.demodrop-wrap .demodrop-file-name {
  font-size: 0.85rem !important;
  font-weight: 500 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  color: #222 !important;
  margin: 0 !important;
  padding: 0 !important;
}

.demodrop-wrap .demodrop-file-size {
  font-size: 0.7rem !important;
  color: #999 !important;
  margin: 0 !important;
  padding: 0 !important;
}

.demodrop-wrap .demodrop-file-remove {
  background: none !important;
  border: none !important;
  cursor: pointer !important;
  color: #bbb !important;
  padding: 4px !important;
  line-height: 1 !important;
  transition: color 0.15s !important;
  min-width: auto !important;
  width: auto !important;
  box-shadow: none !important;
  border-radius: 0 !important;
}

.demodrop-wrap .demodrop-file-remove:hover {
  color: #e53e3e !important;
  background: none !important;
}

.demodrop-wrap .demodrop-file-summary {
  display: flex !important;
  justify-content: space-between !important;
  font-size: 0.7rem !important;
  color: #aaa !important;
  padding: 2px 2px 0 !important;
  margin: 0 !important;
  background: transparent !important;
  border: none !important;
}

.demodrop-wrap .demodrop-file-total {
  color: rgba(26, 115, 232, 0.65) !important;
}

/* ── Error messages ────────────────────────────────────────── */

.demodrop-wrap .demodrop-error {
  font-size: 0.7rem !important;
  color: #e53e3e !important;
  margin-top: 4px !important;
  display: block !important;
  min-height: 14px !important;
  padding: 0 !important;
  background: transparent !important;
  border: none !important;
}

/* Hidden by default, JS adds .demodrop-show */
.demodrop-wrap .demodrop-alert-error {
  display: none !important;
  gap: 8px !important;
  background: rgba(229, 62, 62, 0.07) !important;
  border: 1px solid rgba(229, 62, 62, 0.2) !important;
  border-radius: 6px !important;
  padding: 10px 14px !important;
  font-size: 0.8rem !important;
  color: #c53030 !important;
  margin-bottom: 16px !important;
  margin-top: 8px !important;
}

.demodrop-wrap .demodrop-alert-error.demodrop-show {
  display: flex !important;
  align-items: flex-start !important;
}

/* ── Submit button ─────────────────────────────────────────── */

.demodrop-wrap .demodrop-btn {
  width: 100% !important;
  background: #FFB833 !important;
  background-color: #FFB833 !important;
  color: #171717 !important;
  border: none !important;
  border-radius: 6px !important;
  padding: 13px 24px !important;
  font-size: 0.88rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.07em !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  transition: opacity 0.15s, transform 0.1s !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  margin-top: 20px !important;
  box-shadow: none !important;
  text-decoration: none !important;
  line-height: 1.5 !important;
  -webkit-appearance: none !important;
  appearance: none !important;
}

.demodrop-wrap .demodrop-btn:hover:not(:disabled) {
  opacity: 0.88 !important;
  background: #FFB833 !important;
  background-color: #FFB833 !important;
  color: #171717 !important;
}

.demodrop-wrap .demodrop-btn:active:not(:disabled) {
  transform: scale(0.99) !important;
}

.demodrop-wrap .demodrop-btn:disabled {
  opacity: 0.6 !important;
  cursor: not-allowed !important;
}

.demodrop-wrap .demodrop-btn-outline {
  background: transparent !important;
  background-color: transparent !important;
  border: 1px solid #d4d4d4 !important;
  color: #555 !important;
  margin-top: 0 !important;
}

.demodrop-wrap .demodrop-btn-outline:hover:not(:disabled) {
  background: rgba(0,0,0,0.04) !important;
  background-color: rgba(0,0,0,0.04) !important;
  color: #555 !important;
  opacity: 1 !important;
}

.demodrop-wrap .demodrop-footer-note {
  text-align: center !important;
  font-size: 0.68rem !important;
  color: #bbb !important;
  margin: 12px 0 0 !important;
  padding: 0 !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
  background: transparent !important;
  border: none !important;
}

/* ── Spinner ───────────────────────────────────────────────── */

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

.demodrop-wrap .demodrop-spin {
  animation: demodrop-spin 0.9s linear infinite !important;
  display: inline-block !important;
}

/* ── Success screen — hidden by default, JS adds .demodrop-show */

.demodrop-wrap .demodrop-success-card {
  display: none !important;
  flex-direction: column !important;
  align-items: center !important;
  text-align: center !important;
  padding: 52px 48px !important;
  margin-top: 0 !important;
}

.demodrop-wrap .demodrop-success-card.demodrop-show {
  display: flex !important;
}

/* Form card — visible by default, JS hides it on success */
.demodrop-wrap #demodrop-form-card {
  display: block !important;
}

.demodrop-wrap #demodrop-form-card.demodrop-hidden {
  display: none !important;
}

.demodrop-wrap .demodrop-success-card .demodrop-logo {
  margin-bottom: 28px !important;
}

.demodrop-wrap .demodrop-success-icon {
  width: 64px !important;
  height: 64px !important;
  border-radius: 50% !important;
  background: rgba(255, 184, 51, 0.12) !important;
  color: #FFB833 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin-bottom: 20px !important;
}

.demodrop-wrap .demodrop-success-msg {
  font-size: 0.9rem !important;
  color: #777 !important;
  line-height: 1.8 !important;
  margin: 8px 0 28px !important;
  max-width: 380px !important;
  text-transform: none !important;
  padding: 0 !important;
  background: transparent !important;
  border: none !important;
}

.demodrop-wrap .demodrop-success-msg strong {
  color: #222 !important;
}

.demodrop-wrap .demodrop-success-card .demodrop-btn-outline {
  max-width: 280px !important;
}
