@import url("https://fonts.googleapis.com/css2?family=Poppins:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap");

html,
body {
  overscroll-behavior-y: contain;
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  font-family: "Poppins", sans-serif;
  border-radius: 11px;
}
h1 {
  font-size: clamp(1rem, 5vw, 1.8rem);
}
h2 {
  font-size: clamp(1rem, 3vw, 1.5rem);
}
h3 {
  font-size: clamp(1rem, 3vw, 1.2rem);
}
h4,
h5,
h6,
p,
button,
a,
span {
  font-size: clamp(0.7rem, 3vw, 1rem);
}

:root {
  --theme-color: #175676;
  --theme-color-hover: #175676cc;
  --bg-clr-for-dark: rgb(20, 20, 20);
  --clr-for-dark: rgb(185, 185, 185);
  --bg-clr-for-light: rgb(238, 238, 238);
  --clr-for-light: rgb(78, 78, 78);
  --all-radius: 50px;
  --all-padding: 10px 24px 10px 24px;
}
@media (prefers-color-scheme: dark) {
  body {
    background-color: black;
    color: rgb(185, 185, 185);
  }
  .header-con {
    background-color: black;
  }
  .s-i,
  .search-box {
    background-color: var(--bg-clr-for-dark);
    color: var(--clr-for-dark);
  }
  .s-b,
  .h-b {
    background-color: var(--bg-clr-for-dark);
  }
  .progress .bar {
    background-color: var(--theme-color);
  }
  .progress {
    background-color: var(--clr-for-light);
  }
  .loader,
  .loader-2 {
    border: 4px solid var(--theme-color);
    border-top: 4px solid rgba(0, 0, 0, 0);
  }
  .p_w_t {
    color: var(--clr-for-dark);
  }
  .artist {
    color: var(--clr-for-light);
  }
  .loader-con {
    color: var(--clr-for-dark);
  }
  .m-con-div {
    color: var(--clr-for-dark);
  }
  .current-play,
  .player-con-smule {
    background-color: black;
  }
  .time-info {
    color: var(--clr-for-light);
  }
  .app-logo-p {
    stroke: var(--clr-for-dark);
  }
  .app-logo-c,
  .app-logo-t {
    fill: var(--clr-for-dark);
  }
  .m-list-con-div {
    background-color: var(--bg-clr-for-dark);
  }
  .m-list {
    background-color: var(--bg-clr-for-dark);
  }
  .progress .dot {
    background-color: var(--bg-clr-for-light);
  }
  .s-b-svg,
  .smule-s-svg {
    color: var(--bg-clr-for-light);
  }
  .search-user-con {
    background-color: var(--bg-clr-for-dark);
  }
  .search-user-ip,
  .verify-ip {
    color: var(--clr-for-dark);
  }
  .smule-song-con-div h6 {
    color: var(--clr-for-light);
  }
  .player-h1-div h6 {
    color: var(--clr-for-light);
  }
  .smule-time {
    color: var(--clr-for-light);
  }
  .smule-progress-con {
    background-color: var(--bg-clr-for-dark);
  }
  .joinBtn-smule {
    color: var(--clr-for-light);
  }
}
@media (prefers-color-scheme: light) {
  body {
    background-color: white;
    color: rgb(78, 78, 78);
  }
  .s-i,
  .search-box {
    background-color: var(--bg-clr-for-light);
    color: var(--clr-for-light);
  }
  .s-b,
  .h-b {
    background-color: var(--bg-clr-for-light);
  }
  .header-con {
    background-color: white;
  }
  .progress .bar {
    background-color: var(--theme-color);
  }
  .progress {
    background-color: var(--clr-for-dark);
  }
  .loader,
  .loader-2 {
    border: 4px solid var(--theme-color);
    border-top: 4px solid rgba(255, 255, 255, 0);
  }
  .p_w_t {
    color: var(--clr-for-light);
  }
  .artist {
    color: var(--clr-for-dark);
  }
  .loader-con {
    color: var(--clr-for-light);
  }
  .m-con-div {
    color: var(--clr-for-light);
  }
  .current-play,
  .player-con-smule {
    background-color: white;
  }
  .time-info {
    color: var(--clr-for-dark);
  }
  .app-logo-p {
    stroke: var(--clr-for-dark);
  }
  .app-logo-c,
  .app-logo-t {
    fill: var(--clr-for-dark);
  }
  .m-list-con-div {
    background-color: white;
  }
  .m-list {
    background-color: white;
  }
  .progress .dot {
    background-color: var(--bg-clr-for-dark);
  }
  .s-b-svg,
  .smule-s-svg {
    color: var(--bg-clr-for-dark);
  }
  .search-user-con {
    background-color: var(--bg-clr-for-light);
  }
  .search-user-ip,
  .verify-ip {
    color: var(--clr-for-light);
  }
  .smule-song-con-div h6 {
    color: var(--clr-for-dark);
  }
  .player-h1-div h6 {
    color: var(--clr-for-dark);
  }
  .smule-time {
    color: var(--clr-for-dark);
  }
  .smule-progress-con {
    background-color: var(--bg-clr-for-light);
  }
  .joinBtn-smule {
    color: var(--clr-for-dark);
  }
}
.music-logo {
  width: 40px;
  height: 40px;
  color: var(--theme-color);
}
.header {
  width: 95%;
  margin: 0 auto;
  padding: 15px 10px 15px 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 5px;
}
.header h1 {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--theme-color);
  cursor: pointer;
}
.header-con {
  position: fixed;
  width: 100%;
  top: 0;
  z-index: 1;
}
.s-i {
  outline: none;
  border: none;
  padding: var(--all-padding);
}
.search {
  display: flex;
  align-items: center;
  gap: 5px;
  flex-wrap: wrap;
}
.search-box {
  display: flex;
  align-items: center;
  gap: 5px;
  flex-direction: row-reverse;
  padding-right: 10px;
  position: fixed;
  padding-left: 10px;
  top: 100px;
  left: 50%;
  transform: translateX(-50%);
  border-radius: var(--all-radius);
}
.h-b {
  outline: none;
  border: none;
  padding: 8px;
  border-radius: var(--all-radius);
  cursor: pointer;
  display: flex;
  flex-direction: column;
  color: var(--clr-for-dark);
  background-color: var(--theme-color);
}

