:root{
  --bg:#061517;
  --panel:rgba(255,255,255,.78);
  --ink:#102226;
  --muted:#5b6d72;
  --brand:#00bfae;
  --brand2:#8b5cf6;
  --line:rgba(255,255,255,.42);
  --shadow:0 24px 70px rgba(4,21,25,.22);
  --radius:30px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--ink);
  min-height:100vh;
  overflow-x:hidden;
  background:
    radial-gradient(circle at 10% 5%,rgba(0,214,201,.42),transparent 28rem),
    radial-gradient(circle at 90% 12%,rgba(236,72,153,.34),transparent 30rem),
    linear-gradient(135deg,#e9fff5 0%,#edf7ff 44%,#fff3fd 100%);
}
body:before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(115deg,rgba(255,255,255,.55),transparent 32%,rgba(255,255,255,.32) 45%,transparent 64%),
    radial-gradient(circle at 50% -20%,rgba(255,255,255,.85),transparent 26rem);
  mix-blend-mode:screen;
  opacity:.8;
}
.background-orbs{position:fixed;inset:0;pointer-events:none;overflow:hidden;z-index:-1}
.background-orbs span{
  position:absolute;
  width:24rem;
  height:24rem;
  border-radius:999px;
  filter:blur(10px);
  opacity:.5;
  background:linear-gradient(135deg,#13e3ba,#7c3aed,#f044ad);
}
.background-orbs span:nth-child(1){left:-8rem;top:9rem}
.background-orbs span:nth-child(2){right:-8rem;top:5rem;transform:rotate(30deg)}
.background-orbs span:nth-child(3){left:38%;bottom:-14rem;background:linear-gradient(135deg,#fbbf24,#34d399,#38bdf8)}
.shell{width:min(1220px,calc(100% - 32px));margin:0 auto}
.topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:24px 0;
  position:relative;
  z-index:2;
}
.brand{
  display:flex;
  align-items:center;
  gap:12px;
  color:inherit;
  text-decoration:none;
  padding:10px 14px;
  border-radius:22px;
  background:rgba(255,255,255,.5);
  border:1px solid rgba(255,255,255,.42);
  box-shadow:0 12px 36px rgba(12,35,37,.08);
  backdrop-filter:blur(18px);
}
.brand img{
  width:54px;
  height:54px;
  object-fit:contain;
  border-radius:16px;
  background:#fff;
  box-shadow:0 10px 24px rgba(15,65,63,.16);
}
.brand strong{display:block;font-size:1.05rem}
.brand span{display:block;color:var(--muted);font-size:.88rem}
.secure-badge{
  border:1px solid rgba(255,255,255,.55);
  background:rgba(255,255,255,.62);
  backdrop-filter:blur(18px);
  padding:12px 16px;
  border-radius:999px;
  color:#063c37;
  font-weight:900;
  font-size:.9rem;
  box-shadow:0 12px 36px rgba(11,40,44,.08);
}
.hero{padding:28px 0 34px;position:relative;z-index:1}
.hero-card{
  position:relative;
  overflow:hidden;
  border-radius:36px;
  padding:52px;
  min-height:420px;
  display:grid;
  grid-template-columns:minmax(0,1.2fr) minmax(300px,.8fr);
  gap:32px;
  align-items:center;
  background:
    linear-gradient(135deg,rgba(12,190,170,.95) 0%,rgba(35,169,221,.92) 44%,rgba(124,58,237,.9) 72%,rgba(236,72,153,.86) 100%);
  box-shadow:var(--shadow);
  color:#fff;
}
.hero-card:before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(118deg,rgba(255,255,255,.55),transparent 28%,rgba(255,255,255,.2) 42%,transparent 60%),
    radial-gradient(circle at 18% 0%,rgba(255,255,255,.38),transparent 22rem);
  pointer-events:none;
}
.hero-card:after{
  content:"";
  position:absolute;
  right:-8rem;
  bottom:-12rem;
  width:36rem;
  height:36rem;
  border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.35),rgba(255,255,255,.08) 42%,transparent 68%);
  pointer-events:none;
}
.hero-copy{position:relative;z-index:1}
.kicker,.section-kicker{
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:rgba(255,255,255,.18);
  color:#fff;
  border:1px solid rgba(255,255,255,.26);
  padding:9px 13px;
  border-radius:999px;
  font-weight:900;
  font-size:.78rem;
  text-transform:uppercase;
  letter-spacing:.08em;
  backdrop-filter:blur(14px);
}
.hero h1{
  font-size:clamp(2.6rem,7vw,6rem);
  line-height:.9;
  margin:28px 0 20px;
  max-width:860px;
  letter-spacing:-.06em;
  text-shadow:0 10px 34px rgba(4,15,18,.18);
}
.hero p{
  font-size:clamp(1rem,2vw,1.25rem);
  line-height:1.7;
  color:rgba(255,255,255,.9);
  max-width:820px;
}
.hero code{
  background:rgba(255,255,255,.18);
  border:1px solid rgba(255,255,255,.2);
  padding:.1rem .35rem;
  border-radius:.5rem;
  color:#fff;
}
.actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:28px}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  text-decoration:none;
  border-radius:18px;
  padding:15px 20px;
  font-weight:900;
  border:1px solid rgba(255,255,255,.35);
  background:rgba(255,255,255,.88);
  color:#102226;
  box-shadow:0 14px 30px rgba(3,22,26,.12);
}
.btn.primary{
  background:#fff;
  color:#0b6d64;
}
.btn.ghost{
  background:rgba(255,255,255,.14);
  color:#fff;
  backdrop-filter:blur(14px);
}
.hero-visual{
  position:relative;
  z-index:1;
  min-height:340px;
  display:grid;
  place-items:center;
}
.mirror-disk,.mini-disk{
  display:grid;
  place-items:center;
  border-radius:50%;
  background:radial-gradient(circle at 35% 25%,rgba(255,255,255,.92),rgba(255,255,255,.16) 42%,rgba(255,255,255,.05) 70%);
  border:1px solid rgba(255,255,255,.32);
  box-shadow:0 30px 80px rgba(5,20,25,.22), inset 0 0 40px rgba(255,255,255,.2);
  backdrop-filter:blur(14px);
}
.mirror-disk{
  width:min(330px,80vw);
  height:min(330px,80vw);
}
.mirror-disk img{width:82%;height:82%;object-fit:contain;filter:drop-shadow(0 18px 22px rgba(0,0,0,.16))}
.mini-disk{position:absolute;width:108px;height:108px}
.mini-disk img{width:86%;height:86%;object-fit:contain}
.disk-one{left:0;top:18px}
.disk-two{right:8px;bottom:22px}
.apps-section{position:relative;z-index:1}
.section-head{
  display:flex;
  align-items:end;
  justify-content:space-between;
  gap:16px;
  margin:30px 0 22px;
}
.section-kicker{
  color:#08746b;
  background:rgba(255,255,255,.68);
  border-color:rgba(255,255,255,.5);
}
.section-head h2{
  font-size:clamp(1.8rem,4vw,3.3rem);
  letter-spacing:-.04em;
  margin:12px 0 0;
}
.section-head p{margin:10px 0 0;color:var(--muted);max-width:760px;line-height:1.6}
.grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
  margin-bottom:48px;
}
.app-card{
  position:relative;
  overflow:hidden;
  background:
    linear-gradient(145deg,rgba(255,255,255,.76),rgba(255,255,255,.42)),
    linear-gradient(135deg,color-mix(in srgb,var(--accent) 24%,transparent),color-mix(in srgb,var(--accent2) 18%,transparent));
  border:1px solid rgba(255,255,255,.58);
  border-radius:30px;
  box-shadow:0 20px 48px rgba(14,42,46,.14), inset 0 1px 0 rgba(255,255,255,.75);
  padding:22px;
  text-decoration:none;
  color:inherit;
  display:flex;
  flex-direction:column;
  gap:16px;
  min-height:360px;
  transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease;
  backdrop-filter:blur(20px);
}
.app-card:before{
  content:"";
  position:absolute;
  inset:-40% -20% auto auto;
  width:75%;
  height:70%;
  transform:rotate(18deg);
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.58),transparent);
  opacity:.65;
  pointer-events:none;
}
.app-card:after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  height:7px;
  background:linear-gradient(90deg,var(--accent),var(--accent2));
}
.app-card:hover,.app-card:focus{
  transform:translateY(-8px) scale(1.01);
  box-shadow:0 30px 70px rgba(9,36,43,.22), inset 0 1px 0 rgba(255,255,255,.9);
  border-color:rgba(255,255,255,.82);
  outline:none;
}
.card-gloss{
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 25% 0%,rgba(255,255,255,.52),transparent 22rem);
  pointer-events:none;
}
.card-top{
  position:relative;
  z-index:1;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}
