/* ============ JellyPi — landing page (home.css) ============ */

/* mobile menu */
.mobile-menu{
  display:none;flex-direction:column;gap:4px;
  max-width:var(--maxw);margin:10px auto 0;padding:14px;
  background:rgba(31,10,44,.95);backdrop-filter:blur(16px);
  border:1.5px solid var(--plum-line);border-radius:24px;
}
.mobile-menu.open{display:flex;}
.mobile-menu a{padding:.7em 1em;border-radius:14px;font-weight:700;color:var(--ink-soft);}
.mobile-menu a:hover{background:rgba(253,248,241,.07);}
.mobile-menu .mm-cta{color:var(--magenta);}

/* ---------- HERO ---------- */
.hero{padding:54px 26px 80px;}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:30px;align-items:center;}
.hero-copy h1{font-size:clamp(2.9rem,6.6vw,5rem);font-weight:700;margin:22px 0 0;letter-spacing:-.02em;}
.hero-sub{color:var(--ink-soft);font-size:1.22rem;max-width:30ch;margin-top:22px;}
.hero-sub strong{color:var(--cream);}
.hero-sub em{color:var(--magenta-soft);font-style:normal;font-weight:700;}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:32px;}
.hero-platforms{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-top:30px;color:var(--ink-faint);font-size:.95rem;}
.hero-platforms span{font-weight:700;}
.hero-platforms em{font-style:normal;color:var(--ink-dim);font-weight:700;}
.hero-platforms i{color:var(--plum-line);}

.hero-art{position:relative;display:flex;align-items:center;justify-content:center;min-height:420px;}
.hero-art .pie{
  width:min(108%,560px);position:relative;z-index:2;
  filter:drop-shadow(0 30px 50px rgba(0,0,0,.5));
  animation:bob 5.5s ease-in-out infinite;
  transform-origin:50% 70%;
}
.hero-art .pie:hover{animation:wobble .9s ease-in-out;}
@keyframes bob{0%,100%{transform:translateY(0) rotate(-1.2deg);}50%{transform:translateY(-16px) rotate(1.2deg);}}
@keyframes wobble{0%,100%{transform:rotate(0) scale(1);}20%{transform:rotate(-5deg) scale(1.04);}40%{transform:rotate(4deg) scale(1.02);}60%{transform:rotate(-3deg) scale(1.03);}80%{transform:rotate(2deg) scale(1.01);}}
.pie-glow{position:absolute;width:62%;height:62%;border-radius:50%;background:radial-gradient(circle,var(--berry),transparent 65%);filter:blur(60px);opacity:.55;z-index:1;animation:pulse 5.5s ease-in-out infinite;}
@keyframes pulse{0%,100%{opacity:.4;transform:scale(.95);}50%{opacity:.65;transform:scale(1.08);}}
.sprinkle{width:14px;height:14px;}
.sprinkle.s1{background:var(--gold);top:8%;left:14%;animation:bob 4s ease-in-out infinite;}
.sprinkle.s2{background:var(--magenta);top:24%;right:10%;width:11px;height:11px;animation:bob 6s ease-in-out infinite reverse;}
.sprinkle.s3{background:var(--cream);bottom:18%;left:8%;width:9px;height:9px;animation:bob 5s ease-in-out infinite;}
.sprinkle.s4{background:var(--gold);bottom:10%;right:16%;width:12px;height:12px;animation:bob 4.6s ease-in-out infinite reverse;}

/* ---------- STORY ---------- */
.story-band{background:var(--plum-880);}
.story-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:46px;align-items:start;}
.story-lead h2{font-size:clamp(1.9rem,4vw,2.8rem);margin-top:18px;}
.story-body{display:flex;flex-direction:column;gap:18px;}
.story-body p{font-size:1.15rem;color:var(--ink-dim);}
.story-body strong{color:var(--cream);font-weight:700;}
.story-body em{color:var(--magenta-soft);font-style:normal;font-weight:700;}
.story-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:54px;}
.stat{background:var(--plum-850);border:1.5px solid var(--plum-700);border-radius:var(--radius);padding:24px;text-align:center;}
.stat .num{display:block;font-family:var(--font-display);font-weight:700;font-size:2rem;color:var(--magenta);}
.stat .lbl{display:block;margin-top:6px;color:var(--ink-dim);font-weight:600;font-size:.98rem;}

