:root{
  --bg:#0A0E14;--surface:#141A23;--surface-2:#1C242F;--border:#222B38;
  --text:#FFFFFF;--text-2:#8B95A3;--text-3:#5B6573;
  --mint:#3DDC97;--mint-soft:#3DDC9722;--orange:#FFB347;--orange-soft:#FFB34722;
  --red:#FF5C5C;--red-soft:#FF5C5C22;--cyan:#4FC3F7;--cyan-soft:#4FC3F722;
  --purple:#8E7DFF;--purple-soft:#8E7DFF22;
  --grad-mint:linear-gradient(135deg,#3DDC97 0%,#2BB385 100%);
  --grad-purple:linear-gradient(135deg,#8E7DFF 0%,#5E4BDB 100%);
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{background:var(--bg);color:var(--text);font-family:'Inter',-apple-system,sans-serif;font-size:15px;line-height:1.45;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
button{font-family:inherit}

.phone{max-width:420px;margin:0 auto;min-height:100vh;padding-bottom:90px}

/* header */
.header{display:flex;justify-content:space-between;align-items:center;padding:20px 20px 14px}
.greet small{display:block;color:var(--text-2);font-size:13px;font-weight:500}
.greet h1{font-size:22px;font-weight:700;margin-top:2px}
.avatar{width:42px;height:42px;background:var(--surface-2);border-radius:50%;display:grid;place-items:center;font-weight:700;font-size:15px;color:var(--text)}
.icon-btn{width:42px;height:42px;border-radius:14px;background:var(--surface);border:none;color:var(--text);display:grid;place-items:center;cursor:pointer}
.icon-btn svg{width:20px;height:20px}
.badge-admin{font-size:10px;font-weight:700;color:var(--purple);background:var(--purple-soft);padding:3px 8px;border-radius:50px;letter-spacing:.04em;margin-left:6px;vertical-align:middle}

/* topbar (detail) */
.topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 16px}
.topbar .title{font-size:14px;color:var(--text-2);font-weight:600}

/* hero */
.hero{margin:8px 16px 20px;background:var(--grad-mint);border-radius:24px;padding:24px;position:relative;overflow:hidden;color:#0A1F18}
.hero.purple{background:var(--grad-purple);color:#fff}
.hero::before{content:'';position:absolute;right:-50px;top:-50px;width:220px;height:220px;background:radial-gradient(circle,rgba(255,255,255,.22),transparent 70%)}
.hero .badge{display:inline-flex;align-items:center;gap:6px;background:rgba(10,31,24,.18);padding:6px 10px;border-radius:50px;font-size:12px;font-weight:600}
.hero.purple .badge{background:rgba(255,255,255,.18)}
.hero .badge::before{content:'';width:6px;height:6px;background:currentColor;border-radius:50%;opacity:.6}
.hero .label{font-size:13px;font-weight:600;margin-top:14px;opacity:.75}
.hero .score{display:flex;align-items:baseline;gap:10px;margin-top:4px}
.hero .score b{font-size:64px;font-weight:800;letter-spacing:-.03em;line-height:1}
.hero .score span{font-size:24px;font-weight:600;opacity:.5}
.hero .grade{font-size:32px;font-weight:800;margin-left:auto}
.hero .delta{margin-left:auto;background:rgba(255,255,255,.18);padding:6px 10px;border-radius:50px;font-size:13px;font-weight:700}
.hero-row{display:flex;justify-content:space-between;margin-top:18px;padding-top:14px;border-top:1px solid rgba(10,31,24,.15);font-size:12px;font-weight:500;opacity:.85}
.hero.purple .hero-row{border-top-color:rgba(255,255,255,.18)}
.hero-row > div b{display:block;font-size:14px;font-weight:700;opacity:1;margin-bottom:2px}

/* CTA */
.cta{margin:0 16px 24px;display:flex;gap:12px}
.cta button,.cta a{flex:1;border:none;border-radius:18px;padding:18px;font-size:16px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;color:var(--text);text-decoration:none}
.cta .primary{background:var(--mint);color:#0A1F18}
.cta .primary svg{width:20px;height:20px}
.cta .secondary{flex:0 0 64px;background:var(--surface-2);padding:0}

/* stats */
.stats{margin:0 16px 24px;display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.stat{background:var(--surface);border-radius:16px;padding:14px}
.stat .v{font-size:22px;font-weight:700;letter-spacing:-.02em}
.stat .v.up{color:var(--mint)}
.stat .v.down{color:var(--red)}
.stat .l{font-size:11px;color:var(--text-2);font-weight:500;margin-top:2px}

/* section */
.section{margin:0 16px 24px}
.section-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.section-head h2{font-size:17px;font-weight:700}
.section-head a{color:var(--mint);font-size:13px;font-weight:600}
.section-head .pill{background:var(--surface-2);color:var(--text-2);padding:3px 10px;border-radius:50px;font-size:11px;font-weight:600}

/* list items */
.list{display:flex;flex-direction:column;gap:8px}
.item{background:var(--surface);border-radius:16px;padding:14px;display:flex;align-items:center;gap:14px;cursor:pointer;transition:transform .1s}
.item:active{transform:scale(.98)}
.item .ring{flex:0 0 46px;height:46px;border-radius:50%;display:grid;place-items:center;font-weight:700;font-size:15px;background:var(--surface-2)}
.item .ring.a{background:var(--mint-soft);color:var(--mint)}
.item .ring.b{background:var(--mint-soft);color:var(--mint);opacity:.8}
.item .ring.c{background:var(--orange-soft);color:var(--orange)}
.item .ring.d{background:var(--red-soft);color:var(--red)}
.item .ring.f{background:var(--red-soft);color:var(--red)}
.item .body{flex:1;min-width:0}
.item .body .title{font-weight:600;font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.item .body .meta{color:var(--text-2);font-size:12px;margin-top:2px}
.item .score{font-weight:700;font-size:17px;letter-spacing:-.02em}

/* admin actions */
.actions{margin:0 16px 24px;display:grid;grid-template-columns:1fr 1fr;gap:10px}
.actions a{background:var(--surface);border-radius:18px;padding:16px;display:flex;flex-direction:column;gap:8px;position:relative;min-height:96px;cursor:pointer}
.actions .ico{width:36px;height:36px;border-radius:10px;display:grid;place-items:center}
.actions .ico svg{width:18px;height:18px}
.actions .ico.green{background:var(--mint-soft);color:var(--mint)}
.actions .ico.red{background:var(--red-soft);color:var(--red)}
.actions .ico.orange{background:var(--orange-soft);color:var(--orange)}
.actions .ico.cyan{background:var(--cyan-soft);color:var(--cyan)}
.actions .t{font-size:14px;font-weight:600;margin-top:auto}
.actions .d{font-size:12px;color:var(--text-2)}
.actions .count{position:absolute;top:14px;right:14px;font-size:11px;font-weight:700;background:var(--red);color:#fff;padding:2px 8px;border-radius:50px}

/* manager card */
.mgr{background:var(--surface);border-radius:16px;padding:14px;margin-bottom:8px;display:flex;align-items:center;gap:12px;cursor:pointer}
.mgr .av{flex:0 0 42px;height:42px;background:var(--surface-2);border-radius:50%;display:grid;place-items:center;font-weight:700;font-size:14px}
.mgr .body{flex:1;min-width:0}
.mgr .name{font-size:14px;font-weight:600}
.mgr .meta{color:var(--text-2);font-size:12px;margin-top:2px;display:flex;gap:10px;flex-wrap:wrap}
.mgr .meta .up{color:var(--mint)}
.mgr .meta .down{color:var(--red)}
.mgr .score{font-size:18px;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:-.02em}
.mgr .score.a{color:var(--mint)}
.mgr .score.c{color:var(--orange)}
.mgr .score.d, .mgr .score.f{color:var(--red)}

/* eval detail */
.block{background:var(--surface);border-radius:14px;padding:12px 14px;margin-bottom:8px;display:flex;align-items:center;gap:12px}
.block .name{flex:1;font-size:14px;font-weight:500}
.block .bar{flex:0 0 90px;height:6px;background:var(--surface-2);border-radius:50px;overflow:hidden}
.block .bar .fill{height:100%;background:var(--mint);border-radius:50px}
.block .bar .fill.mid{background:var(--orange)}
.block .bar .fill.low{background:var(--red)}
.block .pts{font-size:13px;font-weight:700;font-variant-numeric:tabular-nums;color:var(--text-2);width:48px;text-align:right}

.mistake{background:var(--surface);border-radius:18px;padding:16px;margin-bottom:10px;border-left:3px solid var(--red)}
.mistake.major{border-color:var(--orange)}
.mistake.minor{border-color:var(--text-3)}
.mistake .sev{font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--red);background:var(--red-soft);padding:3px 8px;border-radius:50px;display:inline-block;margin-bottom:6px}
.mistake.major .sev{color:var(--orange);background:var(--orange-soft)}
.mistake.minor .sev{color:var(--text-2);background:var(--surface-2)}
.mistake .desc{font-size:14px;font-weight:600;margin-bottom:8px}
.mistake .quote{font-size:13px;color:var(--text-2);background:var(--surface-2);padding:8px 10px;border-radius:10px;margin-bottom:8px;font-style:italic}
.mistake .quote::before{content:'« '}
.mistake .quote::after{content:' »'}
.mistake .better{font-size:13px;background:var(--mint-soft);color:var(--mint);padding:10px 12px;border-radius:10px}
.mistake .better b{display:block;font-size:10px;letter-spacing:.06em;text-transform:uppercase;margin-bottom:3px;font-weight:700}

.rec{background:var(--surface);border-radius:14px;padding:14px;margin-bottom:8px;display:flex;gap:14px;align-items:start}
.rec .n{flex:0 0 28px;height:28px;background:var(--mint-soft);color:var(--mint);border-radius:8px;font-weight:700;font-size:14px;display:grid;place-items:center}
.rec p{font-size:13px;line-height:1.5}

/* errors */
.err{background:var(--surface);border-radius:14px;padding:12px 14px;margin-bottom:8px;display:flex;align-items:center;gap:12px}
.err .n{flex:0 0 32px;height:32px;background:var(--red-soft);color:var(--red);border-radius:10px;font-weight:700;display:grid;place-items:center;font-size:13px}
.err .body{flex:1}
.err .t{font-size:13px;font-weight:500;line-height:1.35}
.err .m{font-size:11px;color:var(--text-2);margin-top:3px}

/* tabbar */
.tabbar{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:420px;background:rgba(10,14,20,.92);backdrop-filter:blur(20px);border-top:1px solid var(--border);display:flex;justify-content:space-around;padding:10px 0 22px;z-index:10}
.tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;color:var(--text-3);font-size:11px;font-weight:600;padding:6px}
.tab.active{color:var(--mint)}
.tab.active.admin{color:var(--purple)}
.tab svg{width:24px;height:24px}

/* states */
.loading{padding:60px 20px;text-align:center;color:var(--text-2)}
.empty{padding:40px 20px;text-align:center;color:var(--text-2);font-size:14px}

/* login */
.login-wrap{display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:30px;text-align:center}
.login-wrap h1{font-size:32px;margin-bottom:10px}
.login-wrap p{color:var(--text-2);margin-bottom:30px}
.login-wrap .tg-btn{background:var(--mint);color:#0A1F18;padding:18px 24px;border-radius:18px;font-weight:700;font-size:16px;display:inline-block}
