:root{
  --bg:#0b0b0d; --surface:#141417; --surface2:#1c1c21; --line:#2a2a31;
  --text:#f3f1ec; --muted:#8c8c95; --accent:#e0241f; --accent-d:#b51c18; --accent-2:#ff6a3d;
  --good:#2ec46b; --mid:#f4c01f; --bad:#e0241f;
  --r:16px; --r-sm:10px;
  --shadow:0 18px 40px -20px rgba(0,0,0,.8);
  --bebas:'Bebas Neue',Impact,sans-serif; --body:'Manrope',system-ui,sans-serif;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;height:100%}
body{
  font-family:var(--body); background:var(--bg); color:var(--text);
  background-image:radial-gradient(120% 80% at 50% -10%, #1a1a1f 0%, var(--bg) 55%);
  -webkit-font-smoothing:antialiased; line-height:1.45;
  padding-bottom:env(safe-area-inset-bottom);
}
#app{max-width:520px;margin:0 auto;min-height:100%;display:flex;flex-direction:column}
.screen{flex:1;padding:18px 18px 92px;animation:rise .4s ease both}
@keyframes rise{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
h1,h2,h3{margin:0}
.kicker{font-family:var(--bebas);letter-spacing:.16em;color:var(--accent);font-size:14px;text-transform:uppercase}
.title{font-family:var(--bebas);font-size:42px;line-height:.92;letter-spacing:.01em;text-transform:uppercase}
.sub{color:var(--muted);font-size:14px;margin-top:4px}
.muted{color:var(--muted)}
.row{display:flex;gap:10px;align-items:center}
.between{justify-content:space-between}
.wrap{flex-wrap:wrap}

/* top bar */
.topbar{display:flex;align-items:center;justify-content:space-between;padding:16px 18px 6px}
.brand{font-family:var(--bebas);font-size:28px;letter-spacing:.18em}
.brand b{color:var(--accent)}
.brand .dot{color:var(--accent)}

/* cards */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:16px;box-shadow:var(--shadow)}
.card+.card{margin-top:14px}
.card.tight{padding:13px}
.list>*+*{margin-top:10px}

/* buttons */
button,.btn{font-family:var(--body);font-weight:700;font-size:15px;border:none;border-radius:var(--r-sm);
  padding:14px 16px;cursor:pointer;transition:transform .12s ease,filter .12s ease;width:100%}
button:active,.btn:active{transform:scale(.985)}
.btn-primary{background:linear-gradient(180deg,var(--accent),var(--accent-d));color:#fff;
  box-shadow:0 10px 24px -10px var(--accent)}
.btn-ghost{background:var(--surface2);color:var(--text);border:1px solid var(--line)}
.btn-line{background:transparent;border:1px solid var(--accent);color:var(--accent)}
.btn-sm{padding:9px 12px;font-size:13px;width:auto}
.btn:disabled{opacity:.5;pointer-events:none}

/* inputs */
label.field{display:block;margin-top:12px}
label.field span{display:block;font-size:12.5px;color:var(--muted);margin-bottom:5px;letter-spacing:.02em}
input,select,textarea{width:100%;background:var(--surface2);border:1px solid var(--line);color:var(--text);
  border-radius:var(--r-sm);padding:13px 14px;font-family:var(--body);font-size:15px}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent)}
.codebox{font-family:var(--bebas);font-size:30px;letter-spacing:.3em;text-align:center;text-transform:uppercase}

/* pills / chips */
.chip{display:inline-flex;align-items:center;gap:6px;background:var(--surface2);border:1px solid var(--line);
  border-radius:999px;padding:6px 12px;font-size:12.5px;color:var(--muted)}
.tag{font-family:var(--bebas);letter-spacing:.12em;font-size:13px;background:var(--surface2);
  border:1px solid var(--line);color:var(--muted);padding:3px 9px;border-radius:6px;text-transform:uppercase}

