@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&family=Comfortaa:wght@600;700&display=swap');

:root{
  --bg:#0a0a0a; --surface:#141414; --surface2:#1b1b1b; --line:#262626; --line2:#333;
  --text:#f6f6f6; --muted:#8a8a8a; --white:#ffffff;
  --ok:#62d07f; --skip:#777; --crit:#ff6b6b; --accentdim:#e9e4d8;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;}
html,body{height:100%;}
body{font-family:'Manrope',system-ui,sans-serif;background:var(--bg);color:var(--text);
  overscroll-behavior:none;-webkit-font-smoothing:antialiased;}
#app{max-width:640px;margin:0 auto;padding:18px 18px 48px;min-height:100%;}

/* wordmark jikon */
.wm{font-family:'Comfortaa',sans-serif;font-weight:700;letter-spacing:-.5px;line-height:1;}
.h{display:flex;align-items:flex-end;justify-content:space-between;margin:8px 2px 22px;}
.h .wm{font-size:34px;}
.h .wm sup{font-size:11px;font-weight:600;vertical-align:super;opacity:.6;margin-left:1px;}
.h .who{text-align:right;font-size:12px;color:var(--muted);letter-spacing:.5px;
  text-transform:uppercase;padding-bottom:5px;}

.tag{font-size:11px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--muted);}

.icn{display:inline-flex;width:24px;height:24px;color:var(--text);}
.icn svg{width:100%;height:100%;fill:none;stroke:currentColor;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;}

.status{background:var(--surface);border:1px solid var(--line);border-radius:16px;
  padding:15px 16px;margin-bottom:18px;display:flex;align-items:center;gap:12px;}
.status .dot{width:8px;height:8px;border-radius:50%;background:var(--ok);flex:none;
  box-shadow:0 0 0 4px rgba(98,208,127,.15);}
.status .t{font-size:13.5px;color:var(--muted);line-height:1.4;}

