@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;1,300;1,400&family=DM+Sans:wght@300;400;500&family=Cinzel:wght@400;500&display=swap');

/* ══ OVERLAY ══ */
#kdPopupOverlay {
  position: fixed;
  inset: 0;
  background: rgba(12, 10, 7, 0.82);
  z-index: 999999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  opacity: 0;
  transition: opacity 0.3s ease;
  box-sizing: border-box;
}
#kdPopupOverlay.kd-visible { opacity: 1; }

/* ══ POPUP BOX ══ */
.kd-popup-box {
  background: linear-gradient(160deg, #1a1710 0%, #0c0a07 100%);
  border: 1px solid rgba(201, 168, 76, 0.2);
  border-radius: 4px;
  width: 100%;
  max-width: 480px;
  position: relative;
  overflow: hidden;
  transform: translateY(28px) scale(0.97);
  transition: transform 0.45s cubic-bezier(0.16,1,0.3,1), opacity 0.45s;
  opacity: 0;
}
#kdPopupOverlay.kd-visible .kd-popup-box {
  transform: translateY(0) scale(1);
  opacity: 1;
}
.kd-popup-box::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent 0%, #c9a84c 30%, #e8d08a 50%, #c9a84c 70%, transparent 100%);
}

/* ══ CLOSE BTN ══ */
.kd-close {
  position: absolute;
  top: 16px; right: 16px;
  width: 32px; height: 32px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(201,168,76,0.15);
  border-radius: 50%;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  color: #a9a39a;
  font-size: 18px;
  line-height: 1;
  transition: background 0.3s, color 0.3s;
  z-index: 2;
}
.kd-close:hover { background: rgba(201,168,76,0.12); color: #c9a84c; }

/* ══ INNER ══ */
.kd-popup-inner { padding: 44px 40px 36px; }

/* ══ TAG ══ */
.kd-popup-tag {
  font-family: 'Cinzel', serif;
  font-size: 0.72rem;
  letter-spacing: 0.28em;
  color: #c9a84c;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 18px;
  justify-content: center;
}
.kd-popup-tag::before, .kd-popup-tag::after {
  content: '';
  flex: 1;
  height: 1px;
  background: rgba(201,168,76,0.25);
}

/* ══ HEADING ══ */
.kd-popup-box h3 {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 2rem;
  font-weight: 300;
  color: #f4f0e8;
  line-height: 1.15;
  margin: 0 0 8px;
  text-align: center;
}
.kd-popup-box h3 em { font-style: italic; color: #c9a84c; }

.kd-popup-sub {
  font-family: 'DM Sans', sans-serif;
  font-size: 0.85rem;
  font-weight: 300;
  color: #a9a39a;
  text-align: center;
  line-height: 1.7;
  margin: 0 0 28px;
}

/* ══ FIELDS ══ */
.kd-field { margin-bottom: 14px; }
.kd-field label {
  display: block;
  font-family: 'DM Sans', sans-serif;
  font-size: 0.75rem;
  font-weight: 400;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #a9a39a;
  margin-bottom: 7px;
}
.kd-field input {
  width: 100%;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(201,168,76,0.18);
  border-radius: 2px;
  color: #f4f0e8;
  font-family: 'DM Sans', sans-serif;
  font-size: 0.9rem;
  font-weight: 300;
  padding: 11px 14px;
  outline: none;
  transition: border-color 0.3s, background 0.3s;
  box-sizing: border-box;
}
.kd-field input::placeholder { color: rgba(169,163,154,0.45); }
.kd-field input:focus {
  border-color: rgba(201,168,76,0.5);
  background: rgba(255,255,255,0.07);
}

/* ══ SUBMIT BTN ══ */
.kd-submit-btn {
  width: 100%;
  background: #c9a84c;
  color: #0c0a07;
  font-family: 'DM Sans', sans-serif;
  font-size: 0.8rem;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  border: none;
  border-radius: 2px;
  padding: 14px 20px;
  cursor: pointer;
  margin-top: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  transition: background 0.3s, transform 0.2s;
}
.kd-submit-btn:hover { background: #e8d08a; transform: translateY(-1px); }
.kd-submit-btn:disabled { opacity: 0.6; cursor: not-allowed; transform: none; }

/* ══ SPINNER ══ */
.kd-spinner {
  width: 16px; height: 16px;
  border: 2px solid rgba(12,10,7,0.3);
  border-top-color: #0c0a07;
  border-radius: 50%;
  animation: kdSpin 0.7s linear infinite;
  display: none;
}
@keyframes kdSpin { to { transform: rotate(360deg); } }

/* ══ ERROR ══ */
.kd-error-msg {
  font-family: 'DM Sans', sans-serif;
  font-size: 0.78rem;
  color: #f09595;
  text-align: center;
  margin-top: 10px;
  display: none;
}

/* ══ STEP 2 ══ */
.kd-success-icon {
  width: 60px; height: 60px;
  background: rgba(201,168,76,0.1);
  border: 1px solid rgba(201,168,76,0.3);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 20px;
}
.kd-welcome-name {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 1.6rem;
  font-weight: 300;
  color: #f4f0e8;
  text-align: center;
  margin: 0 0 6px;
}
.kd-welcome-name em { color: #c9a84c; font-style: italic; }
.kd-success-sub {
  font-family: 'DM Sans', sans-serif;
  font-size: 0.85rem;
  font-weight: 300;
  color: #a9a39a;
  text-align: center;
  line-height: 1.7;
  margin: 0 0 24px;
}
.kd-download-card {
  background: rgba(201,168,76,0.06);
  border: 1px solid rgba(201,168,76,0.2);
  border-radius: 2px;
  padding: 16px 18px;
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 18px;
}
.kd-audio-icon {
  width: 44px; height: 44px;
  background: rgba(201,168,76,0.12);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.kd-audio-info { flex: 1; }
.kd-audio-title {
  font-family: 'DM Sans', sans-serif;
  font-size: 0.85rem;
  font-weight: 500;
  color: #f4f0e8;
  margin: 0 0 3px;
}
.kd-audio-meta {
  font-family: 'DM Sans', sans-serif;
  font-size: 0.75rem;
  font-weight: 300;
  color: #a9a39a;
  margin: 0;
}
.kd-download-btn {
  display: flex;
  align-items: center;
  gap: 10px;
  background: #c9a84c;
  color: #0c0a07 !important;
  font-family: 'DM Sans', sans-serif;
  font-size: 0.8rem;
  font-weight: 500;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  padding: 13px 20px;
  border-radius: 2px;
  text-decoration: none !important;
  justify-content: center;
  width: 100%;
  box-sizing: border-box;
  transition: background 0.3s, transform 0.2s;
}
.kd-download-btn:hover { background: #e8d08a; transform: translateY(-1px); }

.kd-privacy-note {
  font-family: 'DM Sans', sans-serif;
  font-size: 0.72rem;
  font-weight: 300;
  color: rgba(169,163,154,0.6);
  text-align: center;
  line-height: 1.5;
  margin: 10px 0 0;
}

@media (max-width: 520px) {
  .kd-popup-inner { padding: 36px 22px 28px; }
  .kd-popup-box h3 { font-size: 1.55rem; }
}