.icon-orb{
  width:116px;
  height:116px;
  border-radius:28px;
  display:grid;
  place-items:center;
  background:
    radial-gradient(circle at 38% 24%,rgba(255,255,255,.95),rgba(255,255,255,.24) 48%,rgba(255,255,255,.08) 74%),
    linear-gradient(135deg,color-mix(in srgb,var(--accent) 34%,transparent),color-mix(in srgb,var(--accent2) 28%,transparent));
  border:1px solid rgba(255,255,255,.56);
  box-shadow:0 18px 38px rgba(4,24,30,.14), inset 0 0 28px rgba(255,255,255,.22);
}
.icon-orb img{
  width:105px;
  height:105px;
  object-fit:contain;
  filter:drop-shadow(0 10px 14px rgba(0,0,0,.14));
}
.meta{display:flex;align-items:flex-end;flex-direction:column;gap:8px}
.version,.tag{
  font-size:.78rem;
  font-weight:950;
  color:#0a3a38;
  background:rgba(255,255,255,.68);
  border:1px solid rgba(255,255,255,.58);
  border-radius:999px;
  padding:7px 11px;
  backdrop-filter:blur(10px);
}
.tag{color:color-mix(in srgb,var(--accent2) 70%,#142226);font-weight:900}
.app-card h3{
  position:relative;
  z-index:1;
  font-size:1.65rem;
  line-height:1.05;
  letter-spacing:-.04em;
  margin:2px 0 0;
}
.cat{
  position:relative;
  z-index:1;
  color:color-mix(in srgb,var(--accent) 70%,#09332f);
  font-weight:950;
  font-size:.95rem;
  margin-top:-8px;
}
.desc{
  position:relative;
  z-index:1;
  color:#52686d;
  line-height:1.58;
  margin:0;
  flex:1;
}
.open{
  position:relative;
  z-index:1;
  display:inline-flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
  font-weight:950;
  color:#073f3b;
  background:rgba(255,255,255,.66);
  border:1px solid rgba(255,255,255,.5);
  border-radius:18px;
  padding:12px 14px;
}
.open b{
  display:grid;
  place-items:center;
  width:30px;
  height:30px;
  border-radius:999px;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  color:#fff;
}
.footer{
  padding:26px 0 34px;
  color:#52676a;
  display:flex;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
  border-top:1px solid rgba(13,73,72,.12);
}
@media (max-width:1020px){
  .hero-card{grid-template-columns:1fr;padding:38px}
  .hero-visual{min-height:260px}
  .mirror-disk{width:250px;height:250px}
  .grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:680px){
  .shell{width:min(100% - 24px,1220px)}
  .topbar{align-items:flex-start}
  .secure-badge{display:none}
  .brand{width:100%}
  .hero{padding-top:10px}
  .hero-card{padding:26px;border-radius:28px}
  .hero h1{font-size:clamp(2.3rem,16vw,4rem)}
  .hero-visual{display:none}
  .actions .btn{width:100%}
  .grid{grid-template-columns:1fr}
  .app-card{min-height:0}
}
@supports not (color:color-mix(in srgb,#000,#fff)){
  .app-card{background:rgba(255,255,255,.78)}
  .cat{color:#09776d}
  .tag{color:#12645d}
}