/* ============================================================
   JellyPi — shared styles
   A Jellyfin video player, baked for the Raspberry Pi
   Palette sampled from the logo.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Fredoka:wght@400;500;600;700&family=Nunito:ital,wght@0,400;0,500;0,600;0,700;0,800;1,500&family=Space+Mono:wght@400;700&display=swap');

:root{
  /* surfaces — plum (matches the logo background exactly) */
  --plum-900:#190123;
  --plum-880:#1f0a2c;
  --plum-850:#241033;
  --plum-820:#2b1540;
  --plum-780:#341a4c;
  --plum-700:#46265f;
  --plum-line:#522c6c;

  /* brand */
  --berry:#e60d57;
  --berry-deep:#c2003f;
  --magenta:#ff3a86;
  --magenta-soft:#ff6ea6;
  --gold:#f7c45e;
  --gold-deep:#e6a94e;
  --cream:#fdf8f1;

  /* text */
  --ink:#fdf8f1;
  --ink-soft:#e7d6e6;
  --ink-dim:#b89cc0;
  --ink-faint:#8d6f9b;

  --maxw:1180px;
  --radius:22px;
  --radius-lg:32px;
  --shadow-berry:0 18px 50px -18px rgba(230,13,87,.55);
  --shadow-soft:0 24px 60px -28px rgba(0,0,0,.7);

  --font-display:'Fredoka', system-ui, sans-serif;
  --font-body:'Nunito', system-ui, sans-serif;
  --font-mono:'Space Mono', ui-monospace, monospace;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;scroll-padding-top:88px;}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--plum-900);
  -webkit-font-smoothing:antialiased;
  line-height:1.6;
  overflow-x:clip;
}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;line-height:1.05;margin:0;letter-spacing:-.01em;}
p{margin:0;text-wrap:pretty;}

/* ambient blobs */
.bg-fx{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden;}
.blob{position:absolute;border-radius:50%;filter:blur(70px);opacity:.5;}
.blob.b1{width:520px;height:520px;background:var(--berry);top:-180px;left:-160px;opacity:.32;animation:drift 22s ease-in-out infinite;}
.blob.b2{width:440px;height:440px;background:var(--magenta);top:30%;right:-180px;opacity:.22;animation:drift 27s ease-in-out infinite reverse;}
.blob.b3{width:380px;height:380px;background:var(--gold);bottom:-160px;left:20%;opacity:.14;animation:drift 30s ease-in-out infinite;}
@keyframes drift{0%,100%{transform:translate(0,0) scale(1);}50%{transform:translate(40px,-30px) scale(1.08);}}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 26px;position:relative;z-index:1;}
section{position:relative;z-index:1;}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.55em;
  font-family:var(--font-display);font-weight:600;font-size:1.02rem;
  padding:.82em 1.5em;border-radius:999px;border:0;cursor:pointer;
  transition:transform .18s cubic-bezier(.34,1.56,.64,1), box-shadow .2s, background .2s;
  white-space:nowrap;
}
.btn:active{transform:scale(.96);}
.btn-berry{background:linear-gradient(180deg,var(--berry),var(--berry-deep));color:#fff;box-shadow:var(--shadow-berry);}
.btn-berry:hover{transform:translateY(-2px) scale(1.03) rotate(-1deg);box-shadow:0 22px 56px -16px rgba(230,13,87,.7);}
.btn-ghost{background:rgba(253,248,241,.06);color:var(--ink);border:1.5px solid var(--plum-line);}
.btn-ghost:hover{background:rgba(253,248,241,.12);transform:translateY(-2px);border-color:var(--magenta-soft);}
.btn-gold{background:linear-gradient(180deg,var(--gold),var(--gold-deep));color:#4a2b00;box-shadow:0 16px 40px -18px rgba(247,196,94,.6);}
.btn-gold:hover{transform:translateY(-2px) scale(1.03);}
.btn-lg{font-size:1.15rem;padding:.95em 1.8em;}
.btn svg{width:1.15em;height:1.15em;}

/* ---------- nav ---------- */
.nav{position:sticky;top:0;z-index:50;}
.nav-inner{
  max-width:var(--maxw);margin:14px auto 0;padding:9px 12px 9px 16px;
  display:flex;align-items:center;gap:18px;
  background:rgba(31,10,44,.72);backdrop-filter:blur(16px);
  border:1.5px solid var(--plum-line);border-radius:999px;
  box-shadow:var(--shadow-soft);
}
.brand{display:flex;align-items:center;gap:11px;margin-right:auto;}
.brand img{width:38px;height:38px;border-radius:11px;}
.brand .bt{font-family:var(--font-display);font-weight:600;font-size:1.28rem;line-height:1;}
.brand .bt .pi{color:var(--magenta);}
.brand .bs{font-size:.68rem;color:var(--ink-faint);font-weight:700;letter-spacing:.04em;display:block;margin-top:2px;}
.nav-links{display:flex;align-items:center;gap:4px;}
.nav-links a{padding:.5em .85em;border-radius:999px;font-weight:700;font-size:.96rem;color:var(--ink-soft);transition:.18s;}
.nav-links a:hover{color:var(--ink);background:rgba(253,248,241,.07);}
.nav-cta{display:flex;align-items:center;gap:9px;}
.nav-toggle{display:none;background:none;border:0;color:var(--ink);cursor:pointer;padding:8px;}
.nav-toggle svg{width:26px;height:26px;}

/* ---------- crust divider ---------- */
.crust{
  height:26px;width:100%;position:relative;z-index:1;
  background:linear-gradient(180deg,var(--gold),var(--gold-deep));
  -webkit-mask:radial-gradient(circle 14px at 50% 100%, #000 98%, transparent 100%) repeat-x;
  mask:radial-gradient(circle 14px at 50% 100%, #000 98%, transparent 100%) repeat-x;
  -webkit-mask-size:34px 26px;mask-size:34px 26px;
  margin:-1px 0;
}
.crust.flip{transform:scaleY(-1);}

/* ---------- shared section bits ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:.5em;
  font-family:var(--font-display);font-weight:600;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--magenta-soft);background:rgba(255,58,134,.1);
  border:1.4px solid rgba(255,58,134,.28);padding:.4em 1em;border-radius:999px;
  white-space:nowrap;
}
.section-pad{padding:96px 0;}
.section-head{max-width:680px;margin:0 auto 54px;text-align:center;}
.section-head h2{font-size:clamp(2rem,4.6vw,3.1rem);}
.section-head p{color:var(--ink-dim);font-size:1.12rem;margin-top:16px;}

.card{
  background:var(--plum-850);border:1.5px solid var(--plum-700);
  border-radius:var(--radius);padding:28px;
}

.foot-note{color:var(--ink-faint);font-size:.92rem;}

/* sprinkle dots */
.sprinkle{position:absolute;border-radius:999px;opacity:.85;z-index:1;}

@media (max-width:860px){
  .nav-links{display:none;}
  .nav-toggle{display:block;}
  .section-pad{padding:70px 0;}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;}
  html{scroll-behavior:auto;}
}
