:root{
  --bg:#0b0b14; --bg2:#12121f; --card:#171728; --card2:#1d1d31; --line:#2a2a42;
  --txt:#e9e9f3; --muted:#9a9ab8; --faint:#6e6e8c;
  --blue:#5a60ff; --purple:#9a4fd6; --pink:#ec4f86; --amber:#f5b13d;
  --green:#36d399; --red:#f15a6b;
  --dev:#5a8bff; --tester:#ec6fa0;
  --radius:14px; --shadow:0 10px 30px rgba(0,0,0,.35);
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  background:radial-gradient(1200px 600px at 80% -10%, #1a1430 0%, transparent 60%),
             radial-gradient(900px 500px at -10% 110%, #1a1030 0%, transparent 55%), var(--bg);
  color:var(--txt); font:15px/1.5 'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  -webkit-font-smoothing:antialiased;
}
button{font:inherit;cursor:pointer;border:0;border-radius:10px;color:#fff;padding:9px 16px;transition:.15s}
button:active{transform:translateY(1px)}
button:disabled{opacity:.5;cursor:not-allowed}
input,textarea{font:inherit;color:var(--txt);background:var(--bg2);border:1px solid var(--line);border-radius:10px;padding:10px 12px;width:100%;outline:none}
input:focus,textarea:focus{border-color:var(--blue)}
textarea{resize:vertical;min-height:80px}
a{color:var(--blue)}
.grad{background:linear-gradient(90deg,var(--blue),var(--purple),var(--pink))}
.btn-grad{background:linear-gradient(90deg,var(--blue),var(--pink));box-shadow:0 6px 18px rgba(120,70,220,.35)}
.btn-ghost{background:#ffffff12;color:var(--txt)}
.btn-ghost:hover{background:#ffffff1f}
.btn-green{background:linear-gradient(90deg,#1ea97c,#36d399)}
.btn-red{background:linear-gradient(90deg,#d63a4d,#f15a6b)}
.muted{color:var(--muted)} .faint{color:var(--faint)} .small{font-size:12.5px}

/* ── gate / role pick ── */
.center{min-height:100dvh;display:grid;place-items:center;padding:24px}
.gate{width:min(420px,94vw);background:var(--card);border:1px solid var(--line);border-radius:18px;padding:30px;box-shadow:var(--shadow);text-align:center}
.gate h1{margin:.2em 0 .1em;font-size:24px}
.gate .logo{width:54px;height:54px;border-radius:14px;margin:0 auto 14px;display:grid;place-items:center;font-weight:800;font-size:20px}
.rolepick{display:grid;gap:14px;margin-top:18px}
.rolecard{padding:22px;border-radius:16px;border:1px solid var(--line);background:var(--card2);text-align:left;display:flex;gap:14px;align-items:center;transition:.15s}
.rolecard:hover{border-color:var(--blue);transform:translateY(-2px)}
.rolecard .ico{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;font-size:22px;flex:0 0 auto}
.rolecard b{display:block;font-size:17px}

/* ── app shell ── */
.shell{max-width:1080px;margin:0 auto;padding:0 16px 80px}
header.top{position:sticky;top:0;z-index:20;background:rgba(11,11,20,.82);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);
  display:flex;align-items:center;gap:12px;padding:12px 16px;margin:0 -16px 18px}
.brand{font-weight:800;letter-spacing:.2px;display:flex;align-items:center;gap:9px}
.brand .dot{width:26px;height:26px;border-radius:8px;display:grid;place-items:center;font-size:13px;font-weight:800}
.spacer{flex:1}
.rolebadge{font-weight:700;font-size:13px;padding:5px 11px;border-radius:999px;display:inline-flex;gap:7px;align-items:center}
.rolebadge.dev{background:#5a8bff22;color:var(--dev);border:1px solid #5a8bff44}
.rolebadge.tester{background:#ec6fa022;color:var(--tester);border:1px solid #ec6fa044}

/* ── name chip (header center) ── */
.nametag{background:#ffffff10;color:var(--txt);border:1px solid var(--line);border-radius:999px;padding:6px 14px;font-weight:600;font-size:13px;display:inline-flex;align-items:center;gap:6px;white-space:nowrap}
.nametag:hover{background:#ffffff1c;border-color:var(--blue)}
.nametag .pencil{opacity:.5;font-size:11px}
.nametag.unset{color:var(--muted);border-style:dashed}
.nameinput{width:auto;min-width:160px;max-width:230px;padding:6px 13px;border-radius:999px;font-weight:600;font-size:13px}
/* small role tag shown after a person's name */
.rtag{font-size:9.5px;font-weight:800;text-transform:uppercase;letter-spacing:.4px;padding:1px 5px;border-radius:5px;margin-left:5px;vertical-align:1px;opacity:.9}
.who.dev .rtag{background:#5a8bff22;color:var(--dev)}
.who.tester .rtag{background:#ec6fa022;color:var(--tester)}

.tabs{display:flex;gap:6px;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:5px;margin-bottom:18px;width:fit-content}
.tabs button{background:transparent;color:var(--muted);padding:8px 16px;font-weight:600;border-radius:9px}
.tabs button.active{background:#ffffff12;color:var(--txt)}
.tabs .count{font-size:11px;background:#ffffff1a;border-radius:999px;padding:1px 7px;margin-left:7px}

/* ── cards ── */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px;margin-bottom:14px}
.card h3{margin:0 0 4px;font-size:16px}
.row{display:flex;gap:10px;align-items:center}
.between{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.who{font-size:12px;font-weight:700}
.who.dev{color:var(--dev)} .who.tester{color:var(--tester)}
.pill{font-size:11.5px;font-weight:700;padding:3px 10px;border-radius:999px;white-space:nowrap}
.pill.todo{background:#f5b13d22;color:var(--amber);border:1px solid #f5b13d44}
.pill.review{background:#5a8bff22;color:var(--dev);border:1px solid #5a8bff44}
.pill.done{background:#36d39922;color:var(--green);border:1px solid #36d39944}
.pill.ai{background:#9a4fd622;color:#c79bff;border:1px solid #9a4fd644}
.pill.round{background:#f15a6b22;color:var(--red);border:1px solid #f15a6b44}

.sectionhead{display:flex;align-items:center;gap:9px;margin:22px 2px 10px;font-weight:700;color:var(--muted);font-size:13px;text-transform:uppercase;letter-spacing:.6px}
.sectionhead .ln{flex:1;height:1px;background:var(--line)}

/* thread */
.thread{margin-top:12px;border-top:1px dashed var(--line);padding-top:12px;display:grid;gap:9px}
.cmt{background:var(--bg2);border:1px solid var(--line);border-radius:10px;padding:9px 12px}
.cmt .meta{font-size:11px;margin-bottom:2px}
.composer{display:flex;gap:8px;margin-top:10px}
.composer input{flex:1}

/* ticket events / reports */
.events{margin-top:12px;display:grid;gap:8px}
.evt{font-size:13px;border-left:2px solid var(--line);padding:2px 0 2px 12px}
.evt.bugged{border-color:var(--red)}
.evt.success{border-color:var(--green)}
.evt.completed{border-color:var(--dev)}
.shots{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.shots img{width:96px;height:96px;object-fit:cover;border-radius:9px;border:1px solid var(--line);cursor:zoom-in}

.actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.empty{text-align:center;color:var(--faint);padding:46px 10px}

/* modal */
.backdrop{position:fixed;inset:0;background:#000a;backdrop-filter:blur(4px);display:grid;place-items:center;z-index:60;padding:18px}
.modal{width:min(560px,96vw);max-height:90dvh;overflow:auto;background:var(--card);border:1px solid var(--line);border-radius:18px;padding:22px;box-shadow:var(--shadow)}
.modal h2{margin:0 0 14px;font-size:19px}
.modal .field{margin-bottom:13px}
.modal label{display:block;font-size:12.5px;color:var(--muted);margin-bottom:5px;font-weight:600}
.lightbox{position:fixed;inset:0;background:#000d;display:grid;place-items:center;z-index:80;padding:20px}
.lightbox img{max-width:96vw;max-height:92vh;border-radius:10px}
.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);background:#1d1d31;border:1px solid var(--line);
  padding:11px 18px;border-radius:12px;z-index:90;box-shadow:var(--shadow);font-weight:600}
.spin{display:inline-block;width:15px;height:15px;border:2px solid #ffffff44;border-top-color:#fff;border-radius:50%;animation:s .7s linear infinite;vertical-align:-2px}
@keyframes s{to{transform:rotate(360deg)}}
.drop{border:1.5px dashed var(--line);border-radius:12px;padding:16px;text-align:center;color:var(--muted);cursor:pointer}
.drop:hover{border-color:var(--blue);color:var(--txt)}

/* ── tester test-guide ── */
.testguide{margin-top:12px;border:1px solid var(--line);border-radius:12px;background:var(--bg2);overflow:hidden}
.testguide.on{border-color:#36d39955;background:linear-gradient(180deg,#36d39912,transparent);padding-bottom:6px}
.testguide .tg-head{font-weight:800;padding:11px 14px;color:var(--green);border-bottom:1px solid var(--line);font-size:14px;background:#36d39915}
.testguide summary{cursor:pointer;padding:10px 14px;font-weight:700;color:var(--muted);font-size:13px;user-select:none;list-style:none}
.testguide summary::-webkit-details-marker{display:none}
.testguide summary:hover{color:var(--txt)}
.testguide .tg-body{padding-bottom:6px}
.tg-row{display:flex;gap:10px;padding:8px 14px;font-size:13.5px;align-items:flex-start}
.tg-row+.tg-row{border-top:1px dashed var(--line)}
.tg-k{flex:0 0 60px;font-weight:800;text-transform:uppercase;font-size:10.5px;letter-spacing:.5px;color:var(--faint);padding-top:2px}
.tg-v{flex:1;min-width:0;word-break:break-word}
.tg-steps{margin:0;padding-left:18px;display:grid;gap:4px;flex:1}
.tg-steps li{padding-left:2px}

/* ── dev re-analysis flag ── */
.reflag{margin-top:10px;padding:8px 12px;border-radius:10px;background:#f15a6b18;border:1px solid #f15a6b40;color:#ffb3bd;font-weight:600;font-size:12.5px}

/* ── report type: colored outline + tag + selector ── */
.card.type-bug{border:1.5px solid #f15a6bcc}
.card.type-feature{border:1.5px solid #5a8bffcc}
.typetag{font-size:11px;font-weight:800;padding:2px 9px;border-radius:999px;white-space:nowrap;border:1px solid;letter-spacing:.2px}
.typetag.bug{color:var(--red);border-color:#f15a6b66;background:#f15a6b18}
.typetag.feature{color:var(--blue);border-color:#5a8bff66;background:#5a8bff18}
.typesel{display:flex;gap:10px}
.tsel{flex:1;background:transparent;border:1.5px solid var(--line);color:var(--muted);font-weight:700;padding:11px;border-radius:12px}
.tsel:hover{color:var(--txt)}
.tsel.bug.on{border-color:var(--red);color:var(--red);background:#f15a6b14}
.tsel.feature.on{border-color:var(--blue);color:var(--blue);background:#5a8bff14}

/* ── phone / responsive ── */
@media (max-width:680px){
  .shell{padding:0 11px 96px}
  header.top{flex-wrap:wrap;gap:8px;padding:10px 12px;margin-bottom:14px}
  header.top .spacer{display:none}
  .brand{font-size:15px}
  .nametag,.nameinput{order:9;flex:1 1 100%;justify-content:center}
  .tabs{width:100%}
  .tabs button{flex:1;text-align:center;padding:9px 6px}
  .between{flex-direction:column;align-items:stretch}
  .between>.row{width:100%;flex-wrap:wrap}
  .actions button{flex:1 1 auto}
  .composer{flex-direction:column}
  .composer button{width:100%}
  .modal{padding:17px}
  .shots img{width:84px;height:84px}
  .tg-k{flex-basis:52px}
}
