:root{--rr-bg:#07070c;--rr-panel:#10101a;--rr-panel2:#171727;--rr-text:#f6f3ff;--rr-muted:#a6a0b8;--rr-gold:#f7c948;--rr-pink:#ff3d81;--rr-cyan:#31e8ff;--rr-green:#31d27c;--rr-line:rgba(255,255,255,.10);--rr-radius:28px;--rr-shadow:0 25px 80px rgba(0,0,0,.35)}*{box-sizing:border-box}body.rr-body{margin:0;background:radial-gradient(circle at 10% -10%,rgba(255,61,129,.26),transparent 35%),radial-gradient(circle at 95% 5%,rgba(49,232,255,.16),transparent 35%),var(--rr-bg);color:var(--rr-text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;min-height:100vh;padding-bottom:108px}a{color:inherit;text-decoration:none}.rr-header{position:sticky;top:0;z-index:40;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:18px clamp(18px,4vw,56px);backdrop-filter:blur(18px);background:rgba(7,7,12,.78);border-bottom:1px solid var(--rr-line)}.rr-logo{display:inline-flex;align-items:center;gap:10px;font-weight:900;letter-spacing:-.03em}.rr-logo-mark{display:grid;place-items:center;width:42px;height:42px;border-radius:15px;background:linear-gradient(135deg,var(--rr-gold),var(--rr-pink));color:#08080d;box-shadow:0 12px 35px rgba(255,61,129,.22)}.rr-nav{display:flex;align-items:center;gap:6px}.rr-nav a{padding:10px 13px;border-radius:999px;color:var(--rr-muted);font-weight:700;font-size:14px}.rr-nav a:hover,.rr-nav .rr-nav-cta{color:var(--rr-text);background:rgba(255,255,255,.09)}.rr-nav-cta{border:1px solid rgba(247,201,72,.35)}.rr-menu-btn{display:none;background:rgba(255,255,255,.08);border:1px solid var(--rr-line);color:white;border-radius:14px;padding:9px 12px}.rr-main{padding:0 clamp(18px,4vw,56px)}.rr-hero{position:relative;overflow:hidden;min-height:78vh;display:grid;align-items:end;padding:clamp(42px,8vw,90px);margin:24px 0;border:1px solid var(--rr-line);border-radius:44px;background:linear-gradient(135deg,rgba(255,61,129,.24),rgba(49,232,255,.12)),url('../img/hero-pattern.svg') center/cover,var(--rr-panel);box-shadow:var(--rr-shadow)}.rr-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(7,7,12,.92),transparent 55%);pointer-events:none}.rr-hero-content{position:relative;z-index:2;max-width:860px}.rr-kicker{display:inline-flex;gap:8px;align-items:center;color:var(--rr-gold);font-weight:900;text-transform:uppercase;letter-spacing:.13em;font-size:12px}.rr-hero h1{font-size:clamp(56px,12vw,148px);line-height:.86;letter-spacing:-.08em;margin:16px 0}.rr-hero p{max-width:700px;color:#d8d3e8;font-size:clamp(18px,2vw,23px);line-height:1.55}.rr-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:26px}.rr-btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:14px 20px;border-radius:999px;background:linear-gradient(135deg,var(--rr-gold),var(--rr-pink));color:#08080d;font-weight:900;border:0;cursor:pointer}.rr-btn.secondary{background:rgba(255,255,255,.08);color:var(--rr-text);border:1px solid var(--rr-line)}.rr-btn-sm{padding:10px 14px;font-size:13px}.rr-section{margin:48px 0}.rr-section-head{display:flex;align-items:end;justify-content:space-between;gap:18px;margin-bottom:18px}.rr-section h2{font-size:clamp(28px,4vw,48px);letter-spacing:-.05em;margin:0}.rr-muted{color:var(--rr-muted)}.rr-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}.rr-grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.rr-card{background:linear-gradient(180deg,rgba(255,255,255,.075),rgba(255,255,255,.035));border:1px solid var(--rr-line);border-radius:var(--rr-radius);padding:16px;box-shadow:0 16px 45px rgba(0,0,0,.20)}.rr-cover{width:100%;aspect-ratio:1/1;border-radius:22px;object-fit:cover;background:#191928}.rr-card h3{font-size:20px;margin:14px 0 6px;letter-spacing:-.03em}.rr-card p{color:var(--rr-muted);margin:0 0 12px}.rr-card-actions{display:flex;gap:8px;flex-wrap:wrap}.rr-icon-btn{border:1px solid var(--rr-line);background:rgba(255,255,255,.07);color:white;padding:10px 12px;border-radius:14px;cursor:pointer;font-weight:800}.rr-price{color:var(--rr-gold);font-weight:900}.rr-split{display:grid;grid-template-columns:1.2fr .8fr;gap:18px}.rr-panel{background:rgba(255,255,255,.06);border:1px solid var(--rr-line);border-radius:var(--rr-radius);padding:24px}.rr-form{display:grid;gap:14px}.rr-form input,.rr-form textarea,.rr-form select{width:100%;background:rgba(255,255,255,.07);border:1px solid var(--rr-line);border-radius:16px;color:white;padding:14px}.rr-form textarea{min-height:130px}.rr-table{width:100%;border-collapse:separate;border-spacing:0 10px}.rr-table th{text-align:left;color:var(--rr-muted);font-size:13px}.rr-table td{background:rgba(255,255,255,.055);padding:12px;border-top:1px solid var(--rr-line);border-bottom:1px solid var(--rr-line)}.rr-table td:first-child{border-radius:16px 0 0 16px;border-left:1px solid var(--rr-line)}.rr-table td:last-child{border-radius:0 16px 16px 0;border-right:1px solid var(--rr-line)}.rr-player{position:fixed;left:16px;right:16px;bottom:14px;z-index:60;display:grid;grid-template-columns:64px 1fr auto;gap:14px;align-items:center;background:rgba(14,14,24,.92);border:1px solid var(--rr-line);backdrop-filter:blur(22px);padding:12px;border-radius:24px;box-shadow:var(--rr-shadow)}.rr-player img{width:64px;height:64px;border-radius:16px;object-fit:cover}.rr-player-meta{display:grid;gap:4px}.rr-player-meta span{color:var(--rr-muted);font-size:13px}.rr-player input[type=range]{width:100%}.rr-player-controls{display:flex;gap:8px}.rr-player-controls button{width:42px;height:42px;border-radius:14px;border:1px solid var(--rr-line);background:rgba(255,255,255,.08);color:white}.rr-play-main{background:linear-gradient(135deg,var(--rr-gold),var(--rr-pink))!important;color:#08080d!important}.rr-footer{padding:44px clamp(18px,4vw,56px);border-top:1px solid var(--rr-line);background:rgba(0,0,0,.2)}.rr-footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:28px}.rr-socials{display:flex;gap:10px;flex-wrap:wrap}.rr-socials a{color:var(--rr-muted)}.rr-copy{color:var(--rr-muted);font-size:13px;margin-top:30px}.rr-song-hero{display:grid;grid-template-columns:340px 1fr;gap:30px;align-items:center;margin:38px 0}.rr-lyric-box{white-space:pre-wrap;line-height:1.8;color:#ddd7f0}.rr-admin-body{background:#0b0b12;color:white;margin:0;font-family:Inter,ui-sans-serif,system-ui}.rr-admin-sidebar{position:fixed;inset:0 auto 0 0;width:260px;padding:20px;background:#11111c;border-right:1px solid var(--rr-line);overflow:auto}.rr-admin-sidebar nav{display:grid;gap:6px;margin-top:24px}.rr-admin-sidebar a{padding:11px 12px;border-radius:14px;color:#c9c3d9}.rr-admin-sidebar a:hover{background:rgba(255,255,255,.07);color:white}.rr-admin-main{margin-left:260px;padding:26px}.rr-admin-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.rr-admin-top h1{font-size:34px;letter-spacing:-.04em;margin:0}.rr-stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.rr-stat{background:linear-gradient(180deg,rgba(255,255,255,.075),rgba(255,255,255,.035));border:1px solid var(--rr-line);border-radius:24px;padding:20px}.rr-stat strong{display:block;font-size:32px}.rr-alert{padding:14px 16px;border-radius:16px;margin:12px 0;background:rgba(49,210,124,.12);border:1px solid rgba(49,210,124,.3)}.rr-alert.error{background:rgba(255,61,129,.12);border-color:rgba(255,61,129,.3)}@media(max-width:950px){.rr-nav{display:none;position:absolute;top:72px;left:14px;right:14px;padding:12px;background:rgba(16,16,26,.98);border:1px solid var(--rr-line);border-radius:22px;flex-direction:column;align-items:stretch}.rr-nav.open{display:flex}.rr-menu-btn{display:block}.rr-grid,.rr-grid.three,.rr-split,.rr-footer-grid,.rr-song-hero{grid-template-columns:1fr}.rr-hero{padding:34px 22px;border-radius:30px;min-height:68vh}.rr-player{grid-template-columns:50px 1fr;right:10px;left:10px}.rr-player img{width:50px;height:50px}.rr-player-controls{grid-column:1/-1;justify-content:center}.rr-admin-sidebar{position:relative;width:auto}.rr-admin-main{margin-left:0}.rr-stat-grid{grid-template-columns:1fr 1fr}}@media(max-width:620px){.rr-grid,.rr-stat-grid{grid-template-columns:1fr}.rr-main{padding:0 14px}.rr-header{padding:14px}.rr-section-head{align-items:flex-start;flex-direction:column}.rr-table{font-size:13px}.rr-table td,.rr-table th{padding:9px}.rr-song-hero{gap:18px}.rr-song-hero .rr-cover{max-width:290px}.rr-actions .rr-btn{width:100%}}


/* Ricky Rhythms homepage image slider */
.rr-home-slider{position:relative;overflow:hidden;min-height:78vh;margin:24px 0 54px;border:1px solid var(--rr-line);border-radius:44px;background:#07070c;box-shadow:var(--rr-shadow)}
.rr-slider-track{position:relative;min-height:78vh}
.rr-slide{position:absolute;inset:0;opacity:0;visibility:hidden;transform:scale(1.015);transition:opacity .75s ease,visibility .75s ease,transform 1.2s ease}
.rr-slide.is-active{opacity:1;visibility:visible;transform:scale(1)}
.rr-slide-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;filter:blur(18px) saturate(1.08);transform:scale(1.1);opacity:.48}
.rr-slide-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(7,7,12,.97) 0%,rgba(7,7,12,.82) 38%,rgba(7,7,12,.28) 72%,rgba(7,7,12,.76) 100%),radial-gradient(circle at 78% 18%,rgba(49,210,124,.28),transparent 28%),radial-gradient(circle at 5% 85%,rgba(255,61,129,.28),transparent 32%)}
.rr-slide-inner{position:relative;z-index:2;min-height:78vh;display:grid;grid-template-columns:minmax(0,1fr) minmax(310px,470px);align-items:end;gap:clamp(24px,5vw,70px);padding:clamp(32px,7vw,82px)}
.rr-slide-copy{max-width:790px;padding-bottom:clamp(20px,4vw,42px)}
.rr-slide-copy h1{font-size:clamp(52px,10vw,132px);line-height:.86;letter-spacing:-.08em;margin:16px 0 18px;text-wrap:balance}
.rr-slide-copy p{max-width:690px;color:#e7e1f3;font-size:clamp(17px,2vw,23px);line-height:1.55;text-shadow:0 10px 35px rgba(0,0,0,.55)}
.rr-slide-art{align-self:center;justify-self:end;position:relative;width:min(38vw,430px);aspect-ratio:4/5;border-radius:34px;overflow:hidden;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.06);box-shadow:0 35px 120px rgba(0,0,0,.55)}
.rr-slide-art::before{content:"";position:absolute;inset:0;border-radius:inherit;background:linear-gradient(160deg,rgba(247,201,72,.16),transparent 35%,rgba(49,210,124,.22));z-index:2;pointer-events:none}
.rr-slide-art img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}
.rr-slider-arrow{position:absolute;z-index:5;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:999px;border:1px solid rgba(255,255,255,.2);background:rgba(8,8,13,.58);color:white;font-size:38px;line-height:1;display:grid;place-items:center;cursor:pointer;backdrop-filter:blur(18px);transition:background .2s ease,transform .2s ease}
.rr-slider-arrow:hover{background:rgba(255,255,255,.12);transform:translateY(-50%) scale(1.04)}
.rr-slider-prev{left:18px}.rr-slider-next{right:18px}
.rr-slider-dots{position:absolute;z-index:5;left:50%;bottom:24px;transform:translateX(-50%);display:flex;gap:10px;padding:9px 12px;border-radius:999px;background:rgba(7,7,12,.48);border:1px solid rgba(255,255,255,.12);backdrop-filter:blur(18px)}
.rr-slider-dots button{width:10px;height:10px;border-radius:999px;border:0;background:rgba(255,255,255,.36);cursor:pointer;transition:width .25s ease,background .25s ease}
.rr-slider-dots button.is-active{width:34px;background:linear-gradient(135deg,var(--rr-gold),var(--rr-pink))}
@media(max-width:950px){.rr-home-slider,.rr-slider-track,.rr-slide-inner{min-height:76vh}.rr-slide-inner{grid-template-columns:1fr;align-items:end;padding:32px 22px 82px}.rr-slide-art{position:absolute;right:18px;top:86px;width:min(42vw,230px);opacity:.56;border-radius:26px}.rr-slide-copy{position:relative;z-index:3;padding-bottom:0}.rr-slide-copy h1{font-size:clamp(48px,16vw,86px)}.rr-slide-copy p{font-size:17px}.rr-slider-arrow{display:none}.rr-slide-overlay{background:linear-gradient(0deg,rgba(7,7,12,.96) 0%,rgba(7,7,12,.75) 46%,rgba(7,7,12,.38) 100%),radial-gradient(circle at 80% 10%,rgba(49,210,124,.30),transparent 34%)}}
@media(max-width:620px){.rr-home-slider{border-radius:30px;margin-top:16px}.rr-slider-dots{bottom:18px}.rr-slide-art{width:155px;top:74px;right:12px}.rr-slide-copy h1{font-size:clamp(43px,17vw,72px)}.rr-slide-copy p{max-width:95%}}


