/* platform.css — Cloverance idealized platform UI styling (.cvp scope) */

.cvp {
  --cv-ink: #16241d;
  --cv-muted: #5d6e65;
  --cv-faint: #93a39a;
  --cv-bg: #f4f7f5;
  --cv-card: #ffffff;
  --cv-line: #e8eee9;
  --cv-line2: #d9e2dc;
  --cv-side: #0e1813;
  --cv-side2: #0a120e;
  --cv-sidetext: #9fb4aa;
  --cv-green: #22c55e;
  --cv-greendk: #16a34a;
  --cv-greenso: #ecfdf3;
  --rev-bg: #fdeede; --rev-tx: #b45309;
  --work-bg: #dcfce7; --work-tx: #15803d;
  --appr-bg: #dcfce7; --appr-tx: #166534;
  --wait-bg: #eef1f4; --wait-tx: #51606b;
  width: 100%; height: 100%;
  display: flex; min-height: 0; overflow: hidden;
  background: var(--cv-bg); color: var(--cv-ink);
  font-family: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  -webkit-font-smoothing: antialiased;
  border-radius: inherit;
}
.cvp * { box-sizing: border-box; margin: 0; padding: 0; }
.cvp .cvp-mono { font-family: 'JetBrains Mono', ui-monospace, monospace; }

