/*
  Santosh Kumar "Bechain"
  Fonts: Devanagari + Urdu (Nukhte support)
*/

:root{
  --bg: #f6efe4;              /* soft beige */
  --surface: rgba(255,255,255,.62);
  --surface-2: rgba(255,255,255,.72);
  --brown: #4a2c1a;           /* royal brown */
  --brown-2: #6a3a1f;
  --gold: #caa24a;
  --gold-2: #b88c2a;
  --purpleText: #2d1b4e;      /* dark purple */
  --muted: rgba(45,27,78,.78);
  --shadow: 0 18px 50px rgba(45,27,78,.10);
  --radius: 18px;
  --radius-sm: 14px;
}

/* Soft textured background (no heavy images) */
body{
  font-family: "Noto Serif Devanagari", ui-serif, Georgia, "Times New Roman", serif;
  background:
    radial-gradient(800px 400px at 15% 10%, rgba(202,162,74,.18), transparent 60%),
    radial-gradient(900px 520px at 90% 20%, rgba(74,44,26,.10), transparent 60%),
    linear-gradient(180deg, rgba(246,239,228,1), rgba(246,239,228,.92)),
    repeating-linear-gradient(
      135deg,
      rgba(74,44,26,.025) 0px,
      rgba(74,44,26,.025) 2px,
      rgba(202,162,74,.018) 2px,
      rgba(202,162,74,.018) 8px
    );
  color: var(--purpleText);
  line-height: 1.75;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}

/* Urdu/Nastaliq sections */
.urdu{
  font-family: "Noto Nastaliq Urdu", "Amiri", serif;
  direction: rtl;
  unicode-bidi: plaintext;
  letter-spacing: 0;
  line-height: 2.15;
}

.hi{
  font-family: "Noto Serif Devanagari", ui-serif, Georgia, serif;
}

a{
  color: var(--brown);
  text-decoration: none;
}
a:hover{ color: var(--brown-2); }

.text-muted-ink{ color: var(--muted) !important; }

/* Navbar */
.navbar{
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  background: rgba(246,239,228,.78) !important;
  border-bottom: 1px solid rgba(202,162,74,.25);
}
.navbar .navbar-brand{
  font-weight: 700;
  letter-spacing: .3px;
  color: var(--brown) !important;
}
.nav-link{
  color: rgba(45,27,78,.85) !important;
  font-weight: 600;
}
.nav-link:hover, .nav-link.active{
  color: var(--brown) !important;
}

/* Buttons */
.btn-gold{
  background: linear-gradient(180deg, var(--gold), var(--gold-2));
  border: 1px solid rgba(74,44,26,.18);
  color: #2b1a10;
  font-weight: 800;
  box-shadow: 0 12px 28px rgba(202,162,74,.22);
}
.btn-gold:hover{
  transform: translateY(-1px);
  filter: brightness(1.02);
}
.btn-outline-gold{
  border: 1px solid rgba(202,162,74,.8);
  color: var(--brown);
  font-weight: 800;
}
.btn-outline-gold:hover{
  background: rgba(202,162,74,.12);
}

/* Hero */
.hero{
  position: relative;
  padding: 5.5rem 0 3rem;
}
.hero-card{
  background: linear-gradient(180deg, var(--surface), rgba(255,255,255,.45));
  border: 1px solid rgba(202,162,74,.25);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  overflow: hidden;
}
.hero-border{
  height: 7px;
  background: linear-gradient(90deg, var(--brown), var(--gold), var(--brown));
}
.kicker{
  display: inline-flex;
  gap: .5rem;
  align-items: center;
  padding: .35rem .7rem;
  border-radius: 999px;
  background: rgba(202,162,74,.12);
  border: 1px solid rgba(202,162,74,.22);
  color: var(--brown);
  font-weight: 800;
  font-size: .95rem;
}
.display-name{
  font-weight: 900;
  letter-spacing: .2px;
  color: var(--brown);
}
.subtitle{
  font-weight: 700;
  color: rgba(45,27,78,.86);
}
.quote{
  padding: 1rem 1.1rem;
  border-left: 4px solid rgba(202,162,74,.75);
  background: rgba(255,255,255,.52);
  border-radius: 10px;
}