/* =========================================================
   RICKY RHYTHMS HOMEPAGE SLIDER - FIT READY PRO VERSION
   This block fixes image fitting, text clipping, spacing,
   responsive behavior, and real homepage presentation.
   ========================================================= */

.rr-hero-fit-slider{
  position:relative;
  overflow:hidden;
  min-height:clamp(560px,72vh,780px);
  margin:24px 0 54px;
  border:1px solid var(--rr-line);
  border-radius:44px;
  background:#07070c;
  box-shadow:var(--rr-shadow);
  isolation:isolate;
}

.rr-fit-track,
.rr-fit-slide{
  position:absolute;
  inset:0;
}

.rr-fit-slide{
  opacity:0;
  visibility:hidden;
  transform:scale(1.01);
  transition:opacity .75s ease, visibility .75s ease, transform 1.1s ease;
  pointer-events:none;
}

.rr-fit-slide.is-active{
  opacity:1;
  visibility:visible;
  transform:scale(1);
  pointer-events:auto;
}

.rr-fit-bg{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  max-width:none;
  display:block;
  object-fit:cover;
  filter:blur(18px) saturate(1.12) brightness(.58);
  transform:scale(1.08);
}

.rr-fit-overlay{
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg,rgba(7,7,12,.98) 0%,rgba(7,7,12,.92) 34%,rgba(7,7,12,.48) 66%,rgba(7,7,12,.78) 100%),
    radial-gradient(circle at 78% 16%,rgba(49,210,124,.24),transparent 30%),
    radial-gradient(circle at 8% 85%,rgba(255,61,129,.22),transparent 34%);
}

