/* =========================================================
   SLI Play — redesigned hi-fi mobile app screens (2026)
   Light, playful kids' learning app + dark cinematic player.
   Rendered live inside the Sli.se Play case study.
   ========================================================= */

@import url('https://fonts.googleapis.com/css2?family=Baloo+2:wght@500;600;700;800&family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap');

/* ---------- stage (rows of phones) ---------- */
.appstage {
  display: flex;
  gap: 34px;
  justify-content: center;
  align-items: flex-start;
  flex-wrap: wrap;
}

/* ---------- phone shell ---------- */
.ph {
  --acc:      #6d4ae6;
  --acc-ink:  #5a39d4;
  --acc-soft: #efeafc;
  --blue:     #5b8def;
  --mint:     #1fc9a0;
  --yellow:   #ffc83d;
  --pink:     #ff6fa5;
  --ink:      #1d1a2e;
  --soft:     #6f6a85;
  --faint:    #a8a4b8;
  --surface:  #f4f2fc;
  --card:     #ffffff;
  --line:     rgba(30,25,55,0.07);

  position: relative;
  flex: none;
  width: 290px;
  height: 612px;
  background: #14121d;
  border-radius: 50px;
  padding: 11px;
  box-shadow:
    0 2px 4px rgba(20,15,40,.4) inset,
    0 38px 70px -34px rgba(80,55,170,.55),
    0 10px 26px -16px rgba(40,25,90,.4);
  font-family: 'Plus Jakarta Sans', sans-serif;
}
.ph__island {
  position: absolute;
  top: 17px; left: 50%;
  transform: translateX(-50%);
  width: 96px; height: 26px;
  background: #14121d;
  border-radius: 100px;
  z-index: 20;
}
.scr {
  position: absolute;
  inset: 11px;
  border-radius: 40px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  background: var(--surface);
  color: var(--ink);
}

/* ---------- status bar ---------- */
.sbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 24px 6px;
  font-size: 12px;
  font-weight: 700;
  color: var(--ink);
  flex: none;
}
.sbar .ico { display: flex; gap: 5px; align-items: center; }
.sbar svg { width: 15px; height: 12px; }