/* Hero carousel */
.hero-carousel{
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid rgba(202,162,74,.35);
  box-shadow: 0 14px 40px rgba(45,27,78,.10);
}
.hero-carousel .carousel-inner,
.hero-carousel .carousel-item{
  height: 260px;
}
.hero-carousel img{
  height: 260px;
  object-fit: cover;
}
.hero-carousel .carousel-item{
  position: relative;
}
.hero-carousel .carousel-item:before{
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(45,27,78,.05), rgba(45,27,78,.28));
  pointer-events: none;
}
.hero-carousel .carousel-caption{
  left: 14px;
  right: 14px;
  bottom: 12px;
  text-align: left;
}

.hero-carousel-pill{
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .35rem .65rem;
  border-radius: 999px;
  background: rgba(246,239,228,.88);
  border: 1px solid rgba(202,162,74,.45);
  color: var(--brown);
  font-weight: 900;
  letter-spacing: .2px;
  box-shadow: 0 10px 24px rgba(45,27,78,.10);
}
.hero-carousel .carousel-indicators{
  margin-bottom: .6rem;
}
.hero-carousel .carousel-indicators [data-bs-target]{
  background-color: rgba(202,162,74,.70);
}
.hero-carousel .carousel-control-prev-icon,
.hero-carousel .carousel-control-next-icon{
  filter: drop-shadow(0 10px 18px rgba(45,27,78,.35));
}
/* +++++++++++++++++++++++++++++++++++++++++++++ */
/* Section */
.section{
  padding: 3rem 0;
}
.section-title{
  color: var(--brown);
  font-weight: 900;
  letter-spacing: .2px;
}
.section-sub{
  color: var(--muted);
}

/* Cards */
.card-premium{
  background: linear-gradient(180deg, var(--surface-2), rgba(255,255,255,.56));
  border: 1px solid rgba(202,162,74,.30);
  border-radius: var(--radius-sm);
  box-shadow: 0 14px 40px rgba(45,27,78,.08);
}
.card-premium .card-title{
  color: var(--brown);
  font-weight: 900;
}
.gold-border{
  border: 1px solid rgba(202,162,74,.55) !important;
}
.hover-lift{
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.hover-lift:hover{
  transform: translateY(-3px);
  box-shadow: 0 18px 55px rgba(45,27,78,.14);
  border-color: rgba(202,162,74,.70);
}

/* Timeline */
.timeline{
  position: relative;
  padding-left: 1.25rem;
}
.timeline:before{
  content: "";
  position: absolute;
  left: 10px;
  top: 6px;
  bottom: 6px;
  width: 2px;
  background: linear-gradient(180deg, rgba(202,162,74,.85), rgba(74,44,26,.35));
}
.timeline-item{
  position: relative;
  padding: 1rem 1rem 1rem 1.25rem;
  margin: 0 0 1rem;
  border-radius: var(--radius-sm);
  background: rgba(255,255,255,.48);
  border: 1px solid rgba(202,162,74,.22);
}
.timeline-item:before{
  content: "";
  position: absolute;
  left: -3px;
  top: 1.15rem;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--gold);
  border: 2px solid rgba(74,44,26,.55);
  box-shadow: 0 0 0 6px rgba(202,162,74,.12);
}
.timeline-year{
  font-weight: 900;
  color: var(--brown);
}

/* Gallery */
.img-tile{
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(202,162,74,.28);
  background: linear-gradient(135deg, rgba(74,44,26,.20), rgba(202,162,74,.10));
  min-height: 180px;
}
.img-tile .label{
  position: absolute;
  left: 14px;
  bottom: 12px;
  right: 14px;
  padding: .5rem .65rem;
  border-radius: 12px;
  background: rgba(246,239,228,.82);
  border: 1px solid rgba(202,162,74,.28);
  font-weight: 800;
  color: var(--brown);
}

/* =========================
   Premium Footer
========================= */

.site-footer {
  position: relative;
  overflow: hidden;
  padding: 4rem 0 1.2rem;
  margin-top: 3rem;

  background:
    radial-gradient(circle at top left,
      rgba(202,162,74,.18),
      transparent 30%),

    radial-gradient(circle at bottom right,
      rgba(74,44,26,.12),
      transparent 35%),

    linear-gradient(
      180deg,
      rgba(255,255,255,.55),
      rgba(246,239,228,.96)
    );

  border-top: 1px solid rgba(202,162,74,.28);
}

.site-footer::before {
  content: "";
  position: absolute;
  inset: 0;

  background:
    repeating-linear-gradient(
      135deg,
      rgba(74,44,26,.02) 0px,
      rgba(74,44,26,.02) 2px,
      rgba(202,162,74,.015) 2px,
      rgba(202,162,74,.015) 8px
    );

  pointer-events: none;
}