.rr-fit-inner{
  position:relative;
  z-index:2;
  min-height:clamp(560px,72vh,780px);
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(300px,430px);
  align-items:center;
  gap:clamp(28px,5vw,70px);
  padding:clamp(46px,7vw,82px) clamp(48px,7vw,92px);
}

.rr-fit-copy{
  width:100%;
  max-width:720px;
  min-width:0;
  align-self:center;
}

.rr-fit-copy .rr-kicker{
  margin-bottom:10px;
}

.rr-fit-copy h1{
  font-size:clamp(56px,8vw,118px);
  line-height:.88;
  letter-spacing:-.075em;
  margin:12px 0 18px;
  max-width:8.2em;
  overflow-wrap:normal;
  text-wrap:balance;
}

.rr-fit-copy p{
  max-width:640px;
  color:#f1ecfb;
  font-size:clamp(17px,1.55vw,22px);
  line-height:1.52;
  margin:0;
  text-shadow:0 12px 35px rgba(0,0,0,.62);
}

.rr-fit-copy .rr-actions{
  margin-top:26px;
  display:flex;
  flex-wrap:wrap;
  gap:12px;
}

.rr-fit-portrait{
  width:min(31vw,430px);
  min-width:300px;
  aspect-ratio:4/5;
  justify-self:end;
  margin:0;
  border-radius:34px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.06);
  box-shadow:0 38px 120px rgba(0,0,0,.58);
  position:relative;
}

