.mk-section {
  margin: 2rem auto;
  max-width: 800px;
  padding: 0 1rem;
}

.mk-subtitle {
  opacity: 0.8;
  margin-bottom: 1rem;
}

.mk-audio-grid,
.mk-audio-list {
  display: grid;
  gap: 1.5rem;
}

.mk-audio p {
  margin-bottom: 0.3rem;
  font-weight: 500;
}

.mk-audio audio {
  width: 100%;
}


/* MK Boutique Core Styles */
.mk-dark {
  background: #0a0a0f;
  color: #f3f3ff;
  font-family: 'Inter', sans-serif;
}

.mk-header {
  text-align: center;
  margin: 3rem 0 2rem;
}

.mk-title {
  font-size: 2.4rem;
  letter-spacing: 1px;
}

.mk-subtitle {
  font-size: 1.1rem;
  color: #aaaad6;
  margin-top: 0.6rem;
}

.mk-container {
  width: 90%;
  max-width: 900px;
  margin: 0 auto 4rem;
  display: grid;
  gap: 2rem;
}

.mk-card {
  background: rgba(255, 255, 255, 0.04);
  padding: 1.7rem 2rem;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  transition: 0.25s ease;
}

.mk-card:hover {
  background: rgba(255, 255, 255, 0.06);
  transform: translateY(-3px);
}

.mk-card-title {
  font-size: 1.4rem;
  margin-bottom: 0.7rem;
}

.mk-card-text {
  font-size: 0.98rem;
  color: #c4c4e3;
  margin-bottom: 1.2rem;
}

.mk-btn {
  display: inline-block;
  padding: 0.6rem 1rem;
  border-radius: 10px;
  background: #b53aff;
  color: #fff;
  text-decoration: none;
  font-weight: 600;
  transition: 0.2s ease;
}

.mk-btn:hover {
  background: #d274ff;
}

.mk-btn-disabled {
  display: inline-block;
  padding: 0.6rem 1rem;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.15);
  color: #bbb;
  border: none;
  cursor: not-allowed;
  font-weight: 500;
}

.mk-highlight {
  border-color: #b53aff;
  box-shadow: 0 0 20px rgba(181, 58, 255, 0.2);
}