.h-b:hover {
  background-color: var(--theme-color-hover);
}

.smule-s-svg,
.h-b-svg,
.join-s-svg {
  width: 20px;
  height: 20px;
  cursor: pointer;
}
.s-b-svg,
.smule-s-svg {
  width: 30px;
  height: 30px;
  cursor: pointer;
  background-color: var(--theme-color);
  padding: 5px;
  border-radius: var(--all-radius);
  color: var(--clr-for-dark);
}
.join-s-svg circle,
.join-s-svg path {
  fill: var(--theme-color);
}
.s-b-svg:hover,
.smule-s-svg:hover {
  transform: scale(1.1);
  background-color: var(--theme-color-hover);
}
.m-con-c {
  width: 95%;
  margin: 130px auto 10px auto;
  padding: 5px;
  display: flex;
  flex-direction: row-reverse;
  gap: 20px;
  flex-wrap: wrap-reverse;
}
.m-con-div-con {
  margin-top: 10px;
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  padding: var(--all-padding);
}
.m-con-div2 {
  display: flex;
  flex-direction: column;
  border-radius: 0px;
  flex-grow: 1;
  gap: 10px;
}
.m-con-div {
  display: flex;
  gap: 10px;
  align-items: center;
}
.m-con-div-head2 {
  max-width: 30%;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}
.m-img {
  width: 100%;
  height: 80%;
  object-fit: cover;
  object-position: center;
}
.m-con-div h5 {
  color: var(--theme-color);
}

.player {
  display: flex;
  flex-direction: column-reverse;
}

