/* ── dashboard/css/styles.css ──────────────────────────────────────────────
   Cases / work-items overview. Builds on shared tokens (../shared/cc-shared.css)
   and follows the dataset_family header conventions used by the editors.
─────────────────────────────────────────────────────────────────────────── */

:root{
  --navy:#1A2744;--navy-mid:#243358;--navy-light:#EEF1F8;--green-bright:#22C55E;
  --gold:#C9A84C;--gold-dark:#8B6914;--gold-light:#FDF6E3;
  --slate:#5A6A8A;--slate-light:#F4F6FB;--border:#DDE3EE;
  --white:#FFFFFF;--red:#C0392B;--red-light:#FDECEA;
  --green:#1E7C45;--green-light:#E8F5ED;
  --amber:#B7700A;--amber-light:#FEF3E2;
  --blue:#2563EB;--blue-light:#EFF6FF;
  --purple:#5B21B6;--purple-light:#EDE9FE;
  --font-heading:'DM Serif Display',serif;--font-body:'DM Sans',sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--font-body);background:var(--white);color:var(--navy);min-height:100vh;display:flex;flex-direction:column}

/* HEADER (matches editors) */
.app-header{background:var(--navy);position:sticky;top:0;z-index:100;flex-shrink:0}
.hdr-top{padding:0 1.5rem;height:58px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(255,255,255,.1)}
.logo{display:flex;align-items:center;gap:10px;color:#fff;font-family:var(--font-heading);font-size:1.1rem}
.logo-badge{background:var(--gold);color:var(--navy);font-family:var(--font-body);font-size:.58rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:3px 7px;border-radius:4px}
.hdr-right{display:flex;align-items:center;gap:8px;margin-left:auto}
.hdr-btn{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);color:#fff;padding:5px 12px;border-radius:6px;font-family:var(--font-body);font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s}
.hdr-btn:hover{background:rgba(255,255,255,.15)}
.dash-search{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:#fff;padding:6px 12px;border-radius:6px;font-family:var(--font-body);font-size:.8rem;outline:none;width:220px}
.dash-search::placeholder{color:rgba(255,255,255,.55)}
.dash-search:focus{border-color:var(--gold);background:rgba(255,255,255,.14)}

/* BODY */
.app-main{flex:1;overflow-y:auto;background:var(--slate-light)}
.dash-area{padding:1.25rem 1.75rem;max-width:1500px;margin:0 auto}
.dash-columns{display:grid;grid-template-columns:1fr 1fr;gap:1.75rem;align-items:start}
.dash-col{min-width:0}
.dash-col-title{font-family:var(--font-heading);font-size:1.15rem;color:var(--navy);margin-bottom:.85rem}

/* SUMMARY CARDS */
.dash-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:10px;margin-bottom:1.25rem}
.dash-card{display:flex;flex-direction:column;gap:4px;align-items:flex-start;padding:.85rem 1rem;border:1.5px solid var(--border);border-left-width:4px;border-radius:10px;background:var(--white);cursor:pointer;transition:box-shadow .15s,transform .1s,border-color .15s;font-family:var(--font-body);text-align:left}
.dash-card:hover{box-shadow:0 4px 14px rgba(0,0,0,.08);transform:translateY(-1px)}
.dash-card.active{box-shadow:0 0 0 2px var(--gold)}
.dash-card-count{font-size:1.5rem;font-weight:700;color:var(--navy);line-height:1}
.dash-card-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--slate)}
.dash-card.st-all{border-left-color:var(--navy-mid)}
.dash-card.st-backlog{border-left-color:var(--slate)}
.dash-card.st-todo{border-left-color:var(--blue)}
.dash-card.st-progress{border-left-color:var(--gold)}
.dash-card.st-review{border-left-color:var(--purple)}
.dash-card.st-done{border-left-color:var(--green)}
.dash-card.st-blocked{border-left-color:var(--red)}

/* FILTER PILLS */
.dash-filters{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:1rem}
.dash-pill{font-family:var(--font-body);font-size:.74rem;font-weight:600;padding:5px 12px;border-radius:999px;border:1.5px solid var(--border);background:var(--white);color:var(--slate);cursor:pointer;transition:all .15s}
.dash-pill:hover{border-color:var(--gold);color:var(--navy)}
.dash-pill.active{background:var(--navy);border-color:var(--navy);color:var(--gold)}

