*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  min-height:100vh;
  font-family:Inter,Arial,sans-serif;
  color:#fff;
  background:
    radial-gradient(circle at 20% 0%,rgba(255,235,220,.75),transparent 36%),
    linear-gradient(135deg,#e8bba7 0%,#e9c6b8 52%,#f3d7c8 100%);
}

a{color:inherit;text-decoration:none}

.page-shell{
  min-height:100vh;
  padding:clamp(16px,4vw,64px);
  display:grid;
  place-items:center;
}

.web-card{
  width:min(1180px,100%);
  min-height:720px;
  border-radius:32px;
  overflow:hidden;
  position:relative;
  background:
    linear-gradient(180deg,rgba(7,12,20,.80),rgba(7,12,20,.58) 52%,rgba(255,255,255,.92) 52.3%,rgba(255,249,245,.96) 100%);
  box-shadow:0 40px 120px rgba(55,29,20,.25);
  border:1px solid rgba(255,255,255,.38);
}

.topbar{
  height:72px;
  padding:0 30px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  border-bottom:1px solid rgba(255,255,255,.13);
  position:relative;
  z-index:20;
}

.brand{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:250px;
}

.brand-orb{
  width:46px;
  height:46px;
  border-radius:50%;
  border:1px solid #13e6e8;
  display:grid;
  place-items:center;
  color:#13e6e8;
  font-size:26px;
  font-weight:900;
  box-shadow:0 0 22px rgba(19,230,232,.32);
}

.brand-text strong{
  display:block;
  color:#13e6e8;
  font-size:31px;
  letter-spacing:.06em;
  line-height:.85;
}

.brand-text small{
  display:block;
  margin-top:7px;
  color:#fff;
  font-size:11px;
  letter-spacing:.30em;
}

.nav{
  display:flex;
  gap:34px;
  color:rgba(255,255,255,.82);
  font-size:13px;
  letter-spacing:.02em;
}

.nav a:hover{color:#13e6e8}

.menu-pill{
  width:66px;
  height:36px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.35);
  background:rgba(255,255,255,.08);
  display:flex;
  align-items:center;
  justify-content:center;
  gap:4px;
  cursor:pointer;
}

.menu-pill span{
  width:4px;
  height:4px;
  border-radius:50%;
  background:#fff;
}

.hero{
  position:relative;
  min-height:500px;
  padding:46px 30px 40px;
}

.planet-wrap{
  position:absolute;
  left:0;
  right:0;
  top:-40px;
  height:470px;
  overflow:hidden;
  pointer-events:none;
}

.planet{
  position:absolute;
  width:min(520px,48vw);
  aspect-ratio:1/1;
  left:35%;
  top:46%;
  transform:translate(-50%,-50%);
  border-radius:50%;
  overflow:hidden;
  background:
    radial-gradient(circle at 34% 24%,#ffffff 0 1.2%,#7befff 2.5%,#1b8bd5 9%,#063f78 36%,#021b35 66%,#000916 100%);
  box-shadow:
    0 0 44px rgba(28,232,238,.45),
    0 0 110px rgba(28,147,255,.24),
    inset -70px -42px 110px rgba(0,0,0,.78),
    inset 28px 18px 58px rgba(255,255,255,.14);
  animation:planetFloat 7s ease-in-out infinite;
}

.planet:after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:50%;
  box-shadow:inset 0 0 24px rgba(255,255,255,.58),0 0 34px rgba(19,230,232,.55);
  pointer-events:none;
}

.land,.clouds{
  position:absolute;
  top:-8%;
  bottom:-8%;
  width:260%;
  left:-85%;
  background-repeat:repeat-x;
  background-size:50% 100%;
}