.cards{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.tile{background:var(--surface);border:1px solid var(--line);border-radius:20px;padding:20px 18px;
  cursor:pointer;transition:transform .08s,border-color .2s;position:relative;overflow:hidden;}
.tile:active{transform:scale(.97);border-color:var(--line2);}
.tile .ic{display:inline-flex;width:30px;height:30px;color:var(--text);opacity:.9;}
.tile .ic svg{width:100%;height:100%;fill:none;stroke:currentColor;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round;}
.tile h3{font-size:16px;font-weight:700;margin:14px 0 4px;letter-spacing:-.2px;}
.tile p{font-size:12.5px;color:var(--muted);}
.tile .pg{margin-top:12px;font-size:12px;font-weight:700;color:var(--text);letter-spacing:.3px;}
.tile.admin{grid-column:1/3;background:var(--white);color:#0a0a0a;border:none;}
.tile.admin h3{color:#0a0a0a;} .tile.admin p{color:#555;} .tile.admin .ic{color:#0a0a0a;opacity:1;}

/* статусная подсветка плиток */
.tbadge{position:absolute;top:13px;right:13px;font-size:10px;font-weight:800;letter-spacing:.6px;
  text-transform:uppercase;padding:3px 9px;border-radius:99px;}
.tbadge.urgent{background:var(--crit);color:#fff;}
.tbadge.soon{background:var(--gold);color:#1a1206;}
.tbadge.done{background:#163a27;color:#62d07f;}
.tile.t-urgent{border-color:var(--crit);box-shadow:0 0 0 1px var(--crit),0 0 22px rgba(255,107,107,.28);
  animation:pulseU 1.9s ease-in-out infinite;}
.tile.t-soon{border-color:#7a5a2a;box-shadow:0 0 0 1px rgba(200,137,47,.45);}
.tile.t-done{opacity:.6;} .tile.t-done h3{color:var(--muted);}
@keyframes pulseU{0%,100%{box-shadow:0 0 0 1px var(--crit),0 0 12px rgba(255,107,107,.20);}
  50%{box-shadow:0 0 0 1px var(--crit),0 0 26px rgba(255,107,107,.45);}}
.status.urgent{border-color:rgba(255,107,107,.45);}
.status.urgent .dot{background:var(--crit);box-shadow:0 0 0 4px rgba(255,107,107,.16);}
.status.soon .dot{background:var(--gold);box-shadow:0 0 0 4px rgba(200,137,47,.16);}

.bar{height:6px;border-radius:99px;background:#242424;overflow:hidden;margin:10px 0;}
.bar > i{display:block;height:100%;background:var(--white);transition:width .35s ease;border-radius:99px;}

.topbar{display:flex;align-items:center;gap:14px;margin-bottom:18px;}
.back{width:42px;height:42px;border-radius:13px;background:var(--surface);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;cursor:pointer;flex:none;}
.back svg{width:20px;height:20px;stroke:var(--text);fill:none;stroke-width:2;}
.topbar .ttl{font-weight:800;font-size:19px;letter-spacing:-.3px;}
.topbar .cnt{margin-left:auto;font-weight:700;color:var(--muted);font-variant-numeric:tabular-nums;}

.step{background:var(--surface);border:1px solid var(--line);border-radius:24px;padding:26px 24px;
  min-height:250px;display:flex;flex-direction:column;}
.step .sn{font-size:12px;color:var(--muted);font-weight:700;letter-spacing:1.5px;text-transform:uppercase;}
.step .crit{color:var(--crit);}
.step .txt{font-size:25px;font-weight:700;line-height:1.25;margin:14px 0;flex:1;letter-spacing:-.4px;}
.step .lbl{font-size:14px;color:var(--muted);}
.step .state{margin-top:8px;font-weight:700;font-size:14px;}
.state.ok{color:var(--ok);} .state.skip{color:var(--muted);}

.btns{display:flex;flex-direction:column;gap:10px;margin-top:20px;}
.btn{border:none;border-radius:15px;padding:17px;font-size:16px;font-weight:700;cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:8px;font-family:inherit;letter-spacing:.2px;
  transition:transform .07s,opacity .2s;}
.btn:active{transform:scale(.98);}
.btn .icn{width:20px;height:20px;}
.btn.gold{background:var(--white);color:#0a0a0a;}            /* основная — белая */
.btn.gold .icn{color:#0a0a0a;}
.btn.dark{background:var(--surface2);color:var(--text);border:1px solid var(--line2);}
.btn.ghost{background:transparent;border:1px solid var(--line2);color:var(--text);}
.btn.red{background:transparent;border:1px solid rgba(255,107,107,.4);color:var(--crit);}
.btn.sm{padding:13px;font-size:14px;}
.nav{display:flex;gap:10px;margin-top:12px;}
.nav .btn{flex:1;}

.field{width:100%;padding:15px;border-radius:14px;border:1px solid var(--line2);font-size:16px;
  margin-top:12px;background:var(--surface2);color:var(--text);font-family:inherit;}
.field::placeholder{color:#666;}
textarea.field{resize:none;min-height:84px;}

/* камера */
.cam{position:fixed;inset:0;background:#000;z-index:50;display:flex;flex-direction:column;}
.cam video,.cam img{flex:1;width:100%;object-fit:cover;background:#000;}
.cam .ctl{padding:22px;display:flex;gap:12px;align-items:center;justify-content:center;background:#000;}
.cam .shoot{width:72px;height:72px;border-radius:50%;border:4px solid #fff;background:transparent;
  cursor:pointer;box-shadow:0 0 0 2px #000 inset;}
.cam .shoot:active{background:rgba(255,255,255,.25);}
.cam .x{position:absolute;top:16px;right:16px;width:42px;height:42px;border-radius:50%;
  background:rgba(255,255,255,.12);color:#fff;border:none;font-size:20px;cursor:pointer;z-index:2;}
.cam .hint{position:absolute;top:18px;left:0;right:0;text-align:center;color:#fff;font-size:13px;opacity:.8;}

/* список */
.list .row{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--line);
  border-radius:15px;padding:15px;margin-bottom:9px;cursor:pointer;}
.list .row:active{border-color:var(--line2);}
.list .row .m{width:24px;height:24px;flex:none;color:var(--text);opacity:.85;}
.list .row .m svg{width:100%;height:100%;fill:none;stroke:currentColor;stroke-width:1.7;}
.list .row.done{opacity:.5;} .list .row.skipped{opacity:.55;}
.list .row .tx{font-size:15px;flex:1;}
.list .row .mini{font-size:11px;color:var(--muted);margin-top:3px;}
.list .row .mini.crit{color:var(--crit);}

/* итог */
.done-card{text-align:center;padding:38px 22px;}
.done-card .big{width:88px;height:88px;border-radius:50%;margin:0 auto 18px;
  background:var(--white);display:flex;align-items:center;justify-content:center;}
.done-card .big svg{width:42px;height:42px;stroke:#0a0a0a;fill:none;stroke-width:2.5;}

/* дашборд */
.sec{background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:18px;margin-bottom:14px;}
.sec h3{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:2px;margin-bottom:14px;font-weight:700;}
.line{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--line);font-size:15px;}
.line:last-child{border:none;}
.pillm{display:inline-block;background:var(--surface2);border:1px solid var(--line2);border-radius:99px;padding:2px 10px;font-size:13px;font-weight:700;}
.r{color:var(--crit);} .g{color:var(--ok);}
.feed{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;}
.feed img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:12px;background:var(--surface2);border:1px solid var(--line);}

.acts{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.chip{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--line);
  border-radius:14px;padding:15px 14px;cursor:pointer;font-size:14px;font-weight:600;}
.chip:active{border-color:var(--line2);transform:scale(.98);}
.chip .icn{width:20px;height:20px;color:var(--muted);flex:none;}
.admin-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px;}
.muted2{color:var(--muted);font-size:13px;margin:2px 0 12px;}
select.field{appearance:none;}
.itemrow{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--line);
  border-radius:13px;padding:12px 14px;margin-bottom:8px;}
.itemrow .tx{flex:1;font-size:14px;} .itemrow .mini{font-size:11px;color:var(--muted);}
.iconbtn{width:34px;height:34px;border-radius:9px;border:1px solid var(--line2);background:transparent;
  color:var(--text);display:flex;align-items:center;justify-content:center;cursor:pointer;flex:none;}
.iconbtn svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.8;}
.tabs{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap;}
.tab{padding:9px 14px;border-radius:99px;border:1px solid var(--line2);font-size:13px;font-weight:700;cursor:pointer;color:var(--muted);}
.tab.on{background:var(--white);color:#0a0a0a;border-color:var(--white);}

.toast{position:fixed;left:50%;bottom:28px;transform:translateX(-50%) translateY(40px);
  background:var(--white);color:#0a0a0a;padding:12px 22px;border-radius:99px;font-size:14px;font-weight:600;
  opacity:0;transition:.25s;z-index:100;pointer-events:none;max-width:90%;text-align:center;}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
.center{display:flex;align-items:center;justify-content:center;min-height:60vh;color:var(--muted);}

/* афиша: обложки событий */
.sec.evc{cursor:pointer;transition:border-color .15s;}
.sec.evc:active{border-color:var(--line2);}
.evcover{border-radius:14px;overflow:hidden;margin-bottom:12px;border:1px solid var(--line);}
.evcover img{width:100%;display:block;aspect-ratio:16/9;object-fit:cover;background:var(--surface2);}
.evcover.lg{border-radius:18px;margin-bottom:14px;}
.evcover.lg img{aspect-ratio:4/3;}
.evdesc{font-size:14px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}

/* афиша: информационная шапка */
.hero{background:linear-gradient(160deg,#1b1b20,#0d0d0f);border:1px solid var(--line);border-radius:20px;padding:22px;margin-bottom:18px;}
.hero-t{font-size:22px;font-weight:800;letter-spacing:-.3px;}
.hero-s{font-size:14px;color:var(--muted);margin-top:8px;line-height:1.5;}
.hero-perk{margin-top:14px;background:rgba(230,182,98,.12);border:1px solid rgba(230,182,98,.35);color:var(--gold2);border-radius:12px;padding:11px 13px;font-size:13px;line-height:1.45;}

/* билет / QR */
.tk{text-align:center;}
.qrbox{background:#fff;border-radius:16px;padding:16px;width:min(260px,72vw);margin:0 auto 14px;}
.qrbox img,.qrbox svg{width:100%;height:auto;display:block;}
.tkcode{font-family:ui-monospace,Menlo,Consolas,monospace;font-size:22px;font-weight:800;letter-spacing:3px;color:var(--text);}
.tkstatus{margin-top:10px;font-size:14px;color:var(--muted);}
.tkstatus.ok{color:var(--ok);font-weight:700;}