.top-bar {
  display: flex;
  flex-direction: column;
}
.song-info {
  font-weight: bold;
}

.progress {
  position: relative;
  height: 2px;
  border-radius: 5px;
  cursor: pointer;
  margin: 0px 0px 0px 0px;
  flex-grow: 1;
}

.progress-con {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.progress .bar {
  width: 0%;
  height: 100%;
  position: relative;
  border-radius: 5px;
}

.progress .dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  position: absolute;
  right: -12px;
  top: 50%;
  transform: translateY(-50%);
}

.controls {
  display: flex;
  align-items: center;
  padding: 8px;
  border-radius: var(--all-radius);
  gap: 10px;
  justify-content: center;
  align-self: flex-start;
}

.controls button {
  border: none;
  cursor: pointer;
  background: var(--theme-color);
}

.repeat-btn,
.download-btn {
  color: var(--theme-color);
  padding: 5px;
  display: flex;
}
.download-btn-zip {
  color: var(--clr-for-dark);
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 5px;
  background-color: var(--theme-color);
  width: fit-content;
  border-radius: var(--all-radius);
  padding: 0px 10px 0px 10px;
}
.download-btn-zip:hover {
  background-color: var(--theme-color-hover);
}
.play-btn {
  border-radius: var(--all-radius);
  padding: var(--all-padding);
  display: flex;
  background: var(--theme-color);
}
.download-btn {
  background-color: var(--theme-color);
}
.play-btn:hover,
.repeat-btn:hover,
.download-btn:hover {
  background-color: var(--theme-color-hover);
}
.repeat-svg,
.download-svg,
.download-svg-zip {
  width: 15px;
  height: 15px;
}
.play-svg,
.play-smule-svg {
  width: 15px;
  height: 15px;
}
.play-svg:hover {
  transform: scale(1.5);
  transition: all 0.2s ease-in-out;
}
.p_w_t {
  text-align: center;
}
.loader,
.loader-2 {
  border-radius: 50%;
  width: 25px;
  height: 25px;
  animation: spinLoader 0.8s linear infinite;
}
.loader-2 {
  display: none;
}