.rr-fit-portrait::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:2;
  pointer-events:none;
  background:linear-gradient(160deg,rgba(247,201,72,.14),transparent 35%,rgba(49,210,124,.20));
}

.rr-fit-portrait img{
  width:100%;
  height:100%;
  max-width:none;
  display:block;
  object-fit:cover;
  object-position:center center;
}

.rr-hero-fit-slider .rr-slider-arrow{
  z-index:6;
}

.rr-hero-fit-slider .rr-slider-dots{
  z-index:6;
  bottom:24px;
}

@media(max-width:1100px){
  .rr-fit-inner{
    grid-template-columns:minmax(0,1fr) minmax(250px,340px);
    padding:42px 38px 72px;
  }

  .rr-fit-portrait{
    width:min(34vw,340px);
    min-width:250px;
  }

  .rr-fit-copy h1{
    font-size:clamp(50px,8.8vw,92px);
  }
}

@media(max-width:860px){
  .rr-hero-fit-slider{
    min-height:clamp(650px,84vh,820px);
    border-radius:34px;
    margin-top:16px;
  }

  .rr-fit-inner{
    min-height:clamp(650px,84vh,820px);
    display:flex;
    flex-direction:column;
    justify-content:flex-end;
    align-items:flex-start;
    gap:20px;
    padding:28px 22px 82px;
  }

  .rr-fit-copy{
    position:relative;
    z-index:3;
    max-width:100%;
  }

  .rr-fit-copy h1{
    font-size:clamp(48px,15vw,82px);
    line-height:.9;
    max-width:7.8em;
  }

  .rr-fit-copy p{
    max-width:100%;
    font-size:16.5px;
    line-height:1.48;
  }

  .rr-fit-portrait{
    position:absolute;
    top:24px;
    right:22px;
    width:min(44vw,230px);
    min-width:150px;
    border-radius:26px;
    opacity:.72;
    z-index:2;
  }

  .rr-fit-overlay{
    background:
      linear-gradient(0deg,rgba(7,7,12,.98) 0%,rgba(7,7,12,.88) 46%,rgba(7,7,12,.38) 100%),
      radial-gradient(circle at 80% 12%,rgba(49,210,124,.26),transparent 34%);
  }

  .rr-slider-arrow{
    display:none;
  }
}

@media(max-width:520px){
  .rr-hero-fit-slider{
    min-height:680px;
    border-radius:28px;
  }

  .rr-fit-inner{
    min-height:680px;
    padding:24px 18px 78px;
  }

  .rr-fit-portrait{
    width:155px;
    top:18px;
    right:16px;
    opacity:.62;
  }

  .rr-fit-copy h1{
    font-size:clamp(43px,16vw,66px);
    letter-spacing:-.065em;
  }

  .rr-fit-copy .rr-actions{
    gap:10px;
  }

  .rr-fit-copy .rr-btn{
    padding:12px 15px;
    font-size:13px;
  }

  .rr-hero-fit-slider .rr-slider-dots{
    bottom:16px;
  }
}


/* =========================================================
   RICKY RHYTHMS STAGE HERO SLIDER REDESIGN
   Clean new slider design: no half image, no text overlap,
   desktop horizontal layout, mobile stacked layout.
   ========================================================= */

.rr-stage-slider{
  position:relative;
  width:calc(100% - 48px);
  max-width:1480px;
  height:clamp(620px, calc(100vh - 116px), 840px);
  margin:24px auto 58px;
  overflow:hidden;
  border-radius:46px;
  border:1px solid rgba(255,255,255,.12);
  background:#07070c;
  box-shadow:0 40px 140px rgba(0,0,0,.55);
  isolation:isolate;
}

.rr-stage-track,
.rr-stage-slide{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
}

.rr-stage-slide{
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transform:scale(1.01);
  transition:opacity .75s ease, visibility .75s ease, transform 1.1s ease;
}

.rr-stage-slide.is-active{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  transform:scale(1);
}

.rr-stage-bg{
  position:absolute;
  inset:-28px;
  width:calc(100% + 56px);
  height:calc(100% + 56px);
  max-width:none;
  object-fit:cover;
  object-position:center;
  filter:blur(24px) brightness(.40) saturate(1.28);
  transform:scale(1.05);
}

.rr-stage-slide::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  background:
    linear-gradient(90deg, rgba(7,7,12,.96) 0%, rgba(7,7,12,.86) 38%, rgba(7,7,12,.50) 67%, rgba(7,7,12,.88) 100%),
    radial-gradient(circle at 77% 18%, rgba(49,210,124,.30), transparent 28%),
    radial-gradient(circle at 0% 86%, rgba(255,61,129,.24), transparent 34%);
}

.rr-stage-inner{
  position:relative;
  z-index:2;
  height:100%;
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(380px, 540px);
  gap:clamp(32px, 5vw, 82px);
  align-items:center;
  padding:clamp(46px, 6vw, 88px) clamp(58px, 7vw, 104px) clamp(86px, 7vw, 110px);
  box-sizing:border-box;
}

.rr-stage-copy{
  max-width:710px;
  min-width:0;
}

.rr-stage-copy .rr-kicker{
  margin-bottom:14px;
}

.rr-stage-copy h1{
  font-size:clamp(54px, 7.2vw, 112px);
  line-height:.88;
  letter-spacing:-.078em;
  margin:0 0 22px;
  max-width:8.1em;
  text-wrap:balance;
}

.rr-stage-copy p{
  max-width:610px;
  color:#f2edf8;
  font-size:clamp(17px, 1.45vw, 21px);
  line-height:1.58;
  margin:0;
  text-shadow:0 12px 40px rgba(0,0,0,.55);
}

