/* ═══════════════════════════════════════════════════════════════════════════
   TE Tool v2 — Design System  ·  "KPO Pro"
   Dense, calm, data-first. Inspired by Linear / Stripe.  KPO cyan + signal yellow.
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Tokens ──────────────────────────────────────────────────────────────── */
:root{
  /* Brand — Karachaganak cyan */
  --brand:        #0098b5;
  --brand-600:    #007e98;
  --brand-700:    #006d83;
  --brand-800:    #00576a;
  --brand-ink:    #00323d;
  --brand-100:    #e2f5f9;
  --brand-50:     #f0fafc;
  --brand-tint:   rgba(0,152,181,.08);
  --brand-tint-2: rgba(0,152,181,.14);
  --brand-ring:   rgba(0,152,181,.28);

  /* Signal — KPO yellow (accent, used sparingly) */
  --signal:       #f5b800;
  --signal-700:   #b97e00;
  --signal-tint:  rgba(245,184,0,.14);

  /* Neutrals — cool slate */
  --ink:    #0c1116;   /* primary text */
  --ink-2:  #3b4654;   /* secondary */
  --ink-3:  #69727f;   /* tertiary / captions */
  --ink-4:  #97a0ac;   /* disabled / faint */

  --canvas: #f4f6f8;   /* app background */
  --surface:#ffffff;   /* cards, panels */
  --surface-2:#f8fafb; /* subtle fills, table stripes */
  --surface-3:#eef2f5; /* hover fills, inset */
  --surface-4:#e6ebf0;

  --line:   #e3e8ee;   /* default border */
  --line-2: #d3dae2;   /* stronger border */
  --line-3: #c2cad4;
  --hair:   rgba(12,17,22,.06);

  /* Status */
  --ok:      #0e7c43;  --ok-bg:#e7f6ee;  --ok-line:#bfe6cf;
  --no:      #c8312b;  --no-bg:#fdecec;  --no-line:#f3c4c2;
  --warn:    #9a6400;  --warn-bg:#fef4dd; --warn-line:#f5dca0;
  --info:    #2456c9;  --info-bg:#e9effd; --info-line:#c4d4f7;
  --muted-bg:#eef1f4; --muted-line:#dfe4ea;

  /* Typography */
  --font: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --mono: 'JetBrains Mono', ui-monospace, 'SF Mono', 'Cascadia Code', Menlo, monospace;

  --fs-11: 11px; --fs-12: 12px; --fs-13: 13px; --fs-14: 14px;
  --fs-16: 16px; --fs-18: 18px; --fs-22: 22px; --fs-28: 28px;

  /* Radius */
  --r-xs: 4px; --r-sm: 6px; --r: 8px; --r-md: 10px; --r-lg: 14px; --r-pill: 999px;

  /* Elevation — soft, brand-tinted */
  --sh-1: 0 1px 1px rgba(12,17,22,.04), 0 1px 2px rgba(12,17,22,.06);
  --sh-2: 0 1px 2px rgba(12,17,22,.05), 0 4px 10px -2px rgba(0,50,61,.10);
  --sh-3: 0 2px 4px rgba(12,17,22,.06), 0 12px 28px -6px rgba(0,50,61,.16);
  --sh-pop: 0 8px 24px -4px rgba(0,50,61,.22), 0 2px 6px rgba(12,17,22,.10);
  --ring: 0 0 0 3px var(--brand-ring);

  /* Motion */
  --ease: cubic-bezier(.2,.7,.3,1);
  --fast: .12s; --med: .2s;

  /* Layout */
  --topbar-h: 52px;
  --nav-w: 216px;
  --nav-w-collapsed: 56px;
}

/* ── Reset ───────────────────────────────────────────────────────────────── */
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:var(--font);
  font-size:var(--fs-13);
  line-height:1.45;
  color:var(--ink);
  background:var(--canvas);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  font-feature-settings:'cv11','ss01','tnum';
}
button,input,select,textarea{font:inherit;color:inherit}
button{cursor:pointer;background:none;border:none}
a{color:inherit;text-decoration:none}
::selection{background:var(--brand-tint-2)}
:focus-visible{outline:none;box-shadow:var(--ring)}

