/* ===========================================================
   推し活ノート — in-app phone UI mockups
   =========================================================== */

.phone{
  --w:300px;
  width:var(--w);
  aspect-ratio:300/620;
  background:#1c1820;
  border-radius:46px;
  padding:11px;
  box-shadow:var(--sh-phone);
  position:relative;
  flex:0 0 auto;
}
.phone::after{ /* side button hint */
  content:"";position:absolute;right:-2px;top:150px;width:3px;height:54px;border-radius:3px;background:#2a2630;
}
.phone-screen{
  width:100%;height:100%;
  background:#F7F8FE;
  border-radius:36px;
  overflow:hidden;
  position:relative;
  display:flex;flex-direction:column;
  font-size:11px;
}
.notch{
  position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:120px;height:24px;background:#1c1820;border-radius:0 0 16px 16px;z-index:30;
}

/* status bar */
.statusbar{
  height:30px;display:flex;align-items:center;justify-content:space-between;
  padding:0 18px 0 22px;font-size:11px;font-weight:700;color:var(--ink);
  font-family:var(--font-num);flex:0 0 auto;
}
.statusbar .sig{display:flex;gap:3px;align-items:center}
.statusbar .sig i{display:block;width:3px;background:var(--ink);border-radius:1px}
.statusbar .sig i:nth-child(1){height:5px}
.statusbar .sig i:nth-child(2){height:7px}
.statusbar .sig i:nth-child(3){height:9px}
.statusbar .sig i:nth-child(4){height:11px}
.batt{width:22px;height:11px;border:1.4px solid var(--ink);border-radius:3px;position:relative;display:inline-block}
.batt::before{content:"";position:absolute;inset:1.6px;width:70%;background:var(--ink);border-radius:1px}
.batt::after{content:"";position:absolute;right:-3px;top:3px;width:2px;height:5px;background:var(--ink);border-radius:1px}