/* ---------- logo ---------- */
.lg { display: inline-flex; align-items: center; gap: 4px; }
.lg b {
  width: 22px; height: 22px; border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Baloo 2', 'Plus Jakarta Sans', sans-serif; font-weight: 800; font-size: 13px;
  color: #fff; line-height: 1;
  box-shadow: 0 3px 7px -2px rgba(0,0,0,.22);
}
.lg .s { background: var(--yellow); color: #6a45cc; }
.lg .l { background: var(--mint); }
.lg .i { background: var(--blue); }
.lg .play {
  background: var(--acc); color: #fff;
  font-family: 'Baloo 2', 'Plus Jakarta Sans', sans-serif; font-weight: 700; font-size: 12px;
  padding: 4px 10px; border-radius: 8px; margin-left: 3px; line-height: 1;
}
.lg--lg b { width: 38px; height: 38px; border-radius: 13px; font-size: 22px; }
.lg--lg .play { font-size: 20px; padding: 7px 15px; border-radius: 13px; }

/* generic scroll body */
.body { flex: 1; overflow: hidden; padding: 2px 18px 0; }
.body::-webkit-scrollbar { display: none; }

/* section heading */
.sh {
  display: flex; align-items: center; justify-content: space-between;
  margin: 18px 2px 11px;
}
.sh h4 { font-family: 'Baloo 2', 'Plus Jakarta Sans', sans-serif; font-weight: 700; font-size: 15px; color: var(--ink); letter-spacing: -.01em; }
.sh a { font-size: 11px; font-weight: 700; color: var(--acc); }

/* ---------- floating bottom nav ---------- */
.fnav {
  position: absolute; left: 16px; right: 16px; bottom: 14px;
  height: 60px;
  background: rgba(255,255,255,.86);
  backdrop-filter: blur(14px);
  border: 1px solid rgba(255,255,255,.8);
  border-radius: 26px;
  box-shadow: 0 16px 34px -16px rgba(60,40,130,.5), 0 2px 6px rgba(60,40,130,.08);
  display: flex; align-items: center; justify-content: space-around;
  padding: 0 8px;
  z-index: 15;
}
.fnav .n { display: flex; flex-direction: column; align-items: center; gap: 3px; color: var(--faint); }
.fnav .n svg { width: 21px; height: 21px; }
.fnav .n span { font-size: 9px; font-weight: 700; }
.fnav .n.on { color: var(--acc); }
.fnav .n.on .pad {
  background: var(--acc); color: #fff;
  width: 46px; height: 32px; border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 8px 16px -6px var(--acc);
}
.fnav .n.on .pad svg { width: 19px; height: 19px; }
.fnav .n .pad { display: flex; align-items: center; justify-content: center; }

/* color-block thumbnail (illustration stand-in) */
.thumb {
  border-radius: 16px; position: relative; overflow: hidden;
  display: flex; align-items: center; justify-content: center;
  font-size: 30px;
}
.thumb::after { content: ""; position: absolute; inset: 0; background: radial-gradient(120% 90% at 80% 10%, rgba(255,255,255,.35), transparent 55%); }
.thumb .pl {
  position: absolute; width: 30px; height: 30px; border-radius: 50%;
  background: rgba(255,255,255,.92); display: flex; align-items: center; justify-content: center;
  color: var(--acc); font-size: 11px;
  box-shadow: 0 4px 10px -3px rgba(0,0,0,.3);
}
.thumb .dur {
  position: absolute; right: 7px; bottom: 7px;
  background: rgba(20,15,40,.6); color: #fff; font-size: 9px; font-weight: 700;
  padding: 2px 7px; border-radius: 100px; backdrop-filter: blur(3px);
}
.thumb .fav {
  position: absolute; top: 7px; right: 7px; width: 22px; height: 22px; border-radius: 50%;
  background: rgba(255,255,255,.9); display: flex; align-items: center; justify-content: center;
  color: var(--pink); font-size: 11px;
}

/* =========================================================
   ONBOARDING
   ========================================================= */
.ob { flex: 1; display: flex; flex-direction: column; padding: 4px 24px 22px; }
.ob__art {
  flex: 1; border-radius: 28px; margin: 6px 0 22px; position: relative; overflow: hidden;
  background: linear-gradient(160deg, #efeafc, #e7eeff 60%, #e6fbf4);
  display: flex; align-items: center; justify-content: center;
}
.ob__blob { position: absolute; border-radius: 50%; filter: blur(2px); opacity: .85; }
.ob__hero { font-size: 96px; position: relative; z-index: 2; filter: drop-shadow(0 14px 22px rgba(80,55,170,.28)); }
.ob__tag { position: absolute; z-index: 3; background: #fff; border-radius: 14px; padding: 7px 11px; font-size: 11px; font-weight: 800; color: var(--ink); box-shadow: 0 10px 22px -10px rgba(60,40,130,.4); display: flex; align-items: center; gap: 6px; }
.ob__tag .d { width: 8px; height: 8px; border-radius: 50%; }
.ob h2 { font-family: 'Baloo 2', 'Plus Jakarta Sans', sans-serif; font-weight: 800; font-size: 27px; line-height: 1.08; letter-spacing: -.02em; }
.ob h2 em { font-style: normal; color: var(--acc); }
.ob p { font-size: 13px; color: var(--soft); line-height: 1.5; margin: 10px 0 0; }
.ob__dots { display: flex; gap: 6px; margin: 18px 0; }
.ob__dots i { width: 7px; height: 7px; border-radius: 50%; background: #d8d3ec; }
.ob__dots i.on { width: 22px; background: var(--acc); }
.btn-pri {
  width: 100%; border: 0; cursor: default;
  background: var(--acc); color: #fff;
  font-family: 'Plus Jakarta Sans', sans-serif; font-weight: 800; font-size: 15px;
  padding: 15px; border-radius: 18px;
  box-shadow: 0 14px 26px -10px var(--acc);
  display: flex; align-items: center; justify-content: center; gap: 8px;
}

/* =========================================================
   SIGN IN
   ========================================================= */
.si { flex: 1; display: flex; flex-direction: column; padding: 10px 24px 24px; }
.si__top { text-align: center; margin: 16px 0 4px; }
.si h2 { font-family: 'Baloo 2', 'Plus Jakarta Sans', sans-serif; font-weight: 800; font-size: 24px; margin-top: 16px; letter-spacing: -.01em; }
.si p { font-size: 12.5px; color: var(--soft); margin: 5px 0 0; }
.field { margin-top: 14px; }
.field label { font-size: 11px; font-weight: 700; color: var(--soft); margin-left: 4px; }
.field .inp {
  display: flex; align-items: center; gap: 10px;
  background: var(--card); border: 1.5px solid var(--line); border-radius: 16px;
  padding: 13px 15px; margin-top: 6px; font-size: 13px; color: var(--faint); font-weight: 600;
}
.field .inp.focus { border-color: var(--acc); box-shadow: 0 0 0 4px var(--acc-soft); color: var(--ink); }
.field .inp svg { width: 17px; height: 17px; color: var(--acc); }
.field .inp .eye { margin-left: auto; color: var(--faint); }
.si__row { display: flex; align-items: center; justify-content: space-between; margin: 14px 2px; font-size: 11.5px; font-weight: 700; }
.si__chk { display: flex; align-items: center; gap: 7px; color: var(--soft); }
.si__chk .box { width: 16px; height: 16px; border-radius: 5px; background: var(--acc); display: flex; align-items: center; justify-content: center; color: #fff; font-size: 10px; }
.si__row a { color: var(--acc); }
.si__or { display: flex; align-items: center; gap: 12px; margin: 16px 2px; color: var(--faint); font-size: 11px; font-weight: 700; }
.si__or::before, .si__or::after { content: ""; flex: 1; height: 1px; background: var(--line); }
.si__soc { display: flex; gap: 10px; }
.si__soc div { flex: 1; background: var(--card); border: 1.5px solid var(--line); border-radius: 14px; padding: 11px; display: flex; align-items: center; justify-content: center; gap: 7px; font-size: 12px; font-weight: 700; color: var(--ink); }
.si__soc .g { color: #4285f4; font-weight: 800; }

/* =========================================================
   HOME
   ========================================================= */
.greet { display: flex; align-items: center; gap: 11px; padding: 6px 2px 0; }
.greet .av { width: 42px; height: 42px; border-radius: 14px; background: linear-gradient(140deg, var(--acc), var(--blue)); display: flex; align-items: center; justify-content: center; color: #fff; font-family: 'Baloo 2', 'Plus Jakarta Sans', sans-serif; font-weight: 800; font-size: 18px; }
.greet .hi { font-size: 11.5px; color: var(--soft); font-weight: 600; }
.greet .nm { font-family: 'Baloo 2', 'Plus Jakarta Sans', sans-serif; font-weight: 700; font-size: 17px; line-height: 1.1; }
.greet .bell { margin-left: auto; width: 38px; height: 38px; border-radius: 13px; background: var(--card); border: 1px solid var(--line); display: flex; align-items: center; justify-content: center; color: var(--ink); position: relative; }
.greet .bell svg { width: 18px; height: 18px; }
.greet .bell i { position: absolute; top: 9px; right: 10px; width: 7px; height: 7px; border-radius: 50%; background: var(--pink); border: 1.5px solid var(--card); }

.search {
  display: flex; align-items: center; gap: 9px;
  background: var(--card); border: 1px solid var(--line); border-radius: 16px;
  padding: 12px 15px; margin: 14px 2px 0; font-size: 13px; color: var(--faint); font-weight: 600;
  box-shadow: 0 8px 20px -14px rgba(60,40,130,.4);
}
.search svg { width: 17px; height: 17px; color: var(--acc); }
.search .mic { margin-left: auto; color: var(--acc); }

/* continue-watching card */
.cw {
  margin: 16px 2px 0; border-radius: 22px; overflow: hidden; position: relative;
  background: linear-gradient(135deg, var(--acc), #8a6bf0 70%, var(--blue));
  padding: 16px; color: #fff;
  box-shadow: 0 18px 30px -16px var(--acc);
}
.cw::after { content: ""; position: absolute; right: -30px; top: -30px; width: 120px; height: 120px; border-radius: 50%; background: rgba(255,255,255,.12); }
.cw .lab { font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: .1em; opacity: .85; }
.cw .ttl { font-family: 'Baloo 2', 'Plus Jakarta Sans', sans-serif; font-weight: 700; font-size: 17px; margin: 4px 0 2px; line-height: 1.12; position: relative; }
.cw .sub { font-size: 11px; opacity: .85; }
.cw .row { display: flex; align-items: center; gap: 11px; margin-top: 13px; position: relative; }
.cw .play { width: 38px; height: 38px; border-radius: 13px; background: #fff; color: var(--acc); display: flex; align-items: center; justify-content: center; font-size: 14px; flex: none; box-shadow: 0 6px 14px -5px rgba(0,0,0,.3); }
.cw .bar { flex: 1; height: 6px; border-radius: 6px; background: rgba(255,255,255,.28); position: relative; }
.cw .bar i { position: absolute; left: 0; top: 0; bottom: 0; width: 64%; border-radius: 6px; background: #fff; }
.cw .pct { font-size: 11px; font-weight: 800; }

/* category chips strip */
.crow { display: flex; gap: 9px; overflow: hidden; padding: 1px; }
.cpill { flex: none; display: flex; align-items: center; gap: 7px; padding: 9px 13px; border-radius: 100px; background: var(--card); border: 1px solid var(--line); font-size: 12px; font-weight: 700; color: var(--soft); }
.cpill.on { background: var(--ink); color: #fff; border-color: var(--ink); }
.cpill .e { font-size: 14px; }

/* horizontal video cards */
.hrow { display: flex; gap: 12px; overflow: hidden; padding: 1px; }
.vc { width: 138px; flex: none; }
.vc .thumb { height: 92px; }
.vc .t { font-size: 12px; font-weight: 700; color: var(--ink); margin-top: 8px; line-height: 1.25; }
.vc .m { font-size: 10.5px; color: var(--faint); margin-top: 3px; font-weight: 600; display: flex; align-items: center; gap: 5px; }
.vc .m .dot { width: 3px; height: 3px; border-radius: 50%; background: var(--faint); }

/* list row */
.lrow { display: flex; gap: 11px; align-items: center; background: var(--card); border: 1px solid var(--line); border-radius: 16px; padding: 9px; margin-bottom: 10px; }
.lrow .thumb { width: 72px; height: 54px; flex: none; font-size: 22px; border-radius: 12px; }
.lrow .lr-tx { flex: 1; min-width: 0; }
.lrow .t { font-size: 12.5px; font-weight: 700; color: var(--ink); line-height: 1.25; }
.lrow .m { font-size: 10.5px; color: var(--faint); margin-top: 4px; display: flex; gap: 8px; font-weight: 600; white-space: nowrap; }
.lrow .go { margin-left: auto; color: var(--faint); font-size: 16px; }

/* =========================================================
   CATEGORIES (bento)
   ========================================================= */
.bento { display: grid; grid-template-columns: 1fr 1fr; grid-auto-rows: 92px; gap: 11px; padding-bottom: 84px; }
.bt { border-radius: 20px; padding: 14px; position: relative; overflow: hidden; display: flex; flex-direction: column; color: #fff; }
.bt::after { content: ""; position: absolute; inset: 0; background: linear-gradient(160deg, rgba(255,255,255,.18), transparent 50%); }
.bt.tall { grid-row: span 2; }
.bt .e { font-size: 27px; line-height: 1; margin-bottom: auto; position: relative; filter: drop-shadow(0 4px 8px rgba(0,0,0,.2)); }
.bt .nm { font-family: 'Baloo 2', 'Plus Jakarta Sans', sans-serif; font-weight: 700; font-size: 14px; line-height: 1.05; position: relative; margin-top: 9px; }
.bt .ct { font-size: 10px; font-weight: 600; opacity: .85; margin-top: 3px; position: relative; }

/* =========================================================
   SEARCH + FILTER
   ========================================================= */
.fgroup { margin-top: 16px; }
.fgroup .lbl { font-size: 12px; font-weight: 700; color: var(--ink); margin: 0 2px 9px; display: flex; align-items: center; justify-content: space-between; }
.fchips { display: flex; gap: 8px; flex-wrap: wrap; }
.fch { font-size: 11.5px; font-weight: 700; padding: 8px 13px; border-radius: 100px; background: var(--card); color: var(--soft); border: 1px solid var(--line); }
.fch.on { background: var(--acc); color: #fff; border-color: var(--acc); box-shadow: 0 8px 16px -8px var(--acc); }

/* =========================================================
   VIDEO DETAIL
   ========================================================= */
.dhero { height: 168px; border-radius: 22px; position: relative; overflow: hidden; display: flex; align-items: center; justify-content: center; font-size: 60px; margin-top: 4px; }
.dhero .big { position: absolute; width: 56px; height: 56px; border-radius: 50%; background: rgba(255,255,255,.95); display: flex; align-items: center; justify-content: center; color: var(--acc); font-size: 20px; box-shadow: 0 10px 24px -6px rgba(0,0,0,.35); }
.dhero .back { position: absolute; top: 12px; left: 12px; width: 34px; height: 34px; border-radius: 12px; background: rgba(20,15,40,.42); backdrop-filter: blur(4px); display: flex; align-items: center; justify-content: center; color: #fff; font-size: 16px; }
.dhero .fav { position: absolute; top: 12px; right: 12px; width: 34px; height: 34px; border-radius: 12px; background: rgba(20,15,40,.42); backdrop-filter: blur(4px); display: flex; align-items: center; justify-content: center; color: #fff; font-size: 15px; }
.dchips { display: flex; gap: 7px; margin: 14px 2px 0; }
.dchip { font-size: 10px; font-weight: 700; padding: 5px 11px; border-radius: 100px; }
.dchip.sub { background: var(--acc-soft); color: var(--acc-ink); }
.dchip.rec { background: #fff0f6; color: var(--pink); }
.dchip.gr { background: #e7fbf4; color: #099e7a; }
.dttl { font-family: 'Baloo 2', 'Plus Jakarta Sans', sans-serif; font-weight: 700; font-size: 20px; color: var(--ink); margin: 11px 2px 0; line-height: 1.14; letter-spacing: -.01em; }
.dmeta { display: flex; gap: 10px; align-items: center; margin: 8px 2px 0; font-size: 11px; color: var(--soft); font-weight: 600; }
.dmeta .star { color: var(--yellow); }
.ddesc { font-size: 12px; color: var(--soft); line-height: 1.6; margin: 12px 2px 0; }
.dnext { font-family: 'Baloo 2', 'Plus Jakarta Sans', sans-serif; font-weight: 700; font-size: 14px; margin: 16px 2px 10px; }

/* =========================================================
   PLAYER (dark, immersive)
   ========================================================= */
.scr.dark { background: #100e18; color: #fff; }
.pl { flex: 1; display: flex; flex-direction: column; }
.pl__stage { flex: 1; position: relative; display: flex; align-items: center; justify-content: center; font-size: 72px; overflow: hidden; }
.pl__stage::before { content: ""; position: absolute; inset: 0; background: linear-gradient(160deg, #2a2150, #4536a8 55%, #2b6ad1); }
.pl__stage .em { position: relative; z-index: 2; filter: drop-shadow(0 16px 30px rgba(0,0,0,.4)); }
.pl__top { position: absolute; top: 0; left: 0; right: 0; display: flex; align-items: center; justify-content: space-between; padding: 18px 18px 0; z-index: 3; }
.pl__top .b { width: 36px; height: 36px; border-radius: 13px; background: rgba(255,255,255,.16); backdrop-filter: blur(4px); display: flex; align-items: center; justify-content: center; color: #fff; font-size: 15px; }
.pl__top .b svg { width: 16px; height: 16px; display: block; }
.pl__cc { position: absolute; bottom: 16px; left: 50%; transform: translateX(-50%); background: rgba(0,0,0,.55); backdrop-filter: blur(4px); color: #fff; font-size: 11px; font-weight: 600; padding: 6px 13px; border-radius: 10px; z-index: 3; white-space: nowrap; }
.pl__sheet { background: #161325; padding: 18px 20px 22px; border-radius: 28px 28px 0 0; margin-top: -22px; position: relative; z-index: 4; }
.pl__title { font-family: 'Baloo 2', 'Plus Jakarta Sans', sans-serif; font-weight: 700; font-size: 16px; color: #fff; }
.pl__by { font-size: 11px; color: #9a93b8; margin-top: 2px; font-weight: 600; }
.pl__bar { height: 6px; border-radius: 6px; background: rgba(255,255,255,.16); position: relative; margin: 16px 0 7px; }
.pl__bar i { position: absolute; left: 0; top: 0; bottom: 0; width: 42%; background: linear-gradient(90deg, var(--acc), var(--pink)); border-radius: 6px; }
.pl__bar i::after { content: ""; position: absolute; right: -6px; top: 50%; transform: translateY(-50%); width: 14px; height: 14px; border-radius: 50%; background: #fff; box-shadow: 0 2px 6px rgba(0,0,0,.4); }
.pl__time { display: flex; justify-content: space-between; font-size: 10px; color: #9a93b8; font-weight: 700; }
.pl__btns { display: flex; align-items: center; justify-content: space-between; padding: 0 6px; margin: 16px 0 4px; color: #fff; }
.pl__btns .ic { width: 26px; height: 26px; display: flex; align-items: center; justify-content: center; opacity: .92; flex: none; }
.pl__btns .ic svg { width: 19px; height: 19px; display: block; }
.pl__btns .skip { width: 30px; height: 30px; }
.pl__btns .skip svg { width: 28px; height: 28px; }
.pl__btns .main { width: 58px; height: 58px; border-radius: 50%; background: #fff; color: var(--acc); display: flex; align-items: center; justify-content: center; box-shadow: 0 10px 22px -6px rgba(120,90,240,.7); flex: none; }
.pl__btns .main svg { width: 22px; height: 22px; display: block; }
.pl__opts { display: flex; justify-content: space-between; margin-top: 18px; }
.pl__opt { display: flex; flex-direction: column; align-items: center; gap: 5px; font-size: 9.5px; color: #9a93b8; font-weight: 700; }
.pl__opt .v { width: 38px; height: 38px; border-radius: 13px; background: rgba(255,255,255,.08); display: flex; align-items: center; justify-content: center; color: #fff; font-size: 13px; font-weight: 800; }
.pl__opt .v svg { width: 15px; height: 15px; display: block; }
.pl__opt.act .v { background: var(--acc); }

/* =========================================================
   PROGRESS / QUIZ
   ========================================================= */
.streak { display: flex; align-items: center; gap: 13px; background: linear-gradient(135deg, var(--yellow), #ff9f43); border-radius: 22px; padding: 15px 17px; color: #fff; margin: 8px 2px 0; box-shadow: 0 16px 28px -16px #ff9f43; }
.streak .ic { font-size: 34px; filter: drop-shadow(0 4px 8px rgba(0,0,0,.2)); }
.streak .v { font-family: 'Baloo 2', 'Plus Jakarta Sans', sans-serif; font-weight: 800; font-size: 24px; line-height: 1; }
.streak .l { font-size: 11px; font-weight: 700; opacity: .9; margin-top: 2px; }
.streak .badge { margin-left: auto; text-align: center; }
.streak .badge .n { font-family: 'Baloo 2', 'Plus Jakarta Sans', sans-serif; font-weight: 800; font-size: 19px; }
.streak .badge .t { font-size: 9px; font-weight: 700; opacity: .9; }

.week { display: flex; align-items: flex-end; justify-content: space-between; gap: 7px; height: 96px; margin: 6px 4px 0; }
.week .d { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 6px; height: 100%; justify-content: flex-end; }
.week .d .bar { width: 100%; max-width: 22px; border-radius: 8px 8px 4px 4px; background: var(--acc-soft); }
.week .d.on .bar { background: linear-gradient(180deg, var(--acc), var(--blue)); }
.week .d .lab { font-size: 9.5px; font-weight: 700; color: var(--faint); }
.week .d.on .lab { color: var(--acc); }

.gstats { display: flex; gap: 10px; margin: 8px 2px 0; }
.gstat { flex: 1; background: var(--card); border: 1px solid var(--line); border-radius: 16px; padding: 13px; text-align: center; }
.gstat .v { font-family: 'Baloo 2', 'Plus Jakarta Sans', sans-serif; font-weight: 800; font-size: 20px; color: var(--acc); }
.gstat .l { font-size: 9.5px; font-weight: 700; color: var(--faint); margin-top: 2px; text-transform: uppercase; letter-spacing: .04em; }

.badges { display: flex; gap: 11px; }
.bdg { flex: 1; text-align: center; }
.bdg .ring { width: 52px; height: 52px; border-radius: 50%; margin: 0 auto; display: flex; align-items: center; justify-content: center; font-size: 24px; }
.bdg .nm { font-size: 9.5px; font-weight: 700; color: var(--soft); margin-top: 6px; line-height: 1.2; }
.bdg.lock .ring { background: #ece9f6; filter: grayscale(1); opacity: .5; }
.bdg.lock .nm { color: var(--faint); }

/* =========================================================
   ACCOUNT
   ========================================================= */
.prof { display: flex; flex-direction: column; align-items: center; text-align: center; padding: 8px 0 2px; }
.prof .av { width: 72px; height: 72px; border-radius: 24px; background: linear-gradient(140deg, var(--acc), var(--blue)); display: flex; align-items: center; justify-content: center; color: #fff; font-family: 'Baloo 2', 'Plus Jakarta Sans', sans-serif; font-weight: 800; font-size: 30px; box-shadow: 0 14px 26px -10px var(--acc); }
.prof .nm { font-family: 'Baloo 2', 'Plus Jakarta Sans', sans-serif; font-weight: 700; font-size: 19px; margin-top: 11px; white-space: nowrap; }
.prof .mt { font-size: 11.5px; color: var(--soft); font-weight: 600; margin-top: 2px; }
.prof .edit { margin-top: 11px; font-size: 11.5px; font-weight: 700; color: var(--acc); border: 1.5px solid var(--acc-soft); background: var(--acc-soft); padding: 7px 18px; border-radius: 100px; }
.pstats { display: flex; gap: 9px; margin: 16px 2px 0; }
.pstat { flex: 1; background: var(--card); border: 1px solid var(--line); border-radius: 16px; padding: 12px 8px; text-align: center; }
.pstat .v { font-family: 'Baloo 2', 'Plus Jakarta Sans', sans-serif; font-weight: 800; font-size: 19px; color: var(--ink); }
.pstat .l { font-size: 9px; color: var(--faint); margin-top: 2px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; }
.plist { margin-top: 16px; }
.prow { display: flex; align-items: center; gap: 12px; background: var(--card); border: 1px solid var(--line); border-radius: 16px; padding: 13px 14px; margin-bottom: 9px; font-size: 13px; font-weight: 700; color: var(--ink); }
.prow .ic { width: 32px; height: 32px; border-radius: 11px; display: flex; align-items: center; justify-content: center; font-size: 15px; }
.prow .ar { margin-left: auto; color: var(--faint); font-size: 17px; }
.prow.out { color: var(--pink); }