/* Scrollbars — slim */
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:var(--line-3);border-radius:8px;border:2px solid var(--canvas);background-clip:padding-box}
::-webkit-scrollbar-thumb:hover{background:var(--ink-4)}
::-webkit-scrollbar-track{background:transparent}

/* ── App frame ───────────────────────────────────────────────────────────── */
#app{display:flex;flex-direction:column;height:100vh;overflow:hidden}

.topbar{
  height:var(--topbar-h);flex:0 0 auto;
  display:flex;align-items:center;gap:14px;
  padding:0 16px;
  background:var(--surface);
  border-bottom:1px solid var(--line);
  z-index:50;
}
.tb-brand{display:flex;align-items:center;gap:9px;font-weight:650;letter-spacing:-.01em;font-size:var(--fs-14)}
.tb-brand img{height:22px;width:auto;display:block}
.tb-brand .mark{display:flex;align-items:center;gap:7px}
.tb-brand .badge{font-size:9.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--brand-700);background:var(--brand-tint);padding:2px 6px;border-radius:var(--r-xs)}
.tb-sep{width:1px;height:22px;background:var(--line);margin:0 2px}
.tb-spacer{flex:1}
.tb-search{
  display:flex;align-items:center;gap:8px;width:340px;max-width:38vw;
  background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r);
  padding:0 10px;height:34px;color:var(--ink-3);transition:border-color var(--fast),background var(--fast);
}
.tb-search:focus-within{border-color:var(--brand);background:var(--surface);box-shadow:var(--ring)}
.tb-search input{flex:1;border:none;background:none;outline:none;font-size:var(--fs-13);color:var(--ink)}
.tb-search kbd{font-family:var(--mono);font-size:10px;color:var(--ink-4);border:1px solid var(--line-2);border-radius:var(--r-xs);padding:1px 5px;background:var(--surface)}
.tb-user{display:flex;align-items:center;gap:9px;padding:4px 6px 4px 4px;border-radius:var(--r);cursor:pointer;transition:background var(--fast)}
.tb-user:hover{background:var(--surface-3)}
.avatar{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:650;color:#fff;flex:0 0 auto}
.tb-user .who{line-height:1.1}
.tb-user .who b{font-weight:600;font-size:var(--fs-13)}
.tb-user .who span{font-size:11px;color:var(--ink-3)}

/* Horizontal top nav (replaces left sidebar — frees width for wide tables) */
.topnav{display:flex;align-items:center;gap:2px;height:100%}
.topnav-item{position:relative;height:100%;display:flex;align-items:center}
.topnav-item > button{display:flex;align-items:center;gap:6px;height:34px;padding:0 12px;border-radius:var(--r-sm);
  font-size:var(--fs-13);font-weight:550;color:var(--ink-2);transition:background var(--fast),color var(--fast)}
.topnav-item > button .ic{width:16px;height:16px;opacity:.85}
.topnav-item > button:hover{background:var(--surface-3);color:var(--ink)}
.topnav-item.active > button{background:var(--brand-tint);color:var(--brand-700);font-weight:650}
.topnav-item.active > button .ic{opacity:1}
.topnav-item .dd-caret{font-size:9px;opacity:.55}
.topnav-dd{display:none;position:absolute;top:calc(100% + 3px);left:0;min-width:208px;
  background:var(--surface);border:1px solid var(--line-2);border-radius:var(--r-md);box-shadow:var(--sh-pop);padding:5px;z-index:120}
.topnav-item:hover .topnav-dd{display:block;animation:pop var(--fast) var(--ease)}
.topnav-dd a{display:block;padding:8px 11px;border-radius:var(--r-sm);font-size:var(--fs-13);color:var(--ink-2);cursor:pointer;font-weight:500;white-space:nowrap}
.topnav-dd a:hover{background:var(--brand-tint);color:var(--brand-700)}
.topnav-dd .dd-div{height:1px;background:var(--line);margin:4px 6px}

.body{display:flex;flex:1;min-height:0}

/* ── Side nav ────────────────────────────────────────────────────────────── */
.nav{
  width:var(--nav-w);flex:0 0 auto;
  background:var(--surface);border-right:1px solid var(--line);
  display:flex;flex-direction:column;padding:10px 8px;gap:2px;overflow-y:auto;
  transition:width var(--med) var(--ease);
}
.nav-group-label{font-size:10px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-4);padding:12px 10px 5px}
.nav-item{
  display:flex;align-items:center;gap:10px;
  padding:7px 10px;border-radius:var(--r-sm);
  color:var(--ink-2);font-weight:500;font-size:var(--fs-13);
  cursor:pointer;transition:background var(--fast),color var(--fast);position:relative;
}
.nav-item .ic{width:17px;height:17px;flex:0 0 auto;opacity:.85;stroke-width:1.9}
.nav-item:hover{background:var(--surface-3);color:var(--ink)}
.nav-item.active{background:var(--brand-tint);color:var(--brand-700);font-weight:600}
.nav-item.active .ic{opacity:1}
.nav-item .count{margin-left:auto;font-size:11px;font-weight:600;color:var(--ink-3);background:var(--surface-3);border-radius:var(--r-pill);padding:1px 7px;min-width:20px;text-align:center}
.nav-item.active .count{background:var(--brand-tint-2);color:var(--brand-700)}
.nav .grow{flex:1}

