/* ============================================================
   РАЗРЯД — design tokens & base styles
   Taekwondo gamification platform
   ============================================================ */

/* ---- Fonts loaded in index.html (Unbounded, Golos Text) ---- */

:root {
  /* shift accent — organizer-chosen brand color (default orange) */
  --shift-accent: #ff5a1f;
  --shift-accent-ink: #1a0d04;       /* text on accent */
  --shift-accent-soft: rgba(255, 90, 31, 0.14);

  /* brand orange (platform) */
  --brand: #ff5a1f;
  --brand-600: #f04d12;

  /* medals (semantic) */
  --gold: #f5b73d;
  --silver: #c2cbd4;
  --bronze: #d08a4e;

  /* taekwondo belts (level colors) */
  --belt-white: #eef0f2;
  --belt-yellow: #f2c43d;
  --belt-green: #4caa6a;
  --belt-blue: #3f7bd6;
  --belt-red: #e24b48;
  --belt-black: #2a2d33;

  /* radii / motion */
  --r-sm: 8px;
  --r-md: 12px;
  --r-lg: 18px;
  --r-xl: 26px;
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);

  --font-display: "Unbounded", system-ui, sans-serif;
  --font-body: "Golos Text", system-ui, sans-serif;

  /* attendance status colors */
  --att-present: #2fb763;
  --att-late: #efb02a;
  --att-absent: #e24b48;
  --att-excused: #8d8475;
}

/* ---------- THEME: DARK (default) ---------- */
[data-theme="dark"] {
  --bg: #15130f;
  --bg-1: #1c1a15;
  --surface: #211e18;
  --surface-2: #29251e;
  --surface-3: #332e25;
  --line: rgba(255, 255, 255, 0.09);
  --line-strong: rgba(255, 255, 255, 0.16);
  --ink: #f6f1e9;
  --ink-2: #c8c0b2;
  --ink-3: #8d8475;
  --shadow: 0 18px 50px -22px rgba(0, 0, 0, 0.8);
  --shadow-sm: 0 6px 18px -10px rgba(0, 0, 0, 0.7);
  --grid-line: rgba(255, 255, 255, 0.035);
}

/* ---------- THEME: LIGHT ---------- */
[data-theme="light"] {
  --bg: #f3efe8;
  --bg-1: #efe9e0;
  --surface: #ffffff;
  --surface-2: #faf7f1;
  --surface-3: #f1ece2;
  --line: rgba(30, 22, 10, 0.10);
  --line-strong: rgba(30, 22, 10, 0.18);
  --ink: #241d12;
  --ink-2: #5c5443;
  --ink-3: #8d8473;
  --shadow: 0 22px 50px -26px rgba(60, 40, 12, 0.40);
  --shadow-sm: 0 8px 20px -14px rgba(60, 40, 12, 0.34);
  --grid-line: rgba(30, 22, 10, 0.045);
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--font-body);
  background: var(--bg);
  color: var(--ink);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* scrollbars */
*::-webkit-scrollbar { width: 10px; height: 10px; }
*::-webkit-scrollbar-thumb { background: var(--line-strong); border-radius: 20px; border: 3px solid transparent; background-clip: padding-box; }
*::-webkit-scrollbar-track { background: transparent; }

/* ---------- typography helpers ---------- */
.display { font-family: var(--font-display); font-weight: 700; letter-spacing: -0.02em; line-height: 0.98; }
.num { font-family: var(--font-display); font-weight: 600; font-variant-numeric: tabular-nums; letter-spacing: -0.01em; }
.eyebrow { font-family: var(--font-body); font-weight: 700; font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-3); }

h1,h2,h3,h4 { margin: 0; }

/* ---------- buttons ---------- */
.btn {
  font-family: var(--font-body); font-weight: 700; font-size: 14px;
  border: none; border-radius: var(--r-md); padding: 11px 18px;
  display: inline-flex; align-items: center; gap: 9px; cursor: pointer;
  transition: transform 0.12s var(--ease), background 0.18s, box-shadow 0.18s, border-color 0.18s, color 0.18s;
  white-space: nowrap; line-height: 1;
}
.btn:active { transform: translateY(1px) scale(0.99); }
.btn-primary { background: var(--shift-accent); color: #fff; box-shadow: 0 10px 24px -12px var(--shift-accent); }
.btn-primary:hover { filter: brightness(1.06); box-shadow: 0 14px 30px -12px var(--shift-accent); }
.btn-ghost { background: var(--surface-2); color: var(--ink); border: 1px solid var(--line); }
.btn-ghost:hover { background: var(--surface-3); border-color: var(--line-strong); }
.btn-quiet { background: transparent; color: var(--ink-2); padding: 9px 12px; }
.btn-quiet:hover { background: var(--surface-2); color: var(--ink); }
.btn-sm { padding: 8px 13px; font-size: 13px; border-radius: var(--r-sm); }
.btn-lg { padding: 15px 26px; font-size: 16px; border-radius: var(--r-lg); }
.btn:disabled { opacity: 0.45; cursor: not-allowed; }

/* ---------- cards ---------- */
.card {
  background: var(--surface); border: 1px solid var(--line);
  border-radius: var(--r-lg); box-shadow: var(--shadow-sm);
}
.card-pad { padding: 22px; }

/* ---------- chips / pills ---------- */
.chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 11px; border-radius: 99px; font-size: 12.5px; font-weight: 600;
  background: var(--surface-2); color: var(--ink-2); border: 1px solid var(--line);
}
.chip-accent { background: var(--shift-accent-soft); color: var(--shift-accent); border-color: transparent; }

/* level/belt swatch */
.belt-dot { width: 14px; height: 14px; border-radius: 4px; flex: none; box-shadow: inset 0 0 0 1px rgba(0,0,0,0.18); }

/* progress bar */
.pbar { height: 8px; border-radius: 99px; background: var(--surface-3); overflow: hidden; position: relative; }
.pbar > span { position: absolute; inset: 0 auto 0 0; border-radius: 99px; background: var(--shift-accent); transition: width 0.7s var(--ease); }

/* input */
.field { display: flex; flex-direction: column; gap: 7px; }
.field > label { font-size: 12.5px; font-weight: 600; color: var(--ink-2); }
.input {
  font-family: var(--font-body); font-size: 14.5px; color: var(--ink);
  background: var(--surface-2); border: 1px solid var(--line);
  border-radius: var(--r-md); padding: 12px 14px; width: 100%;
  transition: border-color 0.16s, box-shadow 0.16s, background 0.16s;
}
.input::placeholder { color: var(--ink-3); }
.input:focus { outline: none; border-color: var(--shift-accent); box-shadow: 0 0 0 3px var(--shift-accent-soft); background: var(--surface); }