.land-a{
  opacity:.78;
  mix-blend-mode:screen;
  background-image:
    radial-gradient(ellipse 14% 9% at 10% 36%,rgba(112,211,140,.86) 0 58%,transparent 62%),
    radial-gradient(ellipse 18% 11% at 22% 48%,rgba(208,174,91,.83) 0 55%,transparent 60%),
    radial-gradient(ellipse 15% 9% at 38% 34%,rgba(102,202,145,.87) 0 55%,transparent 60%),
    radial-gradient(ellipse 18% 12% at 56% 50%,rgba(210,181,98,.84) 0 56%,transparent 61%),
    radial-gradient(ellipse 16% 9% at 75% 38%,rgba(113,212,150,.86) 0 57%,transparent 62%),
    radial-gradient(ellipse 20% 12% at 92% 55%,rgba(215,184,101,.82) 0 56%,transparent 61%);
  animation:earthRotate 34s linear infinite;
}

.land-b{
  opacity:.35;
  filter:blur(1px);
  mix-blend-mode:screen;
  background-image:
    radial-gradient(ellipse 12% 7% at 17% 59%,rgba(241,217,135,.7) 0 58%,transparent 63%),
    radial-gradient(ellipse 16% 8% at 48% 30%,rgba(139,219,164,.68) 0 58%,transparent 63%),
    radial-gradient(ellipse 17% 8% at 83% 61%,rgba(238,211,132,.7) 0 58%,transparent 63%);
  animation:earthRotate 44s linear infinite reverse;
}

.clouds{
  opacity:.34;
  filter:blur(7px);
  background-image:
    radial-gradient(ellipse 14% 4% at 9% 34%,rgba(255,255,255,.88) 0 58%,transparent 64%),
    radial-gradient(ellipse 18% 5% at 26% 49%,rgba(255,255,255,.62) 0 58%,transparent 64%),
    radial-gradient(ellipse 19% 5% at 45% 29%,rgba(255,255,255,.78) 0 58%,transparent 64%),
    radial-gradient(ellipse 15% 4% at 67% 52%,rgba(255,255,255,.55) 0 58%,transparent 64%),
    radial-gradient(ellipse 18% 5% at 89% 38%,rgba(255,255,255,.72) 0 58%,transparent 64%);
  animation:cloudRotate 22s linear infinite;
}

.clouds-b{opacity:.2;animation-duration:16s;animation-direction:reverse}

.planet-shadow{
  position:absolute;
  inset:0;
  border-radius:50%;
  background:linear-gradient(105deg,rgba(0,0,0,.05) 0%,transparent 32%,rgba(0,0,0,.28) 58%,rgba(0,0,0,.82) 100%);
}

.planet-glow{
  position:absolute;
  inset:-3%;
  border-radius:50%;
  background:radial-gradient(circle at 50% 50%,transparent 61%,rgba(19,230,232,.28) 67%,transparent 76%);
  animation:pulse 5.5s ease-in-out infinite;
}

.headline{
  position:relative;
  z-index:5;
  padding-top:34px;
}

.pretitle{
  margin:0 0 8px;
  text-transform:uppercase;
  letter-spacing:.22em;
  color:#13e6e8;
  font-size:11px;
  font-weight:900;
}

.headline h1{
  margin:0;
  font-size:clamp(48px,7vw,104px);
  letter-spacing:-.07em;
  line-height:.8;
  color:rgba(255,255,255,.54);
  text-transform:uppercase;
  white-space:nowrap;
}

.headline h2{
  margin:36px 0 0;
  max-width:790px;
  text-transform:uppercase;
  letter-spacing:.06em;
  line-height:1.05;
}

.headline h2 span{
  display:block;
  font-size:clamp(23px,3.1vw,44px);
  font-weight:300;
  color:rgba(255,255,255,.92);
}

.headline h2 strong{
  display:block;
  margin-top:10px;
  font-size:clamp(34px,4.6vw,70px);
  color:#13e6e8;
  text-shadow:0 0 24px rgba(19,230,232,.34);
}

.floating-moods{
  position:absolute;
  right:120px;
  top:86px;
  z-index:8;
  display:grid;
  gap:18px;
}