.rr-stage-copy .rr-actions{
  margin-top:28px;
}

.rr-stage-visual{
  position:relative;
  width:100%;
  height:min(100%, 690px);
  min-height:460px;
  border-radius:38px;
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
  background:
    linear-gradient(135deg, rgba(142,48,12,.96), rgba(19,11,10,.94)),
    radial-gradient(circle at 50% 18%, rgba(49,210,124,.24), transparent 30%);
  border:1px solid rgba(255,255,255,.18);
  box-shadow:0 38px 120px rgba(0,0,0,.58);
}

.rr-stage-visual::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(180deg, rgba(255,255,255,.08), transparent 28%, rgba(0,0,0,.34)),
    radial-gradient(circle at 78% 14%, rgba(49,210,124,.20), transparent 24%);
}

.rr-stage-visual img{
  width:100%;
  height:100%;
  max-width:none;
  display:block;
  object-fit:contain;
  object-position:center center;
  position:relative;
  z-index:1;
}

.rr-stage-badge{
  position:absolute;
  z-index:3;
  top:18px;
  left:18px;
  display:inline-flex;
  align-items:center;
  gap:8px;
  border-radius:999px;
  padding:10px 13px;
  background:rgba(8,8,13,.58);
  color:#fff;
  border:1px solid rgba(255,255,255,.16);
  backdrop-filter:blur(16px);
  font-size:12px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.rr-stage-slider .rr-slider-arrow{
  z-index:6;
  width:48px;
  height:48px;
}

.rr-stage-slider .rr-slider-prev{
  left:18px;
}

.rr-stage-slider .rr-slider-next{
  right:18px;
}

.rr-stage-dots{
  left:auto !important;
  right:clamp(76px, 7vw, 128px) !important;
  bottom:30px !important;
  transform:none !important;
  z-index:6;
}

@media(max-width:1180px){
  .rr-stage-slider{
    width:calc(100% - 32px);
    height:clamp(600px, calc(100vh - 112px), 790px);
  }

  .rr-stage-inner{
    grid-template-columns:minmax(0, 1fr) minmax(320px, 430px);
    gap:36px;
    padding:42px 44px 92px;
  }

  .rr-stage-copy h1{
    font-size:clamp(48px, 7.5vw, 86px);
  }

  .rr-stage-visual{
    min-height:430px;
    border-radius:32px;
  }
}

@media(max-width:880px){
  .rr-stage-slider{
    width:calc(100% - 24px);
    height:auto;
    min-height:0;
    border-radius:32px;
  }

  .rr-stage-track{
    position:relative;
    height:auto;
  }

  .rr-stage-slide{
    position:absolute;
    height:auto;
    min-height:0;
  }

  .rr-stage-slide.is-active{
    position:relative;
  }

  .rr-stage-inner{
    height:auto;
    display:flex;
    flex-direction:column;
    align-items:stretch;
    justify-content:flex-start;
    gap:24px;
    padding:18px 18px 88px;
  }

  .rr-stage-copy{
    order:2;
    max-width:100%;
  }

  .rr-stage-copy h1{
    font-size:clamp(44px, 14vw, 78px);
    line-height:.92;
    letter-spacing:-.065em;
    max-width:100%;
    margin-bottom:16px;
  }

  .rr-stage-copy p{
    max-width:100%;
    font-size:16.2px;
    line-height:1.52;
  }

  .rr-stage-copy .rr-actions{
    margin-top:21px;
  }

  .rr-stage-visual{
    order:1;
    width:100%;
    min-height:0;
    height:auto;
    aspect-ratio:4/5;
    max-height:none;
    border-radius:26px;
  }

  .rr-stage-slider .rr-slider-arrow{
    display:none;
  }

  .rr-stage-dots{
    left:18px !important;
    right:auto !important;
    bottom:22px !important;
  }
}

@media(max-width:520px){
  .rr-stage-slider{
    width:calc(100% - 18px);
    margin-top:12px;
    border-radius:24px;
  }

  .rr-stage-inner{
    padding:14px 14px 82px;
    gap:18px;
  }

  .rr-stage-visual{
    border-radius:20px;
  }

  .rr-stage-badge{
    top:12px;
    left:12px;
    font-size:10px;
    padding:8px 10px;
  }

  .rr-stage-copy h1{
    font-size:clamp(39px, 14.5vw, 62px);
  }

  .rr-stage-copy p{
    font-size:15.5px;
  }

  .rr-stage-copy .rr-actions{
    gap:9px;
  }

  .rr-stage-copy .rr-btn{
    padding:11px 13px;
    font-size:13px;
  }
}


/* =========================================================
   COMPLETE HOMEPAGE FIX - Ricky Rhythms
   Fixes incomplete index behavior, slider layout, empty states,
   real homepage sections, gallery preview, stats, and CTAs.
   ========================================================= */

.rr-stage-slider{
  position:relative;
  width:calc(100% - 48px);
  max-width:1480px;
  min-height:620px;
  height:clamp(620px, calc(100vh - 116px), 840px);
  margin:24px auto 58px;
  overflow:hidden;
  border-radius:46px;
  border:1px solid rgba(255,255,255,.12);
  background:#07070c;
  box-shadow:0 40px 140px rgba(0,0,0,.55);
  isolation:isolate;
}

.rr-stage-track,
.rr-stage-slide{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
}

.rr-stage-slide{
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transform:scale(1.01);
  transition:opacity .75s ease, visibility .75s ease, transform 1.1s ease;
}

.rr-stage-slide.is-active{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  transform:scale(1);
}

.rr-stage-bg{
  position:absolute;
  inset:-28px;
  width:calc(100% + 56px);
  height:calc(100% + 56px);
  max-width:none;
  object-fit:cover;
  object-position:center;
  filter:blur(24px) brightness(.40) saturate(1.28);
  transform:scale(1.05);
}

.rr-stage-slide::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  background:
    linear-gradient(90deg, rgba(7,7,12,.96) 0%, rgba(7,7,12,.86) 38%, rgba(7,7,12,.50) 67%, rgba(7,7,12,.88) 100%),
    radial-gradient(circle at 77% 18%, rgba(49,210,124,.30), transparent 28%),
    radial-gradient(circle at 0% 86%, rgba(255,61,129,.24), transparent 34%);
}

