/* =========================================================
   Pipeline — dark production-tool theme
   (faithful to reference: near-black, amber + mint accents,
    mono labels, dense shot table, gallery, prompt dock, bible)
   ========================================================= */
:root {
  --bg:        #0A0A0B;
  --bg-2:      #0E0F11;
  --panel:     #141518;
  --panel-2:   #191A1E;
  --raise:     #1F2024;
  --line:      #26272B;
  --line-2:    #34353A;
  --txt:       #ECECEE;
  --txt-2:     #9A9AA0;
  --txt-3:     #5E5F66;
  --txt-4:     #3E3F45;
  --amber:     #D6A24C;
  --amber-2:   #E7B25A;
  --amber-dim: #8A6E36;
  --mint:      #45D699;
  --mint-dim:  #1E5B43;
  --blue:      #6E84D4;
  --red:       #D6614C;
  --font-ui:   "Archivo", "Helvetica Neue", sans-serif;
  --font-mono: "IBM Plex Mono", ui-monospace, monospace;
}
* { box-sizing: border-box; }
html, body { height: 100%; }
body.cl { margin: 0; background: var(--bg); color: var(--txt); font-family: var(--font-ui);
  font-size: 14px; line-height: 1.5; overflow: hidden; -webkit-font-smoothing: antialiased; }
#root { height: 100%; }
::selection { background: rgba(214,162,76,.3); }
.mono { font-family: var(--font-mono); }
.cl-app { display: grid; grid-template-columns: 232px 1fr; height: 100%; }