.footer-main,
.footer-bottom {
  position: relative;
  z-index: 1;
}

/* Layout */
.footer-main {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr;
  gap: 3rem;
  padding-bottom: 2rem;
}

/* Brand */
.footer-logo {
  width: 4rem;
  height: 4rem;

  border-radius: 20px;

  display: flex;
  align-items: center;
  justify-content: center;

  margin-bottom: 1rem;

  background:
    linear-gradient(
      180deg,
      var(--gold),
      var(--gold-2)
    );

  color: #2b1a10;
  font-size: 1.5rem;

  box-shadow:
    0 16px 35px rgba(202,162,74,.25);
}

.footer-brand h3 {
  color: var(--brown);
  font-weight: 900;
  margin-bottom: .8rem;
}

.footer-brand p {
  color: var(--muted);
  font-weight: 600;
  max-width: 420px;
  margin-bottom: 1.3rem;
}

/* Social Icons */
.footer-socials {
  display: flex;
  gap: .8rem;
}

.footer-socials a {
  width: 2.7rem;
  height: 2.7rem;

  border-radius: 50%;

  display: flex;
  align-items: center;
  justify-content: center;

  background: rgba(255,255,255,.65);

  border: 1px solid rgba(202,162,74,.35);

  color: var(--brown);

  transition:
    transform .2s ease,
    background .2s ease,
    color .2s ease;
}

.footer-socials a:hover {
  transform: translateY(-3px);

  background:
    linear-gradient(
      180deg,
      var(--gold),
      var(--gold-2)
    );

  color: #2b1a10;
}

/* Links */
.footer-links h4 {
  color: var(--brown);
  font-weight: 900;
  margin-bottom: 1rem;
}

.footer-links {
  display: flex;
  flex-direction: column;
}

.footer-links a {
  width: fit-content;

  margin-bottom: .7rem;

  color: var(--muted);

  font-weight: 700;

  position: relative;

  transition:
    color .2s ease,
    transform .2s ease;
}

.footer-links a::after {
  content: "";

  position: absolute;
  left: 0;
  bottom: -2px;

  width: 0%;
  height: 2px;

  background: var(--gold);

  transition: width .2s ease;
}

.footer-links a:hover {
  color: var(--brown);
  transform: translateX(4px);
}

.footer-links a:hover::after {
  width: 100%;
}

/* Bottom */
.footer-bottom {
  padding-top: 1rem;

  border-top:
    1px solid rgba(202,162,74,.30);

  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;

  color: var(--muted);

  font-weight: 700;
}

.footer-bottom p {
  margin: 0;
}

.footer-highlight {
  color: var(--brown);
  font-weight: 900;
}

/* Responsive */
@media (max-width: 991.98px) {

  .footer-main {
    grid-template-columns: 1fr 1fr;
  }

  .footer-brand {
    grid-column: 1 / -1;
  }
}

@media (max-width: 575.98px) {

  .site-footer {
    padding: 3rem 0 1rem;
  }

  .footer-main {
    grid-template-columns: 1fr;
    gap: 2rem;
  }

  .footer-bottom {
    flex-direction: column;
    text-align: center;
  }

  .footer-socials {
    justify-content: center;
  }
}

/* Back to top */
.back-to-top{
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 1050;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(202,162,74,.98), rgba(184,140,42,.98));
  border: 1px solid rgba(74,44,26,.20);
  color: #2b1a10;
  box-shadow: 0 12px 28px rgba(45,27,78,.18);
  opacity: 0;
  transform: translateY(10px);
  pointer-events: none;
  transition: opacity .2s ease, transform .2s ease;
}
.back-to-top.show{
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

/* Scroll animation */
.reveal{
  opacity: 0;
  transform: translateY(14px);
  transition: opacity .6s ease, transform .6s ease;
}
.reveal.in-view{
  opacity: 1;
  transform: translateY(0);
}

/* Forms */
.form-control, .form-select{
  border-radius: 14px;
  border: 1px solid rgba(202,162,74,.25);
  background: rgba(255,255,255,.7);
}
.form-control:focus, .form-select:focus{
  border-color: rgba(202,162,74,.75);
  box-shadow: 0 0 0 .25rem rgba(202,162,74,.18);
}

/* Utilities */
.divider{
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(202,162,74,.55), transparent);
}

@media (min-width: 992px){
  .hero{ padding: 6.5rem 0 3.5rem; }
  .hero-carousel .carousel-inner,
  .hero-carousel .carousel-item,
  .hero-carousel img{
    height: 320px;
  }
}