.rr-stage-inner{
  position:relative;
  z-index:2;
  height:100%;
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(380px, 540px);
  gap:clamp(32px, 5vw, 82px);
  align-items:center;
  padding:clamp(46px, 6vw, 88px) clamp(58px, 7vw, 104px) clamp(86px, 7vw, 110px);
  box-sizing:border-box;
}

.rr-stage-copy{
  max-width:710px;
  min-width:0;
}

.rr-stage-copy .rr-kicker{
  margin-bottom:14px;
}

.rr-stage-copy h1{
  font-size:clamp(54px, 7.2vw, 112px);
  line-height:.88;
  letter-spacing:-.078em;
  margin:0 0 22px;
  max-width:8.1em;
  text-wrap:balance;
}

.rr-stage-copy p{
  max-width:610px;
  color:#f2edf8;
  font-size:clamp(17px, 1.45vw, 21px);
  line-height:1.58;
  margin:0;
  text-shadow:0 12px 40px rgba(0,0,0,.55);
}

.rr-stage-copy .rr-actions{
  margin-top:28px;
}

.rr-stage-visual{
  position:relative;
  width:100%;
  height:min(100%, 690px);
  min-height:460px;
  border-radius:38px;
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg, rgba(142,48,12,.96), rgba(19,11,10,.94));
  border:1px solid rgba(255,255,255,.18);
  box-shadow:0 38px 120px rgba(0,0,0,.58);
}

.rr-stage-visual::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(180deg, rgba(255,255,255,.08), transparent 28%, rgba(0,0,0,.34)),
    radial-gradient(circle at 78% 14%, rgba(49,210,124,.20), transparent 24%);
}

.rr-stage-visual img{
  width:100%;
  height:100%;
  max-width:none;
  display:block;
  object-fit:contain;
  object-position:center center;
  position:relative;
  z-index:1;
}

.rr-stage-badge{
  position:absolute;
  z-index:3;
  top:18px;
  left:18px;
  display:inline-flex;
  align-items:center;
  gap:8px;
  border-radius:999px;
  padding:10px 13px;
  background:rgba(8,8,13,.58);
  color:#fff;
  border:1px solid rgba(255,255,255,.16);
  backdrop-filter:blur(16px);
  font-size:12px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.rr-stage-slider .rr-slider-arrow{
  z-index:6;
  width:48px;
  height:48px;
}

.rr-stage-slider .rr-slider-prev{left:18px}
.rr-stage-slider .rr-slider-next{right:18px}

.rr-stage-dots{
  left:auto !important;
  right:clamp(76px, 7vw, 128px) !important;
  bottom:30px !important;
  transform:none !important;
  z-index:6;
}

.rr-home-stats{
  width:min(1180px, calc(100% - 48px));
  margin:-26px auto 56px;
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:14px;
  position:relative;
  z-index:8;
}

.rr-home-stats div{
  padding:18px;
  border-radius:22px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.11);
  box-shadow:0 20px 60px rgba(0,0,0,.24);
}

.rr-home-stats strong{
  display:block;
  font-size:clamp(24px, 3vw, 38px);
  line-height:1;
}

.rr-home-stats span{
  display:block;
  margin-top:6px;
  color:var(--rr-muted);
  font-weight:700;
  font-size:13px;
}

.rr-home-split{
  display:grid;
  grid-template-columns:minmax(0, 1.2fr) minmax(320px, .8fr);
  gap:22px;
}

.rr-section-head.compact{
  margin-bottom:18px;
}

.rr-link-more{
  color:var(--rr-gold);
  font-weight:900;
  font-size:13px;
}

.rr-card-body{
  padding-top:12px;
}

.rr-song-card .rr-cover{
  aspect-ratio:1/1;
}

.rr-song-rank{
  width:30px;
  height:30px;
  border-radius:999px;
  display:grid;
  place-items:center;
  background:rgba(255,255,255,.08);
  color:var(--rr-gold);
  font-weight:900;
  flex:0 0 auto;
}

.rr-empty-wide{
  grid-column:1/-1;
}

.rr-empty{
  display:flex;
  flex-direction:column;
  gap:10px;
  align-items:flex-start;
  justify-content:center;
  padding:26px;
  border-radius:24px;
  background:rgba(255,255,255,.05);
  border:1px dashed rgba(255,255,255,.16);
  color:var(--rr-muted);
}

.rr-empty strong{
  color:var(--rr-text);
}

.rr-booking-panel,
.rr-newsletter-panel,
.rr-artist-cta{
  background:
    radial-gradient(circle at 20% 10%, rgba(247,201,72,.16), transparent 28%),
    radial-gradient(circle at 90% 0%, rgba(255,61,129,.18), transparent 30%),
    rgba(255,255,255,.055);
}

.rr-gallery-preview{
  display:grid;
  grid-template-columns:repeat(6, minmax(0, 1fr));
  gap:12px;
}

.rr-gallery-tile{
  position:relative;
  overflow:hidden;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.12);
  aspect-ratio:3/4;
  background:rgba(255,255,255,.05);
  display:block;
}

.rr-gallery-tile img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:transform .35s ease;
}

.rr-gallery-tile:hover img{
  transform:scale(1.05);
}

.rr-gallery-tile span{
  position:absolute;
  left:10px;
  right:10px;
  bottom:10px;
  border-radius:999px;
  padding:7px 10px;
  background:rgba(0,0,0,.48);
  color:#fff;
  font-size:12px;
  font-weight:800;
  backdrop-filter:blur(12px);
}