/* ── Main scroll region ──────────────────────────────────────────────────── */
.main{flex:1;min-width:0;display:flex;flex-direction:column;overflow:hidden;background:var(--canvas)}
.screen{flex:1;min-height:0;display:none;flex-direction:column;overflow:hidden}
.screen.active{display:flex}
.scroll{overflow:auto;flex:1;min-height:0}
.pad{padding:18px 22px}

/* Page header */
.page-head{display:flex;align-items:flex-end;gap:14px;padding:16px 22px 0;flex:0 0 auto}
.page-head h1{font-size:var(--fs-22);font-weight:680;letter-spacing:-.02em}
.page-head .sub{font-size:var(--fs-13);color:var(--ink-3);margin-top:2px}
.page-head .ph-actions{margin-left:auto;display:flex;gap:8px;align-items:center}
.crumbs{display:flex;align-items:center;gap:6px;font-size:var(--fs-12);color:var(--ink-3);margin-bottom:3px}
.crumbs a{cursor:pointer}.crumbs a:hover{color:var(--brand-700)}
.crumbs .sl{opacity:.5}

/* ── Buttons ─────────────────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:7px;
  height:34px;padding:0 14px;border-radius:var(--r-sm);
  font-size:var(--fs-13);font-weight:600;white-space:nowrap;
  border:1px solid var(--line-2);background:var(--surface);color:var(--ink);
  transition:background var(--fast),border-color var(--fast),box-shadow var(--fast),transform var(--fast);
}
.btn:hover{background:var(--surface-3);border-color:var(--line-3)}
.btn:active{transform:translateY(.5px)}
.btn .ic{width:16px;height:16px;stroke-width:2}
.btn.primary{background:var(--brand);border-color:var(--brand);color:#fff;box-shadow:var(--sh-1)}
.btn.primary:hover{background:var(--brand-600);border-color:var(--brand-600)}
.btn.dark{background:var(--brand-ink);border-color:var(--brand-ink);color:#fff}
.btn.dark:hover{background:#063a47}
.btn.ok{background:var(--ok);border-color:var(--ok);color:#fff}
.btn.ok:hover{filter:brightness(1.05)}
.btn.danger{background:var(--surface);border-color:var(--no-line);color:var(--no)}
.btn.danger:hover{background:var(--no-bg)}
.btn.ghost{border-color:transparent;background:transparent}
.btn.ghost:hover{background:var(--surface-3)}
.btn.sm{height:28px;padding:0 10px;font-size:var(--fs-12);border-radius:var(--r-xs)}
.btn.xs{height:24px;padding:0 8px;font-size:var(--fs-11);gap:5px;border-radius:var(--r-xs)}
.btn.icon{width:34px;padding:0}.btn.icon.sm{width:28px}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn-group{display:inline-flex;border:1px solid var(--line-2);border-radius:var(--r-sm);overflow:hidden;background:var(--surface)}
.btn-group .btn{border:none;border-radius:0;border-right:1px solid var(--line)}
.btn-group .btn:last-child{border-right:none}
.btn-group .btn.active{background:var(--brand-tint);color:var(--brand-700)}

/* ── Forms ───────────────────────────────────────────────────────────────── */
.field{display:flex;flex-direction:column;gap:5px;position:relative}
.field > label{font-size:var(--fs-12);font-weight:600;color:var(--ink-2)}
.field .hint{font-size:11px;color:var(--ink-3)}
.inp,.sel,.ta{
  width:100%;height:34px;padding:0 11px;border-radius:var(--r-sm);
  border:1px solid var(--line-2);background:var(--surface);color:var(--ink);font-size:var(--fs-13);
  transition:border-color var(--fast),box-shadow var(--fast);outline:none;
}
.ta{height:auto;padding:9px 11px;resize:vertical;min-height:72px;line-height:1.5}
.inp:focus,.sel:focus,.ta:focus{border-color:var(--brand);box-shadow:var(--ring)}
.inp::placeholder,.ta::placeholder{color:var(--ink-4)}
.inp:disabled,.sel:disabled{background:var(--surface-3);color:var(--ink-3);cursor:not-allowed}
.sel{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2369727f' stroke-width='2.2' stroke-linecap='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 9px center;padding-right:30px}
.inp.sm,.sel.sm{height:28px;font-size:var(--fs-12);padding:0 8px}
.inp.mono{font-family:var(--mono);font-size:var(--fs-12)}