/* toggle switch */
.tgl { width: 44px; height: 25px; border-radius: 99px; background: var(--surface-3); border: 1px solid var(--line); position: relative; cursor: pointer; transition: background 0.2s, border-color 0.2s; flex: none; }
.tgl::after { content: ""; position: absolute; top: 2px; left: 2px; width: 19px; height: 19px; border-radius: 50%; background: var(--ink-3); transition: transform 0.22s var(--ease-spring), background 0.2s; }
.tgl[data-on="true"] { background: var(--shift-accent); border-color: transparent; }
.tgl[data-on="true"]::after { transform: translateX(19px); background: #fff; }

/* dotted-grid backdrop */
.gridbg {
  background-image: radial-gradient(var(--grid-line) 1.2px, transparent 1.2px);
  background-size: 22px 22px;
}

/* icon wrapper */
.ic { display: inline-flex; align-items: center; justify-content: center; }
.ic svg { display: block; }

/* utility */
.row { display: flex; align-items: center; }
.col { display: flex; flex-direction: column; }
.gap-2 { gap: 8px; } .gap-3 { gap: 12px; } .gap-4 { gap: 16px; } .gap-5 { gap: 20px; } .gap-6 { gap: 24px; }
.grow { flex: 1; }
.muted { color: var(--ink-3); }
.center { align-items: center; justify-content: center; }
.between { justify-content: space-between; }
.wrap { flex-wrap: wrap; }

/* fade/slide entrance */
@keyframes rzFadeUp { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }
/* transform-only entrance — safe even if the animation engine is paused (content stays visible) */
@keyframes rzSlideUp { from { transform: translateY(12px); } to { transform: none; } }
@keyframes rzPop { 0% { opacity: 0; transform: scale(0.8); } 60% { opacity: 1; } 100% { transform: scale(1); } }
@keyframes rzSpark { 0%,100% { opacity: 0.5; transform: scale(1); } 50% { opacity: 1; transform: scale(1.08); } }
.fade-up { animation: rzSlideUp 0.45s var(--ease) both; }

/* count-up number flash */
@keyframes rzSlideIn { from { transform: translateX(40px); opacity: 0; } to { transform: none; opacity: 1; } }
@keyframes rzFlash { 0% { color: var(--shift-accent); transform: scale(1.12); } 100% { color: inherit; transform: none; } }
.flash { animation: rzFlash 0.6s var(--ease); display: inline-block; }
/* ============================================================
   РАЗРЯД — shell / chrome styles
   ============================================================ */

.rz-root { height: 100vh; display: flex; flex-direction: column; overflow: hidden; background: #000; }

/* ---- prototype bar (chrome, always dark) ---- */
.rz-protobar {
  height: 50px; flex: none; background: #0c0b0a; color: #fff;
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 16px; border-bottom: 1px solid rgba(255,255,255,0.08); position: relative; z-index: 50;
}
.rz-proto-dot { width: 10px; height: 10px; border-radius: 50%; background: var(--brand); box-shadow: 0 0 0 0 var(--brand); animation: rzSpark 2s ease-in-out infinite; }
.rz-seg { display: flex; gap: 3px; background: rgba(255,255,255,0.06); border-radius: 11px; padding: 3px; }
.rz-seg button {
  border: none; background: transparent; color: rgba(255,255,255,0.6); font-family: var(--font-body);
  font-weight: 600; font-size: 13px; padding: 7px 14px; border-radius: 8px; cursor: pointer; transition: all 0.16s; white-space: nowrap;
}
.rz-seg button:hover { color: #fff; }
.rz-seg button.active { background: var(--brand); color: #fff; }
.rz-seg.small button { font-size: 12px; padding: 6px 11px; }
.rz-seg.small button.active { background: rgba(255,255,255,0.16); color: #fff; }
.rz-iconbtn { border: none; background: rgba(255,255,255,0.06); color: #fff; width: 36px; height: 36px; border-radius: 10px; display: grid; place-items: center; cursor: pointer; transition: background 0.16s; }
.rz-iconbtn:hover { background: rgba(255,255,255,0.14); }

.rz-stage { flex: 1; min-height: 0; position: relative; overflow: hidden; }

/* ---- mobile role wrapper ---- */
.rz-mobilewrap { width: 100%; height: 100%; display: grid; place-items: center; background: var(--bg-1); overflow: auto; padding: 20px; }

/* ---- organizer shell ---- */
.rz-shell { display: flex; height: 100%; background: var(--bg); }
.rz-sidebar {
  width: 256px; flex: none; background: var(--surface); border-right: 1px solid var(--line);
  display: flex; flex-direction: column; padding: 18px 14px; gap: 6px;
}
.rz-brand { display: flex; align-items: center; gap: 11px; padding: 6px 8px 16px; }
.rz-logo { width: 40px; height: 40px; border-radius: 12px; background: var(--shift-accent); display: grid; place-items: center; color: #fff; box-shadow: 0 8px 20px -8px var(--shift-accent); }
.rz-logo .display { font-size: 22px; }
.rz-nav { display: flex; flex-direction: column; gap: 2px; margin-top: 4px; overflow-y: auto; flex: 1; }
.rz-navitem {
  display: flex; align-items: center; gap: 12px; padding: 10px 12px; border-radius: 11px;
  border: none; background: transparent; color: var(--ink-2); font-family: var(--font-body);
  font-weight: 600; font-size: 14px; cursor: pointer; text-align: left; transition: all 0.15s; position: relative;
}
.rz-navitem:hover { background: var(--surface-2); color: var(--ink); }
.rz-navitem.active { background: var(--shift-accent-soft); color: var(--shift-accent); }
.rz-navitem.active::before { content: ""; position: absolute; left: -14px; top: 8px; bottom: 8px; width: 3px; border-radius: 3px; background: var(--shift-accent); }
.rz-shiftcard { margin-top: auto; padding: 14px; border-radius: var(--r-md); background: var(--surface-2); border: 1px solid var(--line); }
.rz-shiftcard-btn { width: 100%; text-align: left; background: none; border: none; padding: 0; cursor: pointer; color: var(--ink); font-family: var(--font-body); }
.rz-shiftmenu { position: absolute; left: 0; right: 0; bottom: calc(100% + 8px); background: var(--surface); border: 1px solid var(--line-strong); border-radius: var(--r-md); box-shadow: var(--shadow); padding: 6px; z-index: 60; }
.rz-shiftopt { display: flex; align-items: center; gap: 10px; width: 100%; padding: 9px 8px; border-radius: 9px; border: none; background: transparent; cursor: pointer; color: var(--ink); font-family: var(--font-body); text-align: left; transition: background 0.14s; }
.rz-shiftopt:hover { background: var(--surface-2); }
.rz-shiftopt.on { background: var(--shift-accent-soft); }
.rz-shiftopt.create { border-top: 1px solid var(--line); margin-top: 4px; padding-top: 12px; color: var(--shift-accent); }
.rz-shiftopt.create:disabled { opacity: 0.4; cursor: not-allowed; color: var(--ink-3); }

.rz-main { flex: 1; min-width: 0; overflow: auto; }
.rz-canvas { max-width: 1080px; margin: 0 auto; padding: 34px 40px 80px; animation: rzSlideUp 0.4s var(--ease) both; }
.rz-headicon { width: 38px; height: 38px; border-radius: 11px; background: var(--shift-accent-soft); color: var(--shift-accent); display: grid; place-items: center; flex: none; }

/* topbar inside canvas */
.rz-topbar { display: flex; align-items: center; justify-content: space-between; margin-bottom: 26px; }

/* generic grid — container-responsive via auto-fit */
.rz-grid { display: grid; gap: 16px; }
.rz-grid.c4 { grid-template-columns: repeat(auto-fit, minmax(214px, 1fr)); }
.rz-grid.c3 { grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); }
.rz-grid.c2 { grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); }
.g4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.g3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }

/* table */
.rz-table { width: 100%; border-collapse: collapse; }
.rz-table th { text-align: left; font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-3); font-weight: 700; padding: 0 14px 12px; }
.rz-table td { padding: 13px 14px; border-top: 1px solid var(--line); font-size: 14px; }
.rz-table tbody tr { transition: background 0.14s; }
.rz-table tbody tr:hover { background: var(--surface-2); }

/* list row */
.rz-listrow { display: flex; align-items: center; gap: 14px; padding: 14px 16px; border-radius: var(--r-md); border: 1px solid var(--line); background: var(--surface); transition: all 0.15s; }
.rz-listrow:hover { border-color: var(--line-strong); transform: translateX(2px); }

/* segmented filter */
.rz-filter { display: inline-flex; gap: 4px; background: var(--surface-2); border: 1px solid var(--line); border-radius: 11px; padding: 4px; }
.rz-filter button { border: none; background: transparent; color: var(--ink-2); font-family: var(--font-body); font-weight: 600; font-size: 13px; padding: 7px 13px; border-radius: 8px; cursor: pointer; transition: all 0.15s; }
.rz-filter button.active { background: var(--surface); color: var(--ink); box-shadow: var(--shadow-sm); }

/* mobile bottom nav */
.rz-tabbar { position: absolute; left: 0; right: 0; bottom: 0; height: 78px; background: color-mix(in srgb, var(--surface) 86%, transparent); backdrop-filter: blur(16px); border-top: 1px solid var(--line); display: flex; align-items: center; justify-content: space-around; padding: 0 8px 16px; z-index: 20; }
.rz-tab { display: flex; flex-direction: column; align-items: center; gap: 3px; border: none; background: transparent; color: var(--ink-3); font-size: 10.5px; font-weight: 600; cursor: pointer; padding: 8px 12px; transition: color 0.15s; }
.rz-tab.active { color: var(--shift-accent); }

/* mobile page padding */
.rz-mpage { padding: 52px 18px 96px; min-height: 100%; }
/* ============================================================
   РАЗРЯД — screen-specific styles
   ============================================================ */

/* ---- auth ---- */
.rz-auth-split { display: flex; height: 100%; background: var(--bg); }
.rz-auth-brand { flex: 1.05; background: var(--surface); border-right: 1px solid var(--line); display: flex; align-items: center; padding: 56px; position: relative; overflow: hidden; }
.rz-auth-brand::after { content: ""; position: absolute; right: -120px; bottom: -120px; width: 360px; height: 360px; border-radius: 50%; background: radial-gradient(circle, var(--shift-accent-soft), transparent 70%); }
.rz-auth-brandinner { position: relative; z-index: 2; }
.rz-auth-form { flex: 1; display: flex; align-items: center; justify-content: center; padding: 40px; overflow: auto; }
.rz-auth-divider { display: flex; align-items: center; gap: 12px; margin: 26px 0 16px; color: var(--ink-3); font-size: 12px; }
.rz-auth-divider::before, .rz-auth-divider::after { content: ""; height: 1px; flex: 1; background: var(--line); }
@media (max-width: 860px) { .rz-auth-brand { display: none; } }

.rz-otp { text-align: center; font-family: var(--font-display); font-size: 24px; font-weight: 600; padding: 14px 0; aspect-ratio: 1; }

/* ---- onboarding ---- */
.rz-onb { height: 100%; display: flex; flex-direction: column; background: var(--bg); }
.rz-onb-top { flex: none; padding: 22px 40px; display: flex; align-items: center; justify-content: space-between; border-bottom: 1px solid var(--line); }
.rz-onb-steps { display: flex; align-items: center; gap: 8px; }
.rz-onb-stepdot { display: flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 600; color: var(--ink-3); }
.rz-onb-stepdot .n { width: 26px; height: 26px; border-radius: 50%; display: grid; place-items: center; background: var(--surface-2); border: 1px solid var(--line); font-size: 12.5px; transition: all 0.25s; }
.rz-onb-stepdot.active { color: var(--ink); }
.rz-onb-stepdot.active .n { background: var(--shift-accent); border-color: transparent; color: #fff; }
.rz-onb-stepdot.done .n { background: var(--shift-accent-soft); border-color: transparent; color: var(--shift-accent); }
.rz-onb-body { flex: 1; overflow: auto; display: flex; justify-content: center; padding: 40px; }
.rz-onb-inner { width: 100%; max-width: 760px; animation: rzSlideUp 0.4s var(--ease) both; }
.rz-onb-foot { flex: none; padding: 18px 40px; border-top: 1px solid var(--line); display: flex; justify-content: space-between; align-items: center; background: var(--surface); }
.rz-emojibtn { width: 42px; height: 42px; flex: none; border-radius: var(--r-md); border: 1px solid var(--line); background: var(--surface-2); font-size: 20px; cursor: pointer; display: grid; place-items: center; transition: background 0.15s; }
.rz-emojibtn:hover { background: var(--surface-3); }
@media (max-width: 940px) { .rz-onb-steplabel { display: none; } .rz-onb-steps span[style*="width: 18px"] { display: none; } }

.rz-choice { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.rz-choicecard { border: 1.5px solid var(--line); border-radius: var(--r-xl); padding: 28px; cursor: pointer; transition: all 0.2s var(--ease); background: var(--surface); position: relative; overflow: hidden; }
.rz-choicecard:hover { border-color: var(--line-strong); transform: translateY(-3px); box-shadow: var(--shadow); }
.rz-choicecard.sel { border-color: var(--shift-accent); box-shadow: 0 0 0 4px var(--shift-accent-soft); }
.rz-choicecard .badge-rec { position: absolute; top: 16px; right: 16px; }

.rz-tpl-preview { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; margin-top: 8px; }
.rz-tpl-item { display: flex; align-items: center; gap: 10px; padding: 11px 13px; border-radius: var(--r-md); background: var(--surface-2); border: 1px solid var(--line); font-size: 13.5px; font-weight: 600; animation: rzSlideUp 0.4s var(--ease) both; }
.rz-tpl-item .dot { width: 28px; height: 28px; border-radius: 9px; display: grid; place-items: center; background: var(--shift-accent-soft); color: var(--shift-accent); flex: none; }

/* color picker swatches */
.rz-swatches { display: flex; gap: 10px; flex-wrap: wrap; }
.rz-swatch { width: 42px; height: 42px; border-radius: 12px; cursor: pointer; border: 2px solid transparent; transition: transform 0.15s, border-color 0.15s; position: relative; }
.rz-swatch:hover { transform: scale(1.08); }
.rz-swatch.sel { border-color: var(--ink); }
.rz-swatch.sel::after { content: ""; position: absolute; inset: 0; display: grid; place-items: center; }

/* ---- badges grid ---- */
.rz-badge-card { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 10px; padding: 22px 16px; border-radius: var(--r-lg); border: 1px solid var(--line); background: var(--surface); transition: all 0.18s; position: relative; }
.rz-badge-card:hover { transform: translateY(-3px); box-shadow: var(--shadow); }
.rz-badge-medal { width: 64px; height: 64px; border-radius: 50%; display: grid; place-items: center; background: radial-gradient(circle at 35% 30%, color-mix(in srgb, var(--shift-accent) 55%, #fff), var(--shift-accent)); color: #fff; box-shadow: 0 10px 22px -10px var(--shift-accent); flex: none; }
.rz-badge-medal.locked { background: var(--surface-3); color: var(--ink-3); box-shadow: none; }
.rz-badge-medal.auto { background: radial-gradient(circle at 35% 30%, #6fd6a8, #2e9e6e); box-shadow: 0 10px 22px -10px #2e9e6e; }

/* belt row */
.rz-belt-row { display: flex; align-items: center; gap: 14px; padding: 14px 16px; border-radius: var(--r-md); border: 1px solid var(--line); background: var(--surface); }
.rz-belt-bar { width: 46px; height: 22px; border-radius: 6px; flex: none; box-shadow: inset 0 0 0 1px rgba(0,0,0,0.2); }

/* leaderboard rank */
.rz-rank { width: 30px; height: 30px; border-radius: 9px; display: grid; place-items: center; font-family: var(--font-display); font-weight: 700; font-size: 14px; background: var(--surface-3); color: var(--ink-2); flex: none; }
.rz-rank.g1 { background: var(--gold); color: #5a3d00; }
.rz-rank.g2 { background: var(--silver); color: #3a4047; }
.rz-rank.g3 { background: var(--bronze); color: #fff; }

/* segmented day picker for attendance */
.rz-att-grid { width: 100%; border-collapse: collapse; }
.rz-att-grid th, .rz-att-grid td { padding: 8px; text-align: center; }
.rz-att-cell { width: 30px; height: 30px; border-radius: 8px; border: 1px solid var(--line); background: var(--surface-2); cursor: pointer; display: inline-grid; place-items: center; transition: all 0.14s; color: transparent; }
.rz-att-cell.yes { background: var(--shift-accent); border-color: transparent; color: #fff; }
.rz-att-cell.future { opacity: 0.35; pointer-events: none; }

/* mobile cards */
.rz-hero { border-radius: var(--r-xl); padding: 24px; color: #fff; position: relative; overflow: hidden; background: var(--shift-accent); }
.rz-hero::after { content: ""; position: absolute; right: -40px; top: -40px; width: 180px; height: 180px; border-radius: 50%; background: rgba(255,255,255,0.14); }
.rz-hero::before { content: ""; position: absolute; right: 30px; bottom: -60px; width: 140px; height: 140px; border-radius: 50%; background: rgba(0,0,0,0.08); }

/* segmented pill for variations */
.rz-varbar { display: flex; gap: 4px; background: var(--surface-2); border: 1px solid var(--line); border-radius: 12px; padding: 4px; }
.rz-varbar button { flex: 1; border: none; background: transparent; color: var(--ink-2); font-family: var(--font-body); font-weight: 700; font-size: 12.5px; padding: 9px 6px; border-radius: 9px; cursor: pointer; transition: all 0.16s; }
.rz-varbar button.active { background: var(--shift-accent); color: #fff; }

/* bento grid (mobile) */
.rz-bento { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; }
.rz-bento-cell { display: flex; flex-direction: column; min-height: 92px; padding: 14px; border-radius: var(--r-lg); border: 1px solid var(--line); background: var(--surface); }
.rz-bento-cell.big { grid-column: span 1; grid-row: span 1; }
.rz-bento .rz-bento-cell:first-child.big { grid-column: 1 / 2; grid-row: 1 / 1; min-height: 132px; }

/* belt journey path */
.rz-path { display: flex; flex-direction: column; }
.rz-path-step { display: flex; gap: 14px; position: relative; padding-bottom: 18px; }
.rz-path-step:last-child { padding-bottom: 0; }
.rz-path-line { position: absolute; left: 15px; top: 30px; bottom: -2px; width: 2px; }
.rz-path-step:last-child .rz-path-line { display: none; }
.rz-path-node { width: 32px; height: 32px; border-radius: 50%; flex: none; display: grid; place-items: center; border: 2px solid var(--line); background: var(--surface-2); color: var(--ink-3); z-index: 2; }
.rz-path-node.done { color: #fff; }
.rz-path-node.cur { color: #fff; box-shadow: 0 0 0 4px var(--shift-accent-soft); }
.rz-path-info { flex: 1; padding-top: 5px; }

/* podium (rank) */
.rz-podium { display: flex; align-items: flex-end; gap: 8px; margin-bottom: 18px; }
.rz-podium-col { flex: 1; display: flex; flex-direction: column; align-items: center; }
.rz-podium-ava { border-radius: 50%; display: grid; place-items: center; flex: none; }
.rz-podium-name { font-size: 12px; font-weight: 700; margin: 7px 0 1px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 100%; }
.rz-podium-bar { width: 100%; margin-top: 8px; border-radius: 12px 12px 0 0; display: grid; place-items: center; position: relative; }

/* distribute options */
.rz-distopt { display: flex; align-items: center; gap: 14px; width: 100%; text-align: left; padding: 16px; border-radius: var(--r-lg); border: 1.5px solid var(--line); background: var(--surface); cursor: pointer; transition: all 0.18s; font-family: var(--font-body); color: var(--ink); }
.rz-distopt:hover { border-color: var(--line-strong); }
.rz-distopt.sel { border-color: var(--shift-accent); box-shadow: 0 0 0 3px var(--shift-accent-soft); }
.rz-distopt.sel > .ic:last-child, .rz-distopt.sel svg { color: var(--shift-accent); }

/* squad member row */
.rz-sqmember { transition: background 0.14s; }
.rz-sqmember:hover { background: var(--surface-2); }
.rz-movebtn { opacity: 0; }
.rz-sqmember:hover .rz-movebtn { opacity: 1; }

/* ---- attendance roster ---- */
.rz-roster-row { display: flex; align-items: center; gap: 14px; padding: 11px 14px; border-radius: var(--r-md); border: 1px solid var(--line); background: var(--surface); transition: border-color 0.14s; }
.rz-roster-row:hover { border-color: var(--line-strong); }
.rz-statbtns { display: flex; gap: 8px; flex: none; }
.rz-statbtn { width: 40px; height: 40px; border-radius: 50%; border: 2px solid var(--line); background: var(--surface-2); cursor: pointer; display: grid; place-items: center; color: var(--ink-3); transition: all 0.15s var(--ease); }
.rz-statbtn:hover { transform: scale(1.08); }
.rz-statbtn[data-k="present"] { color: var(--att-present); background: color-mix(in srgb, var(--att-present) 13%, transparent); border-color: color-mix(in srgb, var(--att-present) 30%, transparent); }
.rz-statbtn[data-k="late"] { color: var(--att-late); background: color-mix(in srgb, var(--att-late) 14%, transparent); border-color: color-mix(in srgb, var(--att-late) 32%, transparent); }
.rz-statbtn[data-k="absent"] { color: var(--att-absent); background: color-mix(in srgb, var(--att-absent) 13%, transparent); border-color: color-mix(in srgb, var(--att-absent) 30%, transparent); }
.rz-statbtn[data-k="excused"] { color: var(--att-excused); background: color-mix(in srgb, var(--att-excused) 13%, transparent); border-color: color-mix(in srgb, var(--att-excused) 28%, transparent); }
.rz-statbtn.on[data-k="present"] { background: var(--att-present); border-color: var(--att-present); color: #fff; box-shadow: 0 6px 16px -8px var(--att-present); }
.rz-statbtn.on[data-k="late"] { background: var(--att-late); border-color: var(--att-late); color: #3a2c00; box-shadow: 0 6px 16px -8px var(--att-late); }
.rz-statbtn.on[data-k="absent"] { background: var(--att-absent); border-color: var(--att-absent); color: #fff; box-shadow: 0 6px 16px -8px var(--att-absent); }
.rz-statbtn.on[data-k="excused"] { background: var(--att-excused); border-color: var(--att-excused); color: #fff; }
.rz-statbtn.dim { opacity: 0.35; }
.rz-statbtn.dim:hover { opacity: 1; }

/* count pill (отмечено сводка) */
.rz-countpill { display: inline-flex; align-items: center; gap: 6px; font-weight: 700; font-size: 13px; }
.rz-countdot { width: 11px; height: 11px; border-radius: 50%; }

/* day picker */
.rz-daypick { display: inline-flex; align-items: center; gap: 6px; background: var(--surface-2); border: 1px solid var(--line); border-radius: var(--r-md); padding: 4px; }
.rz-daypick .nav { width: 34px; height: 34px; border-radius: 8px; border: none; background: transparent; color: var(--ink-2); cursor: pointer; display: grid; place-items: center; transition: background 0.14s; }
.rz-daypick .nav:hover { background: var(--surface-3); color: var(--ink); }
.rz-daypick .nav:disabled { opacity: 0.3; cursor: not-allowed; }
.rz-daypick .lbl { padding: 0 10px; text-align: center; line-height: 1.15; min-width: 132px; white-space: nowrap; }

/* ---- points awarder ---- */
.rz-amtbtn { flex: 1; min-width: 64px; border: 1px solid var(--line); background: var(--surface-2); color: var(--ink); font-family: var(--font-display); font-weight: 600; font-size: 18px; padding: 14px 8px; border-radius: var(--r-md); cursor: pointer; transition: all 0.15s; }
.rz-amtbtn:hover { border-color: var(--line-strong); }
.rz-amtbtn.on { background: var(--shift-accent); border-color: transparent; color: #fff; box-shadow: 0 8px 20px -10px var(--shift-accent); }
.rz-amtbtn.neg.on { background: var(--att-absent); box-shadow: 0 8px 20px -10px var(--att-absent); }
.rz-reasonchip { border: 1px solid var(--line); background: var(--surface-2); color: var(--ink-2); font-family: var(--font-body); font-weight: 600; font-size: 13px; padding: 9px 14px; border-radius: 99px; cursor: pointer; transition: all 0.15s; }
.rz-reasonchip:hover { border-color: var(--line-strong); color: var(--ink); }
.rz-reasonchip.on { background: var(--shift-accent-soft); border-color: var(--shift-accent); color: var(--shift-accent); }
.rz-bigaward { width: 100%; justify-content: center; font-family: var(--font-display); font-size: 18px; padding: 17px; letter-spacing: 0.01em; }
.rz-segbig { display: flex; gap: 4px; background: var(--surface-2); border: 1px solid var(--line); border-radius: 13px; padding: 4px; flex: 1; }
.rz-segbig button { flex: 1; border: none; background: transparent; color: var(--ink-2); font-family: var(--font-body); font-weight: 700; font-size: 14px; padding: 11px; border-radius: 9px; cursor: pointer; transition: all 0.16s; }
.rz-segbig button.on { background: var(--shift-accent); color: #fff; }
.rz-pm { display: flex; gap: 4px; background: var(--surface-2); border: 1px solid var(--line); border-radius: 13px; padding: 4px; }
.rz-pm button { width: 46px; border: none; background: transparent; color: var(--ink-2); font-size: 20px; font-weight: 700; border-radius: 9px; cursor: pointer; transition: all 0.16s; }
.rz-pm button.on-plus { background: var(--att-present); color: #fff; }
.rz-pm button.on-minus { background: var(--att-absent); color: #fff; }

/* rules setting row */
.rz-rulerow { padding: 14px 0; border-bottom: 1px solid var(--line); }
.rz-ruleinput { display: flex; align-items: center; gap: 10px; margin-top: 12px; padding-left: 42px; }

/* ---- editors: emoji picker ---- */
.rz-emojipop { position: absolute; top: calc(100% + 6px); left: 0; z-index: 60; display: grid; grid-template-columns: repeat(5, 1fr); gap: 4px; padding: 8px; background: var(--surface); border: 1px solid var(--line-strong); border-radius: var(--r-md); box-shadow: var(--shadow); width: 220px; }
.rz-emojiopt { width: 36px; height: 36px; border-radius: 8px; border: none; background: transparent; font-size: 19px; cursor: pointer; transition: background 0.14s; }
.rz-emojiopt:hover { background: var(--surface-3); }
.rz-emojiopt.sel { background: var(--shift-accent-soft); box-shadow: inset 0 0 0 1.5px var(--shift-accent); }

/* ---- editors: level rows + DnD ---- */
.rz-lvlrow { display: flex; align-items: center; gap: 10px; padding: 9px 12px; border-radius: var(--r-md); border: 1px solid var(--line); background: var(--surface); transition: border-color 0.14s, box-shadow 0.14s, opacity 0.14s; }
.rz-lvlrow.over { border-color: var(--shift-accent); box-shadow: 0 0 0 3px var(--shift-accent-soft); }
.rz-lvlrow.dragging { opacity: 0.4; }
.rz-drag { color: var(--ink-3); cursor: grab; flex: none; display: inline-flex; }
.rz-drag:active { cursor: grabbing; }
.rz-colordots { display: flex; gap: 4px; flex: none; }
.rz-colordot { width: 18px; height: 18px; border-radius: 5px; border: 2px solid transparent; cursor: pointer; padding: 0; box-shadow: inset 0 0 0 1px rgba(0,0,0,0.15); transition: transform 0.12s; }
.rz-colordot:hover { transform: scale(1.12); }
.rz-colordot.sel { border-color: var(--ink); }

/* suggestion chip */
.rz-suggchip { display: inline-flex; align-items: center; gap: 7px; padding: 8px 12px; border-radius: 99px; border: 1px dashed var(--line-strong); background: var(--surface-2); color: var(--ink); font-family: var(--font-body); font-weight: 600; font-size: 13px; cursor: pointer; transition: all 0.15s; }
.rz-suggchip:hover { border-color: var(--shift-accent); color: var(--shift-accent); border-style: solid; }
.rz-suggchip:hover .ic { color: var(--shift-accent); }

/* badge add tile + library */
.rz-badge-add { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; padding: 22px 16px; border-radius: var(--r-lg); border: 1.5px dashed var(--line-strong); background: transparent; color: var(--ink-3); font-family: var(--font-body); font-weight: 600; font-size: 13px; cursor: pointer; transition: all 0.16s; }
.rz-badge-add:hover { border-color: var(--shift-accent); color: var(--shift-accent); }
.rz-libcard { display: flex; align-items: center; gap: 11px; padding: 12px 14px; border-radius: var(--r-md); border: 1px solid var(--line); background: var(--surface); cursor: pointer; transition: all 0.15s; font-family: var(--font-body); }
.rz-libcard:hover { border-color: var(--shift-accent); transform: translateY(-2px); box-shadow: var(--shadow-sm); }
.rz-libplus { width: 26px; height: 26px; border-radius: 8px; background: var(--shift-accent-soft); color: var(--shift-accent); display: grid; place-items: center; flex: none; }
.rz-iconpick { width: 38px; height: 38px; border-radius: 9px; border: 1px solid var(--line); display: grid; place-items: center; cursor: pointer; transition: all 0.14s; }

/* badge emoji tiles */
.rz-btile { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 7px; padding: 18px 12px 14px; border-radius: var(--r-lg); border: 1px solid var(--line); background: var(--surface); cursor: pointer; transition: all 0.18s; }
.rz-btile:hover { transform: translateY(-3px); box-shadow: var(--shadow); border-color: var(--line-strong); }
.rz-btile-emoji { width: 60px; height: 60px; border-radius: 50%; display: grid; place-items: center; font-size: 32px; background: var(--surface-2); border: 1px solid var(--line); }
.rz-btile-auto { font-size: 10.5px; font-weight: 600; color: var(--att-present); background: color-mix(in srgb, var(--att-present) 14%, transparent); padding: 3px 9px; border-radius: 99px; margin-top: 2px; }
.rz-autochip { background: color-mix(in srgb, var(--att-present) 16%, transparent) !important; color: var(--att-present) !important; border-color: transparent !important; }
.rz-libemoji { width: 40px; height: 40px; border-radius: 50%; display: grid; place-items: center; font-size: 21px; background: var(--surface-2); border: 1px solid var(--line); flex: none; }

/* ---- access / codes ---- */
.rz-codepill { font-family: "Unbounded", var(--font-display); font-weight: 600; font-size: 16px; letter-spacing: 2px; background: var(--surface-3); padding: 5px 12px; border-radius: 8px; }

/* print overlay */
.rz-printroot { position: fixed; inset: 0; z-index: 200; background: var(--bg-1); display: flex; flex-direction: column; }
.rz-print-toolbar { flex: none; display: flex; align-items: center; justify-content: space-between; padding: 14px 20px; background: var(--surface); border-bottom: 1px solid var(--line); }
.rz-print-pages { flex: 1; overflow: auto; padding: 24px; display: flex; flex-direction: column; align-items: center; gap: 24px; }
.rz-a4card { width: 520px; max-width: 100%; aspect-ratio: 210 / 297; background: #fff; color: #14110c; border-radius: 4px; box-shadow: 0 18px 50px -22px rgba(0,0,0,0.6); padding: 48px 44px; display: flex; flex-direction: column; align-items: center; text-align: center; }
.rz-a4top { width: 100%; display: flex; justify-content: center; padding-bottom: 28px; border-bottom: 2px dashed #d8d2c6; }
.rz-a4brand { font-family: "Unbounded", sans-serif; font-weight: 700; font-size: 19px; color: #14110c; }
.rz-a4sub { font-size: 12.5px; color: #8a8377; font-weight: 600; }
.rz-a4qr { margin: 44px 0 36px; padding: 16px; border: 1px solid #e6e1d7; border-radius: 12px; }
.rz-a4name { font-family: "Unbounded", sans-serif; font-weight: 700; font-size: 28px; color: #14110c; }
.rz-a4codewrap { display: flex; flex-direction: column; align-items: center; gap: 4px; margin-top: 22px; }
.rz-a4codelabel { font-size: 12px; letter-spacing: 2px; color: #8a8377; font-weight: 700; }
.rz-a4code { font-family: "Unbounded", sans-serif; font-weight: 800; font-size: 52px; letter-spacing: 10px; color: var(--shift-accent); }
.rz-a4hint { margin-top: auto; font-size: 13px; color: #8a8377; font-weight: 500; max-width: 320px; line-height: 1.5; }

@media print {
  body > *:not(.rz-printroot) { display: none !important; }
  .no-print { display: none !important; }
  body, .rz-printroot { background: #fff !important; }
  .rz-printroot { position: static; }
  .rz-print-pages { padding: 0; gap: 0; display: block; }
  .rz-a4card { width: 100%; max-width: none; box-shadow: none; border-radius: 0; page-break-after: always; aspect-ratio: auto; min-height: 100vh; justify-content: center; }
}

/* ============================================================
   РАЗРЯД — Django-MVP добавки (org-shell + participant + auth)
   ============================================================ */

* { box-sizing: border-box; }
.rz-body { background:#FAF9F6; color:#0B0F2E; font-family:'Manrope',-apple-system,sans-serif; margin:0; }
.rz-body * { box-sizing:border-box; }

.rz-mono { font-family:'JetBrains Mono',ui-monospace,monospace; }

/* Кнопки */
.rz-btn { display:inline-flex; align-items:center; justify-content:center; gap:8px; padding:10px 18px; border-radius:10px; font-weight:700; font-size:14px; text-decoration:none; cursor:pointer; border:1px solid transparent; background:#fff; color:#0B0F2E; font-family:inherit; }
.rz-btn-primary { background:#0B0F2E; color:#fff; }
.rz-btn-primary:hover { background:#6B3CFF; }
.rz-btn-ghost { background:transparent; color:#0B0F2E; border:1px solid #E5E1D8; }
.rz-btn-ghost:hover { background:#fff; }
.rz-btn-lg { padding:14px 24px; font-size:15px; }
.rz-btn-sm { padding:6px 12px; font-size:12px; }

/* Поля */
.rz-field { display:flex; flex-direction:column; gap:6px; margin-bottom:14px; }
.rz-field span { font-size:12px; font-weight:700; color:#5B5750; letter-spacing:.04em; text-transform:uppercase; }
.rz-input, .rz-field input, .rz-field select, .rz-field textarea { padding:10px 14px; border:1px solid #E5E1D8; border-radius:10px; font-size:14px; font-family:inherit; background:#fff; color:#0B0F2E; }
.rz-input:focus, .rz-field input:focus, .rz-field select:focus { outline:none; border-color:#6B3CFF; }
.rz-row { display:flex; gap:12px; align-items:flex-end; flex-wrap:wrap; }
.rz-fl-1 { max-width:120px; }
.rz-err { background:#FFE5E2; color:#B91A0F; padding:10px 14px; border-radius:10px; margin-bottom:14px; font-size:13px; }
.rz-tag { font-family:'JetBrains Mono',monospace; font-size:11px; letter-spacing:.14em; text-transform:uppercase; font-weight:700; margin-bottom:10px; }
.rz-fset { border:1px solid #E5E1D8; border-radius:12px; padding:14px 18px; margin-bottom:14px; }
.rz-fset legend { font-size:12px; font-weight:700; color:#5B5750; text-transform:uppercase; padding:0 8px; }
.rz-chk, .rz-rad { display:flex; align-items:center; gap:10px; padding:6px 0; font-size:14px; cursor:pointer; }

/* Auth */
.rz-auth { min-height:100vh; display:grid; place-items:center; padding:24px; background:linear-gradient(160deg,#F4F2EC,#FAF9F6); }
.rz-auth-card { background:#fff; border:1px solid #E5E1D8; border-radius:18px; padding:32px; max-width:420px; width:100%; }
.rz-auth-h { font-family:'Montserrat',sans-serif; font-weight:900; font-size:28px; margin:0 0 6px; }
.rz-auth-sub { color:#5B5750; margin:0 0 22px; font-size:14px; }
.rz-auth-foot { margin-top:18px; text-align:center; font-size:13px; color:#5B5750; }
.rz-auth-foot a { color:#6B3CFF; text-decoration:none; font-weight:700; }

/* Onboarding */
.rz-onb { min-height:100vh; padding:40px 20px; background:#FAF9F6; }
.rz-onb-card { background:#fff; border:1px solid #E5E1D8; border-radius:20px; padding:36px; max-width:680px; margin:0 auto; }
.rz-onb-h { font-family:'Montserrat',sans-serif; font-weight:900; font-size:36px; margin:0 0 8px; }
.rz-onb-sub { color:#5B5750; margin:0 0 24px; }
.rz-onb-form .rz-field { margin-bottom:14px; }

/* Toaster */
.rz-toaster { position:fixed; top:18px; right:18px; z-index:1000; display:flex; flex-direction:column; gap:8px; }
.rz-toast { background:#0B0F2E; color:#fff; padding:12px 18px; border-radius:10px; font-size:14px; box-shadow:0 10px 30px -10px rgba(0,0,0,.25); animation:rz-toast-in .3s ease; }
.rz-toast-success { background:#1F9D4D; }
.rz-toast-error { background:#B91A0F; }
.rz-toast-warning { background:#B9770A; }
@keyframes rz-toast-in { from {opacity:0; transform:translateY(-8px);} to {opacity:1; transform:translateY(0);} }

/* Shell (org cabinet) */
.rz-shell { display:grid; grid-template-columns:240px 1fr; min-height:100vh; }
.rz-sidebar { background:#0B0F2E; color:#fff; padding:20px 16px; display:flex; flex-direction:column; }
.rz-sb-brand { padding-bottom:18px; border-bottom:1px solid rgba(255,255,255,.08); margin-bottom:12px; }
.rz-sb-logo { display:flex; gap:12px; align-items:center; text-decoration:none; color:#fff; }
.rz-sb-emoji { font-size:32px; }
.rz-sb-name { font-weight:800; font-size:15px; line-height:1.2; }
.rz-sb-sub { font-family:'JetBrains Mono',monospace; font-size:11px; color:rgba(255,255,255,.55); margin-top:2px; }
.rz-sb-nav { display:flex; flex-direction:column; gap:2px; flex:1; }
.rz-sb-item { color:rgba(255,255,255,.75); text-decoration:none; padding:10px 12px; border-radius:8px; font-size:14px; font-weight:600; transition:background .12s; }
.rz-sb-item:hover { background:rgba(255,255,255,.05); color:#fff; }
.rz-sb-item.is-on { background:#6B3CFF; color:#fff; }
.rz-sb-foot { border-top:1px solid rgba(255,255,255,.08); padding-top:14px; font-size:12px; color:rgba(255,255,255,.55); }
.rz-sb-user { font-weight:700; color:#fff; margin-bottom:6px; }
.rz-sb-logout { color:rgba(255,255,255,.7); text-decoration:none; font-size:12px; }
.rz-main { padding:32px; background:#FAF9F6; }
.rz-page { max-width:1100px; margin:0 auto; }
.rz-page-head { display:flex; justify-content:space-between; align-items:center; gap:14px; margin-bottom:20px; flex-wrap:wrap; }
.rz-h1 { font-family:'Montserrat',sans-serif; font-weight:900; font-size:28px; margin:0 0 18px; letter-spacing:-.02em; }
.rz-h1-sub { font-family:'JetBrains Mono',monospace; font-size:13px; color:#8A93B8; font-weight:500; margin-left:8px; }
.rz-back a { color:#6B3CFF; text-decoration:none; font-size:13px; }
.rz-back { margin-bottom:14px; }

/* KPI */
.rz-kpis { display:grid; grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); gap:14px; margin-bottom:20px; }
.rz-kpi { background:#fff; border:1px solid #E5E1D8; border-radius:14px; padding:18px; }
.rz-kpi-v { font-family:'Montserrat',sans-serif; font-weight:900; font-size:32px; line-height:1; color:#0B0F2E; }
.rz-kpi-l { font-family:'JetBrains Mono',monospace; font-size:11px; color:#8A93B8; text-transform:uppercase; letter-spacing:.06em; margin-top:6px; }

/* Cards */
.rz-card { background:#fff; border:1px solid #E5E1D8; border-radius:14px; padding:18px 20px; margin-bottom:14px; }
.rz-card-h { font-size:14px; font-weight:800; margin:0 0 12px; color:#0B0F2E; text-transform:uppercase; letter-spacing:.04em; }
.rz-grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.rz-grid-3 { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:14px; }
@media (max-width:780px){ .rz-grid-2 { grid-template-columns:1fr; } .rz-shell { grid-template-columns:1fr; } .rz-sidebar { padding:14px; } }

/* Line list */
.rz-line { display:flex; align-items:center; gap:10px; padding:8px 0; border-bottom:1px solid #F4F0E8; }
.rz-line:last-child { border-bottom:0; }
.rz-line-num { font-family:'JetBrains Mono',monospace; font-size:12px; color:#8A93B8; min-width:24px; }
.rz-line-name { font-weight:600; color:#0B0F2E; flex:1; text-decoration:none; }
.rz-line-name.rz-link, a.rz-line-name { color:#0B0F2E; }
.rz-line-name:hover { color:#6B3CFF; }
.rz-line-sub { font-family:'JetBrains Mono',monospace; font-size:11px; color:#8A93B8; }
.rz-line-pts { font-family:'Montserrat',sans-serif; font-weight:900; color:#0B0F2E; }
.rz-neg { color:#B91A0F; }
.rz-undo { background:transparent; border:1px solid #E5E1D8; color:#8A93B8; border-radius:6px; padding:2px 8px; font-size:12px; cursor:pointer; }
.rz-undo:hover { color:#B91A0F; border-color:#B91A0F; }
.rz-muted { color:#8A93B8; font-size:13px; }

/* Banner */
.rz-banner-warn { background:#FFF6E5; border:1px solid #FFE0A8; color:#7A5008; padding:14px 18px; border-radius:12px; margin-bottom:18px; display:flex; align-items:center; gap:14px; flex-wrap:wrap; }

/* Table */
.rz-table { width:100%; border-collapse:collapse; background:#fff; border:1px solid #E5E1D8; border-radius:14px; overflow:hidden; }
.rz-table th { text-align:left; padding:12px 16px; background:#F4F2EC; font-size:11px; color:#5B5750; text-transform:uppercase; letter-spacing:.06em; font-weight:700; }
.rz-table td { padding:12px 16px; border-top:1px solid #F4F0E8; font-size:14px; }
.rz-table a.rz-link { color:#0B0F2E; text-decoration:none; font-weight:600; }
.rz-code { background:#F4F2EC; padding:2px 8px; border-radius:6px; font-size:13px; }
.rz-add { background:#fff; border:1px solid #E5E1D8; border-radius:14px; padding:14px 18px; margin-bottom:14px; }
.rz-add summary { cursor:pointer; font-weight:700; color:#6B3CFF; }
.rz-add[open] summary { margin-bottom:10px; }

/* Search */
.rz-search input { padding:8px 14px; border:1px solid #E5E1D8; border-radius:8px; font-size:13px; min-width:240px; background:#fff; font-family:inherit; }

/* Chips & tabs (points) */
.rz-tabs { display:flex; gap:6px; margin-bottom:12px; background:#F4F2EC; padding:4px; border-radius:10px; }
.rz-tab { flex:1; display:flex; align-items:center; justify-content:center; gap:6px; padding:8px; border-radius:8px; cursor:pointer; font-weight:700; font-size:13px; color:#5B5750; }
.rz-tab input { display:none; }
.rz-tab:has(input:checked) { background:#0B0F2E; color:#fff; }
.rz-chips { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:10px; }
.rz-chip { padding:8px 14px; border-radius:999px; background:#F4F2EC; border:0; font-weight:700; font-size:13px; cursor:pointer; color:#0B0F2E; }
.rz-chip:hover { background:#0B0F2E; color:#fff; }
.rz-chip-neg { background:#FFE5E2; color:#B91A0F; }
.rz-chip-neg:hover { background:#B91A0F; color:#fff; }
.rz-chip-ghost { background:transparent; border:1px solid #E5E1D8; }
.rz-presets { display:flex; flex-wrap:wrap; gap:6px; margin-top:8px; }

/* Attendance buttons */
.rz-attstatus { display:flex; gap:4px; flex-wrap:wrap; }
.rz-att-btn { padding:6px 12px; border-radius:6px; border:1px solid #E5E1D8; background:#fff; font-size:12px; font-weight:700; cursor:pointer; color:#0B0F2E; }
.rz-att-present.is-on { background:#1F9D4D; color:#fff; border-color:#1F9D4D; }
.rz-att-late.is-on { background:#FFB020; color:#0B0F2E; border-color:#FFB020; }
.rz-att-excused.is-on { background:#8A93B8; color:#fff; border-color:#8A93B8; }
.rz-att-absent.is-on { background:#B91A0F; color:#fff; border-color:#B91A0F; }
.rz-att-info { color:#1F9D4D; font-weight:700; font-size:13px; }

/* Squads/Badges */
.rz-squad { text-align:center; }
.rz-squad-emoji { font-size:42px; line-height:1; margin-bottom:4px; }
.rz-squad-name { font-weight:800; font-size:18px; margin-bottom:4px; }
.rz-squad-pts { font-family:'Montserrat',sans-serif; font-weight:900; font-size:36px; line-height:1; color:#0B0F2E; }
.rz-squad-sub { font-family:'JetBrains Mono',monospace; font-size:11px; color:#8A93B8; margin:6px 0 14px; }
.rz-squad-list { text-align:left; max-height:200px; overflow:auto; padding-top:8px; border-top:1px dashed #E5E1D8; }
.rz-badge { background:#fff; border:1px solid #E5E1D8; border-radius:12px; padding:14px; text-align:center; }
.rz-badge-emoji { font-size:36px; }
.rz-badge-name { font-weight:800; margin-top:6px; }
.rz-badge-desc { font-size:12px; color:#5B5750; margin-top:4px; }
.rz-badge-meta { font-family:'JetBrains Mono',monospace; font-size:10px; color:#8A93B8; margin-top:8px; text-transform:uppercase; letter-spacing:.04em; }

/* MEMBER DETAIL */
.rz-md-pts { font-family:'Montserrat',sans-serif; font-weight:900; font-size:54px; line-height:1; color:#0B0F2E; margin:14px 0 18px; }
.rz-md-pts span { font-size:14px; font-weight:600; color:#8A93B8; margin-left:4px; }
.rz-md-sub { color:#5B5750; font-size:13px; margin-top:4px; }
.rz-md-head { margin-bottom:8px; }

/* PARTICIPANT */
.rz-pbody { background:#0B0F2E; }
.rz-phone-shell { max-width:430px; margin:0 auto; min-height:100vh; background:#FAF9F6; display:flex; flex-direction:column; padding-bottom:80px; }
.rz-pheader { display:flex; justify-content:space-between; align-items:center; padding:14px 20px; border-bottom:1px solid #E5E1D8; background:#fff; }
.rz-pheader-name { font-weight:800; }
.rz-plogout { color:#8A93B8; font-size:12px; text-decoration:none; }
.rz-pmain { flex:1; padding:14px; }
.rz-ptabs { position:fixed; bottom:0; left:0; right:0; max-width:430px; margin:0 auto; background:#fff; border-top:1px solid #E5E1D8; display:flex; padding:8px; gap:4px; }
.rz-ptab { flex:1; display:flex; flex-direction:column; align-items:center; gap:2px; padding:8px; border-radius:8px; text-decoration:none; color:#8A93B8; font-size:11px; font-weight:700; }
.rz-ptab span { font-size:11px; }
.rz-ptab.is-on { color:#6B3CFF; background:rgba(107,60,255,.08); }
.rz-phero { padding:30px 24px; border-radius:18px; text-align:center; background:#fff; border:1px solid #E5E1D8; margin-bottom:14px; }
.rz-phero-emoji { font-size:64px; line-height:1; }
.rz-phero-level { font-weight:800; font-size:18px; margin-top:8px; }
.rz-phero-pts { font-family:'Montserrat',sans-serif; font-weight:900; font-size:48px; line-height:1; margin-top:8px; color:#0B0F2E; }
.rz-phero-pts span { font-size:14px; font-weight:600; color:#8A93B8; }
.rz-progress { height:8px; background:#F4F2EC; border-radius:4px; margin:14px 0 6px; overflow:hidden; }
.rz-progress-bar { height:100%; background:linear-gradient(90deg,#6B3CFF,#8B62FF); border-radius:4px; }
.rz-progress-sub { font-family:'JetBrains Mono',monospace; font-size:11px; color:#8A93B8; }
.rz-pcard { background:#fff; border:1px solid #E5E1D8; border-radius:14px; padding:18px 20px; margin-bottom:12px; }
.rz-pcard-h { font-weight:800; margin-bottom:8px; font-size:14px; color:#5B5750; text-transform:uppercase; letter-spacing:.04em; }
.rz-pbadges { display:flex; flex-wrap:wrap; gap:10px; }
.rz-pbadge { width:48px; height:48px; display:flex; align-items:center; justify-content:center; font-size:24px; background:#F4F2EC; border-radius:12px; }
.rz-ptabs2 { display:flex; gap:6px; background:#fff; border:1px solid #E5E1D8; padding:4px; border-radius:10px; margin-bottom:14px; }
.rz-ptab2 { flex:1; padding:10px; text-align:center; border-radius:8px; text-decoration:none; color:#5B5750; font-weight:700; font-size:13px; }
.rz-ptab2.is-on { background:#0B0F2E; color:#fff; }
.rz-prank { list-style:none; padding:0; margin:0; }
.rz-prank li { display:flex; align-items:center; gap:10px; padding:12px 14px; background:#fff; border:1px solid #E5E1D8; border-radius:10px; margin-bottom:6px; }
.rz-prank li.is-me { background:rgba(107,60,255,.08); border-color:#6B3CFF; }
.rz-prank-num { font-family:'JetBrains Mono',monospace; color:#8A93B8; min-width:24px; }
.rz-prank-name { flex:1; font-weight:700; }
.rz-phone { min-height:100vh; display:grid; place-items:center; padding:24px; background:#0B0F2E; }