@keyframes spinLoader {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
.loader-con {
  display: flex;
  align-items: center;
  justify-content: center;
  position: fixed;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  gap: 5px;
  padding: 10px;
  z-index: 1;
  background-color: transparent;
  width: 100%;
}
.blocker {
  height: 100%;
  background-color: transparent;
  width: 100%;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  position: fixed;
  z-index: 1;
}
.blocker-joins {
  height: 50%;
  background-color: transparent;
  width: 100%;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  position: fixed;
  z-index: 1;
}
.repeat-svg,
.download-svg,
.play-svg,
.repeat-svg-text,
polygon {
  color: var(--clr-for-dark);
}
.m-con-div-head1 h2 {
  color: var(--theme-color);
}
.current-play {
  display: flex;
  flex-direction: column;
  width: 100%;
  margin: 0 auto;
  position: sticky;
  left: 0%;
  bottom: 0%;
  top: 0%;
  right: 0%;
  transform: translate(0%, 0%);
  z-index: 1;
  border-radius: 0px;
}
.current-play h4 {
  font-size: 20px;
}

.song-title.active {
  color: var(--theme-color);
}

.time-info {
  font-size: 12px;
  margin-top: 5px;
}

.disabled-btn {
  opacity: 0.5;
  cursor: not-allowed;
}
.app-logo {
  width: 100%;
  max-width: 200px;
  height: auto;
}
.app-logo-t {
  font-size: 35px;
}

.m-list {
  width: 95%;
  margin: 0px auto 0px auto;
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 1;
}

.m-list-con-div {
  max-height: 300px;
  overflow-y: scroll;
  border-radius: 0px;
  margin-top: 0px;
  margin-bottom: 10px;
  padding: var(--all-padding);
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  justify-content: space-around;
  gap: 10px;
}
.m-list-btn {
  width: fit-content;
  outline: none;
  border: none;
  background-color: transparent;
  color: var(--theme-color);
  text-align: left;
}
.m-list-div-h {
  display: flex;
  flex-direction: column;
}

.m-list-div-h h6,
.m-list-div-h h5 {
  width: 100px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.h-t-b-svg {
  width: 20px;
  height: 20px;
  stroke: var(--clr-for-dark);
}
.h-t-btn {
  cursor: pointer;
  outline: none;
  border: none;
  background-color: var(--theme-color);
  border-radius: 50px;
  padding: 5px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.h-t-btn:hover {
  background-color: var(--theme-color-hover);
}
.h-t-div {
  padding: var(--all-padding);
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
}
.m-list-img {
  width: 100px;
  height: 80px;
  object-fit: cover;
  object-position: center;
  cursor: pointer;
}
.m-list-img:hover {
  transform: scale(1.05);
  transition: all 0.3s ease-in-out;
}
.m-list-con-div-2 {
  padding: var(--all-padding);
  gap: 10px;
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  justify-content: space-around;
}
.m-list-2 {
  width: 95%;
  margin: 0px auto 10px auto;
  display: flex;
  flex-wrap: wrap;
}
.m-list-btn-next {
  outline: none;
  border: none;
  padding: var(--all-padding);
  border-radius: var(--all-radius);
  background-color: var(--theme-color);
  color: var(--clr-for-dark);
  cursor: pointer;
}
.m-list-btn-next:hover {
  background-color: var(--theme-color-hover);
}
.btn_next-div {
  align-self: center;
  display: flex;
  gap: 5px;
  align-items: center;
  width: 100%;
  justify-content: center;
}
.load-app-btn {
  outline: none;
  border: none;
  padding: var(--all-padding);
  border-radius: var(--all-radius);
  margin-left: 10px;
  background-color: var(--theme-color);
  color: var(--bg-clr-for-light);
  cursor: pointer;
  box-shadow: 0px 0px 5px var(--clr-for-light);
}
.smule-con {
  transform: translate(-50%, 50%);
  position: fixed;
  left: 50%;
  top: 55%;
}
.smule-con-h {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}
.smule-btn {
  outline: none;
  border: none;
  background-color: transparent;
  cursor: pointer;
  color: var(--theme-color);
  font-weight: bold;
}
.smule-btn:hover {
  text-decoration: underline;
}
.smule-list-con {
  display: flex;
  width: 95%;
  margin: 0 auto;
  flex-direction: column;
}
.search-user-con {
  display: flex;
  align-self: center;
  border-radius: var(--all-radius);
  flex-direction: row-reverse;
  position: fixed;
  top: 100px;
  gap: 5px;
  align-items: center;
  padding-right: 10px;
}
.search-user-ip {
  outline: none;
  border: none;
  border-radius: var(--all-radius);
  padding: var(--all-padding);
  background: transparent;
}
.smule-list-con-div {
  margin-top: 30px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.smule-list-user-div {
  display: flex;
  flex-direction: column-reverse;
  margin-top: 0px;
  margin-bottom: 20px;
}
.smule-song-con-div {
  flex-grow: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 5px;
  padding: var(--all-padding);
}
.like-h6-1:hover {
  color: var(--theme-color-hover);
  cursor: pointer;
}
.smule-song-con-div-2 {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
}
.smule-song-con-div-2 h5 {
  flex-grow: 1;
  word-break: break-all;
}
.color-h5.smule-active {
  color: var(--theme-color);
}
.smule-song-con-div h6:nth-of-type(1) {
  width: fit-content;
}
.like-h6-2 {
  display: flex;
  align-items: center;
  gap: 5px;
}
.player-con-smule {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  margin: 0 auto;
  position: sticky;
  left: 0%;
  bottom: 0%;
  top: 0%;
  right: 0%;
  transform: translate(0%, 0%);
  z-index: 1;
  border-radius: 0px;
  gap: 5px;
}
.play-btn-smule {
  outline: none;
  border: none;
  background-color: var(--theme-color);
  padding: var(--all-padding);
  border-radius: var(--all-radius);
  cursor: pointer;
  color: var(--theme-color);
  display: flex;
  align-items: center;
  justify-content: center;
}
.verify-div-con {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: var(--all-padding);
}
.verify-ip {
  outline: none;
  border: 1px solid var(--theme-color);
  border-radius: var(--all-radius);
  background: transparent;
  padding: var(--all-padding);
}
.all-user-list-div {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: var(--all-padding);
  width: fit-content;
  cursor: pointer;
  flex-direction: column;
  align-items: flex-start;
}
.all-user-list-div:hover {
  color: var(--theme-color);
}
.all-user-list-div h5 {
  width: 80px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.all-user-list-img {
  width: 80px;
  height: 80px;
}
.all-user-list-img:hover {
  transform: scale(1.05);
  transition: all 0.3s ease-in-out;
}
.all-smule-user-con {
  padding: var(--all-padding);
  display: flex;
  flex-direction: column-reverse;
  flex-wrap: wrap;
}
.restrict-h {
  color: var(--theme-color);
}
.all-user-list-con {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  justify-content: space-around;
}
.all-user-list-con h3 {
  width: 100%;
}
.smule-user-img {
  width: 25%;
  height: 25%;
}
.smule-user-div {
  display: flex;
  align-items: center;
  gap: 15px;
  padding: var(--all-padding);
  flex-wrap: wrap;
}
.smule-user-div-2 {
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.smule-list-user-name-3 {
  display: flex;
  align-items: center;
  gap: 5px;
}
.player-h3-smule {
  width: fit-content;
  color: var(--theme-color);
}
.player-h2-smule:hover {
  color: var(--theme-color-hover);
}
.player-h2-smule {
  cursor: pointer;
  width: fit-content;
  color: var(--theme-color);
}
.player-h1-smule {
  width: fit-content;
}
.smule-time {
  display: flex;
  align-items: center;
  width: fit-content;
}
.smule-time span {
  font-size: 12px;
}
.smule-progress {
  height: 3px;
  background-color: var(--theme-color);
}
.smule-progress-con {
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
  cursor: pointer;
}
.joinBtn-smule {
  outline: none;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  background-color: transparent;
  gap: 5px;
  font-weight: bold;
}
.joinBtn-smule:hover {
  text-decoration: underline;
  color: var(--theme-color-hover);
}
.join-div {
  display: flex;
  align-items: center;
  gap: 5px;
}
.smule-list-join-con {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 1;
  width: 95%;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  backdrop-filter: blur(50px);
}
.join-list-div-con {
  max-height: 300px;
  overflow-y: scroll;
  padding: var(--all-padding);
  display: flex;
  flex-direction: column-reverse;
  gap: 30px;
}
.join-close-btn {
  outline: none;
  border: none;
  cursor: pointer;
  background-color: var(--theme-color);
  color: var(--clr-for-dark);
  padding: 3px 10px 3px 10px;
  border-radius: var(--all-radius);
}
.join-close-btn:hover {
  background-color: var(--theme-color-hover);
}
.join-div-head {
  display: flex;
  align-items: center;
  gap: 10px;
  justify-content: space-between;
}
.join-div-head h5{
  color: var(--theme-color);
}
.join-div-new {
  display: flex;
  flex-direction: column;
  gap: 5px;
  align-items: flex-start;
}
.join-div-header {
  display: flex;
  align-items: center;
  gap: 5px;
  justify-content: space-between;
  padding: var(--all-padding);
}
.join-div-con {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  gap: 10px;
}
.join-div-new-con {
  display: flex;
  align-items: center;
  gap: 5px;
  justify-content: space-between;
}
.loader-con-smule{
  display: none;
  align-items: center;
  justify-content: center;
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  gap: 5px;
  z-index: 2;
}