/* ── Cards / panels ──────────────────────────────────────────────────────── */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--sh-1)}
.card.flat{box-shadow:none}
.card-head{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--line)}
.card-head h3{font-size:var(--fs-14);font-weight:650}
.card-head .sub{font-size:var(--fs-12);color:var(--ink-3)}
.card-body{padding:16px}
.toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.toolbar .grow{flex:1}

/* KPI tiles */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}
.kpi{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);
  padding:13px 15px;cursor:pointer;transition:border-color var(--fast),box-shadow var(--fast),transform var(--fast);position:relative;overflow:hidden;
}
.kpi:hover{border-color:var(--line-3);box-shadow:var(--sh-2);transform:translateY(-1px)}
.kpi.active{border-color:var(--brand);box-shadow:0 0 0 1px var(--brand)}
.kpi .k-label{font-size:11px;font-weight:600;letter-spacing:.02em;color:var(--ink-3);text-transform:uppercase;display:flex;align-items:center;gap:6px}
.kpi .k-val{font-size:var(--fs-28);font-weight:700;letter-spacing:-.02em;margin-top:4px;font-variant-numeric:tabular-nums}
.kpi .k-foot{font-size:11px;color:var(--ink-3);margin-top:1px}
.kpi .k-dot{width:7px;height:7px;border-radius:50%}

/* ── Tables ──────────────────────────────────────────────────────────────── */
.tbl-wrap{border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;background:var(--surface)}
table.tbl{border-collapse:separate;border-spacing:0;width:100%;font-size:var(--fs-13)}
.tbl thead th{
  position:sticky;top:0;z-index:2;
  background:var(--surface-2);color:var(--ink-3);
  font-size:11px;font-weight:650;letter-spacing:.02em;text-transform:uppercase;
  text-align:left;padding:8px 12px;border-bottom:1px solid var(--line-2);white-space:nowrap;user-select:none;
}
.tbl thead th.sortable{cursor:pointer}
.tbl thead th.sortable:hover{color:var(--ink)}
.tbl thead th .arr{opacity:.4;margin-left:4px;font-size:10px}
.tbl thead th.sorted .arr{opacity:1;color:var(--brand-700)}
.tbl tbody td{padding:9px 12px;border-bottom:1px solid var(--hair);vertical-align:middle}
.tbl tbody tr{transition:background var(--fast)}
.tbl tbody tr:hover{background:var(--brand-50)}
.tbl tbody tr.clickable{cursor:pointer}
.tbl tbody tr:last-child td{border-bottom:none}
.tbl .num{text-align:right;font-variant-numeric:tabular-nums;font-family:var(--mono);font-size:var(--fs-12)}
.tbl .mono{font-family:var(--mono);font-size:var(--fs-12)}
.tbl .muted{color:var(--ink-3)}
.tbl-zebra tbody tr:nth-child(even){background:var(--surface-2)}
.tbl-zebra tbody tr:nth-child(even):hover{background:var(--brand-50)}