/* scrollbars */
.cl ::-webkit-scrollbar { width: 10px; height: 10px; }
.cl ::-webkit-scrollbar-thumb { background: #25262A; border-radius: 6px; border: 2px solid var(--bg); }
.cl ::-webkit-scrollbar-thumb:hover { background: #32333800; }

/* =========================================================
   SIDEBAR
   ========================================================= */
.cl-side { background: var(--bg-2); border-right: 1px solid var(--line); display: flex; flex-direction: column;
  min-height: 0; padding: 14px 0 0; }
.cl-side-top { padding: 4px 16px 14px; }
.cl-allproj { font-family: var(--font-mono); font-size: 10px; letter-spacing: .14em; text-transform: uppercase;
  color: var(--txt-3); display: flex; align-items: center; gap: 6px; cursor: pointer; }
.cl-allproj:hover { color: var(--txt-2); }
.cl-projname { font-size: 18px; font-weight: 750; letter-spacing: -.02em; margin-top: 10px; }
.cl-projrole { font-family: var(--font-mono); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--txt-3); margin-top: 3px; }
.cl-nav { overflow-y: auto; flex: 1; min-height: 0; padding: 4px 10px 16px; }
.cl-navgrp { font-family: var(--font-mono); font-size: 10px; letter-spacing: .16em; text-transform: uppercase;
  color: var(--txt-4); padding: 16px 8px 8px; }
.cl-navi { display: flex; align-items: center; gap: 11px; padding: 8px 9px; border-radius: 7px; font-size: 13.5px;
  color: var(--txt-2); cursor: pointer; user-select: none; transition: background .1s, color .1s; }
.cl-navi:hover { background: #161719; color: var(--txt); }
.cl-navi.on { background: #1A1B1F; color: var(--txt); font-weight: 500; }
.cl-navi .ic { width: 16px; height: 16px; flex: none; opacity: .8; }
.cl-navi.on .ic { opacity: 1; }
.cl-navi .ct { margin-left: auto; font-family: var(--font-mono); font-size: 10.5px; color: var(--txt-3); }
.cl-navi .badge { margin-left: auto; background: var(--mint); color: #08251A; font-family: var(--font-mono);
  font-size: 10px; font-weight: 600; padding: 1px 6px; border-radius: 4px; }
.cl-navi .chev { width: 12px; height: 12px; transition: transform .14s; opacity: .6; }
.cl-navi.exp .chev { transform: rotate(90deg); }
.cl-subnav { margin: 2px 0 4px 30px; border-left: 1px solid var(--line); padding-left: 2px; }
.cl-subi { display: flex; align-items: center; gap: 9px; padding: 5px 9px; border-radius: 6px; font-size: 12.5px;
  color: var(--txt-2); cursor: pointer; }
.cl-subi:hover { background: #161719; color: var(--txt); }
.cl-subi.on { color: var(--txt); }
.cl-subi .dot { width: 5px; height: 5px; border-radius: 50%; background: var(--txt-4); flex: none; }
.cl-subi.on .dot { background: var(--amber); }
.cl-subi .more { color: var(--txt-3); font-family: var(--font-mono); font-size: 11px; }

/* =========================================================
   MAIN
   ========================================================= */
.cl-main { display: flex; flex-direction: column; min-width: 0; min-height: 0; background: var(--bg); }
.cl-bnr { background: #15161A; border-bottom: 1px solid var(--line); font-size: 12.5px; color: var(--txt-2);
  padding: 8px 18px; display: flex; align-items: center; gap: 10px; }
.cl-bnr .k { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: .12em; text-transform: uppercase; color: var(--amber); }
.cl-bnr a { color: var(--amber); margin-left: auto; }
.cl-body { flex: 1; overflow-y: auto; min-height: 0; }
.cl-pad { padding: 26px 34px 80px; }
@media (max-width: 720px){ .cl-pad { padding: 20px 18px 60px; } }

.cl-h { display: flex; align-items: flex-end; justify-content: space-between; gap: 18px; margin-bottom: 24px; flex-wrap: wrap; }
.cl-h h1 { margin: 0; font-size: 26px; font-weight: 750; letter-spacing: -.025em; }
.cl-h .sub { font-family: var(--font-mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--txt-3); margin-top: 6px; }

/* buttons */
.btn { font-family: var(--font-ui); font-size: 13px; font-weight: 550; padding: 8px 14px; border-radius: 7px;
  border: 1px solid var(--line-2); background: var(--panel); color: var(--txt); cursor: pointer; display: inline-flex;
  align-items: center; gap: 7px; transition: background .12s, border-color .12s, transform .07s; white-space: nowrap; }
.btn:hover { background: var(--raise); border-color: #3F4046; }
.btn:active { transform: translateY(1px); }
.btn .ic { width: 14px; height: 14px; }
.btn.amber { border-color: var(--amber-dim); color: var(--amber-2); background: rgba(214,162,76,.07); }
.btn.amber:hover { background: rgba(214,162,76,.14); }
.btn.mint { background: var(--mint); border-color: var(--mint); color: #08251A; font-weight: 650; }
.btn.mint:hover { filter: brightness(1.06); }
.btn.ghost { background: transparent; border-color: transparent; color: var(--txt-2); }
.btn.ghost:hover { background: var(--panel); color: var(--txt); }
.btn.sm { padding: 5px 10px; font-size: 12px; }
.btn[disabled] { opacity: .45; cursor: default; }

/* status badges */
.st { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: .1em; text-transform: uppercase;
  padding: 3px 9px; border-radius: 5px; white-space: nowrap; display: inline-flex; align-items: center; gap: 5px; border: 1px solid transparent; }
.st.notstarted { color: var(--txt-3); border-color: var(--line-2); }
.st.inprogress { color: var(--blue); border-color: rgba(110,132,212,.4); background: rgba(110,132,212,.08); }
.st.review { color: var(--amber-2); border-color: var(--amber-dim); background: rgba(214,162,76,.08); }
.st.changes { color: var(--red); border-color: rgba(214,97,76,.4); background: rgba(214,97,76,.08); }
.st.approved { color: var(--mint); border-color: var(--mint-dim); background: rgba(69,214,153,.08); }

/* avatar */
.avt { border-radius: 50%; display: flex; align-items: center; justify-content: center; font-family: var(--font-mono);
  font-weight: 600; flex: none; color: #fff; }
.avt.s22 { width: 22px; height: 22px; font-size: 9px; }
.avt.s26 { width: 26px; height: 26px; font-size: 10px; }
.avt.s30 { width: 30px; height: 30px; font-size: 11px; }
.avt.a { background: #7A4FB0; } .avt.b { background: #2E6F8E; } .avt.c { background: #B0497A; }
.avt.d { background: #5D8E2E; } .avt.e { background: #8E6A2E; }

/* =========================================================
   SHOTS TABLE
   ========================================================= */
.cl-table { width: 100%; }
.cl-thead { display: grid; grid-template-columns: 90px 1fr 130px 90px 150px; gap: 16px; padding: 0 16px 12px;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--txt-3);
  border-bottom: 1px solid var(--line); }
.cl-trow { display: grid; grid-template-columns: 90px 1fr 130px 90px 150px; gap: 16px; padding: 16px; align-items: start;
  border-bottom: 1px solid var(--line); cursor: pointer; transition: background .1s; }
.cl-trow:hover { background: #101113; }
.cl-trow .lbl { font-family: var(--font-mono); font-size: 13px; color: var(--amber-2); font-weight: 500; }
.cl-trow .desc .dt { font-size: 14.5px; font-weight: 600; letter-spacing: -.01em; margin-bottom: 4px; }
.cl-trow .desc .dd { font-size: 13px; color: var(--txt-2); line-height: 1.45; display: -webkit-box; -webkit-line-clamp: 2;
  -webkit-box-orient: vertical; overflow: hidden; }
.cl-trow .dur { font-family: var(--font-mono); font-size: 12px; color: var(--txt-2); display: inline-flex; align-items: center; gap: 5px; }
.cl-asg { display: flex; align-items: center; gap: 6px; position: relative; }
@media (max-width: 820px){
  .cl-thead { display: none; }
  .cl-trow { grid-template-columns: 1fr; gap: 8px; }
  .cl-trow .lbl::after { content: " · "; }
}
.cl-mention { color: var(--amber-2); font-weight: 500; }

/* assign popover */
.cl-pop { position: absolute; top: 30px; right: 0; width: 240px; background: var(--panel); border: 1px solid var(--line-2);
  border-radius: 9px; box-shadow: 0 24px 50px -20px rgba(0,0,0,.7); z-index: 30; overflow: hidden; }
.cl-pop .ph { font-family: var(--font-mono); font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--txt-3);
  padding: 12px 14px; border-bottom: 1px solid var(--line); display: flex; align-items: center; }
.cl-pop .ph .x { margin-left: auto; cursor: pointer; color: var(--txt-3); }
.cl-pop .row { display: flex; align-items: center; gap: 10px; padding: 10px 14px; cursor: pointer; }
.cl-pop .row:hover { background: var(--panel-2); }
.cl-pop .row .ck { width: 16px; height: 16px; border: 1px solid var(--line-2); border-radius: 4px; flex: none; display: flex; align-items: center; justify-content: center; }
.cl-pop .row.on .ck { background: var(--mint); border-color: var(--mint); color: #08251A; }
.cl-pop .row .nm { font-size: 13px; font-weight: 500; }
.cl-pop .row .rl { font-family: var(--font-mono); font-size: 9px; letter-spacing: .1em; text-transform: uppercase; color: var(--txt-3); }
.cl-pop .foot { display: flex; align-items: center; gap: 8px; padding: 10px 14px; border-top: 1px solid var(--line); }
.cl-pop .foot .sel { font-family: var(--font-mono); font-size: 10px; letter-spacing: .08em; text-transform: uppercase; color: var(--txt-3); margin-right: auto; }

/* =========================================================
   SHOT DETAIL  (gallery + prompt dock)
   ========================================================= */
.cl-back { font-family: var(--font-mono); font-size: 11px; letter-spacing: .08em; text-transform: uppercase; color: var(--txt-3);
  cursor: pointer; display: inline-flex; align-items: center; gap: 6px; }
.cl-back:hover { color: var(--txt); }
.cl-shot-h { display: flex; align-items: center; gap: 12px; margin: 14px 0 4px; flex-wrap: wrap; }
.cl-shot-h .id { font-family: var(--font-mono); font-size: 18px; color: var(--amber-2); font-weight: 500; }
.cl-shot-h .dur { font-family: var(--font-mono); font-size: 12px; color: var(--txt-2); display: inline-flex; align-items: center; gap: 5px; }
.cl-shot-h .asg { margin-left: auto; font-family: var(--font-mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: var(--txt-3); display: flex; align-items: center; gap: 8px; }
.cl-shot-title { font-size: 22px; font-weight: 700; letter-spacing: -.02em; margin: 2px 0 8px; }
.cl-shot-desc { font-size: 14.5px; color: var(--txt-2); line-height: 1.55; max-width: 880px; }

.cl-gal-h { display: flex; align-items: center; gap: 14px; margin: 30px 0 16px; flex-wrap: wrap; }
.cl-gal-h .gt { font-size: 22px; font-weight: 700; letter-spacing: -.02em; }
.cl-gal-h .gc { font-family: var(--font-mono); font-size: 11px; color: var(--txt-3); letter-spacing: .08em; }
.cl-gal-tools { margin-left: auto; display: flex; align-items: center; gap: 10px; }
.cl-seg { display: inline-flex; background: var(--panel); border: 1px solid var(--line); border-radius: 8px; padding: 2px; }
.cl-seg button { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .06em; text-transform: uppercase;
  padding: 6px 11px; border: 0; background: transparent; color: var(--txt-3); cursor: pointer; border-radius: 6px; }
.cl-seg button.on { background: var(--raise); color: var(--txt); }
.cl-size { display: flex; align-items: center; gap: 8px; font-family: var(--font-mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: var(--txt-3); }
.cl-size input { accent-color: var(--amber); }

.cl-gallery { display: grid; gap: 14px; }
.cl-gen { border-radius: 10px; overflow: hidden; border: 1px solid var(--line); background: var(--panel); position: relative; }
.cl-gen.appr { border-color: var(--mint-dim); }
.cl-gen .frame { aspect-ratio: 16/9; position: relative; display: flex; align-items: flex-start; justify-content: space-between; padding: 9px; }
.cl-gen .frame img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.cl-gen .badge-appr { position: relative; z-index: 2; font-family: var(--font-mono); font-size: 9px; letter-spacing: .08em;
  text-transform: uppercase; background: var(--mint); color: #08251A; padding: 3px 8px; border-radius: 5px; font-weight: 600; display: inline-flex; align-items: center; gap: 5px; }
.cl-gen .dur-tag { position: relative; z-index: 2; margin-left: auto; font-family: var(--font-mono); font-size: 10px;
  background: rgba(0,0,0,.6); color: #fff; padding: 3px 8px; border-radius: 5px; display: inline-flex; align-items: center; gap: 5px; }
.cl-gen .actions { position: absolute; left: 0; right: 0; bottom: 0; z-index: 3; display: flex; gap: 6px; padding: 9px;
  background: linear-gradient(transparent, rgba(0,0,0,.72)); opacity: 0; transition: opacity .14s; }
.cl-gen:hover .actions { opacity: 1; }
.cl-gact { width: 30px; height: 30px; border-radius: 7px; background: rgba(20,21,24,.85); border: 1px solid var(--line-2);
  color: var(--txt); display: flex; align-items: center; justify-content: center; cursor: pointer; backdrop-filter: blur(4px); }
.cl-gact:hover { background: var(--raise); }
.cl-gact.on { background: var(--mint); border-color: var(--mint); color: #08251A; }
.cl-gact.heart.on { background: var(--red); border-color: var(--red); color: #fff; }

/* prompt dock */
.cl-dock { position: sticky; bottom: 0; margin: 24px -34px -80px; background: var(--bg-2); border-top: 1px solid var(--line-2);
  box-shadow: 0 -20px 40px -20px rgba(0,0,0,.6); }
@media (max-width: 720px){ .cl-dock { margin: 24px -18px -60px; } }
.cl-dock-grip { width: 44px; height: 4px; background: var(--line-2); border-radius: 4px; margin: 8px auto 0; }
.cl-dock-body { padding: 14px 34px 18px; }
@media (max-width: 720px){ .cl-dock-body { padding: 14px 18px; } }
.cl-prompt-area { background: var(--panel); border: 1px solid var(--line); border-radius: 10px; padding: 14px 16px;
  font-family: var(--font-mono); font-size: 12.5px; line-height: 1.6; color: var(--txt-2); max-height: 130px; overflow-y: auto; }
.cl-prompt-area .ph { color: var(--amber-2); }
.cl-prompt-area b { color: var(--txt); font-weight: 600; }
.cl-dock-bar { display: flex; align-items: center; gap: 10px; margin-top: 12px; flex-wrap: wrap; }
.cl-opt { font-family: var(--font-mono); font-size: 11px; color: var(--txt-2); display: inline-flex; align-items: center; gap: 6px;
  background: var(--panel); border: 1px solid var(--line); border-radius: 7px; padding: 7px 11px; cursor: pointer; }
.cl-opt:hover { border-color: var(--line-2); color: var(--txt); }
.cl-opt .ic { width: 13px; height: 13px; opacity: .7; }

/* =========================================================
   BIBLE
   ========================================================= */
.cl-bible { max-width: 880px; }
.cl-bible-tools { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; flex-wrap: wrap; }
.cl-chunk { margin-bottom: 30px; }
.cl-chunk-h { display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap; line-height: 1.25; }
.cl-chunk-h .ct { font-size: 18px; font-weight: 700; letter-spacing: -.01em; }
.cl-chunk-h .tc { font-family: var(--font-mono); font-size: 12px; color: var(--txt-3); margin-left: auto; white-space: nowrap; }
.cl-chunk-env { font-size: 13px; color: var(--txt-2); margin: 12px 0 16px; }
.cl-chunk-env b { font-weight: 600; }
.cl-chunk-env .env { color: var(--amber-2); font-family: var(--font-mono); font-size: 12.5px; }
.cl-bshot { display: grid; grid-template-columns: auto 1fr; gap: 12px; padding: 9px 0; border-top: 1px solid var(--line); align-items: start; }
.cl-bshot:first-child { border-top: none; }
.cl-bshot .bdot { width: 5px; height: 5px; border-radius: 50%; background: var(--txt-4); margin-top: 9px; }
.cl-bshot .btxt { font-size: 14px; line-height: 1.6; color: var(--txt-2); }
.cl-bshot .btxt .sid { font-family: var(--font-mono); font-weight: 600; color: var(--amber-2); cursor: pointer; }
.cl-bshot .btxt .sid:hover { text-decoration: underline; }
.cl-bshot .btxt .tc { font-family: var(--font-mono); font-size: 12px; color: var(--txt-3); }
.cl-link { font-weight: 500; cursor: pointer; border-bottom: 1px dotted transparent; }
.cl-link.char { color: #E7B25A; }
.cl-link.env { color: var(--amber-2); }
.cl-link.asset { color: #7FB0C9; }
.cl-link:hover { border-bottom-color: currentColor; }

/* analyze dropzone */
.cl-analyze { border: 1.5px dashed var(--line-2); border-radius: 14px; padding: 40px; text-align: center; background: var(--bg-2); }
.cl-analyze .big { font-size: 17px; font-weight: 650; margin: 14px 0 6px; }
.cl-analyze .sm { font-size: 13px; color: var(--txt-2); max-width: 440px; margin: 0 auto 18px; }

/* =========================================================
   PROMPT BUILDER  (axes + sections)
   ========================================================= */
.cl-pb { display: grid; grid-template-columns: 320px 1fr; gap: 0; height: 100%; min-height: 0; }
@media (max-width: 820px){ .cl-pb { grid-template-columns: 1fr; } .cl-pb .pb-axes { display: none; } }
.pb-axes { border-right: 1px solid var(--line); overflow-y: auto; padding: 20px 18px 60px; background: var(--bg-2); min-height: 0; }
.pb-presets { display: flex; flex-direction: column; gap: 8px; }
.pb-preset { display: flex; align-items: center; gap: 11px; padding: 10px; border: 1px solid var(--line); border-radius: 9px;
  cursor: pointer; background: var(--panel); }
.pb-preset:hover { border-color: var(--line-2); }
.pb-preset.on { border-color: var(--mint-dim); background: rgba(69,214,153,.06); }
.pb-preset .pthumb { width: 38px; height: 38px; border-radius: 7px; flex: none; background-size: cover; background-position: center; }
.pb-preset .pn { font-size: 13.5px; font-weight: 550; }
.pb-preset.on .pn { color: var(--mint); }
.pb-save { width: 100%; justify-content: center; margin-top: 8px; border-style: dashed; }
.pb-axhead { display: flex; align-items: center; justify-content: space-between; font-family: var(--font-mono);
  font-size: 10px; letter-spacing: .16em; text-transform: uppercase; color: var(--txt-3); margin: 24px 0 4px; }
.pb-ax { padding: 12px 0 4px; border-top: 1px solid var(--line); }
.pb-ax:first-of-type { border-top: none; }
.pb-ax .axn { font-size: 13.5px; font-weight: 550; margin-bottom: 8px; }
.pb-chips { display: flex; flex-wrap: wrap; gap: 6px; }
.pb-chip { font-family: var(--font-mono); font-size: 11.5px; line-height: 1.35; padding: 5px 10px; border-radius: 6px; cursor: pointer;
  border: 1px solid var(--line-2); color: var(--txt-3); background: transparent; max-width: 100%; white-space: normal; word-break: break-word; text-align: left; }
.pb-chip:hover { color: var(--txt); border-color: #44454A; }
.pb-chip.on { color: var(--mint); border-color: var(--mint-dim); background: rgba(69,214,153,.07); }
.pb-chip.pick { color: var(--txt-3); }

.pb-main { overflow-y: auto; padding: 22px 26px 60px; min-height: 0; }
.pb-subj { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 18px; }
@media (max-width:620px){ .pb-subj { grid-template-columns: 1fr; } }
.pb-ta { width: 100%; background: var(--panel); border: 1px solid var(--line); border-radius: 9px; padding: 12px 14px;
  font-family: var(--font-mono); font-size: 13px; color: var(--txt); resize: vertical; min-height: 70px; }
.pb-ta:focus { outline: none; border-color: var(--amber-dim); }
.pb-ta::placeholder { color: var(--txt-4); }
.pb-preview { border: 1px solid var(--amber-dim); border-radius: 12px; overflow: hidden; }
.pb-pv-h { display: flex; align-items: center; gap: 14px; padding: 14px 18px; border-bottom: 1px solid var(--line); }
.pb-pv-h .lab { font-family: var(--font-mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--amber-2); }
.pb-pv-h .count { margin-left: auto; font-family: var(--font-mono); font-size: 11px; color: var(--txt-3); letter-spacing: .04em; }
.pb-sec { display: grid; grid-template-columns: 180px 1fr; border-top: 1px solid var(--line); }
.pb-sec:first-child { border-top: none; }
.pb-sec .sk { font-family: var(--font-mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--txt-2);
  padding: 16px 18px; background: var(--bg-2); }
.pb-sec.empty .sk { color: var(--txt-4); }
.pb-sec .sv { padding: 16px 18px; font-family: var(--font-mono); font-size: 13px; line-height: 1.5; color: var(--txt); }
.pb-sec.empty .sv { color: var(--txt-4); font-style: italic; }
.pb-normal { padding: 20px 22px; font-family: var(--font-mono); font-size: 13.5px; line-height: 1.7; color: var(--txt); }
.pb-normal .hl { color: var(--mint); }

/* =========================================================
   MY WORK / REVIEW / progress
   ========================================================= */
.cl-tiles { display: grid; grid-template-columns: repeat(4,1fr); gap: 12px; margin-bottom: 26px; }
@media (max-width:760px){ .cl-tiles { grid-template-columns: repeat(2,1fr); } }
.cl-tile { background: var(--panel); border: 1px solid var(--line); border-radius: 10px; padding: 16px 18px; }
.cl-tile .n { font-size: 28px; font-weight: 750; letter-spacing: -.02em; }
.cl-tile .n.mint { color: var(--mint); } .cl-tile .n.amber { color: var(--amber-2); } .cl-tile .n.red { color: var(--red); }
.cl-tile .l { font-family: var(--font-mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: var(--txt-3); margin-top: 6px; }

.cl-donut-wrap { display: flex; align-items: center; gap: 28px; background: var(--panel); border: 1px solid var(--line);
  border-radius: 12px; padding: 24px; flex-wrap: wrap; }
.cl-donut { width: 132px; height: 132px; border-radius: 50%; flex: none; position: relative; }
.cl-donut::after { content: ""; position: absolute; inset: 22px; background: var(--panel); border-radius: 50%; }
.cl-donut .ctr { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; z-index: 2; }
.cl-donut .ctr .pc { font-size: 26px; font-weight: 750; }
.cl-donut .ctr .lb { font-family: var(--font-mono); font-size: 9px; letter-spacing: .1em; text-transform: uppercase; color: var(--txt-3); }
.cl-legend { display: flex; flex-direction: column; gap: 10px; }
.cl-legend .lr { display: flex; align-items: center; gap: 10px; font-size: 13px; }
.cl-legend .sw { width: 11px; height: 11px; border-radius: 3px; }
.cl-legend .lv { margin-left: auto; font-family: var(--font-mono); color: var(--txt-2); }

.cl-bars { display: flex; flex-direction: column; gap: 14px; }
.cl-barrow { display: grid; grid-template-columns: 170px 1fr 70px; align-items: center; gap: 16px; }
.cl-barrow .who { display: flex; align-items: center; gap: 10px; font-size: 13px; }
.cl-barrow .who .rl { font-family: var(--font-mono); font-size: 9px; letter-spacing: .08em; text-transform: uppercase; color: var(--txt-3); }
.cl-track { height: 7px; background: var(--raise); border-radius: 10px; overflow: hidden; }
.cl-track .fill { height: 100%; background: var(--amber); border-radius: 10px; transition: width .9s cubic-bezier(.2,.8,.2,1); }
.cl-barrow .pct { font-family: var(--font-mono); font-size: 12px; color: var(--txt-2); text-align: right; }
@media (max-width:620px){ .cl-barrow { grid-template-columns: 1fr; gap: 5px; } }

/* review cards */
.cl-rev { display: flex; flex-direction: column; gap: 14px; }
.cl-revcard { background: var(--panel); border: 1px solid var(--line); border-radius: 12px; overflow: hidden; display: grid; grid-template-columns: 300px 1fr; }
@media (max-width:720px){ .cl-revcard { grid-template-columns: 1fr; } }
.cl-revcard .rt { position: relative; min-height: 168px; display: flex; align-items: flex-start; justify-content: space-between; padding: 10px; }
.cl-revcard .rt img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.cl-revcard .rb { padding: 18px 20px; display: flex; flex-direction: column; }
.cl-note { background: var(--bg-2); border: 1px solid var(--line); border-left: 3px solid var(--amber); border-radius: 8px; padding: 11px 13px; font-size: 13px; color: var(--txt-2); }
.cl-note.mint { border-left-color: var(--mint); }
.cl-note.red { border-left-color: var(--red); }
.cl-note .nh { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--amber-2); margin-bottom: 5px; }
.cl-note.mint .nh { color: var(--mint); } .cl-note.red .nh { color: var(--red); }
.cl-ta { width: 100%; background: var(--bg-2); border: 1px solid var(--line); border-radius: 8px; padding: 10px 12px;
  font-family: var(--font-ui); font-size: 13px; color: var(--txt); resize: vertical; min-height: 58px; }
.cl-ta:focus { outline: none; border-color: var(--amber-dim); }

/* entity grid */
.cl-egrid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px,1fr)); gap: 14px; }
.cl-ecard { border: 1px solid var(--line); border-radius: 11px; overflow: hidden; background: var(--panel); cursor: pointer; transition: border-color .12s, transform .12s; }
.cl-ecard:hover { border-color: var(--line-2); transform: translateY(-2px); }
.cl-ecard .ethumb { aspect-ratio: 1/1; background-size: cover; background-position: center; position: relative; }
.cl-ecard .ebody { padding: 11px 13px; }
.cl-ecard .en { font-size: 14px; font-weight: 600; }
.cl-ecard .em { font-family: var(--font-mono); font-size: 10.5px; color: var(--txt-3); margin-top: 3px; }
.cl-ring { position: absolute; top: 9px; right: 9px; font-family: var(--font-mono); font-size: 10px; padding: 3px 7px;
  border-radius: 5px; background: rgba(0,0,0,.6); }
.cl-ring.good { color: var(--mint); } .cl-ring.warn { color: var(--amber-2); }

/* folders / library */
.cl-folders { display: grid; grid-template-columns: repeat(auto-fill, minmax(190px,1fr)); gap: 14px; }
.cl-folder { background: var(--panel); border: 1px solid var(--line); border-radius: 11px; padding: 16px; cursor: pointer; }
.cl-folder:hover { border-color: var(--line-2); }
.cl-folder .fi { width: 36px; height: 28px; border-radius: 4px 7px 7px 7px; background: var(--raise); border: 1px solid var(--line-2); position: relative; margin-bottom: 12px; }
.cl-folder .fi::before { content:""; position:absolute; top:-5px; left:4px; width:15px; height:6px; background: var(--raise); border:1px solid var(--line-2); border-bottom:none; border-radius:4px 4px 0 0; }
.cl-folder .fn { font-weight: 600; font-size: 14px; }
.cl-folder .fc { font-family: var(--font-mono); font-size: 10.5px; color: var(--txt-3); margin-top: 4px; }

/* sync */
.cl-syncbox { max-width: 620px; }
.cl-path { flex: 1; background: var(--panel); border: 1px solid var(--line); border-radius: 8px; padding: 11px 14px;
  font-family: var(--font-mono); font-size: 12px; color: var(--txt-2); }
.cl-syncrow { display: flex; align-items: center; gap: 12px; font-family: var(--font-mono); font-size: 12px; color: var(--txt-2);
  padding: 9px 12px; background: var(--panel); border: 1px solid var(--line); border-radius: 8px; }
.cl-syncrow .tick { color: var(--mint); }
.cl-spin { width: 13px; height: 13px; border: 2px solid var(--line-2); border-top-color: var(--amber); border-radius: 50%; animation: clspin .7s linear infinite; flex: none; }
@keyframes clspin { to { transform: rotate(360deg); } }
.cl-report { width: 100%; border-collapse: collapse; font-size: 13px; }
.cl-report th { text-align: left; font-family: var(--font-mono); font-size: 9.5px; letter-spacing: .1em; text-transform: uppercase;
  color: var(--txt-3); padding: 10px 12px; border-bottom: 1px solid var(--line); font-weight: 400; }
.cl-report td { padding: 11px 12px; border-bottom: 1px solid var(--line); color: var(--txt-2); }
.cl-report .mono { font-family: var(--font-mono); font-size: 11.5px; color: var(--amber-2); }

/* members */
.cl-memrow { display: flex; align-items: center; gap: 12px; padding: 13px 14px; border-bottom: 1px solid var(--line); }
.cl-memrow .nm { font-weight: 600; } .cl-memrow .em { font-size: 12px; color: var(--txt-3); }
.cl-memrow .rl { margin-left: auto; font-family: var(--font-mono); font-size: 10px; letter-spacing: .08em; text-transform: uppercase;
  color: var(--txt-2); border: 1px solid var(--line); padding: 4px 10px; border-radius: 20px; }
.cl-invite { display: flex; gap: 10px; align-items: center; max-width: 540px; }

/* toast */
.cl-toasts { position: absolute; bottom: 22px; left: 50%; transform: translateX(-50%); z-index: 90; display: flex; flex-direction: column; gap: 9px; align-items: center; pointer-events: none; }
.cl-toast { background: var(--raise); border: 1px solid var(--line-2); color: var(--txt); padding: 10px 16px; border-radius: 9px; font-size: 13px;
  box-shadow: 0 16px 36px -16px rgba(0,0,0,.7); display: flex; align-items: center; gap: 9px; animation: cltoast .24s; }
.cl-toast .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--mint); }
.cl-toast.warn .dot { background: var(--amber); }
@keyframes cltoast { from { transform: translateY(12px); opacity: 0; } }

.cl-empty { text-align: center; padding: 60px 20px; color: var(--txt-3); }
.cl-empty .big { font-size: 16px; color: var(--txt-2); font-weight: 600; margin-bottom: 6px; }
.divider { height: 1px; background: var(--line); margin: 20px 0; }

/* =========================================================
   LIGHT THEME  — same app, alternate skin (style flexibility)
   ========================================================= */
.cl.light {
  --bg: #F3F1EA; --bg-2: #FAF8F2; --panel: #FFFFFF; --panel-2: #F4F1E9; --raise: #ECE7DC;
  --line: #E4DECF; --line-2: #D4CCBB; --txt: #1A1712; --txt-2: #5C5648; --txt-3: #8C8474; --txt-4: #B6AE9C;
  --amber: #B26A1B; --amber-2: #97570F; --amber-dim: #D8BE8E;
  --mint: #1F9462; --mint-dim: #A9D9C0; --blue: #4E68B8; --red: #C0560E;
}
.cl.light { background: var(--bg); color: var(--txt); }
.cl.light ::-webkit-scrollbar-thumb { background: #D6CEBE; border: 2px solid var(--bg); }
.cl.light .cl-navi:hover, .cl.light .cl-subi:hover { background: #EFEBE1; }
.cl.light .cl-navi.on { background: #FFFFFF; box-shadow: inset 0 0 0 1px var(--line); }
.cl.light .cl-trow:hover { background: #FBF9F4; }
.cl.light .cl-bnr { background: #FFFFFF; }
.cl.light .btn:hover { border-color: #C3BBAA; }
.cl.light .btn.mint, .cl.light .cl-navi .badge, .cl.light .badge-appr { color: #FFFFFF; }
.cl.light .cl-prompt-area, .cl.light .pb-ta, .cl.light .cl-gact { color: var(--txt); }
.cl.light .cl-gact { background: rgba(255,255,255,.9); }
.cl.light .cl-toast { color: var(--txt); }
.cl.light .pb-sec.empty .sv { color: var(--txt-3); }
.cl.light .cl-donut::after { background: var(--panel); }