/* ---------- FEATURES ---------- */
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.feat{transition:transform .2s, border-color .2s, background .2s;}
.feat:hover{transform:translateY(-5px);border-color:var(--plum-line);background:var(--plum-820);}
.feat-ico{
  width:58px;height:58px;border-radius:17px;display:grid;place-items:center;font-size:1.7rem;
  background:color-mix(in srgb, var(--c) 18%, var(--plum-820));
  border:1.5px solid color-mix(in srgb, var(--c) 45%, transparent);
  box-shadow:0 10px 26px -12px var(--c);margin-bottom:18px;
}
.feat h3{font-size:1.34rem;margin-bottom:9px;}
.feat p{color:var(--ink-dim);}

/* ---------- REMOTE ---------- */
.remote-band{background:var(--plum-880);overflow:hidden;}
.remote-grid{display:grid;grid-template-columns:1fr .85fr;gap:50px;align-items:center;}
.remote-copy h2{font-size:clamp(2rem,4.4vw,3rem);margin-top:18px;}
.remote-copy>p{color:var(--ink-dim);font-size:1.16rem;margin-top:18px;}
.remote-copy strong{color:var(--cream);}
.remote-list{list-style:none;padding:0;margin:28px 0 0;display:flex;flex-direction:column;gap:16px;}
.remote-list li{display:flex;gap:14px;align-items:flex-start;}
.remote-list li span{font-size:1.4rem;flex:none;line-height:1.2;}
.remote-list strong{color:var(--cream);font-family:var(--font-display);font-weight:600;}
.remote-list div{color:var(--ink-dim);}
.remote-kicker{margin-top:26px;font-family:var(--font-display);font-weight:600;font-size:1.2rem;color:var(--gold);}