/* HERO SECTION – AUDIO STORIES */
.hero-audiostories {
  background: radial-gradient(circle at top left, #303a70 0%, #050611 55%, #050609 100%);
  padding: 3rem 1.5rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.hero-inner {
  max-width: 960px;
  margin: 0 auto;
  text-align: left;
}

.hero-kicker {
  text-transform: uppercase;
  letter-spacing: 0.15em;
  font-size: 0.8rem;
  color: #b3bee9;
  margin-bottom: 0.4rem;
}

.hero-title {
  font-size: 2.4rem;
  margin: 0 0 0.6rem;
  color: #f6f7ff;
}

.hero-subtitle {
  max-width: 40rem;
  font-size: 1rem;
  color: #c0c6e8;
}

/* PAGE MAIN WRAPPER (if not already set) */
.page-main {
  max-width: 960px;
  margin: 2.5rem auto 3.5rem;
  padding: 0 1.5rem;
}

/* EPISODES LIST */
.episodes-list {
  display: grid;
  gap: 1.5rem;
  margin-top: 1.5rem;
}

.episode-card {
  background: rgba(255, 255, 255, 0.03);
  border-radius: 12px;
  padding: 1.2rem 1.4rem;
  border: 1px solid rgba(255, 255, 255, 0.06);
}

.episode-title {
  margin: 0 0 0.4rem;
  font-size: 1.1rem;
}

.episode-meta {
  margin: 0 0 0.6rem;
  font-size: 0.85rem;
  color: #aab1d4;
}

.episode-desc {
  margin: 0 0 0.9rem;
  font-size: 0.95rem;
  color: #c4caea;
}

.episode-player {
  width: 100%;
}


/* ===== OSC AUDIO STORIES – PAGE WRAPPER ===== */

.osc-audio-body {
  background: #05060a;
  color: #f5f6ff;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

/* HEADER */

.osc-header {
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  background: linear-gradient(to right, #05060a, #0b0d18);
}

.osc-header-inner {
  max-width: 1080px;
  margin: 0 auto;
  padding: 1rem 1.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
}

.osc-logo-lockup {
  display: flex;
  flex-direction: column;
}

.osc-logo-text {
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 0.9rem;
}

.osc-logo-tagline {
  font-size: 0.8rem;
  color: #a5acd4;
}

.osc-nav ul {
  list-style: none;
  display: flex;
  gap: 1rem;
  padding: 0;
  margin: 0;
}

.osc-nav a {
  text-decoration: none;
  font-size: 0.9rem;
  color: #d8dcff;
  padding-bottom: 0.15rem;
  border-bottom: 1px solid transparent;
  transition: color 0.18s ease, border-color 0.18s ease;
}

.osc-nav a:hover {
  color: #ffffff;
  border-color: #5fd0ff;
}

/* HERO */

.osc-hero-audio {
  background: radial-gradient(circle at top left, #283465 0%, #05060a 55%, #02030a 100%);
  padding: 2.8rem 1.5rem 2.6rem;
}

.osc-hero-inner {
  max-width: 960px;
  margin: 0 auto;
}

.osc-hero-kicker {
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-size: 0.78rem;
  color: #b3bee9;
  margin-bottom: 0.4rem;
}

.osc-hero-title {
  font-size: 2.2rem;
  margin: 0 0 0.6rem;
}

.osc-hero-subtitle {
  max-width: 40rem;
  font-size: 0.98rem;
  color: #c4caee;
  line-height: 1.6;
}

/* MAIN LAYOUT */

.osc-main {
  max-width: 960px;
  margin: 2.3rem auto 3.2rem;
  padding: 0 1.5rem;
}

.osc-card {
  background: rgba(255, 255, 255, 0.02);
  border-radius: 14px;
  padding: 1.6rem 1.7rem;
  border: 1px solid rgba(255, 255, 255, 0.06);
  margin-bottom: 1.6rem;
  box-shadow: 0 14px 40px rgba(0, 0, 0, 0.45);
}

.osc-card-soft {
  background: rgba(255, 255, 255, 0.015);
}

.osc-card h2 {
  font-size: 1.25rem;
  margin-top: 0;
  margin-bottom: 0.5rem;
}

.osc-card p {
  font-size: 0.96rem;
  line-height: 1.7;
  color: #d2d4f3;
}

.osc-card a {
  color: #7fd4ff;
  text-decoration: none;
  border-bottom: 1px solid rgba(127, 212, 255, 0.4);
}

.osc-card a:hover {
  border-color: rgba(127, 212, 255, 0.9);
}

/* CARD HEADING */

.osc-card-heading {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  margin-bottom: 0.8rem;
}

.osc-card-tagline {
  font-size: 0.86rem;
  color: #a9b0de;
}

/* EPISODES LIST */

.osc-episodes {
  display: grid;
  gap: 1.1rem;
  margin-top: 0.4rem;
}

.osc-episode {
  border-radius: 12px;
  padding: 1.1rem 1.2rem 1.15rem;
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.05);
}

.osc-episode-title {
  margin: 0 0 0.25rem;
  font-size: 1.05rem;
}

.osc-episode-meta {
  margin: 0 0 0.5rem;
  font-size: 0.82rem;
  color: #a6aed9;
}

.osc-episode-desc {
  margin: 0 0 0.7rem;
  font-size: 0.92rem;
  color: #ced1f3;
}

/* PLAYER SHELL (MINIMALIST LOOK) */

.osc-player-shell {
  background: rgba(5, 8, 20, 0.9);
  border-radius: 10px;
  padding: 0.55rem 0.7rem;
  border: 1px solid rgba(118, 186, 255, 0.35);
}

.osc-audio-player {
  width: 100%;
}

/* MINI-SERIES HINT TEXT */

.osc-mini-hint {
  margin-top: 0.7rem;
  font-size: 0.9rem;
  color: #bfc4f0;
}

/* FOOTER */

.osc-footer {
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  padding: 1rem 1.5rem 1.4rem;
  text-align: center;
  font-size: 0.85rem;
  color: #9fa5cc;
  background: #05060a;
}

/* RESPONSIVE */

@media (max-width: 700px) {
  .osc-header-inner {
    flex-direction: column;
    align-items: flex-start;
  }

  .osc-nav ul {
    flex-wrap: wrap;
    justify-content: flex-start;
  }

  .osc-hero-title {
    font-size: 1.9rem;
  }

  .osc-main {
    margin-top: 1.8rem;
  }

  .osc-card {
    padding: 1.3rem 1.2rem;
  }
}


/* ============================
   MIRANDA KADE – WHISPER VAULT
   Silhouette Noir Theme
   ============================ */

.vault-page {
  background: radial-gradient(circle at top, #1b1428 0, #050509 55%, #020207 100%);
  color: #f5f1ff;
  min-height: 100vh;
  margin: 0;
}

/* HEADER / NAV */
.vault-header {
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  backdrop-filter: blur(12px);
  background: linear-gradient(to bottom, rgba(5, 5, 9, 0.9), rgba(5, 5, 9, 0.7));
}

.vault-header-inner {
  max-width: 1040px;
  margin: 0 auto;
  padding: 0.75rem 1rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.vault-logo {
  font-family: "Georgia", "Times New Roman", serif;
  font-size: 1.25rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #f5f1ff;
  text-decoration: none;
}

.vault-logo:hover {
  color: #e8d7b9;
}

.vault-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.vault-nav a {
  text-decoration: none;
  padding: 0.35rem 0.75rem;
  border-radius: 999px;
  font-size: 0.85rem;
  background: transparent;
  border: 1px solid transparent;
  color: #d8d0ff;
}

.vault-nav a[aria-current="page"],
.vault-nav a:hover {
  border-color: rgba(126, 92, 226, 0.9);
  background: radial-gradient(circle at top, rgba(126, 92, 226, 0.2), rgba(20, 18, 40, 0.85));
  color: #fef9e8;
}

/* MAIN LAYOUT */
.vault-main {
  max-width: 1040px;
  margin: 0 auto;
  padding: 2rem 1rem 3rem;
}

/* HERO */
.vault-hero {
  text-align: center;
  padding: 2.5rem 1.5rem 2rem;
  margin-bottom: 2rem;
  border-radius: 18px;
  background: radial-gradient(circle at top, rgba(126, 92, 226, 0.25), rgba(10, 8, 26, 0.97));
  box-shadow: 0 18px 60px rgba(0, 0, 0, 0.7);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.vault-hero h1 {
  font-family: "Georgia", "Times New Roman", serif;
  font-size: 2.1rem;
  margin: 1rem 0 0.75rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.vault-tagline {
  max-width: 640px;
  margin: 0 auto 0.5rem;
  font-size: 0.98rem;
  color: #f4ecff;
}

.vault-subnote {
  max-width: 540px;
  margin: 0 auto;
  font-size: 0.9rem;
  color: #d4caef;
}

/* LOCK ICON */
.vault-lock {
  width: 64px;
  height: 64px;
  margin: 0 auto;
  position: relative;
}

.vault-lock-bar,
.vault-lock-body {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
}

.vault-lock-bar {
  width: 38px;
  height: 26px;
  border-radius: 999px;
  border: 2px solid #e8d7b9;
  border-bottom-color: transparent;
  top: 4px;
}

.vault-lock-body {
  width: 40px;
  height: 32px;
  top: 20px;
  border-radius: 8px;
  background: linear-gradient(135deg, #1d182b, #4e3968);
  border: 2px solid #e8d7b9;
  box-shadow: 0 0 14px rgba(232, 215, 185, 0.4);
}

/* ACCESS SECTION */
.vault-access,
.vault-content,
.vault-membership,
.vault-latest {
  border-radius: 18px;
  background: radial-gradient(circle at top left, rgba(126, 92, 226, 0.15), rgba(9, 8, 19, 0.97));
  box-shadow: 0 16px 50px rgba(0, 0, 0, 0.65);
  border: 1px solid rgba(255, 255, 255, 0.06);
  padding: 1.75rem 1.5rem 2rem;
  margin-bottom: 2rem;
}

.vault-access h2,
.vault-content h2,
.vault-membership h2,
.vault-latest h2 {
  font-family: "Georgia", "Times New Roman", serif;
  font-size: 1.4rem;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  margin-bottom: 0.75rem;
}

.vault-access p,
.vault-content p,
.vault-membership p,
.vault-latest p {
  font-size: 0.95rem;
  line-height: 1.6;
  color: #efe8ff;
}

/* FORM */
.vault-form {
  margin-top: 1rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  align-items: flex-end;
}

.vault-label {
  width: 100%;
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: #d4caef;
}

.vault-input {
  flex: 1 1 180px;
  min-width: 0;
  padding: 0.6rem 0.75rem;
  border-radius: 999px;
  border: 1px solid rgba(232, 215, 185, 0.5);
  background: rgba(5, 5, 11, 0.9);
  color: #f5f1ff;
  font-size: 0.95rem;
}

.vault-input:focus {
  outline: none;
  border-color: rgba(126, 92, 226, 0.9);
  box-shadow: 0 0 0 1px rgba(126, 92, 226, 0.9);
}

.vault-btn-primary {
  flex: 0 0 auto;
  padding: 0.6rem 1.4rem;
  border-radius: 999px;
  border: none;
  background: linear-gradient(135deg, #7e5ce2, #e8d7b9);
  color: #050509;
  font-weight: 600;
  font-size: 0.92rem;
  cursor: pointer;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.7);
}

.vault-btn-primary:hover {
  filter: brightness(1.05);
}

.vault-error {
  width: 100%;
  margin-top: 0.35rem;
  font-size: 0.88rem;
  color: #ff9b9b;
}

.vault-access-note {
  margin-top: 0.75rem;
  font-size: 0.86rem;
  color: #cbbfe9;
}

/* GRID & CARDS */
.vault-intro-text {
  margin-top: 0.5rem;
  margin-bottom: 1.25rem;
}

.vault-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 1.4rem;
  margin-top: 0.5rem;
}

.vault-card {
  padding: 1rem 1rem 1.2rem;
  border-radius: 14px;
  background: radial-gradient(circle at top, rgba(126, 92, 226, 0.2), rgba(9, 7, 18, 0.95));
  border: 1px solid rgba(232, 215, 185, 0.2);
}

.vault-card h3 {
  font-family: "Georgia", "Times New Roman", serif;
  font-size: 1.05rem;
  margin-bottom: 0.45rem;
}

.vault-list {
  list-style: none;
  padding-left: 0;
  margin: 0.5rem 0 0;
  font-size: 0.88rem;
  color: #e9e1ff;
}

.vault-list li::before {
  content: "• ";
  color: #e8d7b9;
}

/* LATEST EPISODES */
.vault-latest-note {
  margin-bottom: 1rem;
  font-size: 0.9rem;
  color: #d9d0ff;
}

.vault-episode {
  margin-bottom: 1.25rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.vault-episode h3 {
  font-size: 1rem;
  margin-bottom: 0.2rem;
}

.vault-episode p {
  margin-bottom: 0.4rem;
  font-size: 0.9rem;
}

.vault-episode audio {
  width: 100%;
  max-width: 420px;
}

/* MEMBERSHIP BOX */
.vault-membership-box {
  margin-top: 0.75rem;
  padding: 1rem 1.1rem 1.2rem;
  border-radius: 14px;
  background: radial-gradient(circle at top left, rgba(232, 215, 185, 0.08), rgba(7, 6, 15, 0.95));
  border: 1px solid rgba(232, 215, 185, 0.4);
}

.vault-price {
  font-size: 0.98rem;
  margin-bottom: 0.35rem;
}

.vault-price span {
  font-weight: 700;
  color: #e8d7b9;
}

.vault-membership-note {
  margin-top: 0.7rem;
  font-size: 0.88rem;
  color: #d9d0ff;
}

.vault-cta-note {
  margin-top: 0.8rem;
  font-size: 0.88rem;
  color: #c6bce2;
}

/* RESPONSIVE */
@media (max-width: 680px) {
  .vault-header-inner {
    flex-direction: column;
    align-items: flex-start;
  }

  .vault-nav {
    justify-content: flex-start;
  }

  .vault-hero {
    padding: 2rem 1.2rem 1.75rem;
  }

  .vault-form {
    flex-direction: column;
    align-items: stretch;
  }

  .vault-btn-primary {
    width: 100%;
    text-align: center;
  }
}