/* crousall — homepage top carousel */
#topCarousel {
  margin-top: 0;
}

/* Inner wrapper only — do NOT set display on .carousel-item (breaks Bootstrap show/hide + fade). */
#topCarousel #mainCarousel .top-carousel-slide {
  display: flex;
  flex-direction: column;
  width: 100%;
}

/* Do not override .carousel-item display/transform — required for carousel-fade + cycling */

#topCarousel #mainCarousel .carousel-caption {
  position: static;
  left: auto !important;
  right: auto !important;
  top: auto;
  bottom: auto;
  transform: none !important;
  width: 100%;
  max-width: 100%;
  margin: 0;
  padding: 0.35rem 0.65rem 0.55rem;
  text-align: center;
  color: var(--brown, #4a2c1a);
  display: flex;
  justify-content: center;
  align-items: flex-start;
}

#topCarousel #mainCarousel .hero-carousel-pill {
  display: inline-block;
  max-width: min(100%, 52rem);
  box-sizing: border-box;
  margin: 0 auto;
  text-align: center;
  font-size: 0.7rem;
  line-height: 1.35;
  font-weight: 600;
  letter-spacing: 0.01em;
  padding: 0.3rem 0.45rem;
  border-radius: 8px;
  white-space: normal;
  word-break: break-word;
  hyphens: auto;
}

@media (min-width: 400px) {
  #topCarousel #mainCarousel .hero-carousel-pill {
    font-size: 0.74rem;
  }
}

@media (min-width: 576px) {
  #topCarousel #mainCarousel .hero-carousel-pill {
    font-size: 0.8rem;
    padding: 0.32rem 0.5rem;
  }
}

@media (min-width: 768px) {
  #topCarousel #mainCarousel .carousel-caption {
    padding: 0.45rem 0.85rem 0.65rem;
  }
  #topCarousel #mainCarousel .hero-carousel-pill {
    font-size: 0.88rem;
    font-weight: 700;
    padding: 0.35rem 0.6rem;
    border-radius: 999px;
  }
}

@media (min-width: 992px) {
  #topCarousel #mainCarousel .hero-carousel-pill {
    font-size: 0.95rem;
    font-weight: 800;
  }
}

/* Dots sit on the image (caption is below the slide) */
#topCarousel #mainCarousel .carousel-indicators {
  bottom: auto;
  top: 0.75rem;
  margin-bottom: 0;
  z-index: 6;
}

#topCarousel #mainCarousel .carousel-control-prev,
#topCarousel #mainCarousel .carousel-control-next {
  z-index: 5;
}

@media (min-width: 769px) {
  #topCarousel #mainCarousel .carousel-control-prev,
  #topCarousel #mainCarousel .carousel-control-next {
    top: clamp(10rem, 42vh, 50rem);
    bottom: auto;
    transform: translateY(-50%);
  }
}

.carousel-img {
  width: 100%;
  height: 85vh;
  object-fit: cover;
  flex-shrink: 0;
}
/* 2nd slide image (top carousel only) */
#topCarousel .carousel-item:nth-child(2) .carousel-img {
  object-position: 50% 18%;
}

/* 3rd slide image (top carousel only) */
#topCarousel .carousel-item:nth-child(3) .carousel-img {
  object-position: top;
}



@media (max-width: 768px) {
  #topCarousel .carousel-img {
    height: 38vh;
    max-height: 300px;
  }

  #topCarousel #mainCarousel .carousel-control-prev,
  #topCarousel #mainCarousel .carousel-control-next {
    top: clamp(5rem, 19vh, 11rem);
    bottom: auto;
    transform: translateY(-50%);
  }
}
  /* Ghazal Section */
#top-ghazal {
  background: linear-gradient(180deg, rgba(255,255,255,.45), rgba(255,255,255,.6));
  padding: 30px 0;
}

/* Remove box look */
.ghazal-card {
  max-width: 900px;
  margin: auto;
  padding: 0;
  background: none;
  border: none;
  box-shadow: none;
  text-align: center;
  position: relative;
}

/* Decorative poetic line above ghazal */
.ghazal-card::before {
  content: "";
  width: 90px;
  height: 1px;
  background: var(--gold);
  display: block;
  margin: 0 auto 5px;
  opacity: 0.6;
}

.ghazal-text {
  font-size: 1.1rem;
  line-height: 2;
  color: var(--purpleText);
  margin-bottom: 2rem;
  font-weight: 500;
}