.remote-art{display:flex;justify-content:center;}
.phone{
  width:300px;height:600px;background:#0e0518;border-radius:42px;
  border:9px solid #2a1140;position:relative;
  box-shadow:0 40px 90px -30px rgba(0,0,0,.8), inset 0 0 0 2px rgba(255,255,255,.04);
  padding:18px 16px;animation:bob 6s ease-in-out infinite;
}
.phone-notch{width:120px;height:24px;background:#0e0518;border-radius:0 0 16px 16px;position:absolute;top:-1px;left:50%;transform:translateX(-50%);z-index:3;}
.phone-screen{height:100%;border-radius:28px;background:linear-gradient(180deg,var(--plum-850),var(--plum-900));overflow:hidden;padding:30px 16px 16px;display:flex;flex-direction:column;gap:13px;}
.rm-top{display:flex;align-items:center;gap:11px;}
.rm-dot{width:34px;height:34px;border-radius:11px;background:linear-gradient(135deg,var(--berry),var(--magenta));flex:none;box-shadow:0 6px 16px -6px var(--berry);}
.rm-title{font-family:var(--font-display);font-weight:600;font-size:1.02rem;}
.rm-sub{font-size:.72rem;color:#7ee0a0;font-weight:700;}
.rm-search{display:flex;align-items:center;gap:9px;background:rgba(253,248,241,.06);border:1.4px solid var(--plum-700);border-radius:13px;padding:11px 12px;color:var(--ink-faint);font-size:.86rem;}
.rm-search span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.rm-search svg{width:17px;height:17px;flex:none;}
.rm-now{display:flex;gap:12px;background:var(--plum-820);border:1.4px solid var(--plum-700);border-radius:16px;padding:12px;}
.rm-art{width:62px;height:62px;border-radius:11px;flex:none;background:
  repeating-linear-gradient(135deg,var(--berry) 0 7px,var(--berry-deep) 7px 14px);
  box-shadow:0 6px 16px -8px var(--berry);}
.rm-meta{flex:1;min-width:0;}
.rm-show{font-family:var(--font-display);font-weight:600;font-size:.98rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.rm-ep{font-size:.74rem;color:var(--ink-faint);margin-bottom:8px;}
.rm-bar{height:6px;border-radius:99px;background:rgba(253,248,241,.1);overflow:hidden;}
.rm-bar i{display:block;width:40%;height:100%;background:linear-gradient(90deg,var(--magenta),var(--berry));}
.rm-time{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:.66rem;color:var(--ink-faint);margin-top:5px;}
.rm-controls{display:flex;justify-content:center;align-items:center;gap:18px;margin-top:2px;}
.rm-controls button{background:none;border:0;color:var(--ink-soft);cursor:pointer;padding:4px;}
.rm-controls button svg{width:26px;height:26px;}
.rm-play{width:58px;height:58px;border-radius:50%!important;background:linear-gradient(180deg,var(--berry),var(--berry-deep))!important;color:#fff!important;display:grid;place-items:center;box-shadow:0 10px 24px -8px var(--berry);}
.rm-play svg{width:24px!important;height:24px!important;}
.rm-vol{display:flex;align-items:center;gap:10px;color:var(--ink-faint);}
.rm-vol svg{width:20px;height:20px;flex:none;}
.rm-vbar{flex:1;height:6px;border-radius:99px;background:rgba(253,248,241,.1);overflow:hidden;}
.rm-vbar i{display:block;width:65%;height:100%;background:var(--gold);}
.rm-chips{display:flex;gap:8px;margin-top:auto;}
.rm-chips span{flex:1;text-align:center;font-size:.72rem;font-weight:700;color:var(--ink-dim);background:rgba(253,248,241,.05);border:1.3px solid var(--plum-700);border-radius:10px;padding:7px;}

/* ---------- HOW IT WORKS ---------- */
.how-row{display:flex;align-items:stretch;gap:8px;}
.how-node{flex:1;text-align:center;}
.how-node.accent{border-color:var(--berry);box-shadow:0 18px 50px -24px var(--berry);}
.how-ico{width:62px;height:62px;border-radius:18px;display:grid;place-items:center;font-size:1.9rem;margin:0 auto 16px;
  background:color-mix(in srgb,var(--c) 18%,var(--plum-820));border:1.5px solid color-mix(in srgb,var(--c) 45%,transparent);}
.how-node h3{font-size:1.3rem;margin-bottom:8px;}
.how-node p{color:var(--ink-dim);font-size:.98rem;}
.how-arrow{flex:none;width:78px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;color:var(--magenta-soft);}
.how-arrow span{font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-faint);}
.how-arrow svg{width:54px;height:22px;}
.how-arrow.rev{color:var(--gold);}

/* ---------- SCREENSHOTS ---------- */
.shots-band{background:var(--plum-880);}
.shots-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.shot{margin:0;}
.shot.wide{grid-column:auto;}
.shot-ph{
  aspect-ratio:16/10;border-radius:18px;border:1.5px solid var(--plum-700);
  background:
    repeating-linear-gradient(45deg,rgba(255,110,166,.07) 0 11px,transparent 11px 22px),
    var(--plum-850);
  position:relative;overflow:hidden;
}
.shot-ph::after{
  content:attr(data-cap);position:absolute;left:14px;bottom:12px;
  font-family:var(--font-mono);font-size:.78rem;color:var(--ink-faint);
  background:rgba(25,1,35,.7);padding:5px 9px;border-radius:8px;
}
.shot figcaption{margin-top:12px;color:var(--ink-dim);font-weight:600;}

/* ---------- OPEN SOURCE ---------- */
.os-card{
  display:grid;grid-template-columns:1.4fr .9fr;gap:34px;align-items:center;
  background:linear-gradient(135deg,var(--plum-850),var(--plum-820));
  border:1.5px solid var(--plum-700);border-radius:var(--radius-lg);padding:46px;
}
.os-left h2{font-size:clamp(1.8rem,3.6vw,2.6rem);margin:16px 0 14px;}
.os-left>p{color:var(--ink-dim);font-size:1.12rem;max-width:48ch;}
.os-cta{display:flex;flex-wrap:wrap;gap:13px;margin:26px 0 14px;}
.os-right{background:var(--plum-900);border:1.5px solid var(--plum-700);border-radius:var(--radius);padding:26px;}
.os-badge{display:flex;align-items:baseline;gap:10px;padding-bottom:18px;margin-bottom:18px;border-bottom:1.5px dashed var(--plum-700);}
.os-badge code{font-family:var(--font-mono);font-weight:700;font-size:2rem;color:var(--gold);}
.os-badge span{color:var(--ink-faint);font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-size:.8rem;}
.os-points{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:11px;}
.os-points li{color:var(--ink-soft);font-weight:600;}

/* ---------- FAQ ---------- */
.faq-band{background:var(--plum-880);}
.faq-list{max-width:780px;margin:0 auto;display:flex;flex-direction:column;gap:12px;}
.faq-list details{background:var(--plum-850);border:1.5px solid var(--plum-700);border-radius:18px;padding:4px 22px;transition:border-color .2s;}
.faq-list details[open]{border-color:var(--plum-line);}
.faq-list summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 0;font-family:var(--font-display);font-weight:600;font-size:1.16rem;}
.faq-list summary::-webkit-details-marker{display:none;}
.faq-list summary i{flex:none;width:24px;height:24px;border-radius:50%;background:rgba(255,58,134,.12);position:relative;transition:.25s;}
.faq-list summary i::before,.faq-list summary i::after{content:"";position:absolute;background:var(--magenta);border-radius:2px;top:50%;left:50%;transform:translate(-50%,-50%);}
.faq-list summary i::before{width:11px;height:2.4px;}
.faq-list summary i::after{width:2.4px;height:11px;transition:.25s;}
.faq-list details[open] summary i::after{transform:translate(-50%,-50%) scaleY(0);}
.faq-list details[open] summary i{transform:rotate(90deg);}
.faq-list p{color:var(--ink-dim);padding:0 0 20px;font-size:1.05rem;}
.faq-list a{color:var(--magenta-soft);font-weight:700;}

/* ---------- CTA ---------- */
.cta-band{padding:84px 26px;text-align:center;position:relative;
  background:radial-gradient(circle at 50% -10%,rgba(230,13,87,.22),transparent 60%),var(--plum-900);}
.cta-inner{display:flex;flex-direction:column;align-items:center;}
.cta-pie img{width:96px;height:96px;border-radius:24px;animation:bob 5s ease-in-out infinite;filter:drop-shadow(0 16px 30px rgba(230,13,87,.4));}
.cta-band h2{font-size:clamp(2.2rem,5vw,3.4rem);margin:22px 0 12px;}
.cta-band p{color:var(--ink-dim);font-size:1.18rem;max-width:42ch;margin:0 auto 30px;}

/* ---------- FOOTER ---------- */
.footer{background:var(--plum-880);border-top:1.5px solid var(--plum-700);padding:60px 0 34px;}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:34px;}
.foot-brand .brand{margin-bottom:14px;}
.foot-brand .brand img{width:42px;height:42px;border-radius:12px;}
.foot-brand p{color:var(--ink-dim);max-width:34ch;margin-bottom:8px;}
.foot-col h4{font-family:var(--font-display);font-weight:600;font-size:1.05rem;margin-bottom:14px;color:var(--cream);}
.foot-col a{display:block;color:var(--ink-dim);padding:5px 0;font-weight:600;transition:.18s;}
.foot-col a:hover{color:var(--magenta-soft);}
.foot-bottom{margin-top:44px;padding-top:24px;border-top:1.5px solid var(--plum-700);display:flex;flex-wrap:wrap;justify-content:space-between;gap:10px;}
.foot-bottom p{color:var(--ink-faint);font-size:.88rem;}

/* ---------- responsive ---------- */
@media (max-width:980px){
  .hero-grid{grid-template-columns:1fr;text-align:center;}
  .hero-copy .eyebrow{margin:0 auto;}
  .hero-sub{margin-left:auto;margin-right:auto;}
  .hero-cta,.hero-platforms{justify-content:center;}
  .hero-art{grid-row:1;min-height:320px;margin-bottom:10px;}
  .story-grid{grid-template-columns:1fr;gap:26px;}
  .feature-grid{grid-template-columns:1fr 1fr;}
  .remote-grid{grid-template-columns:1fr;gap:40px;}
  .remote-copy{text-align:center;}
  .remote-copy .eyebrow{margin:0 auto;}
  .remote-list{text-align:left;max-width:440px;margin-left:auto;margin-right:auto;}
  .how-row{flex-direction:column;}
  .how-arrow{width:100%;flex-direction:row;transform:rotate(90deg);height:50px;}
  .os-card{grid-template-columns:1fr;padding:32px;}
}
@media (max-width:680px){
  .story-stats{grid-template-columns:1fr 1fr;}
  .feature-grid{grid-template-columns:1fr;}
  .shots-grid{grid-template-columns:1fr;}
  .foot-grid{grid-template-columns:1fr 1fr;}
  .foot-brand{grid-column:1/-1;}
}
@media (max-width:430px){
  .story-stats{grid-template-columns:1fr;}
  .foot-grid{grid-template-columns:1fr;}
}