.bubble{
  width:64px;
  height:64px;
  border-radius:50%;
  display:grid;
  place-items:center;
  font-size:10px;
  font-weight:900;
  border:2px solid rgba(255,255,255,.62);
  background:rgba(255,255,255,.12);
  backdrop-filter:blur(8px);
  box-shadow:0 14px 30px rgba(0,0,0,.16);
}

.bubble.explore{
  width:96px;
  height:96px;
  margin-left:-18px;
}

.bubble.dance{color:#c66bff}.bubble.relax{color:#45df68}.bubble.explore{color:#ff9c2a}

.mood-search{
  position:absolute;
  z-index:12;
  left:50%;
  bottom:-38px;
  transform:translateX(-50%);
  width:min(900px,78%);
  min-height:82px;
  border-radius:22px;
  background:rgba(255,255,255,.95);
  display:grid;
  grid-template-columns:repeat(4,1fr) 66px;
  align-items:center;
  box-shadow:0 24px 55px rgba(45,22,12,.16);
  overflow:hidden;
}

.search-item{
  min-height:82px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:0 26px;
  color:#1a1d23;
  border-right:1px solid rgba(0,0,0,.06);
}

.search-item:hover{background:#f8f8f8}

.search-item small{
  color:#9b9b9b;
  font-size:12px;
}

.search-item strong{
  font-size:20px;
  margin-top:4px;
}

.go-btn{
  width:42px;
  height:42px;
  border:0;
  border-radius:50%;
  background:#000;
  color:#fff;
  font-size:24px;
  cursor:pointer;
  margin:auto;
}

.recommended{
  color:#161616;
  padding:68px 120px 40px;
}

.section-head{
  display:flex;
  justify-content:space-between;
  align-items:end;
  gap:16px;
}

.section-head h3{
  font-family:Georgia,serif;
  font-weight:500;
  margin:0;
  font-size:34px;
}

.section-head a{
  border:1px solid rgba(0,0,0,.18);
  border-radius:999px;
  padding:9px 18px;
  font-size:12px;
}

.cards{
  margin-top:22px;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}

.rec-card{
  min-height:150px;
  border-radius:16px;
  padding:18px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  overflow:hidden;
  position:relative;
  color:#fff;
  box-shadow:0 22px 50px rgba(0,0,0,.10);
}

.rec-card:before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.1),rgba(0,0,0,.55));
}

.rec-card span,.rec-card strong{position:relative;z-index:2}

.rec-card span{
  width:max-content;
  border-radius:999px;
  padding:7px 12px;
  background:rgba(255,255,255,.18);
  font-size:12px;
  font-weight:900;
}

.rec-card strong{font-size:20px;line-height:1.18}