/* Carousel arrows */
.carousel-control-prev-icon,
.carousel-control-next-icon {
  filter: invert(1);
}

   

       
 /* SECTION */



/* ----- Songs / YouTube strip (scoped — do not use .carousel or bare .card here) ----- */
.song-carousel-section {
    overflow-x: clip;
}

.song-carousel-container {
    max-width: 1280px;
    margin-left: auto;
    margin-right: auto;
}

.songs-section-title {
    text-align: center;
    letter-spacing: 0.04em;
    color: #555;
    margin-bottom: 1.25rem;
    font-size: clamp(1.1rem, 2.8vw, 1.5rem);
}

.song-carousel-ui {
    display: flex;
    align-items: stretch;
    gap: 0.35rem;
    width: 100%;
    max-width: 100%;
}

@media (min-width: 576px) {
    .song-carousel-ui {
        gap: 0.5rem;
    }
}

.song-carousel-viewport {
    flex: 1;
    min-width: 0;
    overflow: hidden;
    border-radius: 12px;
    container-type: inline-size;
    container-name: songvp;
}

.song-carousel-strip {
    display: flex;
    gap: 1rem;
    transition: transform 0.38s ease;
    will-change: transform;
}

.song-carousel-arrow {
    flex-shrink: 0;
    align-self: center;
    width: 2.5rem;
    height: 2.5rem;
    min-width: 2.5rem;
    border: 0;
    border-radius: 50%;
    background: #fff;
    color: var(--brown, #4a2c1a);
    font-size: 1rem;
    line-height: 1;
    cursor: pointer;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.12);
    z-index: 2;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.song-carousel-arrow:hover:not(:disabled) {
    transform: scale(1.06);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.16);
}

.song-carousel-arrow:disabled {
    opacity: 0.35;
    cursor: default;
}

.song-card {
    flex: 0 0 calc((100cqw - 3rem) / 4);
    min-width: 0;
    max-width: 100%;
    background: #fff;
    border-radius: 12px;
    overflow: hidden;
    cursor: pointer;
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.08);
    transition: transform 0.25s ease, box-shadow 0.25s ease;
    display: flex;
    flex-direction: column;
}

@container songvp (max-width: 1100px) {
    .song-card {
        flex: 0 0 calc((100cqw - 2rem) / 3);
    }
}

@container songvp (max-width: 768px) {
    .song-card {
        flex: 0 0 calc((100cqw - 1rem) / 2);
    }
}

@container songvp (max-width: 520px) {
    .song-card {
        flex: 0 0 100%;
    }
}

.song-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 10px 26px rgba(0, 0, 0, 0.12);
}

.song-card:focus-visible {
    outline: 3px solid rgba(202, 162, 74, 0.85);
    outline-offset: 2px;
}

.song-card-media {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 9;
    background: #111;
    overflow: hidden;
}

.song-card-media img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}





@media (max-width: 520px) {
    .song-carousel-arrow {
        width: 2.15rem;
        height: 2.15rem;
        min-width: 2.15rem;
        font-size: 0.9rem;
    }
}

@media (prefers-reduced-motion: reduce) {
    .song-carousel-strip {
        transition: none;
    }

    .song-card,
    .song-carousel-arrow {
        transition: none;
    }

    .song-card:hover {
        transform: none;
    }

    .song-carousel-arrow:hover:not(:disabled) {
        transform: none;
    }
}




 







/*  Contact Page */
.contact-rich-section {
  padding: clamp(2rem, 5vw, 4rem) 0;
}

.contact-rich-header {
  max-width: 900px;
  margin: 0 auto clamp(1.5rem, 4vw, 2.3rem);
}


.contact-rich-header h1 {
  color: var(--brown);
  font-weight: 900;
  font-size: clamp(1.9rem, 5vw, 3.6rem);
  line-height: 1.08;
  margin-bottom: .7rem;
  white-space: nowrap;
}

.contact-rich-header p {
  color: var(--muted);
  font-size: 1.05rem;
  margin: 0;
}

.contact-rich-grid {
  max-width: 1050px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: .9fr 1.1fr;
  gap: 1.25rem;
  align-items: start;
}

.contact-rich-profile,
.contact-rich-details {
  border-radius: 24px;
  background: linear-gradient(180deg, var(--surface-2), rgba(255,255,255,.55));
  border: 1px solid rgba(202,162,74,.30);
  box-shadow: var(--shadow);
}

.contact-rich-profile {
  padding: clamp(1.4rem, 4vw, 2rem);
}

