:root{
  --bg:#0f1419; --panel:#1a2129; --panel2:#222c37; --line:#2c3946;
  --text:#e6edf3; --muted:#9aa7b4; --accent:#3b82f6;
  --green:#22c55e; --green-bg:#0f2a1b; --red:#ef4444; --red-bg:#2a1416;
  --amber:#f59e0b; --mem:#a855f7;
}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text)}
.hidden{display:none!important}
button{cursor:pointer;font-family:inherit}
input,select,textarea{font-family:inherit}

/* LOGIN */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(1200px 600px at 50% -10%,#16202b,var(--bg))}
.login-card{background:var(--panel);border:1px solid var(--line);border-radius:14px;
  padding:32px;width:340px;display:flex;flex-direction:column;gap:14px;box-shadow:0 20px 60px rgba(0,0,0,.4)}
.brand{font-size:24px;font-weight:700}
.brand span{color:var(--accent)}
.subtitle{color:var(--muted);margin-top:-8px;font-size:13px}
.login-card label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--muted)}
.login-card input{background:var(--panel2);border:1px solid var(--line);border-radius:8px;
  padding:10px;color:var(--text);font-size:14px}
.btn-primary{background:var(--accent);border:none;color:#fff;padding:11px;border-radius:8px;font-weight:600;font-size:14px}
.btn-primary:hover{filter:brightness(1.08)}
.error{color:var(--red);font-size:13px;min-height:16px}
.hint{color:var(--muted);font-size:12px;text-align:center}

/* TOPBAR */
.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:10px 18px;background:var(--panel);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:5}
.brand-sm{font-weight:700;font-size:16px;white-space:nowrap}
.brand-sm span{color:var(--accent)}
.topbar-mid{display:flex;align-items:center;gap:14px;flex:1;min-width:0}
.topbar-right{display:flex;align-items:center;gap:12px;color:var(--muted);font-size:13px}
#project-select{background:var(--panel2);border:1px solid var(--line);color:var(--text);
  border-radius:8px;padding:8px 10px;font-size:13px;max-width:260px}
.page-nav{display:flex;gap:6px;flex-wrap:wrap}
.page-nav button{background:var(--panel2);border:1px solid var(--line);color:var(--muted);
  border-radius:7px;padding:6px 11px;font-size:13px}