/* app header */
.app-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:6px 16px 12px;flex:0 0 auto;
}
.app-head .ti{font-family:var(--font-display);font-weight:800;font-size:14px;color:var(--ink)}
.app-head .ico{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;color:var(--ink-2);font-size:15px}
.app-head .ico.plus{background:var(--pink-500);color:#fff;box-shadow:0 4px 10px rgba(75,81,206,.4)}

/* scroll body */
.app-body{flex:1;overflow:hidden;padding:0 14px 8px;display:flex;flex-direction:column;gap:13px}
.app-body::-webkit-scrollbar{display:none}

/* big summary card */
.sum-card{
  background:linear-gradient(135deg,#7C82EC,#4B51CE);
  border-radius:20px;padding:15px 16px;color:#fff;position:relative;overflow:hidden;
  box-shadow:0 12px 24px rgba(58,63,174,.28);
}
.sum-card .lab{font-size:10px;font-weight:600;opacity:.92;font-family:var(--font-display)}
.sum-card .amt{font-family:var(--font-num);font-weight:700;font-size:30px;line-height:1.1;margin:3px 0 2px;letter-spacing:-.01em}
.sum-card .sub{font-size:10px;opacity:.9}
.sum-card .mascot{
  position:absolute;right:10px;bottom:8px;width:64px;height:64px;border-radius:50%;
  background:rgba(255,255,255,.22);display:grid;place-items:center;font-size:34px;
}
.sum-card .spark{position:absolute;font-size:13px;opacity:.85}

/* section label inside app */
.app-lab{font-family:var(--font-display);font-weight:800;font-size:12px;color:var(--ink);display:flex;align-items:center;justify-content:space-between}
.app-lab a{font-size:10px;color:var(--pink-600);font-weight:700}

/* oshi ranking rows */
.oshi{display:flex;align-items:center;gap:10px}
.oshi .av{width:30px;height:30px;border-radius:50%;flex:0 0 auto;box-shadow:0 2px 6px rgba(0,0,0,.12)}
.oshi .mid{flex:1;min-width:0}
.oshi .nm{font-weight:700;font-size:11px;color:var(--ink);display:flex;justify-content:space-between;gap:6px}
.oshi .nm .yen{font-family:var(--font-num);font-weight:700}
.oshi .bar{height:5px;border-radius:4px;background:var(--pink-50);margin-top:5px;overflow:hidden}
.oshi .bar i{display:block;height:100%;border-radius:4px}
.oshi .pct{font-size:9px;color:var(--ink-3);margin-top:3px;display:flex;gap:5px}
.oshi .up{color:var(--pink-600);font-weight:700}
.oshi .down{color:var(--blue);font-weight:700}

/* upcoming list */
.plan-card{background:#fff;border-radius:16px;padding:10px 12px;box-shadow:var(--sh-sm);display:flex;flex-direction:column;gap:9px}
.plan{display:flex;align-items:center;gap:10px;font-size:11px}
.plan .dt{font-family:var(--font-num);font-weight:700;color:var(--pink-600);width:34px;flex:0 0 auto}
.plan .nm{flex:1;color:var(--ink);font-weight:500}
.plan .tg{font-size:8.5px;font-weight:700;padding:2px 8px;border-radius:999px;font-family:var(--font-display)}
.tg.tk{background:#E5E7FB;color:var(--pink-700)}
.tg.ev{background:#EFEAFF;color:var(--lav)}

/* bottom tab bar */
.tabbar{
  flex:0 0 auto;height:54px;background:#fff;border-top:1px solid var(--line);
  display:flex;align-items:flex-start;justify-content:space-around;padding-top:7px;
}
.tab{display:flex;flex-direction:column;align-items:center;gap:3px;font-size:8px;color:var(--ink-3);font-weight:600}
.tab .ti{font-size:16px;line-height:1}
.tab.on{color:var(--pink-600)}

/* ---------- record screen ---------- */
.field{display:flex;flex-direction:column;gap:5px}
.field > .k{font-family:var(--font-display);font-weight:700;font-size:10px;color:var(--ink-2)}
.inp{
  background:#fff;border:1.4px solid var(--line);border-radius:12px;
  padding:9px 11px;font-size:11px;color:var(--ink);display:flex;align-items:center;justify-content:space-between;
}
.inp.sel{justify-content:flex-start;gap:8px}
.inp .av{width:20px;height:20px;border-radius:50%}
.inp .muted{color:var(--ink-3)}
.cat-row{display:flex;gap:7px}
.cat{
  flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;
  background:#fff;border:1.4px solid var(--line);border-radius:12px;padding:9px 2px;
  font-size:8.5px;color:var(--ink-2);font-weight:600;
}
.cat .e{font-size:16px}
.cat.on{background:var(--pink-500);border-color:var(--pink-500);color:#fff;box-shadow:0 6px 14px rgba(75,81,206,.32)}
.inp.big{align-items:flex-end;padding:9px 11px}
.inp.amt{font-family:var(--font-num);font-weight:700;font-size:15px;color:var(--pink-700);justify-content:flex-end}
.photo-row{display:flex;gap:8px}
.photo-row .ph{width:54px;height:54px;border-radius:12px;object-fit:cover}
.photo-row .add{width:54px;height:54px;border-radius:12px;border:1.6px dashed var(--pink-200);display:grid;place-items:center;color:var(--pink-400);font-size:20px;background:var(--pink-50)}
.save-btn{
  margin-top:4px;background:linear-gradient(180deg,var(--pink-500),var(--pink-600));
  color:#fff;text-align:center;font-family:var(--font-display);font-weight:800;font-size:12px;
  padding:12px;border-radius:14px;box-shadow:0 10px 20px rgba(75,81,206,.32);
}

/* ---------- report screen ---------- */
.seg{display:flex;background:var(--pink-50);border-radius:11px;padding:3px;gap:3px}
.seg span{flex:1;text-align:center;font-size:10px;font-weight:700;padding:6px;border-radius:8px;color:var(--ink-2);font-family:var(--font-display)}
.seg span.on{background:#fff;color:var(--pink-600);box-shadow:var(--sh-sm)}
.total-line{text-align:center}
.total-line .k{font-size:9.5px;color:var(--ink-2);font-weight:600}
.total-line .v{font-family:var(--font-num);font-weight:700;font-size:24px;color:var(--ink)}
.donut-wrap{display:flex;align-items:center;gap:14px}
.donut{
  width:108px;height:108px;border-radius:50%;flex:0 0 auto;
  background:conic-gradient(
    var(--pink-500) 0 49%,
    var(--lav) 49% 70%,
    var(--blue) 70% 85%,
    var(--gold) 85% 94%,
    #C9C4D0 94% 100%);
  display:grid;place-items:center;position:relative;
}
.donut::before{content:"";position:absolute;width:62px;height:62px;border-radius:50%;background:#F7F8FE}
.donut .ctr{position:relative;text-align:center}
.donut .ctr b{display:block;font-family:var(--font-num);font-weight:700;font-size:13px;color:var(--ink);line-height:1}
.donut .ctr small{font-size:8px;color:var(--ink-3)}
.legend{flex:1;display:flex;flex-direction:column;gap:6px}
.leg{display:flex;align-items:center;gap:7px;font-size:10px}
.leg .sw{width:9px;height:9px;border-radius:3px;flex:0 0 auto}
.leg .nm{flex:1;color:var(--ink-2);font-weight:600}
.leg .vv{font-family:var(--font-num);font-weight:700;color:var(--ink)}
.bars{display:flex;align-items:flex-end;gap:8px;height:74px;padding:0 2px}
.bars .col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;height:100%;justify-content:flex-end}
.bars .col i{width:100%;max-width:16px;border-radius:5px 5px 2px 2px;background:linear-gradient(180deg,var(--pink-400),var(--pink-500))}
.bars .col.hot i{background:linear-gradient(180deg,var(--pink-500),var(--pink-700))}
.bars .col small{font-size:8px;color:var(--ink-3);font-family:var(--font-num)}

/* ---------- summary (year) screen ---------- */
.year-hero{
  background:linear-gradient(135deg,#DADCFB,#BFC3F6);
  border-radius:20px;padding:15px;position:relative;overflow:hidden;
}
.year-hero .k{font-size:10px;font-weight:700;color:var(--pink-700);font-family:var(--font-display)}
.year-hero .v{font-family:var(--font-num);font-weight:700;font-size:27px;color:#2E3290;margin:2px 0}
.year-hero .s{font-size:9.5px;color:var(--pink-700);opacity:.9}
.year-hero .mascot{position:absolute;right:8px;bottom:4px;font-size:40px}
.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px}
.stat{background:#fff;border-radius:13px;padding:11px;box-shadow:var(--sh-sm)}
.stat .k{font-size:9px;color:var(--ink-2);font-weight:600}
.stat .v{font-family:var(--font-num);font-weight:700;font-size:18px;color:var(--ink);margin-top:2px}
.stat .v small{font-size:10px;color:var(--ink-3)}
.stat.full{grid-column:1/-1}
.stat .v.txt{font-family:var(--font-display);font-size:13px}
.line-chart{position:relative;height:76px;margin-top:4px}
.line-chart svg{width:100%;height:100%;overflow:visible}
.share-btn{
  background:#fff;border:1.6px solid var(--pink-200);color:var(--pink-600);
  text-align:center;font-family:var(--font-display);font-weight:800;font-size:11px;
  padding:10px;border-radius:13px;
}

/* avatar gradients (no images needed) */
.av-a{background:linear-gradient(135deg,#8189E8,#4B51CE)}
.av-b{background:linear-gradient(135deg,#9FB6FF,#6F7CE8)}
.av-c{background:linear-gradient(135deg,#FFC97A,#F39B4C)}
.av-d{background:linear-gradient(135deg,#9BE0C4,#5FB89A)}

/* ---------- calendar screen ---------- */
.cal-head{display:flex;align-items:center;justify-content:center;gap:14px;font-family:var(--font-display);font-weight:800;font-size:13px;color:var(--ink)}
.cal-head .arr{color:var(--ink-3);font-size:14px}
.cal{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;text-align:center}
.cal .dow{font-size:8.5px;color:var(--ink-3);font-weight:700;padding-bottom:4px}
.cal .dow.sun{color:var(--pink-500)}
.cal .dow.sat{color:var(--blue)}
.cal .d{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:10px;font-family:var(--font-num);font-weight:600;color:var(--ink);position:relative;border-radius:9px}
.cal .d.mute{color:var(--ink-3);opacity:.45}
.cal .d.today{background:var(--pink-500);color:#fff;box-shadow:0 4px 10px rgba(75,81,206,.32)}
.cal .d .dotrow{display:flex;gap:2px;margin-top:1px;height:3px}
.cal .d .dotrow i{width:3px;height:3px;border-radius:50%}
.cal .d.today .dotrow i{background:rgba(255,255,255,.8)}
.day-card{background:#fff;border-radius:13px;padding:9px 11px;box-shadow:var(--sh-sm);display:flex;align-items:center;justify-content:space-between;gap:8px}
.day-card .l .dt{font-family:var(--font-num);font-weight:700;font-size:10px;color:var(--pink-600)}
.day-card .l .nm{font-size:10.5px;color:var(--ink);font-weight:600;margin-top:1px}
.day-card .amt{font-family:var(--font-num);font-weight:700;font-size:12px;color:var(--ink);white-space:nowrap}
.fab{position:absolute;right:14px;bottom:64px;width:42px;height:42px;border-radius:50%;background:linear-gradient(180deg,var(--pink-500),var(--pink-600));color:#fff;display:grid;place-items:center;font-size:22px;box-shadow:0 10px 20px rgba(241,84,140,.42);z-index:20}

/* phone tilt presentation */
.phone.tilt{transform:perspective(1600px) rotateY(-14deg) rotateX(4deg)}
.phone.tilt-r{transform:perspective(1600px) rotateY(12deg) rotateX(4deg)}