.dance-card{background:radial-gradient(circle at 20% 0%,#cf5cff,#371348)}
.relax-card{background:radial-gradient(circle at 20% 0%,#56e37a,#12391f)}
.discover-card{background:radial-gradient(circle at 20% 0%,#42a0ff,#102b5a)}

.ecosystem-mini{
  margin:8px 120px 44px;
  padding:26px;
  border-radius:24px;
  background:linear-gradient(135deg,rgba(255,255,255,.96),rgba(245,248,252,.82));
  border:1px solid rgba(0,0,0,.08);
  color:#07111d;
  display:grid;
  gap:18px;
}

.ecosystem-mini p{
  margin:0 0 6px;
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:10px;
  font-weight:900;
  color:rgba(7,17,29,.48);
}

.ecosystem-mini h3{
  margin:0;
  font-family:Georgia,serif;
  font-size:38px;
  font-weight:500;
}

.eco-rail{
  display:flex;
  gap:10px;
  overflow-x:auto;
  padding-bottom:5px;
}

.eco-rail a{
  flex:0 0 auto;
  border-radius:999px;
  padding:10px 15px;
  background:#07111d;
  color:#fff;
  font-size:12px;
  font-weight:900;
}

footer{
  color:#6c6f76;
  display:flex;
  justify-content:space-between;
  gap:18px;
  padding:0 120px 34px;
  font-size:12px;
}

@keyframes earthRotate{from{transform:translateX(0)}to{transform:translateX(50%)}}
@keyframes cloudRotate{from{transform:translateX(0)}to{transform:translateX(50%)}}
@keyframes planetFloat{0%,100%{transform:translate(-50%,-50%) translateY(0)}50%{transform:translate(-50%,-50%) translateY(-16px)}}
@keyframes pulse{0%,100%{opacity:.75;transform:scale(1)}50%{opacity:1;transform:scale(1.012)}}

@media(max-width:820px){
  .page-shell{padding:0}
  .web-card{
    width:100%;
    min-height:100vh;
    border-radius:0;
    background:linear-gradient(180deg,rgba(7,12,20,.86),rgba(7,12,20,.60) 58%,rgba(255,255,255,.94) 58.3%,rgba(255,249,245,.98) 100%);
  }

  .topbar{height:86px;padding:0 22px}
  .nav{display:none}
  .brand{min-width:auto}
  .brand-orb{width:48px;height:48px}
  .brand-text strong{font-size:28px}
  .brand-text small{font-size:10px;letter-spacing:.26em}
  .hero{min-height:690px;padding:32px 22px 0}
  .planet-wrap{top:58px;height:480px}
  .planet{
    width:92vw;
    left:50%;
    top:50%;
  }

  .headline{padding-top:44px}
  .pretitle{font-size:10px}
  .headline h1{
    font-size:clamp(42px,14vw,66px);
    white-space:normal;
    line-height:.82;
    max-width:92vw;
  }

  .headline h2{
    margin-top:220px;
    max-width:92vw;
  }

  .headline h2 span{font-size:26px;line-height:1.12}
  .headline h2 strong{font-size:38px;line-height:1.05}

  .floating-moods{
    right:26px;
    top:128px;
    gap:14px;
  }
  .bubble{width:54px;height:54px;font-size:9px}
  .bubble.explore{width:80px;height:80px;margin-left:-12px}

  .mood-search{
    bottom:-48px;
    width:calc(100% - 30px);
    grid-template-columns:1fr 1fr;
    min-height:0;
    border-radius:20px;
  }

  .search-item{
    min-height:70px;
    padding:0 18px;
  }

  .search-item:nth-child(2){border-right:0}
  .search-item:nth-child(n+3){border-top:1px solid rgba(0,0,0,.06)}
  .search-item strong{font-size:17px}
  .go-btn{
    grid-column:1/-1;
    margin:10px auto 16px;
  }

  .recommended{
    padding:94px 18px 34px;
  }

  .section-head h3{font-size:30px}
  .section-head a{display:none}
  .cards{
    display:flex;
    overflow-x:auto;
    gap:14px;
  }
  .rec-card{min-width:245px}

  .ecosystem-mini{
    margin:0 18px 34px;
    padding:20px;
  }
  .ecosystem-mini h3{font-size:30px}

  footer{
    padding:0 18px 28px;
    flex-direction:column;
  }
}


.dev-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin:4px 0 16px;
  padding:8px 13px;
  border-radius:999px;
  border:1px solid rgba(19,230,232,.34);
  background:rgba(19,230,232,.10);
  color:#13e6e8;
  font-size:11px;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
  backdrop-filter:blur(10px);
  box-shadow:0 0 22px rgba(19,230,232,.12);
}
.dev-badge::before{
  content:"";
  width:7px;
  height:7px;
  border-radius:50%;
  background:#13e6e8;
  box-shadow:0 0 12px #13e6e8;
}

@media(max-width:820px){
  .dev-badge{
    font-size:9px;
    letter-spacing:.08em;
    padding:7px 10px;
    margin-bottom:14px;
  }
}