.page-nav button.active{background:var(--accent);border-color:var(--accent);color:#fff}
.page-nav button.done{color:var(--green);border-color:#1f4030}
.learn-badge{background:var(--panel2);border:1px solid var(--mem);color:#d6b8ff;
  border-radius:20px;padding:4px 10px;font-size:12px}
.btn-ghost{background:transparent;border:1px solid var(--line);color:var(--muted);border-radius:8px;padding:7px 12px}
.btn-ghost:hover{color:var(--text)}
.btn-upload{background:var(--accent);border:none;color:#fff;border-radius:8px;padding:8px 13px;font-size:13px;font-weight:600;white-space:nowrap}
.btn-upload:hover{filter:brightness(1.08)}

/* MODAL */
.modal-wrap{position:fixed;inset:0;background:rgba(5,8,12,.66);display:flex;align-items:center;
  justify-content:center;z-index:20;backdrop-filter:blur(2px)}
.modal-card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:26px;
  width:420px;max-width:92vw;display:flex;flex-direction:column;gap:13px;box-shadow:0 24px 70px rgba(0,0,0,.5)}
.modal-card h3{margin:0;font-size:19px}
.modal-sub{margin:-6px 0 4px;color:var(--muted);font-size:13px;line-height:1.4}
.modal-card label{display:flex;flex-direction:column;gap:5px;font-size:13px;color:var(--muted)}
.modal-card .opt{color:var(--line)}
.modal-card input,.modal-card select{background:var(--panel2);border:1px solid var(--line);border-radius:8px;
  padding:9px 10px;color:var(--text);font-size:14px}
.modal-card input[type=file]{padding:8px;font-size:13px}
.modal-row{display:flex;gap:10px;justify-content:flex-end;margin-top:6px}

/* SUBBAR (page title + progress + legend) */
.subbar{display:flex;align-items:center;gap:18px;padding:9px 18px;background:var(--panel);
  border-bottom:1px solid var(--line);flex-wrap:wrap}
.subbar h2{margin:0;font-size:15px;white-space:nowrap}
.progress{position:relative;background:var(--panel2);border-radius:20px;height:22px;overflow:hidden;
  border:1px solid var(--line);min-width:180px;flex:0 1 240px}
.progress .bar{position:absolute;left:0;top:0;bottom:0;background:linear-gradient(90deg,#1f9d55,#22c55e);width:0;transition:width .3s}
.progress .ptext{position:relative;display:block;text-align:center;font-size:12px;line-height:22px;color:#fff}
.legend{display:flex;gap:16px;color:var(--muted);font-size:12px;margin-left:auto;flex-wrap:wrap}
.legend .dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:6px;vertical-align:middle}
.dot.green{background:var(--green)} .dot.red{background:var(--red)} .dot.mem{background:var(--mem)}
.btn-build{background:var(--green);border:none;color:#06210f;border-radius:8px;padding:7px 13px;font-size:13px;font-weight:700;white-space:nowrap}
.btn-build:hover{filter:brightness(1.08)} .btn-build:disabled{opacity:.5}
/* batch translate control */
.translate-ctl{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted)}
.tr-label{white-space:nowrap}
.pg-input{width:46px;background:var(--panel2);border:1px solid var(--line);color:var(--text);
  border-radius:6px;padding:5px 6px;font-size:12px;text-align:center}
.btn-translate{background:var(--accent);border:none;color:#fff;border-radius:7px;padding:6px 11px;font-size:12px;font-weight:600}
.btn-translate.ghost{background:var(--panel2);border:1px solid var(--accent);color:#8fb8ff}
.btn-translate:hover{filter:brightness(1.08)} .btn-translate:disabled{opacity:.5}
.tr-status{color:var(--muted);font-size:12px;min-width:60px}

/* ROLE VIEW CONTAINERS */
#admin-view,#translator-view{height:100vh;display:flex;flex-direction:column}
#panel-booklets{flex:1;display:flex;flex-direction:column;min-height:0}
#panel-users{flex:1;overflow:auto}
.toolbar2{display:flex;align-items:center;gap:12px;padding:9px 16px;background:var(--panel);
  border-bottom:1px solid var(--line);flex-wrap:wrap}

/* BOOKLET DASHBOARD */
#booklets-list{flex:1;overflow:auto;display:flex;flex-direction:column}
#booklet-detail{flex:1;display:flex;flex-direction:column;min-height:0}
.bl-toolbar{display:flex;align-items:center;gap:10px;padding:14px 20px;background:var(--panel);
  border-bottom:1px solid var(--line);flex-wrap:wrap}
.bl-search{background:var(--panel2);border:1px solid var(--line);color:var(--text);border-radius:8px;
  padding:9px 12px;font-size:14px;min-width:220px;flex:1;max-width:340px}
.bl-filter{background:var(--panel2);border:1px solid var(--line);color:var(--text);border-radius:8px;padding:9px 10px;font-size:13px}
.muted-sm{color:var(--muted);font-size:13px;margin-left:auto}
.bd-name{font-weight:600;font-size:15px;white-space:nowrap;max-width:340px;overflow:hidden;text-overflow:ellipsis}
.bl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;padding:20px;align-content:start}
.bl-card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:16px;
  display:flex;flex-direction:column;gap:10px;transition:border-color .15s,transform .12s}
.bl-card:hover{border-color:var(--accent);transform:translateY(-2px)}
.bl-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}
.bl-title{font-weight:700;font-size:15px;line-height:1.25;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.bl-lang{flex:none;font-size:11px;background:var(--panel2);border:1px solid var(--accent);color:#8fb8ff;border-radius:10px;padding:2px 9px;white-space:nowrap}
.bl-status{align-self:flex-start;font-size:11px;text-transform:capitalize;padding:2px 10px;border-radius:10px;border:1px solid var(--line);color:var(--muted)}
.bl-status.status-translating{color:#8fb8ff;border-color:#2d4a7a}
.bl-status.status-completed{color:var(--green);border-color:#1f4030}
.bl-status.status-built{color:#d6b8ff;border-color:var(--mem)}
.bl-status.status-rejected{color:#ffb4b4;border-color:var(--red)}
.bl-bar{position:relative;height:8px;background:var(--panel2);border-radius:8px;overflow:hidden;border:1px solid var(--line)}
.bl-bar-tr{position:absolute;left:0;top:0;bottom:0;background:#2d4a7a}
.bl-bar-sub{position:absolute;left:0;top:0;bottom:0;background:linear-gradient(90deg,#1f9d55,#22c55e)}
.bl-stats{font-size:12px;color:var(--muted)} .bl-stats b{color:var(--green)}
.bl-actions{display:flex;flex-wrap:wrap;gap:6px;margin-top:2px}
.bl-msg{font-size:12px;color:var(--muted);min-height:14px}

/* ADMIN TABS */
.admin-tabs{display:flex;gap:6px}
.atab{background:transparent;border:1px solid var(--line);color:var(--muted);border-radius:8px;padding:7px 16px;font-size:13px;font-weight:600}
.atab.active{background:var(--accent);border-color:var(--accent);color:#fff}

/* TRANSLATOR QUEUE HEADER */
.q-meta{display:flex;align-items:center;gap:12px;flex:1;justify-content:center}
.q-stat{font-size:13px;color:var(--muted);background:var(--panel2);border:1px solid var(--line);border-radius:20px;padding:4px 12px}
.empty-big{display:flex;align-items:center;justify-content:center;height:60vh;color:var(--muted);font-size:20px;text-align:center}

/* USERS TABLE */
.users-wrap{max-width:980px;margin:0 auto;padding:24px 18px}
.users-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.users-head h2{margin:0}
.users-table{width:100%;border-collapse:collapse;font-size:14px}
.users-table th{text-align:left;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.04em;padding:8px 10px;border-bottom:1px solid var(--line)}
.users-table td{padding:9px 10px;border-bottom:1px solid var(--line);vertical-align:middle}
.role-chip{font-size:11px;padding:2px 9px;border-radius:10px;border:1px solid var(--line);text-transform:capitalize}
.role-chip.admin{color:#ffce8f;border-color:#7a5a2d} .role-chip.translator{color:#8fb8ff;border-color:#2d4a7a}
.status-chip{font-size:11px;padding:2px 9px;border-radius:10px}
.status-chip.active{color:var(--green);border:1px solid #1f4030} .status-chip.hold{color:var(--red);border:1px solid #5a2424}
.lang-cell{max-width:300px}
.lchip{display:inline-block;font-size:11px;background:var(--panel2);border:1px solid var(--line);border-radius:9px;padding:1px 8px;margin:2px 3px 2px 0;color:var(--text)}
.row-actions{display:flex;gap:6px;white-space:nowrap}
.btn-mini{background:var(--panel2);border:1px solid var(--line);color:var(--text);border-radius:6px;padding:5px 10px;font-size:12px}
.btn-mini:hover{border-color:var(--accent)} .btn-mini.danger{color:#ffb4b4} .btn-mini.danger:hover{border-color:var(--red)}
.btn-mini:disabled{opacity:.4;cursor:default;border-color:var(--line);color:var(--muted)}
.btn-mini:disabled:hover{border-color:var(--line)}
#user-modal select[multiple]{height:auto}

/* REPORTS */
#panel-reports{flex:1;overflow:auto}
.reports-wrap{max-width:1100px;margin:0 auto;padding:24px 18px}
.rep-filters{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:8px}
.rep-filters label{font-size:13px;color:var(--muted);display:flex;gap:6px;align-items:center}
.rep-filters input[type=date]{background:var(--panel2);border:1px solid var(--line);color:var(--text);border-radius:8px;padding:7px 9px}
.rep-h{margin:20px 0 8px;font-size:15px}
.rep-table{width:100%;border-collapse:collapse;font-size:13px;margin-bottom:8px}
.rep-table th{text-align:left;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.04em;padding:7px 9px;border-bottom:1px solid var(--line)}
.rep-table td{padding:7px 9px;border-bottom:1px solid var(--line)}
.nowrap{white-space:nowrap}
.act-chip{font-size:11px;padding:1px 8px;border-radius:9px;border:1px solid var(--line);color:var(--muted);text-transform:capitalize}
.act-chip.act-submitted{color:var(--green);border-color:#1f4030}
.act-chip.act-claimed{color:#8fb8ff;border-color:#2d4a7a}
.act-chip.act-built{color:#d6b8ff;border-color:var(--mem)}
.act-chip.act-rejected{color:#ffb4b4;border-color:var(--red)}

/* SETTINGS (suffix editor) */
.settings-wrap{max-width:760px;margin:0 auto;padding:24px 18px}
.settings-actions{margin-top:16px;display:flex;gap:12px;align-items:center}
.suffix-in,.font-in{background:var(--panel2);border:1px solid var(--line);color:var(--text);border-radius:6px;padding:6px 8px;font-size:13px}

.train-totals{display:inline-block;background:var(--panel2);border:1px solid var(--line);border-radius:20px;
  padding:6px 14px;font-size:13px;color:var(--text);margin:6px 0 14px}

/* TRANSLATOR: My work + scorecard */
#q-work{flex:1;display:flex;flex-direction:column;min-height:0}
#q-report{flex:1;overflow:auto}
.q-score{font-size:13px;font-weight:700;color:#06210f;background:var(--green);border-radius:20px;padding:5px 14px;white-space:nowrap}
.score-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:8px}
.score-card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:20px;text-align:center}
.score-n{font-size:34px;font-weight:800;color:var(--green);line-height:1}
.score-l{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-top:6px}

/* SIDE-BY-SIDE LAYOUT */
.layout{display:grid;grid-template-columns:1fr 1fr;gap:0;flex:1;min-height:0}
.pane{display:flex;flex-direction:column;min-width:0;border-right:1px solid var(--line)}
.pane:last-child{border-right:none}
.pane-label{padding:8px 16px;font-size:12px;text-transform:uppercase;letter-spacing:.05em;
  color:var(--muted);background:var(--panel);border-bottom:1px solid var(--line)}
.lang-chip{margin-left:8px;color:var(--accent);text-transform:none;letter-spacing:0;font-weight:600}
.surface-scroll{flex:1;overflow:auto;padding:18px;display:flex;justify-content:center;align-items:flex-start}
/* The page itself: a fixed-aspect canvas; blocks are positioned in % of it. */
.page-surface{position:relative;width:100%;max-width:760px;background:#fff;border-radius:6px;
  box-shadow:0 8px 30px rgba(0,0,0,.45);background-size:100% 100%;background-repeat:no-repeat}
.page-surface.has-image{background-color:#fff}
/* Translation pane shows the page in TRUE colors; opaque text boxes sit over the
   English so the rest of the artwork/colors match the original. */

/* Original text blocks (shown when there is no page image) */
.oblock{position:absolute;overflow:hidden;color:#11181f;font-size:13px;line-height:1.3;
  padding:6px 8px;border:1px solid #e3e8ee;border-radius:5px;background:#f7f9fb}

/* Translated blocks with ✓/✗ ticks. Box grows downward (min-height) so longer
   target text never clips; ✓/✗ sit fully ABOVE the box so they never cover text. */
.tblock{position:absolute;overflow:visible;
  border:1px solid rgba(120,140,160,.5);border-radius:5px;background:#fff;color:#11181f;
  font-size:12px;line-height:1.25;transition:border-color .2s,background .2s}
.tblock .tb-text{padding:4px 6px;white-space:normal;overflow-wrap:break-word;word-break:break-word}
.tblock.pending{border-color:#c8d2dc}
.tblock.edited{border-color:var(--green);background:#eafaf0;z-index:1}
.tblock.err{border-color:var(--red);background:#fdecec}
.err-text{color:var(--red)}
/* single dot control at the top-right corner — red by default (assumed correct),
   green once edited. Click to open the editor. */
.tb-dot{position:absolute;top:-7px;right:-7px;width:14px;height:14px;border-radius:50%;padding:0;
  background:var(--red);border:2px solid #fff;box-shadow:0 1px 4px rgba(0,0,0,.35);cursor:pointer;z-index:2;
  transition:transform .12s}
.tb-dot:hover{transform:scale(1.3)}
.tblock.edited .tb-dot{background:var(--green)}
.tblock.err .tb-dot{background:var(--red);animation:dotpulse 1.3s ease-in-out infinite}
@keyframes dotpulse{0%,100%{opacity:1}50%{opacity:.35}}
/* Inline correction editor */
/* Editor popup — fixed comfortable size, breaks out of the (possibly tiny) block.
   Flips horizontally/vertically near the page edges so it never gets clipped. */
.tb-edit{display:none;position:absolute;left:0;top:100%;margin-top:8px;z-index:20;
  width:460px;max-width:88vw;
  flex-direction:column;gap:9px;background:var(--panel);border:1px solid var(--amber);
  border-radius:10px;padding:13px;box-shadow:0 16px 44px rgba(0,0,0,.6)}
.tblock.editing{z-index:30}
.tblock.editing .tb-edit{display:flex}
.tblock.edit-flip .tb-edit{left:auto;right:0}
.tblock.edit-up .tb-edit{top:auto;bottom:100%;margin-top:0;margin-bottom:8px}
.tb-edit textarea{width:100%;min-height:170px;max-height:60vh;background:var(--panel2);border:1px solid var(--amber);
  border-radius:7px;color:var(--text);padding:11px;font-size:14px;line-height:1.5;resize:vertical}
.tb-edit-row{display:flex;gap:8px;justify-content:flex-end;align-items:center}
.btn-save{background:var(--green);border:none;color:#06210f;font-weight:600;border-radius:6px;padding:6px 12px;font-size:12px}
.btn-cancel{background:transparent;border:1px solid var(--line);color:var(--muted);border-radius:6px;padding:6px 12px;font-size:12px}
.btn-revert{background:transparent;border:1px solid var(--line);color:#8fb8ff;border-radius:6px;padding:6px 10px;font-size:12px;margin-right:auto}
.btn-phon,.btn-vkbd{background:var(--panel2);border:1px solid var(--accent);color:#8fb8ff;border-radius:6px;padding:6px 10px;font-size:13px}
.btn-phon:hover,.btn-vkbd:hover{background:var(--accent);color:#fff}
/* phonetic input row */
.tb-phon{display:flex;gap:8px;align-items:center;background:var(--panel2);border:1px solid var(--accent);border-radius:8px;padding:7px 9px}
.tb-phon.hidden{display:none}
.phon-in{flex:1;min-width:80px;background:var(--bg);border:1px solid var(--line);color:var(--text);border-radius:6px;padding:7px 9px;font-size:14px}
.phon-prev{flex:1;font-size:16px;color:var(--green);min-height:20px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
.phon-insert{background:var(--green);border:none;color:#06210f;font-weight:600;border-radius:6px;padding:6px 11px;font-size:12px;white-space:nowrap}
/* on-screen keyboard */
.tb-kbd{display:flex;flex-direction:column;gap:5px;background:var(--panel2);border:1px solid var(--line);border-radius:8px;padding:8px;max-height:42vh;overflow:auto}
.tb-kbd.hidden{display:none}
.kbd-row{display:flex;gap:5px;flex-wrap:wrap}
.kbd-key{background:var(--bg);border:1px solid var(--line);color:var(--text);border-radius:6px;min-width:30px;padding:7px 8px;font-size:16px;line-height:1;cursor:pointer}
.kbd-key:hover{border-color:var(--accent);background:var(--panel)}
.kbd-key.kbd-wide{flex:1;min-width:120px;font-size:12px}
.empty{color:var(--muted);text-align:center;padding:40px}

@media(max-width:860px){
  .layout{grid-template-columns:1fr;height:auto}
  .pane{border-right:none;border-bottom:1px solid var(--line)}
}
