*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
:root{
  --bg:#0a0a0a;--card:#111;--line:#232323;--line2:#2a2a2a;
  --text:#fff;--body:#d2d2d2;--muted:#9a9a9a;--dim:#777;
  --field:#0a0a0a;--inv:#0a0a0a;--solid:#fff;--solid-text:#0a0a0a;
  --sys:#4ade80;
  --warn:#fbbf24;--danger:#f87171;--info:#38bdf8;--pink:#f472b6;
}
html[data-theme="light"]{
  --bg:#f2f2ef;--card:#fff;--line:#ddd;--line2:#ccc;
  --text:#141414;--body:#333;--muted:#5f5f5f;--dim:#767676;
  --field:#fafafa;--inv:#0a0a0a;--solid:#141414;--solid-text:#fff;
  --danger:#dc2626;--info:#0284c7;
}
html,body{background:var(--bg);color:var(--text);font-family:'Helvetica Neue',Arial,system-ui,sans-serif}
body{min-height:100vh;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}
.mono{font-family:ui-monospace,Menlo,Consolas,monospace;font-variant-numeric:tabular-nums}
#app{max-width:480px;margin:0 auto}
.topline{height:3px;background:linear-gradient(90deg,var(--sys),transparent)}
.pad{padding:16px}
.row{display:flex;align-items:center}
.between{justify-content:space-between}
.gap2{gap:8px}.gap1{gap:4px}
h1{font-size:18px;font-weight:800;letter-spacing:2px;text-transform:uppercase}
.card{background:var(--card);border:1px solid var(--line)}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,a:focus-visible{outline:2px solid var(--sys);outline-offset:1px}
.btn{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:11px 8px;display:flex;align-items:center;justify-content:center;gap:8px;width:100%}
.btn-sys{background:var(--sys);color:var(--inv);box-shadow:0 0 14px color-mix(in srgb,var(--sys) 35%,transparent)}
.btn-white{background:var(--solid);color:var(--solid-text)}
.btn-out{background:transparent;color:var(--sys);border:1px solid var(--sys)}
.lvbadge{font-weight:800;font-size:10px;letter-spacing:1px;padding:2px 7px;border:1px solid;border-radius:2px;flex-shrink:0}
.lvpips{font-size:8px;letter-spacing:1px;flex-shrink:0}
.lvbar{height:6px;background:var(--field);border:1px solid var(--line);margin-top:8px}
.rankhero{border:1px solid;padding:14px;margin-top:12px;background:var(--field);text-align:center}
.rankhero .rh-title{font-size:22px;font-weight:800;letter-spacing:2px;text-transform:uppercase;margin-top:6px;font-family:ui-monospace,Menlo,monospace}
.tierhd{display:flex;align-items:center;gap:8px;margin:16px 0 6px;font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;font-family:ui-monospace,Menlo,monospace}
.tierhd .gdot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.rankrow{display:flex;align-items:center;gap:10px;padding:7px 8px;border:1px solid transparent;border-bottom:1px solid var(--line);font-size:12px;color:var(--dim)}
.rankrow .rk{width:26px;text-align:right;font-size:10px;flex-shrink:0}
.rankrow .rname{flex:1;letter-spacing:.5px}
.rankrow .rxp{font-size:9px;letter-spacing:1px;flex-shrink:0}
.rankrow.got{color:var(--body)}
.rankrow.cur{background:var(--field);animation:curglow 2s ease-in-out infinite}
@keyframes curglow{0%,100%{filter:brightness(1)}50%{filter:brightness(1.35)}}
#celebrate .sub3{display:inline-block;text-align:center;font-size:10px;letter-spacing:2px;text-transform:uppercase;margin-top:10px;padding:4px 12px;border:1px solid;font-family:ui-monospace,monospace}
.lvfill{height:100%;background:var(--sys);box-shadow:0 0 10px var(--sys);transition:width .5s ease}
.lvfill.pulse{animation:lvpulse .7s ease}
@keyframes lvpulse{0%{filter:brightness(1)}40%{filter:brightness(1.9)}100%{filter:brightness(1)}}
.seg{display:flex;gap:4px}
.seg button{flex:1;font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:6px;border:1px solid var(--line);background:var(--card);color:var(--muted)}
.seg button.on{background:var(--solid);color:var(--solid-text)}
.chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.chip{display:flex;align-items:center;gap:7px;font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;padding:10px 12px;white-space:nowrap;border:1px solid var(--line);background:transparent;color:var(--body)}
.chip .cdot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.chip .ccnt{font-size:9px;font-weight:700;letter-spacing:0;padding:1px 5px;font-family:ui-monospace,Menlo,monospace}
.qwrap{position:relative;margin-bottom:8px}
.qunder{position:absolute;inset:0;display:flex;align-items:center;justify-content:space-between;padding:0 18px;font-size:20px;border:1px solid transparent}
.qunder .u-done{color:var(--sys)}
.qunder .u-del{color:var(--danger)}
.quest{position:relative;padding:12px;border:1px solid var(--line);background:var(--card);border-left:3px solid var(--dim);touch-action:pan-y;will-change:transform;-webkit-user-select:none;user-select:none}
.dragghost{position:fixed;z-index:80;margin:0;pointer-events:none;opacity:.93;transform:scale(1.03);box-shadow:0 14px 34px rgba(0,0,0,.55);transition:none}
.bucket{border:1px dashed transparent;margin:0 -4px;padding:0 4px}
.bucket.dropover{border-color:var(--sys);background:color-mix(in srgb,var(--sys) 6%,transparent)}
.draghint{font-size:9px;letter-spacing:1px;color:var(--dim);text-transform:uppercase;padding:2px 0 6px}
.badge{font-size:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:2px 6px;font-family:ui-monospace,Menlo,monospace}
.tagb{font-size:9px;font-weight:700;letter-spacing:.5px;padding:2px 7px;font-family:ui-monospace,monospace;border:1px solid var(--line2);color:var(--muted);border-radius:9px}
.pips{font-size:9px;letter-spacing:1px;font-family:ui-monospace,monospace}
.qbody{cursor:pointer}
.qbody:active .qtitle{color:var(--sys)}
.qtitle{font-size:14px;font-weight:700;line-height:1.3;margin-top:8px}
.qnote{font-size:11px;color:var(--muted);line-height:1.45;margin-top:4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.qreadmore{font-size:9px;letter-spacing:1px;text-transform:uppercase;color:var(--sys);font-family:ui-monospace,monospace;margin-top:6px;display:inline-flex;align-items:center;gap:4px;opacity:.75}
.detailnote{padding:12px;background:var(--field);border:1px solid var(--line);border-left:3px solid var(--dim);font-size:13px;color:var(--body);line-height:1.6;margin-top:6px;word-break:break-word}
.detailnote a{color:var(--sys);text-decoration:underline;word-break:break-all}
.detailnote code{background:var(--line);padding:1px 5px;font-family:ui-monospace,monospace;font-size:12px}
.md-h{font-weight:700;color:var(--text);margin-top:8px}
.md-li{padding-left:6px}
.md-li span{color:var(--dim)}
.md-chk{padding-left:2px}
.md-chk .md-on{color:var(--sys)}
.md-gap{height:7px}
.detailmeta{font-size:12px;color:var(--muted);margin-top:6px;line-height:1.5;word-break:break-word}
.qmeta{display:flex;justify-content:space-between;font-size:8px;letter-spacing:1px;text-transform:uppercase;color:var(--dim);margin-top:8px;font-family:ui-monospace,monospace}
.stbtn{font-size:9px;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:3px 6px;color:var(--inv)}
.icobtn{padding:8px;color:var(--dim);background:none;font-size:15px;line-height:1}
.empty{text-align:center;padding:40px 0;font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--dim);font-family:ui-monospace,monospace}
.empty svg{width:44px;height:44px;opacity:.5}
#overlay{position:fixed;inset:0;background:color-mix(in srgb,var(--bg) 96%,transparent);display:flex;align-items:center;justify-content:center;padding:16px;z-index:50}
#overlay.hidden{display:none}
.modal{width:100%;max-width:440px;background:var(--card);border:1px solid var(--line);padding:16px;max-height:88vh;overflow-y:auto}
.modal h2{font-size:13px;font-weight:800;letter-spacing:2px;text-transform:uppercase}
input,textarea,select{width:100%;background:var(--field);border:1px solid var(--line2);color:var(--text);font-size:13px;font-family:inherit;padding:9px;margin-top:10px}
textarea{resize:vertical}
.note-p{font-size:11px;color:var(--muted);line-height:1.55;margin-top:10px}
.tiny{font-size:10px;color:var(--dim);line-height:1.5;margin-top:10px}
.toast{position:fixed;left:0;right:0;bottom:24px;display:flex;justify-content:center;pointer-events:none;z-index:60}
.toast.hidden{display:none}
.toast div{background:var(--sys);color:var(--inv);font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:8px 18px;box-shadow:0 0 20px var(--sys);font-family:ui-monospace,monospace}
.infostep{padding:10px;background:var(--field);border:1px solid var(--line);margin-top:8px}
.infostep b{font-size:10px;color:var(--sys);letter-spacing:1px;text-transform:uppercase;font-family:ui-monospace,monospace}
.infostep p{font-size:11px;color:var(--muted);margin-top:3px;line-height:1.45}
.infohd{font-size:9px;letter-spacing:1.5px;text-transform:uppercase;color:var(--dim);margin-top:18px;margin-bottom:2px;font-family:ui-monospace,Menlo,monospace}
.spin{animation:sp 6s linear infinite}@keyframes sp{to{transform:rotate(360deg)}}
.x{background:none;color:var(--muted);font-size:20px;line-height:1;padding:2px 6px}
.filterbar{position:sticky;top:env(safe-area-inset-top,0px);z-index:20;background:var(--bg);border-bottom:1px solid var(--line);padding-top:10px}
.searchwrap{position:relative}
.searchclear{position:absolute;right:3px;top:0;height:100%;width:34px;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:18px;background:none}
.fab{position:fixed;right:max(16px,calc(50vw - 240px + 16px));bottom:max(20px,env(safe-area-inset-bottom));width:56px;height:56px;border-radius:50%;background:var(--sys);color:var(--inv);font-size:30px;font-weight:400;line-height:1;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 22px color-mix(in srgb,var(--sys) 45%,transparent);z-index:40;transition:transform .15s ease}
.fab:active{transform:scale(.9)}
#overlay:not(.hidden) .modal{animation:popin .18s ease}
@keyframes popin{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.toolrow{display:flex;gap:6px;margin-top:8px;align-items:stretch;flex-wrap:wrap}
.toolrow select{width:auto;flex:1 1 130px;min-width:0;margin-top:0;padding:7px 8px;font-size:11px;background:var(--card);border:1px solid var(--line);color:var(--body);font-family:ui-monospace,Menlo,monospace}
.grpbtn{flex-shrink:0;font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:7px 12px;border:1px solid var(--line);background:var(--card);color:var(--muted)}
.grpbtn.on{background:var(--solid);color:var(--solid-text)}
.grouphd{display:flex;align-items:center;gap:8px;margin:14px 0 8px;font-size:10px;letter-spacing:1.5px;text-transform:uppercase;font-family:ui-monospace,Menlo,monospace}
.grouphd:first-child{margin-top:2px}
.grouphd .gdot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.grouphd .gcnt{font-size:9px;color:var(--dim)}
.subprog{display:flex;align-items:center;gap:8px;margin-top:8px}
.subprog .track{flex:1;height:4px;background:var(--field);border:1px solid var(--line)}
.subprog .fill{height:100%;background:var(--sys)}
.subprog span{font-size:9px;color:var(--muted);font-family:ui-monospace,monospace;flex-shrink:0}
.subitem{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--line)}
.subcheck{width:22px;height:22px;border:1px solid var(--dim);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:13px;color:var(--sys);background:var(--field)}
.subcheck.on{background:var(--sys);color:var(--inv);border-color:var(--sys)}
.subtext{flex:1;font-size:13px;line-height:1.4;word-break:break-word}
.statgrid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:12px}
.statcard{background:var(--field);border:1px solid var(--line);padding:12px}
.statcard .n{font-size:22px;font-weight:800;font-family:ui-monospace,monospace;font-variant-numeric:tabular-nums;line-height:1}
.statcard .l{font-size:9px;letter-spacing:1px;text-transform:uppercase;color:var(--dim);margin-top:6px;font-family:ui-monospace,monospace}
.sbar{display:flex;align-items:center;gap:8px;margin-top:8px;font-size:11px}
.sbar .nm{width:38%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--body)}
.sbar .track{flex:1;height:8px;background:var(--field);border:1px solid var(--line)}
.sbar .fill{height:100%}
.sbar .c{width:26px;text-align:right;color:var(--muted);font-family:ui-monospace,monospace;font-variant-numeric:tabular-nums}
.duepre{padding:6px 12px;font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;border:1px solid var(--line2);background:transparent;color:var(--muted);font-family:ui-monospace,monospace}
.duepre:active{background:var(--line)}
.bulkbar{position:fixed;left:0;right:0;bottom:0;z-index:45;max-width:480px;margin:0 auto;background:var(--card);border-top:1px solid var(--line);display:flex;align-items:center;gap:6px;padding:10px 12px;padding-bottom:calc(10px + env(safe-area-inset-bottom))}
.bulkbar.hidden{display:none}
.modeseg{display:flex;gap:4px;margin-bottom:10px}
.modeseg button{flex:1;font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:9px;border:1px solid var(--line);background:var(--card);color:var(--dim);display:flex;align-items:center;justify-content:center;gap:6px}
.modeseg button.on{background:var(--sys);color:var(--inv);border-color:var(--sys);box-shadow:0 0 12px color-mix(in srgb,var(--sys) 30%,transparent)}
.notec{padding:12px;margin-bottom:8px;border:1px solid var(--line);background:var(--card);border-left:3px solid var(--dim)}
.notec .ntitle{font-size:14px;font-weight:700;line-height:1.3}
.notec .npin{color:var(--sys);font-size:12px;flex-shrink:0}
.nmeta{display:flex;justify-content:space-between;font-size:8px;letter-spacing:1px;text-transform:uppercase;color:var(--dim);margin-top:8px;font-family:ui-monospace,monospace}
.pill{flex:1;padding:8px 4px;font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;border:1px solid var(--line2);background:transparent;font-family:ui-monospace,monospace}
.hidden{display:none!important}
#ptr{position:fixed;top:calc(6px + env(safe-area-inset-top));left:0;right:0;display:flex;justify-content:center;z-index:30;pointer-events:none;opacity:0;transition:opacity .15s}
#ptr div{background:var(--card);border:1px solid var(--sys);color:var(--sys);font-size:10px;letter-spacing:1px;text-transform:uppercase;font-family:ui-monospace,monospace;padding:6px 14px}
#celebrate{position:fixed;inset:0;z-index:70;display:flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--bg) 82%,transparent);pointer-events:none}
#celebrate.hidden{display:none}
#celebrate>div{text-align:center}
#celebrate .big{font-size:34px;font-weight:800;letter-spacing:3px;color:var(--sys);font-family:ui-monospace,monospace;text-shadow:0 0 30px var(--sys);animation:cele .5s ease}
#celebrate .sub2{text-align:center;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--text);margin-top:8px}
@keyframes cele{from{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}
#celebrate .cf{position:absolute;top:38%;width:8px;height:8px;animation:cfall 1.4s ease-in forwards}
@keyframes cfall{from{transform:translateY(0) rotate(0)}to{transform:translateY(52vh) rotate(540deg);opacity:0}}
.skel{height:74px;border:1px solid var(--line);background:linear-gradient(100deg,var(--card) 40%,var(--line) 50%,var(--card) 60%);background-size:200% 100%;animation:skel 1.2s infinite linear;margin-bottom:8px}
@keyframes skel{to{background-position:-200% 0}}
.obstep{text-align:center;padding:18px 6px}
.obstep .obico{font-size:38px}
.obstep h3{font-size:13px;letter-spacing:2px;text-transform:uppercase;margin-top:12px}
.obstep p{font-size:12px;color:var(--muted);line-height:1.6;margin-top:8px}
.obdots{display:flex;justify-content:center;gap:6px;margin-top:14px}
.obdots span{width:7px;height:7px;border-radius:50%;background:var(--line2)}
.obdots span.on{background:var(--sys)}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
}