/* CASE LIST */
.dash-list{display:flex;flex-direction:column;gap:8px}
.dash-empty{padding:2rem;text-align:center;color:var(--slate);font-size:.85rem}
.dash-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:.8rem 1rem;background:var(--white);border:1.5px solid var(--border);border-radius:10px;cursor:pointer;transition:border-color .15s,box-shadow .15s}
.dash-row:hover{border-color:var(--gold);box-shadow:0 3px 12px rgba(0,0,0,.07)}
.dash-row-main{min-width:0;flex:1}
.dash-row-title{font-size:.9rem;font-weight:600;color:var(--navy);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dash-row-sub{font-size:.72rem;color:var(--slate);margin-top:2px}
.dash-row-meta{display:flex;align-items:center;gap:8px;flex-shrink:0}
.dash-due{font-size:.72rem;color:var(--slate);white-space:nowrap}
.dash-progress{font-size:.72rem;color:var(--slate);white-space:nowrap}

/* PRIORITY */
.dash-pri{font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;padding:3px 8px;border-radius:6px}
.pr-critical{background:var(--red-light);color:var(--red)}
.pr-high{background:var(--amber-light);color:var(--amber)}
.pr-medium{background:var(--blue-light);color:var(--blue)}
.pr-low{background:var(--slate-light);color:var(--slate)}

/* STATUS BADGE */
.dash-status{font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;padding:3px 8px;border-radius:6px;white-space:nowrap}
.st-backlog{background:#eef1f6;color:var(--slate)}
.st-todo{background:var(--blue-light);color:var(--blue)}
.st-progress{background:var(--gold-light);color:var(--gold-dark)}
.st-review{background:var(--purple-light);color:var(--purple)}
.st-done{background:var(--green-light);color:var(--green)}
.st-blocked{background:var(--red-light);color:var(--red)}

@media (max-width:560px){
  .dash-area{padding:1rem}
  .dash-columns{grid-template-columns:1fr;gap:1.25rem}
  .dash-search{width:140px}
  .dash-row{flex-direction:column;align-items:flex-start}
  .dash-row-meta{flex-wrap:wrap}
}

/* ── Unbilled-time alert ─────────────────────────────────────────────────── */
.dash-billed{margin-bottom:1.25rem;border:1.5px solid var(--border);border-left-width:4px;border-left-color:var(--green-bright);border-radius:10px;background:var(--white);overflow:hidden}
.dash-billed:empty{display:none}
.dash-billed-head{display:flex;align-items:center;gap:10px;padding:.7rem 1rem;border-bottom:1px solid var(--border)}
.dash-billed-icon{font-size:1.05rem;flex-shrink:0}
.dash-billed-title{font-size:.82rem;font-weight:700;letter-spacing:.02em;color:var(--navy)}
.dash-billed-row{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border)}
.dash-billed-tile{display:flex;flex-direction:column;gap:3px;padding:.85rem 1rem;background:var(--white)}
.dash-billed-label{font-size:.66rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--slate)}
.dash-billed-amount{font-size:1.45rem;font-weight:700;line-height:1;color:var(--navy)}
.dash-billed-hours{font-size:.74rem;color:var(--slate)}
.dash-alert{margin-bottom:1.5rem;border:1.5px solid var(--gold);border-left-width:4px;border-radius:10px;background:var(--gold-light);overflow:hidden}
.dash-alert-head{display:flex;align-items:center;gap:10px;padding:.75rem 1rem;border-bottom:1px solid rgba(201,168,76,.35)}
.dash-alert-icon{font-size:1.1rem;flex-shrink:0}
.dash-alert-msg{font-size:.86rem;color:var(--navy)}
.dash-alert-msg b{font-weight:700}
.dash-alert-total{color:var(--gold-dark);font-weight:600}
.dash-alert-list{display:flex;flex-direction:column}
.dash-alert-row{display:flex;flex-direction:column;gap:8px;padding:.6rem 1rem;border-top:1px solid rgba(201,168,76,.22);background:rgba(255,255,255,.45);transition:background .12s}
.dash-alert-row:first-child{border-top:none}
.dash-alert-row:hover{background:#fff}
.dash-alert-top{display:flex;align-items:center;justify-content:space-between;gap:12px}
.dash-alert-main{min-width:0;flex:1;cursor:pointer}
.dash-alert-title{font-size:.88rem;font-weight:600;color:var(--navy);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dash-alert-sub{font-size:.72rem;color:var(--slate);margin-top:2px}
.dash-alert-hrs{font-size:.84rem;font-weight:700;color:var(--gold-dark);font-variant-numeric:tabular-nums;white-space:nowrap}
.dash-bill-btn{flex-shrink:0;background:var(--navy);color:var(--gold);border:none;padding:6px 12px;border-radius:6px;font-family:var(--font-body);font-size:.74rem;font-weight:700;letter-spacing:.02em;cursor:pointer;transition:background .15s,opacity .15s;white-space:nowrap}
.dash-bill-btn:hover{background:var(--navy-mid)}
.dash-bill-btn:disabled{opacity:.5;cursor:default}
/* Per-activity chips that make up a case's unbilled bill amount. Clicking one
   opens that activity. Indented under the case line. */
.dash-unbilled-chips{display:flex;flex-wrap:wrap;gap:6px;padding-left:2px}
.dash-unbilled-chip{display:inline-flex;align-items:baseline;gap:6px;max-width:100%;background:rgba(201,168,76,.14);color:var(--navy);border:1px solid rgba(201,168,76,.45);border-radius:14px;padding:3px 10px;font-family:var(--font-body);font-size:.72rem;font-weight:600;cursor:pointer;transition:background .12s,border-color .12s}
.dash-unbilled-chip:hover{background:rgba(201,168,76,.28);border-color:var(--gold-dark)}
.dash-chip-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:22rem}
.dash-chip-hrs{color:var(--gold-dark);font-variant-numeric:tabular-nums;white-space:nowrap;font-weight:700}

/* ── Notifications (bell, panel, composer) ─────────────────────────────────── */
.notif-bell{position:relative}
.notif-badge{position:absolute;top:-6px;right:-6px;background:var(--gold);color:var(--navy);font-size:.6rem;font-weight:700;min-width:16px;height:16px;line-height:16px;text-align:center;border-radius:8px;padding:0 4px}

.notif-backdrop{position:fixed;inset:0;background:rgba(26,39,68,.55);z-index:290}
.notif-panel{position:fixed;top:0;right:0;width:360px;max-width:92vw;height:100vh;background:var(--white);box-shadow:-4px 0 24px rgba(0,0,0,.18);z-index:300;display:flex;flex-direction:column}
.notif-panel-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:var(--navy);color:#fff;flex-shrink:0}
.notif-panel-title{font-family:var(--font-heading);font-size:1.05rem}
.notif-panel-actions{display:flex;gap:10px;align-items:center}
/* Panel-header action buttons — match the dashboard header .hdr-btn so they're
   legible against the navy panel head (the old .notif-link was nearly invisible). */
.notif-head-btn{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);color:#fff;padding:5px 12px;border-radius:6px;font-family:var(--font-body);font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s}
.notif-head-btn:hover{background:rgba(255,255,255,.15)}
/* Close box — same UI as cc-activity.js #workitem-note-popup-close. */
.notif-panel-close{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.25);color:#fff;width:28px;height:28px;border-radius:6px;cursor:pointer;font-size:.9rem;display:flex;align-items:center;justify-content:center;transition:background .15s;flex-shrink:0}
.notif-panel-close:hover{background:rgba(255,255,255,.25)}
.notif-link{background:none;border:none;color:#fff;font-family:var(--font-body);font-size:.74rem;font-weight:600;cursor:pointer;opacity:.85}
.notif-link:hover{opacity:1;text-decoration:underline}
.notif-list{flex:1;overflow-y:auto;padding:10px}

.notif-item{display:flex;gap:8px;align-items:flex-start;padding:.7rem .8rem;border:1.5px solid var(--border);border-left-width:4px;border-radius:10px;background:var(--white);margin-bottom:8px;cursor:default}
.notif-item[data-action]{cursor:pointer}
.notif-item.is-unread{background:#fbfdff;box-shadow:0 0 0 1px rgba(0,0,0,.02)}
.notif-item.is-read{opacity:.72}
.notif-item.notif-sev-info{border-left-color:var(--blue)}
.notif-item.notif-sev-warn{border-left-color:var(--gold)}
.notif-item.notif-sev-action{border-left-color:var(--purple,#7c3aed)}
.notif-item-main{flex:1;min-width:0}
.notif-item-title{font-weight:700;color:var(--navy);font-size:.84rem}
.notif-item-body{font-size:.78rem;color:var(--slate);margin-top:2px;white-space:pre-wrap;word-break:break-word}
.notif-item-meta{font-size:.68rem;color:var(--slate);margin-top:5px}
.notif-open-hint{color:var(--blue);font-weight:600}
.notif-item-links{display:flex;flex-wrap:wrap;gap:12px;margin-top:7px}
.notif-link{font-size:.74rem;font-weight:600;color:var(--blue);cursor:pointer;text-decoration:none}
.notif-link:hover{text-decoration:underline}
.notif-item-reply{margin-top:7px}
.notif-reply-box{margin-top:7px;display:flex;flex-direction:column;gap:7px}
.notif-reply-text{width:100%;box-sizing:border-box;padding:6px 8px;border:1px solid var(--border,#DDE3EE);border-radius:6px;font-family:var(--font-body);font-size:.78rem;color:var(--navy,#1A2744);resize:vertical;min-height:50px}
.notif-reply-foot{display:flex;gap:8px}
.notif-reply-send,.notif-reply-cancel{padding:4px 10px;border-radius:6px;font-size:.74rem;font-weight:600;cursor:pointer;font-family:var(--font-body);border:1.5px solid var(--border,#DDE3EE);background:#fff;color:var(--navy,#1A2744)}
.notif-reply-send{background:var(--gold,#C9A84C);border-color:var(--gold,#C9A84C)}
/* Billing-hold resolve popup (mirrors the reply affordance). */
.notif-item-hold{margin-top:7px}
.notif-hold-box{margin-top:7px;display:flex;flex-direction:column;gap:8px;padding:9px;border:1px solid var(--border,#DDE3EE);border-radius:8px;background:rgba(124,58,237,.05)}
.notif-hold-intro{font-size:.74rem;font-weight:600;color:var(--navy,#1A2744)}
.notif-hold-fields{display:flex;flex-direction:column;gap:7px}
.notif-hold-field{display:flex;flex-direction:column;gap:3px}
.notif-hold-label{font-size:.70rem;font-weight:600;color:var(--slate)}
.notif-hold-input{width:100%;box-sizing:border-box;padding:6px 8px;border:1px solid var(--border,#DDE3EE);border-radius:6px;font-family:var(--font-body);font-size:.78rem;color:var(--navy,#1A2744)}
.notif-hold-foot{display:flex;gap:8px}
.notif-hold-send,.notif-hold-cancel{padding:4px 10px;border-radius:6px;font-size:.74rem;font-weight:600;cursor:pointer;font-family:var(--font-body);border:1.5px solid var(--border,#DDE3EE);background:#fff;color:var(--navy,#1A2744)}
.notif-hold-send{background:var(--gold,#C9A84C);border-color:var(--gold,#C9A84C)}
.notif-x{background:none;border:none;color:var(--slate);cursor:pointer;font-size:.85rem;padding:2px 4px;line-height:1}
.notif-x:hover{color:var(--navy)}

.notif-modal{position:fixed;inset:0;background:rgba(15,23,42,.45);z-index:400;display:flex;align-items:center;justify-content:center;padding:16px}
.notif-modal-card{background:var(--white);border-radius:14px;width:460px;max-width:96vw;max-height:90vh;overflow:auto;padding:18px 20px;box-shadow:0 12px 48px rgba(0,0,0,.3)}
.notif-modal-head{display:flex;align-items:center;justify-content:space-between;font-family:var(--font-heading);font-size:1.1rem;color:var(--navy);margin-bottom:14px}
.notif-modal-head .notif-link{color:var(--slate)}
.notif-field{display:flex;flex-direction:column;gap:4px;margin-bottom:12px;font-size:.78rem;font-weight:600;color:var(--navy)}
.notif-field small{font-weight:400;color:var(--slate)}
.notif-field input,.notif-field textarea,.notif-field select{font-family:var(--font-body);font-size:.85rem;font-weight:400;border:1.5px solid var(--border);border-radius:8px;padding:8px 10px;color:var(--navy);background:var(--white);outline:none}
.notif-field input:focus,.notif-field textarea:focus,.notif-field select:focus{border-color:var(--gold)}
.notif-modal-foot{display:flex;justify-content:flex-end;gap:10px;margin-top:6px}
.notif-modal-foot .hdr-btn{background:var(--slate-light,#eef2f7);color:var(--navy);border:1.5px solid var(--border)}
.notif-modal-foot .hdr-btn.primary{background:var(--navy);color:#fff;border-color:var(--navy)}
.notif-modal-foot .hdr-btn:hover{filter:brightness(1.05)}