.contact-rich-avatar {
  width: 4.5rem;
  height: 4.5rem;
  border-radius: 24px;
  display: grid;
  place-items: center;
  background: linear-gradient(180deg, var(--gold), var(--gold-2));
  color: #2b1a10;
  font-size: 1.7rem;
  box-shadow: 0 14px 34px rgba(202,162,74,.24);
  margin-bottom: 1.2rem;
}

.contact-rich-profile h2 {
  color: var(--brown);
  font-weight: 900;
  margin-bottom: .35rem;
}

.contact-rich-profile p {
  color: var(--muted);
  font-weight: 700;
  margin: 0;
}

.contact-rich-divider {
  height: 1px;
  background: linear-gradient(90deg, rgba(202,162,74,.55), transparent);
  margin: 1.4rem 0;
}

.contact-rich-profile ul {
  padding: 0;
  margin: 0;
  list-style: none;
}

.contact-rich-profile li {
  display: flex;
  align-items: center;
  gap: .75rem;
  padding: .65rem 0;
  color: var(--purpleText);
  font-weight: 700;
}

.contact-rich-profile li i {
  color: var(--gold-2);
  width: 1.2rem;
}

.contact-rich-details {
  padding: .7rem;
}

.contact-rich-row {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1.15rem;
  border-radius: 18px;
  color: var(--purpleText);
  transition: background .18s ease, transform .18s ease;
}

.contact-rich-row:hover {
  background: rgba(202,162,74,.12);
  transform: translateY(-2px);
  color: var(--purpleText);
}

.contact-rich-icon {
  width: 3.2rem;
  height: 3.2rem;
  flex: 0 0 3.2rem;
  border-radius: 18px;
  display: grid;
  place-items: center;
  background: rgba(202,162,74,.14);
  border: 1px solid rgba(202,162,74,.30);
  color: var(--brown);
}

.contact-rich-row small {
  display: block;
  color: var(--brown);
  font-size: .75rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .06em;
}

.contact-rich-row strong {
  display: block;
  color: var(--purpleText);
  font-size: 1.05rem;
  word-break: break-word;
}

@media (max-width: 991.98px) {
  .contact-rich-grid {
    grid-template-columns: 1fr;
  }

  .contact-rich-header h1 {
    white-space: normal;
  }
}

@media (max-width: 575.98px) {
  .contact-rich-profile,
  .contact-rich-details {
    border-radius: 18px;
  }

  .contact-rich-row {
    padding: 1rem;
  }
}

/* =========================================
   Updated YouTube Video Section
========================================= */

.song-card {
  display: block !important;
  border-radius: 14px;
  overflow: hidden;
  cursor: pointer;
  background: #fff;
  border: 1px solid rgba(202,162,74,.30);
  box-shadow: 0 8px 22px rgba(45,27,78,.10);
  transition: transform .25s ease, box-shadow .25s ease;
}

.song-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 34px rgba(45,27,78,.16);
}

.song-card-media {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: #111;
}

.song-card-media::after {
  content: "\f04b";
  font-family: "Font Awesome 6 Free";
  font-weight: 900;

  position: absolute;
  inset: 0;
  margin: auto;

  width: 3.5rem;
  height: 3.5rem;

  border-radius: 50%;

  display: flex;
  align-items: center;
  justify-content: center;

  background: rgba(246,239,228,.92);
  color: var(--brown);

  border: 1px solid rgba(202,162,74,.55);

  box-shadow: 0 12px 30px rgba(45,27,78,.22);
}

.song-card-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;

  transition: transform .28s ease;
}

.song-card:hover .song-card-media img {
  transform: scale(1.05);
}

/* Hide old Watch Now section */
.song-card-body {
  display: none !important;
}

@media (max-width: 520px) {
  .song-card-media::after {
    width: 3rem;
    height: 3rem;
    font-size: .9rem;
  }
}
/* Bigger YouTube Video Cards */

.song-carousel-container {
  max-width: 1450px !important;
}

.song-carousel-strip {
  gap: 1.3rem !important;
}

.song-card {
  flex: 0 0 calc((100cqw - 2.6rem) / 3) !important;
}

/* Tablet */
@container songvp (max-width: 900px) {
  .song-card {
    flex: 0 0 calc((100cqw - 1.2rem) / 2) !important;
  }
}

/* Mobile */
@container songvp (max-width: 520px) {
  .song-card {
    flex: 0 0 100% !important;
  }
}

.song-card-media {
  aspect-ratio: 16 / 9.5 !important;
}