.rr-artist-cta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:28px;
  padding:clamp(28px, 5vw, 52px);
  border-radius:32px;
  border:1px solid rgba(255,255,255,.12);
}

.rr-artist-cta h2{
  max-width:760px;
  margin:10px 0;
}

.rr-artist-cta p{
  max-width:720px;
  color:var(--rr-muted);
  margin:0;
}

.rr-lightbox{
  position:fixed;
  inset:0;
  z-index:9999;
  background:rgba(0,0,0,.86);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:20px;
}

.rr-lightbox img{
  max-width:min(1100px, 94vw);
  max-height:90vh;
  object-fit:contain;
  border-radius:18px;
  box-shadow:0 30px 120px rgba(0,0,0,.7);
}

.rr-lightbox button{
  position:absolute;
  top:18px;
  right:18px;
  width:44px;
  height:44px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.09);
  color:#fff;
  font-size:30px;
  line-height:1;
  cursor:pointer;
}

@media(max-width:1180px){
  .rr-stage-slider{
    width:calc(100% - 32px);
    height:clamp(600px, calc(100vh - 112px), 790px);
  }

  .rr-stage-inner{
    grid-template-columns:minmax(0, 1fr) minmax(320px, 430px);
    gap:36px;
    padding:42px 44px 92px;
  }

  .rr-stage-copy h1{
    font-size:clamp(48px, 7.5vw, 86px);
  }

  .rr-stage-visual{
    min-height:430px;
    border-radius:32px;
  }

  .rr-gallery-preview{
    grid-template-columns:repeat(3, minmax(0, 1fr));
  }
}

@media(max-width:880px){
  .rr-stage-slider{
    width:calc(100% - 24px);
    height:auto;
    min-height:0;
    border-radius:32px;
  }

  .rr-stage-track{
    position:relative;
    height:auto;
  }

  .rr-stage-slide{
    position:absolute;
    height:auto;
    min-height:0;
  }

  .rr-stage-slide.is-active{
    position:relative;
  }

  .rr-stage-inner{
    height:auto;
    display:flex;
    flex-direction:column;
    align-items:stretch;
    justify-content:flex-start;
    gap:24px;
    padding:18px 18px 88px;
  }

  .rr-stage-copy{
    order:2;
    max-width:100%;
  }

  .rr-stage-copy h1{
    font-size:clamp(44px, 14vw, 78px);
    line-height:.92;
    letter-spacing:-.065em;
    max-width:100%;
    margin-bottom:16px;
  }

  .rr-stage-copy p{
    max-width:100%;
    font-size:16.2px;
    line-height:1.52;
  }

  .rr-stage-visual{
    order:1;
    width:100%;
    min-height:0;
    height:auto;
    aspect-ratio:4/5;
    max-height:none;
    border-radius:26px;
  }

  .rr-stage-slider .rr-slider-arrow{
    display:none;
  }

  .rr-stage-dots{
    left:18px !important;
    right:auto !important;
    bottom:22px !important;
  }

  .rr-home-stats{
    width:calc(100% - 24px);
    grid-template-columns:repeat(2, minmax(0, 1fr));
    margin-top:-22px;
  }

  .rr-home-split,
  .rr-artist-cta{
    grid-template-columns:1fr;
    display:grid;
  }

  .rr-artist-cta{
    align-items:start;
  }
}

@media(max-width:620px){
  .rr-gallery-preview{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
}

@media(max-width:520px){
  .rr-stage-slider{
    width:calc(100% - 18px);
    margin-top:12px;
    border-radius:24px;
  }

  .rr-stage-inner{
    padding:14px 14px 82px;
    gap:18px;
  }

  .rr-stage-visual{
    border-radius:20px;
  }

  .rr-stage-badge{
    top:12px;
    left:12px;
    font-size:10px;
    padding:8px 10px;
  }

  .rr-stage-copy h1{
    font-size:clamp(39px, 14.5vw, 62px);
  }

  .rr-stage-copy p{
    font-size:15.5px;
  }

  .rr-stage-copy .rr-actions{
    gap:9px;
  }

  .rr-stage-copy .rr-btn{
    padding:11px 13px;
    font-size:13px;
  }

  .rr-home-stats{
    grid-template-columns:1fr;
  }
}

/* =========================================================
   FAN FAVOURITES SECTION — ONLY STYLE FIX
   Paste this at the very bottom of:
   public_html/assets/css/app.css

   This does NOT touch index.php, database, admin, config,
   player logic, or slider logic.
   ========================================================= */

.rr-chart-panel,
.rr-two-col > .rr-panel:first-child{
  position:relative;
  overflow:hidden;
  border-radius:30px;
  border:1px solid rgba(255,255,255,.14);
  background:
    radial-gradient(circle at 12% 0%, rgba(247,201,72,.18), transparent 32%),
    radial-gradient(circle at 100% 18%, rgba(255,61,129,.14), transparent 34%),
    linear-gradient(145deg, rgba(255,255,255,.075), rgba(255,255,255,.035));
  box-shadow:0 28px 90px rgba(0,0,0,.34);
}

.rr-chart-panel::before,
.rr-two-col > .rr-panel:first-child::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(120deg, rgba(255,255,255,.10), transparent 22%, transparent 72%, rgba(247,201,72,.08)),
    radial-gradient(circle at 70% 110%, rgba(49,210,124,.15), transparent 34%);
  opacity:.85;
}

.rr-chart-panel > *,
.rr-two-col > .rr-panel:first-child > *{
  position:relative;
  z-index:1;
}

.rr-chart-panel h2,
.rr-two-col > .rr-panel:first-child h2{
  font-size:clamp(28px,3.5vw,44px);
  letter-spacing:-.055em;
  margin-bottom:18px;
}