/* score donut */
.score{font-family:var(--bebas);font-size:54px;line-height:.8}
.score small{font-size:18px;color:var(--muted)}
.scorewrap{display:flex;align-items:center;gap:16px}
.ring{--p:0;--c:var(--good);width:86px;height:86px;border-radius:50%;flex:0 0 auto;
  background:conic-gradient(var(--c) calc(var(--p)*3.6deg), #26262c 0);display:grid;place-items:center}
.ring i{width:68px;height:68px;border-radius:50%;background:var(--surface);display:grid;place-items:center;font-style:normal;
  font-family:var(--bebas);font-size:34px}
.verdict{font-family:var(--bebas);letter-spacing:.12em;font-size:18px;text-transform:uppercase}
.v-apto{color:var(--good)} .v-moderado{color:var(--mid)} .v-evitar{color:var(--bad)}

/* exercise rows */
.exrow{display:flex;align-items:center;gap:12px;padding:13px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-sm)}
.exrow .n{font-family:var(--bebas);font-size:22px;color:var(--accent);width:24px;text-align:center}
.exrow .checkbtn{background:none;border:2px solid var(--line);color:var(--accent);width:36px;height:36px;
  border-radius:50%;font-family:var(--bebas);font-size:18px;display:grid;place-items:center;flex:0 0 auto;padding:0}
.exrow.done{outline:2px solid var(--good);outline-offset:-2px}
.exrow.done .checkbtn{border-color:var(--good);color:var(--good);background:rgba(46,196,107,.14)}
.exrow.done .exname{color:var(--muted);text-decoration:line-through}
.exrow .meta{font-size:12.5px;color:var(--muted);margin-top:2px}
.exrow a.vid{color:var(--accent-2);font-size:12.5px;text-decoration:none;font-weight:700}
.daypills{display:flex;gap:8px;overflow-x:auto;padding-bottom:6px;margin:0 -2px}
.daypills::-webkit-scrollbar{display:none}
.daypill{font-family:var(--bebas);letter-spacing:.1em;font-size:16px;padding:10px 16px;border-radius:10px;
  background:var(--surface);border:1px solid var(--line);color:var(--muted);white-space:nowrap;flex:0 0 auto}
.daypill.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.daypill.doneday{border-color:var(--good);color:var(--good)}
.daypill.active.doneday{background:var(--accent);color:#fff;border-color:var(--accent)}
.sugdel{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:50%;background:var(--surface2);
  border:1px solid var(--line);color:var(--muted);font-size:14px;padding:0;display:grid;place-items:center;width:28px}

/* meals */
.opt{border:1px solid var(--line);border-radius:var(--r-sm);padding:13px;background:var(--surface)}
.opt.done{border-color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent)}
.opt h4{font-family:var(--bebas);letter-spacing:.08em;font-size:18px;margin:0 0 8px}
.opt ul{margin:0;padding-left:18px;font-size:14px;color:#d8d6d0}
.opt li{margin:2px 0}
.done{outline:2px solid var(--good);outline-offset:-2px}

/* bottom nav */
.nav{position:fixed;left:0;right:0;bottom:0;z-index:30;background:rgba(15,15,18,.92);
  backdrop-filter:blur(12px);border-top:1px solid var(--line);display:flex;
  max-width:520px;margin:0 auto;padding:8px 6px calc(8px + env(safe-area-inset-bottom))}
.nav button{background:none;flex:1;color:var(--muted);font-size:10.5px;font-weight:700;display:flex;
  flex-direction:column;align-items:center;gap:3px;padding:6px 2px;letter-spacing:.04em}
.nav button.active{color:var(--accent)}
.nav svg{width:23px;height:23px}

/* misc */
.center{min-height:78vh;display:flex;flex-direction:column;justify-content:center}
.spin{width:30px;height:30px;border:3px solid var(--line);border-top-color:var(--accent);border-radius:50%;animation:sp 1s linear infinite;margin:18px auto}
@keyframes sp{to{transform:rotate(360deg)}}
.toast{position:fixed;left:50%;bottom:96px;transform:translateX(-50%);background:#000;border:1px solid var(--line);
  color:#fff;padding:11px 16px;border-radius:10px;font-size:13.5px;z-index:50;max-width:90%;box-shadow:var(--shadow)}
video,canvas.cam{width:100%;border-radius:var(--r);background:#000;aspect-ratio:3/4;object-fit:cover}
.scanbox{position:relative}
.scanline{position:absolute;left:8%;right:8%;height:2px;background:var(--accent);box-shadow:0 0 12px var(--accent);
  top:50%;animation:scan 2s ease-in-out infinite}
@keyframes scan{0%,100%{top:28%}50%{top:72%}}
.hr{height:1px;background:var(--line);margin:14px 0}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.stat{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-sm);padding:13px}
.stat .v{font-family:var(--bebas);font-size:30px}
.stat .l{font-size:11.5px;color:var(--muted);letter-spacing:.04em}
.code-item{display:flex;justify-content:space-between;align-items:center;padding:11px 13px;background:var(--surface);
  border:1px solid var(--line);border-radius:var(--r-sm);font-family:var(--bebas);letter-spacing:.18em;font-size:18px}
.code-item small{font-family:var(--body);letter-spacing:0;font-size:11px}