/* ── Pills / badges ──────────────────────────────────────────────────────── */
.pill{
  display:inline-flex;align-items:center;gap:5px;
  height:21px;padding:0 9px;border-radius:var(--r-pill);
  font-size:11px;font-weight:650;letter-spacing:.01em;white-space:nowrap;
  background:var(--muted-bg);color:var(--ink-2);border:1px solid transparent;
}
.pill .dot{width:6px;height:6px;border-radius:50%;background:currentColor}
.pill.ok{background:var(--ok-bg);color:var(--ok);border-color:var(--ok-line)}
.pill.no{background:var(--no-bg);color:var(--no);border-color:var(--no-line)}
.pill.warn{background:var(--warn-bg);color:var(--warn);border-color:var(--warn-line)}
.pill.info{background:var(--info-bg);color:var(--info);border-color:var(--info-line)}
.pill.brand{background:var(--brand-tint);color:var(--brand-700);border-color:var(--brand-tint-2)}
.pill.signal{background:var(--signal-tint);color:var(--signal-700)}
.pill.sq{border-radius:var(--r-xs);height:20px}
.tag{display:inline-flex;align-items:center;height:19px;padding:0 7px;border-radius:var(--r-xs);font-size:10.5px;font-weight:600;background:var(--surface-3);color:var(--ink-2)}

/* ── Tabs ────────────────────────────────────────────────────────────────── */
.tabs{display:flex;align-items:center;gap:2px;border-bottom:1px solid var(--line);padding:0 22px;flex:0 0 auto;background:var(--surface);overflow-x:auto}
.tab{
  position:relative;padding:11px 13px 12px;font-size:var(--fs-13);font-weight:550;color:var(--ink-3);
  white-space:nowrap;cursor:pointer;transition:color var(--fast);border-bottom:2px solid transparent;margin-bottom:-1px;
  display:flex;align-items:center;gap:7px;
}
.tab:hover{color:var(--ink)}
.tab.active{color:var(--brand-700);border-bottom-color:var(--brand);font-weight:650}
.tab .tcount{font-size:10.5px;font-weight:700;background:var(--surface-3);color:var(--ink-3);border-radius:var(--r-pill);padding:1px 6px}
.tab.active .tcount{background:var(--brand-tint-2);color:var(--brand-700)}
.tab .tbadge{font-size:10px;font-weight:700;border-radius:var(--r-pill);padding:1px 6px}
.tab .tbadge.no{background:var(--no-bg);color:var(--no)}
.tab .tbadge.warn{background:var(--warn-bg);color:var(--warn)}
.tab .tbadge.ok{background:var(--ok-bg);color:var(--ok)}

/* ── Modals ──────────────────────────────────────────────────────────────── */
.overlay{position:fixed;inset:0;background:rgba(12,17,22,.42);backdrop-filter:blur(2px);
  display:none;align-items:flex-start;justify-content:center;z-index:200;padding:7vh 16px 16px;overflow:auto}
.overlay.open{display:flex;animation:fade var(--med) var(--ease)}
.modal{background:var(--surface);border-radius:var(--r-lg);box-shadow:var(--sh-pop);width:520px;max-width:96vw;
  animation:pop var(--med) var(--ease);overflow:hidden}