.rr-chart-panel,
.rr-two-col > .rr-panel:first-child{
  counter-reset: fanFavouriteRank;
}

.rr-chart-panel .rr-song-rank,
.rr-two-col > .rr-panel:first-child .rr-song-rank{
  display:none;
}

.rr-chart-panel .rr-row-song,
.rr-two-col > .rr-panel:first-child .rr-row-song{
  counter-increment: fanFavouriteRank;
  display:grid;
  grid-template-columns:44px 66px minmax(0,1fr) 46px;
  align-items:center;
  gap:14px;
  padding:13px 14px;
  margin:0 0 12px;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(10,10,18,.54);
  box-shadow:0 16px 42px rgba(0,0,0,.22);
  transition:transform .22s ease, background .22s ease, border-color .22s ease, box-shadow .22s ease;
}

.rr-chart-panel .rr-row-song:hover,
.rr-two-col > .rr-panel:first-child .rr-row-song:hover{
  transform:translateY(-2px);
  background:rgba(255,255,255,.075);
  border-color:rgba(247,201,72,.32);
  box-shadow:0 24px 58px rgba(0,0,0,.30);
}

.rr-chart-panel .rr-row-song::before,
.rr-two-col > .rr-panel:first-child .rr-row-song::before{
  content:counter(fanFavouriteRank);
  width:38px;
  height:38px;
  border-radius:999px;
  display:grid;
  place-items:center;
  color:#08080d;
  font-weight:1000;
  font-size:15px;
  background:linear-gradient(135deg, var(--rr-gold, #f7c948), var(--rr-pink, #ff3d81));
  box-shadow:0 10px 30px rgba(247,201,72,.18);
}

.rr-chart-panel .rr-row-song img,
.rr-two-col > .rr-panel:first-child .rr-row-song img{
  width:66px;
  height:66px;
  border-radius:18px;
  object-fit:cover;
  display:block;
  border:1px solid rgba(255,255,255,.16);
  box-shadow:0 12px 30px rgba(0,0,0,.30);
}

.rr-chart-panel .rr-row-song div,
.rr-two-col > .rr-panel:first-child .rr-row-song div{
  min-width:0;
}

.rr-chart-panel .rr-row-song strong,
.rr-two-col > .rr-panel:first-child .rr-row-song strong{
  display:block;
  color:var(--rr-text, #fff);
  font-size:16px;
  line-height:1.18;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.rr-chart-panel .rr-row-song span,
.rr-two-col > .rr-panel:first-child .rr-row-song span{
  display:block;
  color:var(--rr-muted, #aaa3b8);
  font-size:12.5px;
  margin-top:6px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.rr-chart-panel .rr-row-song button,
.rr-two-col > .rr-panel:first-child .rr-row-song button{
  width:44px;
  height:44px;
  border-radius:999px;
  display:grid;
  place-items:center;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.08);
  color:#fff;
  cursor:pointer;
  font-size:15px;
  box-shadow:0 12px 32px rgba(0,0,0,.22);
  transition:transform .18s ease, background .18s ease, color .18s ease;
}

.rr-chart-panel .rr-row-song button:hover,
.rr-two-col > .rr-panel:first-child .rr-row-song button:hover{
  transform:scale(1.06);
  background:linear-gradient(135deg, var(--rr-gold, #f7c948), var(--rr-pink, #ff3d81));
  color:#08080d;
}

.rr-chart-panel .rr-row-song:first-of-type,
.rr-two-col > .rr-panel:first-child .rr-row-song:first-of-type{
  background:
    linear-gradient(135deg, rgba(247,201,72,.16), rgba(255,61,129,.10)),
    rgba(255,255,255,.065);
  border-color:rgba(247,201,72,.32);
}

.rr-chart-panel .rr-row-song:first-of-type img,
.rr-two-col > .rr-panel:first-child .rr-row-song:first-of-type img{
  width:76px;
  height:76px;
  border-radius:20px;
}

.rr-chart-panel .rr-row-song:first-of-type strong,
.rr-two-col > .rr-panel:first-child .rr-row-song:first-of-type strong{
  font-size:18px;
}

.rr-chart-panel .rr-muted,
.rr-two-col > .rr-panel:first-child .rr-muted{
  padding:20px;
  border-radius:20px;
  border:1px dashed rgba(255,255,255,.16);
  background:rgba(255,255,255,.045);
  color:var(--rr-muted, #aaa3b8);
}

@media(max-width:680px){
  .rr-chart-panel .rr-row-song,
  .rr-two-col > .rr-panel:first-child .rr-row-song{
    grid-template-columns:34px 56px minmax(0,1fr) 40px;
    gap:10px;
    padding:11px;
    border-radius:18px;
  }

  .rr-chart-panel .rr-row-song::before,
  .rr-two-col > .rr-panel:first-child .rr-row-song::before{
    width:32px;
    height:32px;
    font-size:13px;
  }

  .rr-chart-panel .rr-row-song img,
  .rr-two-col > .rr-panel:first-child .rr-row-song img{
    width:56px;
    height:56px;
    border-radius:15px;
  }

  .rr-chart-panel .rr-row-song:first-of-type img,
  .rr-two-col > .rr-panel:first-child .rr-row-song:first-of-type img{
    width:60px;
    height:60px;
  }

  .rr-chart-panel .rr-row-song button,
  .rr-two-col > .rr-panel:first-child .rr-row-song button{
    width:38px;
    height:38px;
  }

  .rr-chart-panel .rr-row-song strong,
  .rr-two-col > .rr-panel:first-child .rr-row-song strong{
    font-size:14.5px;
  }

  .rr-chart-panel .rr-row-song span,
  .rr-two-col > .rr-panel:first-child .rr-row-song span{
    font-size:11.5px;
  }
}