/* ---- Sidebar ---- */
.cvp-side {
  width: 216px; flex: 0 0 216px;
  background: linear-gradient(180deg, var(--cv-side), var(--cv-side2));
  display: flex; flex-direction: column; padding: 20px 14px; color: var(--cv-sidetext);
}
.cvp-brand { display: flex; align-items: center; gap: 10px; padding: 4px 8px 20px; }
.cvp-clover { font-size: 22px; }
.cvp-name { font-weight: 800; font-size: 19px; letter-spacing: -.4px; color: #fff; }
.cvp-search { display: flex; align-items: center; gap: 9px; background: #0b130f; border: 1px solid #1b2a23; border-radius: 11px; padding: 10px 12px; margin-bottom: 18px; }
.cvp-searchph { color: #5e726a; font-size: 13.5px; }
.cvp-nav { display: flex; flex-direction: column; gap: 4px; }
.cvp-navi { display: flex; align-items: center; gap: 12px; padding: 11px 12px; border-radius: 11px; font-size: 14px; font-weight: 600; position: relative; transition: .15s; }
.cvp-navi.active { background: #18271f; color: #fff; }
.cvp-navi.active::before { content: ""; position: absolute; left: -14px; top: 50%; transform: translateY(-50%); width: 4px; height: 22px; border-radius: 0 4px 4px 0; background: var(--cv-green); }
.cvp-ic { width: 19px; display: flex; justify-content: center; opacity: .9; }
.cvp-chip { margin-left: auto; background: var(--cv-green); color: #052e16; font-size: 11px; font-weight: 800; min-width: 19px; height: 19px; border-radius: 999px; display: flex; align-items: center; justify-content: center; padding: 0 5px; }
.cvp-foot { margin-top: auto; padding-top: 14px; border-top: 1px solid #1a2a22; }

/* ---- Main / layers (crossfade) ---- */
.cvp-main { flex: 1 1 auto; min-width: 0; position: relative; }
.cvp-layer { position: absolute; inset: 0; display: flex; opacity: 0; transform: scale(.992); pointer-events: none; transition: opacity .55s ease, transform .55s ease; }
.cvp-layer.show { opacity: 1; transform: none; }
.cvp-view { flex: 1; display: flex; flex-direction: column; min-width: 0; min-height: 0; background: var(--cv-bg); }

/* ---- Topbar ---- */
.cvp-topbar { flex: 0 0 auto; display: flex; align-items: center; gap: 12px; padding: 16px 24px; background: rgba(255,255,255,.8); backdrop-filter: blur(8px); border-bottom: 1px solid var(--cv-line); }
.cvp-titleblock .cvp-t { font-size: 19px; font-weight: 800; letter-spacing: -.4px; }
.cvp-titleblock .cvp-s { font-size: 13px; color: var(--cv-muted); margin-top: 2px; }
.cvp-spacer { flex: 1; }
.cvp-iconbtn { width: 38px; height: 38px; border-radius: 11px; border: 1px solid var(--cv-line); background: #fff; display: flex; align-items: center; justify-content: center; font-size: 15px; }
.cvp-btn-primary { background: var(--cv-green); color: #fff; font-weight: 700; font-size: 13.5px; padding: 10px 15px; border-radius: 11px; box-shadow: 0 6px 16px rgba(34,197,94,.28); white-space: nowrap; }
.cvp-btn-ghost { border: 1px solid var(--cv-line2); background: #fff; color: var(--cv-ink); font-weight: 600; font-size: 13px; padding: 9px 13px; border-radius: 11px; white-space: nowrap; }
.cvp-me .cvp-meav { width: 36px; height: 36px; border-radius: 10px; background: linear-gradient(135deg, #1f8f6b, #28b487); color: #fff; font-weight: 800; font-size: 13px; display: flex; align-items: center; justify-content: center; }
.cvp-back { width: 36px; height: 36px; border-radius: 10px; border: 1px solid var(--cv-line2); display: flex; align-items: center; justify-content: center; color: var(--cv-muted); font-size: 17px; background: #fff; }

/* ---- Home ---- */
.cvp-scroll { flex: 1 1 auto; overflow: hidden; min-height: 0; }
.cvp-wrap { max-width: 880px; margin: 0 auto; padding: 22px 26px 22px; }
.cvp-hero { background: linear-gradient(135deg, #ffffff 0%, #f1faf4 100%); border: 1px solid var(--cv-line); border-radius: 20px; padding: 24px 26px; box-shadow: 0 4px 16px rgba(16,40,30,.06); position: relative; overflow: hidden; }
.cvp-hero::after { content: ""; position: absolute; right: -60px; top: -60px; width: 220px; height: 220px; border-radius: 50%; background: radial-gradient(circle, rgba(34,197,94,.12), transparent 70%); }
.cvp-greet { font-size: 14px; color: var(--cv-muted); font-weight: 600; }
.cvp-herohead { font-size: 25px; font-weight: 800; letter-spacing: -.6px; margin-top: 5px; display: flex; align-items: center; gap: 10px; flex-wrap: nowrap; white-space: nowrap; }
.cvp-count { background: var(--rev-bg); color: var(--rev-tx); font-size: 14px; font-weight: 800; padding: 4px 12px; border-radius: 999px; transition: background .4s, color .4s; }
.cvp-clear { color: var(--cv-greendk); }
.cvp-checkbig { display: inline-flex; align-items: center; justify-content: center; width: 30px; height: 30px; border-radius: 999px; background: var(--appr-bg); color: var(--appr-tx); font-size: 17px; }
.cvp-cleared { font-size: 14px; color: var(--cv-muted); margin-top: 10px; max-width: 460px; line-height: 1.55; position: relative; z-index: 1; }
.cvp-reviewlist { display: flex; flex-direction: column; gap: 10px; margin-top: 18px; position: relative; z-index: 1; }
.cvp-reviewrow { display: flex; align-items: center; gap: 14px; background: #fff; border: 1px solid var(--cv-line); border-left: 4px solid var(--rev-tx); border-radius: 13px; padding: 13px 15px; }
.cvp-rav { width: 42px; height: 42px; border-radius: 11px; display: flex; align-items: center; justify-content: center; font-size: 20px; flex: 0 0 auto; }
.cvp-rbody { flex: 1; min-width: 0; }
.cvp-rag { font-size: 12px; font-weight: 700; color: var(--cv-greendk); }
.cvp-rti { font-size: 14.5px; font-weight: 700; margin: 1px 0 2px; }
.cvp-rpv { font-size: 12.5px; color: var(--cv-muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cvp-rmeta { display: flex; flex-direction: column; align-items: flex-end; gap: 6px; flex: 0 0 auto; }
.cvp-rtm { font-size: 11.5px; color: var(--cv-faint); }

.cvp-sectionh { display: flex; align-items: baseline; gap: 10px; margin: 22px 4px 12px; }
.cvp-sectionh h2 { font-size: 16px; font-weight: 800; letter-spacing: -.3px; }
.cvp-sectionh span { font-size: 12.5px; color: var(--cv-faint); font-weight: 600; }
.cvp-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
.cvp-acard { background: var(--cv-card); border: 1px solid var(--cv-line); border-radius: 16px; padding: 16px; box-shadow: 0 1px 2px rgba(16,40,30,.05); display: flex; flex-direction: column; opacity: 1; transform: none; }
@media (prefers-reduced-motion: no-preference) {
  .cvp-acard { animation: cvp-rise .5s backwards; }
}
@keyframes cvp-rise { to { opacity: 1; transform: none; } }
.cvp-actop { display: flex; align-items: center; gap: 12px; }
.cvp-aav { width: 44px; height: 44px; border-radius: 12px; display: flex; align-items: center; justify-content: center; font-size: 21px; flex: 0 0 auto; }
.cvp-aav.sm { width: 38px; height: 38px; font-size: 18px; border-radius: 11px; }
.cvp-anm { font-size: 15px; font-weight: 700; letter-spacing: -.2px; }
.cvp-adesc { font-size: 13px; color: var(--cv-muted); line-height: 1.5; margin-top: 10px; min-height: 34px; }
.cvp-foot-line { margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--cv-line); display: flex; align-items: center; gap: 7px; font-size: 12.5px; font-weight: 600; }
.cvp-foot-line .cvp-dot { width: 8px; height: 8px; border-radius: 50%; flex: 0 0 auto; }
.cvp-foot-line.review { color: var(--rev-tx); } .cvp-foot-line.review .cvp-dot { background: var(--rev-tx); }
.cvp-foot-line.working { color: var(--work-tx); } .cvp-foot-line.working .cvp-dot { background: var(--work-tx); }
.cvp-foot-line.ok { color: var(--cv-faint); } .cvp-foot-line.ok .cvp-dot { background: #cdd6d1; }

/* ---- Pills ---- */
.cvp-pill { display: inline-flex; align-items: center; gap: 5px; font-size: 11.5px; font-weight: 700; padding: 3px 9px; border-radius: 999px; white-space: nowrap; }
.cvp-pill .cvp-pd { width: 6px; height: 6px; border-radius: 50%; }
.cvp-pill.review { background: var(--rev-bg); color: var(--rev-tx); } .cvp-pill.review .cvp-pd { background: var(--rev-tx); }
.cvp-pill.working { background: var(--work-bg); color: var(--work-tx); } .cvp-pill.working .cvp-pd { background: var(--work-tx); }
.cvp-pill.approved { background: var(--appr-bg); color: var(--appr-tx); } .cvp-pill.approved .cvp-pd { background: var(--appr-tx); }
.cvp-pill.ok { background: var(--work-bg); color: var(--work-tx); } .cvp-pill.ok .cvp-pd { background: var(--work-tx); }

/* ---- Workspace master-detail ---- */
.cvp-md { flex: 1; display: flex; min-height: 0; }
.cvp-master { width: 290px; flex: 0 0 290px; border-right: 1px solid var(--cv-line); background: #fff; display: flex; flex-direction: column; min-height: 0; }
.cvp-msearch { display: flex; align-items: center; gap: 9px; margin: 14px 14px 8px; background: var(--cv-bg); border: 1px solid var(--cv-line); border-radius: 11px; padding: 10px 12px; }
.cvp-mlist { flex: 1; overflow: hidden; padding: 4px 10px 16px; }
.cvp-mgroup { font-size: 11px; font-weight: 800; letter-spacing: .6px; text-transform: uppercase; color: var(--cv-faint); padding: 12px 8px 7px; display: flex; align-items: center; gap: 7px; }
.cvp-gd { width: 7px; height: 7px; border-radius: 50%; }
.cvp-gd.review { background: var(--rev-tx); } .cvp-gd.working { background: var(--work-tx); }
.cvp-citem { padding: 11px 12px; border-radius: 12px; border: 1px solid transparent; position: relative; margin-bottom: 4px; }
.cvp-citem.active { background: #f1f9f5; border-color: #cdeadd; }
.cvp-citem.active::before { content: ""; position: absolute; left: 0; top: 9px; bottom: 9px; width: 3.5px; border-radius: 3px; background: var(--cv-green); }
.cvp-crow1 { display: flex; align-items: center; gap: 8px; }
.cvp-cti { font-size: 13.5px; font-weight: 700; flex: 1; }
.cvp-ctm { font-size: 11px; color: var(--cv-faint); }
.cvp-cpv { font-size: 12px; color: var(--cv-muted); margin-top: 3px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cvp-cpillrow { margin-top: 7px; }

.cvp-detail { flex: 1; display: flex; flex-direction: column; min-width: 0; background: var(--cv-bg); }
.cvp-dhead { flex: 0 0 auto; display: flex; align-items: center; gap: 12px; padding: 15px 22px; background: #fff; border-bottom: 1px solid var(--cv-line); }
.cvp-dt { font-size: 16px; font-weight: 800; letter-spacing: -.3px; }
.cvp-btn-return { border: 1px solid #e7c3c3; background: #fff; color: #791f1f; font-weight: 700; font-size: 13px; padding: 8px 14px; border-radius: 11px; transition: opacity .4s; }
.cvp-btn-return.faded { opacity: .35; }
.cvp-btn-approve { background: var(--cv-green); color: #fff; font-weight: 700; font-size: 13px; padding: 8px 16px; border-radius: 11px; box-shadow: 0 5px 14px rgba(34,197,94,.26); transition: transform .2s; }
.cvp-btn-approve.done { background: var(--cv-greendk); }

.cvp-thread { flex: 1; overflow: hidden; padding: 24px 26px; }
.cvp-threadinner { max-width: 620px; margin: 0 auto; display: flex; flex-direction: column; gap: 16px; }
.cvp-msguser { align-self: flex-end; max-width: 78%; background: #eef1ef; border: 1px solid var(--cv-line); border-radius: 16px 16px 4px 16px; padding: 12px 15px; font-size: 13.5px; line-height: 1.55; }
.cvp-msgagent { align-self: flex-start; max-width: 92%; }
.cvp-agname { font-size: 11.5px; font-weight: 700; color: var(--cv-greendk); margin-bottom: 5px; display: flex; align-items: center; gap: 6px; }
.cvp-agav { width: 20px; height: 20px; border-radius: 6px; display: flex; align-items: center; justify-content: center; font-size: 12px; background: #FDE7D9; }
.cvp-agtxt { font-size: 13.5px; line-height: 1.6; color: #28332d; }
.cvp-result { margin-top: 11px; border: 1px solid var(--cv-line2); border-radius: 13px; overflow: hidden; background: #fff; max-width: 460px; }
.cvp-rh { display: flex; align-items: center; gap: 9px; padding: 11px 14px; background: #f7faf8; border-bottom: 1px solid var(--cv-line); font-size: 13px; font-weight: 700; }
.cvp-rh .cvp-pill { margin-left: auto; }
.cvp-rb { padding: 12px 15px; font-size: 12px; line-height: 1.7; color: #41504a; white-space: pre; }
.cvp-rfoot { padding: 9px 14px; border-top: 1px solid var(--cv-line); font-size: 12px; font-weight: 700; color: var(--cv-greendk); }
.cvp-decisionnote { margin-top: 12px; background: var(--rev-bg); color: var(--rev-tx); font-size: 12.5px; font-weight: 600; padding: 10px 14px; border-radius: 12px; max-width: 460px; line-height: 1.5; }
.cvp-decisionnote b { font-weight: 800; }
.cvp-approvednote { margin-top: 12px; align-self: flex-start; display: inline-flex; align-items: center; gap: 8px; font-size: 12.5px; font-weight: 700; color: var(--appr-tx); background: var(--appr-bg); padding: 9px 14px; border-radius: 999px; }

.cvp-composer { flex: 0 0 auto; padding: 14px 24px 18px; }
.cvp-cbox { max-width: 620px; margin: 0 auto; display: flex; align-items: center; gap: 10px; background: #fff; border: 1px solid var(--cv-line2); border-radius: 15px; padding: 9px 9px 9px 14px; box-shadow: 0 1px 2px rgba(16,40,30,.05); }
.cvp-attach { width: 32px; height: 32px; border-radius: 9px; color: var(--cv-muted); display: flex; align-items: center; justify-content: center; font-size: 16px; }
.cvp-cph { flex: 1; font-size: 13.5px; color: var(--cv-faint); }
.cvp-send { width: 36px; height: 36px; border-radius: 10px; background: var(--cv-green); color: #fff; display: flex; align-items: center; justify-content: center; }