.modal.wide{width:880px}.modal.xl{width:1100px}
.modal-head{display:flex;align-items:center;gap:10px;padding:15px 18px;border-bottom:1px solid var(--line)}
.modal-head h2{font-size:var(--fs-16);font-weight:680}
.modal-head .x{margin-left:auto;width:30px;height:30px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;color:var(--ink-3)}
.modal-head .x:hover{background:var(--surface-3);color:var(--ink)}
.modal-body{padding:18px;max-height:68vh;overflow:auto}
.modal-foot{display:flex;gap:8px;justify-content:flex-end;padding:13px 18px;border-top:1px solid var(--line);background:var(--surface-2)}

/* Drawer (right side) */
.drawer{position:fixed;top:0;right:0;bottom:0;width:520px;max-width:94vw;background:var(--surface);
  box-shadow:var(--sh-pop);z-index:210;transform:translateX(100%);transition:transform var(--med) var(--ease);
  display:flex;flex-direction:column}
.drawer.open{transform:none}
.drawer-head{display:flex;align-items:center;gap:10px;padding:15px 18px;border-bottom:1px solid var(--line);flex:0 0 auto}
.drawer-body{flex:1;overflow:auto;padding:18px}
.drawer-foot{padding:13px 18px;border-top:1px solid var(--line);background:var(--surface-2);display:flex;gap:8px;justify-content:flex-end;flex:0 0 auto}

@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes pop{from{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:none}}

/* ── Toast ───────────────────────────────────────────────────────────────── */
.toasts{position:fixed;bottom:18px;right:18px;z-index:400;display:flex;flex-direction:column;gap:8px}
.toast{display:flex;align-items:center;gap:10px;background:var(--brand-ink);color:#fff;
  padding:10px 14px;border-radius:var(--r);box-shadow:var(--sh-pop);font-size:var(--fs-13);font-weight:500;
  animation:slideUp var(--med) var(--ease);max-width:360px}
.toast.success{background:var(--ok)}
.toast.error{background:var(--no)}
.toast.warn{background:var(--warn)}
.toast .ic{width:17px;height:17px;flex:0 0 auto}
@keyframes slideUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

/* Save indicator */
.saver{position:fixed;bottom:18px;left:50%;transform:translateX(-50%);z-index:380;
  display:none;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--line-2);
  box-shadow:var(--sh-2);padding:7px 14px;border-radius:var(--r-pill);font-size:var(--fs-12);font-weight:600;color:var(--ink-2)}
.saver.show{display:flex}
.saver .spin{width:13px;height:13px;border:2px solid var(--line-2);border-top-color:var(--brand);border-radius:50%;animation:spin .7s linear infinite}
.saver.done{color:var(--ok)}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── Utility ─────────────────────────────────────────────────────────────── */
.row{display:flex;align-items:center;gap:10px}
.col{display:flex;flex-direction:column;gap:10px}
.wrap{flex-wrap:wrap}
.spacer{flex:1}
.muted{color:var(--ink-3)}
.faint{color:var(--ink-4)}
.mono{font-family:var(--mono)}
.tnum{font-variant-numeric:tabular-nums}
.nowrap{white-space:nowrap}
.center{text-align:center}
.right{text-align:right}
.hidden{display:none!important}
.divider{height:1px;background:var(--line);margin:4px 0}
.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;
  padding:56px 20px;color:var(--ink-3);text-align:center}
.empty .ic{width:38px;height:38px;opacity:.4;stroke-width:1.5}
.empty h4{font-size:var(--fs-14);font-weight:600;color:var(--ink-2)}
.skel{background:linear-gradient(90deg,var(--surface-3) 25%,var(--surface-4) 37%,var(--surface-3) 63%);
  background-size:400% 100%;animation:shimmer 1.3s ease infinite;border-radius:var(--r-xs)}
@keyframes shimmer{0%{background-position:100% 0}100%{background-position:-100% 0}}

/* Segmented control */
.seg{display:inline-flex;background:var(--surface-3);border-radius:var(--r-sm);padding:2px;gap:2px}
.seg button{padding:5px 12px;border-radius:var(--r-xs);font-size:var(--fs-12);font-weight:600;color:var(--ink-3);transition:all var(--fast)}
.seg button.active{background:var(--surface);color:var(--brand-700);box-shadow:var(--sh-1)}

/* Create wizard stepper */
.cpr-steps{display:flex;align-items:center;gap:0;padding:14px 22px;background:var(--surface);border-bottom:1px solid var(--line);flex:0 0 auto}
.cpr-step{display:flex;align-items:center;gap:8px;padding:6px 14px;border-radius:var(--r-pill);font-size:var(--fs-13);font-weight:600;color:var(--ink-3);cursor:default}
.cpr-step .n{width:22px;height:22px;border-radius:50%;background:var(--surface-3);color:var(--ink-3);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700}
.cpr-step.active{color:var(--brand-700)} .cpr-step.active .n{background:var(--brand);color:#fff}
.cpr-step.done{color:var(--ok);cursor:pointer} .cpr-step.done .n{background:var(--ok);color:#fff}
.cpr-step-line{flex:0 0 32px;height:2px;background:var(--line-2);margin:0 4px}

/* Autocomplete dropdown */
.ac-drop{display:none;position:absolute;top:calc(100% + 3px);left:0;right:0;z-index:140;background:var(--surface);
  border:1px solid var(--line-2);border-radius:var(--r-md);box-shadow:var(--sh-pop);max-height:280px;overflow:auto;padding:4px}
.ac-drop.open{display:block}
.ac-item{display:flex;align-items:center;gap:9px;padding:7px 10px;border-radius:var(--r-sm);cursor:pointer;font-size:var(--fs-13);white-space:nowrap}
.ac-item:hover{background:var(--brand-tint)}
.ac-item .mono{font-family:var(--mono);font-size:11px;color:var(--ink-3);flex:0 0 auto}
.ac-item > span:nth-child(2){overflow:hidden;text-overflow:ellipsis}

/* Upload dropzone */
.upd-drop{border:2px dashed var(--line-2);border-radius:var(--r-md);padding:32px 20px;text-align:center;color:var(--ink-3);cursor:pointer;transition:all var(--fast);background:var(--surface-2)}
.upd-drop:hover{border-color:var(--brand);color:var(--brand-700);background:var(--brand-50)}
.upd-drop.over{border-color:var(--brand);background:var(--brand-tint);color:var(--brand-700)}
.upd-drop .ic{opacity:.6}

/* Loading bar (top) */
.loadbar{position:fixed;top:0;left:0;height:2px;background:var(--brand);z-index:500;width:0;opacity:0;transition:width .3s var(--ease),opacity .3s}
.loadbar.on{opacity:1}

/* ═══ Create TER wizard — 2-column layout + live memo preview (all steps) ═══ */
.cpr-2col{display:flex;gap:16px;align-items:flex-start}
.cpr-main{flex:1;min-width:0}
.cpr-rail{flex:0 0 358px;width:358px;position:sticky;top:8px}
@media(max-width:1180px){ .cpr-2col{flex-direction:column} .cpr-rail{position:static;width:100%;flex-basis:auto} }

.cpr-gn{font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-3)}
/* checklist rows */
.cpr-chk{display:flex;align-items:center;gap:10px;font-size:13px}
.cpr-chk .ci{flex:0 0 18px;width:18px;height:18px;border-radius:50%;display:grid;place-items:center;font-size:11px;font-weight:800}
.cpr-chk.ok .ci{background:var(--ok-bg);color:var(--ok)}
.cpr-chk.warn .ci{background:var(--warn-bg);color:var(--warn)}
.cpr-chk.fail .ci{background:var(--no-bg);color:var(--no)}
.cpr-chk.fail span{color:var(--no);font-weight:500}
.cpr-chk.warn span{color:var(--warn)}

/* Memo preview card (the live INTERNAL MEMO) */
.cpr-memo{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--sh-2);overflow:hidden}
.cpr-memo-lh{display:flex;align-items:center;gap:11px;padding:13px 16px;border-bottom:2px solid var(--brand);background:var(--surface-2)}
.cpr-memo-lh img{height:26px;width:auto;flex:0 0 auto}
.cpr-memo-lh .ttl{display:flex;flex-direction:column;line-height:1.25;min-width:0}
.cpr-memo-lh .ttl b{font-size:12.5px;font-weight:750;letter-spacing:.04em;text-transform:uppercase;color:var(--brand-700)}
.cpr-memo-lh .ttl span{font-size:10.5px;color:var(--ink-3)}
.cpr-memo-lh .pill{margin-left:auto}
.cpr-memo-rows{display:grid;grid-template-columns:84px 1fr;gap:5px 12px;padding:13px 16px 10px;font-size:12.5px}
.cpr-memo-rows .dk{color:var(--ink-3);font-weight:600}
.cpr-memo-rows .dv{color:var(--ink);font-weight:500;word-break:break-word}
.cpr-memo-subj-lbl{font-size:10.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3);padding:2px 16px 0}
.cpr-doc-subj{margin:5px 16px 0;padding:9px 11px;background:var(--surface-2);border-left:3px solid var(--brand);border-radius:0 var(--r-sm) var(--r-sm) 0;font-size:12px;line-height:1.45;color:var(--ink-2)}
.cpr-memo-tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:13px 16px 4px}
.cpr-memo-tiles .t{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-sm);padding:8px 6px;text-align:center}
.cpr-memo-tiles .t .n{font-size:16px;font-weight:750;letter-spacing:-.02em;color:var(--ink);font-variant-numeric:tabular-nums;white-space:nowrap}
.cpr-memo-tiles .t .l{font-size:10px;font-weight:600;letter-spacing:.03em;text-transform:uppercase;color:var(--ink-3);margin-top:1px}
.cpr-memo-bidders{padding:8px 16px 2px}
.cpr-doc-bidder{display:flex;align-items:center;gap:8px;font-size:12px;padding:5px 0;border-top:1px dashed var(--line)}
.cpr-doc-bidder .bn{font-family:var(--mono);font-size:11px;color:var(--ink-3);flex:0 0 auto}
.cpr-will{display:flex;flex-wrap:wrap;gap:6px;margin:10px 16px 0;padding:12px 0 0;border-top:1px solid var(--line)}
.cpr-memo-state{margin:12px 0 0;padding:10px 16px;font-size:12.5px;font-weight:600;text-align:center;border-top:1px solid var(--line)}
.cpr-memo-state.ok{background:var(--ok-bg);color:var(--ok)}
.cpr-memo-state.warn{background:var(--warn-bg);color:var(--warn)}
.cpr-memo-state.pending{background:var(--surface-2);color:var(--ink-3)}
.cpr-rail-empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:34px 20px;text-align:center;color:var(--ink-3)}
.cpr-rail-empty .ic{opacity:.5}
.cpr-rail-empty p{font-size:12.5px;margin:0;max-width:200px;line-height:1.4}

/* Step 1 — PR subject block + duplicate check + read-only field */
.cpr-pr-subject{margin-top:13px}
.cpr-pr-subject p{margin:5px 0 0;font-size:12.5px;line-height:1.5;color:var(--ink-2);padding:10px 12px;background:var(--surface-2);border-left:3px solid var(--brand);border-radius:0 var(--r-sm) var(--r-sm) 0}
.cpr-dup{display:flex;gap:9px;align-items:flex-start;margin-top:12px;padding:10px 13px;border-radius:var(--r-sm);font-size:12.5px;line-height:1.4}
.cpr-dup .ic{flex:0 0 auto;margin-top:1px}
.cpr-dup.ok{background:var(--ok-bg);color:var(--ok);border:1px solid var(--ok-line)}
.cpr-dup.bad{background:var(--no-bg);color:var(--no);border:1px solid var(--no-line)}
.inp.ro{display:flex;align-items:center;background:var(--surface-2);color:var(--ink-2);cursor:default;font-weight:500}
