/* ═══════════════════════════════════════════════════════════════
   IBM Case Monitor v2 — Stylesheet
   Dark / Light theme via [data-theme] on <html>
   ═══════════════════════════════════════════════════════════════ */

[data-theme="dark"] {
  --bg:        #161616;
  --bg-2:      #262626;
  --bg-3:      #393939;
  --border:    #525252;
  --text:      #f4f4f4;
  --text-2:    #c6c6c6;
  --text-3:    #8d8d8d;
  --nav-bg:    #000000;
  --shadow:    0 2px 8px rgba(0,0,0,.5);
  --row-hover: rgba(15,98,254,.07);
  --cyan:      #33b1ff;
  --green:     #42be65;
  --yellow:    #f1c21b;
  --orange:    #ff832b;
  --red:       #fa4d56;
  --purple:    #a56eff;
}
[data-theme="light"] {
  --bg:        #f2f4f8;
  --bg-2:      #ffffff;
  --bg-3:      #e0e0e0;
  --border:    #c6c6c6;
  --text:      #161616;
  --text-2:    #393939;
  --text-3:    #6f6f6f;
  --nav-bg:    #161616;
  --shadow:    0 2px 8px rgba(0,0,0,.1);
  --row-hover: rgba(15,98,254,.04);
  --cyan:      #0043ce;
  --green:     #198038;
  --yellow:    #b28600;
  --orange:    #8a3800;
  --red:       #da1e28;
  --purple:    #6929c4;
}
:root {
  --ibm-blue:  #0f62fe;
  --ibm-blue-h:#0353e9;
  --nav-h:     52px;
  --radius:    4px;
  --font:      'IBM Plex Sans','Segoe UI',system-ui,sans-serif;
  --mono:      'IBM Plex Mono','Consolas',monospace;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:14px}
body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;display:flex;flex-direction:column;transition:background .2s,color .2s}
a{color:var(--cyan);text-decoration:none}
a:hover{text-decoration:underline}

/* ── Nav ──────────────────────────────────────────────────────── */
.nav{height:var(--nav-h);background:var(--nav-bg);border-bottom:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:space-between;padding:0 20px;position:sticky;top:0;z-index:200}
.nav-brand{display:flex;align-items:center;gap:10px}
.nav-logo{font-size:22px;color:var(--ibm-blue)}
.nav-title{font-weight:600;font-size:15px;color:#f4f4f4;letter-spacing:.02em}
.nav-sub{font-size:10px;color:#8d8d8d;background:#393939;padding:2px 7px;border-radius:10px;letter-spacing:.05em;text-transform:uppercase}
.nav-links{display:flex;align-items:center;gap:2px}
.nav-link{display:flex;align-items:center;gap:4px;padding:5px 10px;border-radius:var(--radius);color:#c6c6c6;font-size:12px;transition:background .15s,color .15s;white-space:nowrap}
.nav-link:hover{background:rgba(255,255,255,.1);color:#f4f4f4;text-decoration:none}
.nav-link.active{background:rgba(255,255,255,.12);color:#74b1ff}

/* ── User menu ────────────────────────────────────────────────── */
.user-menu{position:relative;margin-left:4px}
.user-btn{background:transparent;border:1px solid rgba(255,255,255,.25);color:#c6c6c6;padding:5px 12px;border-radius:var(--radius);font-size:12px;cursor:pointer;font-family:var(--font);white-space:nowrap}
.user-btn:hover{background:rgba(255,255,255,.1);color:#f4f4f4}
.user-dropdown{position:absolute;right:0;top:calc(100% + 6px);background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);min-width:200px;box-shadow:var(--shadow);z-index:300;padding:6px 0}
.user-dropdown-name{font-weight:600;font-size:13px;padding:8px 14px 2px}
.user-dropdown-email{font-size:11px;color:var(--text-3);padding:0 14px 8px}
.user-dropdown-hr{border:none;border-top:1px solid var(--border);margin:4px 0}
.user-dropdown-item{display:block;padding:7px 14px;font-size:13px;color:var(--text-2);transition:background .1s}
.user-dropdown-item:hover{background:var(--bg-3);text-decoration:none;color:var(--text)}
.user-dropdown-logout{color:var(--red)}

/* ── Buttons ──────────────────────────────────────────────────── */
.btn-sync{margin-left:6px;background:var(--ibm-blue);color:#fff;border:none;border-radius:var(--radius);padding:5px 12px;font-size:12px;cursor:pointer;font-family:var(--font);transition:background .15s}
.btn-sync:hover{background:var(--ibm-blue-h)}
.btn-sync.syncing{opacity:.7}
.btn-theme{margin-left:4px;background:transparent;border:1px solid rgba(255,255,255,.25);border-radius:var(--radius);padding:5px 9px;font-size:14px;cursor:pointer;line-height:1;transition:background .15s}
.btn-theme:hover{background:rgba(255,255,255,.1)}
.btn-primary{background:var(--ibm-blue);color:#fff;border:none;border-radius:var(--radius);padding:8px 18px;font-size:13px;cursor:pointer;font-family:var(--font);transition:background .15s;white-space:nowrap}
.btn-primary:hover{background:var(--ibm-blue-h)}
.btn-primary:disabled{opacity:.5;cursor:not-allowed}
.btn-ghost{background:transparent;color:var(--text-2);border:1px solid var(--border);border-radius:var(--radius);padding:7px 14px;font-size:13px;cursor:pointer;font-family:var(--font);display:inline-block;transition:border-color .15s,color .15s}
.btn-ghost:hover{border-color:var(--text-2);color:var(--text);text-decoration:none}
.btn-danger{background:transparent;color:var(--red);border:1px solid rgba(250,77,86,.4);border-radius:var(--radius);padding:5px 10px;font-size:12px;cursor:pointer;font-family:var(--font)}
.btn-danger:hover{background:rgba(250,77,86,.1)}
.btn-view{color:var(--ibm-blue);font-size:12px;padding:3px 8px;border-radius:var(--radius);border:1px solid rgba(15,98,254,.3)}
.btn-view:hover{background:rgba(15,98,254,.1);text-decoration:none}
.btn-sm{padding:4px 10px;font-size:12px}
.btn-reveal{background:var(--bg-3);border:1px solid var(--border);color:var(--text-3);padding:0 10px;border-radius:var(--radius);cursor:pointer;font-size:12px;font-family:var(--font);white-space:nowrap}
.btn-reveal:hover{color:var(--text)}

/* ── Slack toggle ──────────────────────────────────────────────── */
.slack-toggle-btn{border:none;border-radius:12px;padding:4px 12px;font-size:12px;cursor:pointer;font-family:var(--font);font-weight:500;transition:opacity .15s;white-space:nowrap}
.slack-on{background:rgba(66,190,101,.18);color:var(--green);border:1px solid rgba(66,190,101,.4)}
.slack-off{background:rgba(141,141,141,.12);color:var(--text-3);border:1px solid rgba(141,141,141,.3)}
.slack-toggle-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:13px;color:var(--text-2)}
.slack-checkbox{width:15px;height:15px;accent-color:var(--ibm-blue);cursor:pointer}

/* ── Main ──────────────────────────────────────────────────────── */
.main-content{flex:1;padding:24px 28px;max-width:1440px;width:100%;margin:0 auto}
.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px;gap:16px}
.page-title{font-size:22px;font-weight:300;letter-spacing:-.01em}
.page-sub{font-size:12px;color:var(--text-3);margin-top:4px}
.breadcrumb{display:inline-block;font-size:12px;color:var(--text-3);margin-bottom:5px}
.breadcrumb:hover{color:var(--cyan)}
.case-header-actions{display:flex;gap:8px;align-items:center;padding-top:4px}

/* ── HOME PAGE ──────────────────────────────────────────────────── */
.home-section-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);margin-bottom:10px}
.home-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:2px;margin-bottom:12px}
.home-stat-card{display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-2);border:1px solid var(--border);border-top:3px solid var(--border);padding:18px 12px;text-align:center;transition:border-color .15s,box-shadow .15s;color:var(--text);cursor:pointer}
.home-stat-card:hover{border-top-color:var(--ibm-blue);box-shadow:var(--shadow);text-decoration:none;transform:translateY(-1px)}
.home-stat-total  {border-top-color:var(--ibm-blue)}
.home-stat-pending{border-top-color:var(--orange)}
.home-stat-open   {border-top-color:var(--cyan)}
.home-stat-inprogress{border-top-color:#7f58ff}
.home-stat-waiting{border-top-color:var(--yellow)}
.home-stat-resolved{border-top-color:var(--green)}
.home-stat-closed {border-top-color:var(--text-3)}
.hs-num{font-size:36px;font-weight:200;line-height:1;margin-bottom:4px}
.hs-label{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3)}
.hs-sub{font-size:10px;color:var(--text-3);margin-top:3px}

.sev-bar{display:flex;gap:8px;margin-bottom:12px}
.sev-pill{display:inline-block;padding:5px 14px;border-radius:12px;font-size:12px;font-weight:500;color:var(--text)}
.sev-pill.sev-1{background:rgba(250,77,86,.15);border:1px solid rgba(250,77,86,.3)}
.sev-pill.sev-2{background:rgba(255,131,43,.15);border:1px solid rgba(255,131,43,.3)}
.sev-pill:hover{text-decoration:none;opacity:.8}

/* ── Account breakdown cards ───────────────────────────────────── */
.acc-breakdown-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:8px;overflow:hidden}
.acc-breakdown-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg-3);border-bottom:1px solid var(--border)}
.acc-breakdown-name{font-size:13px;font-weight:600}
.acc-breakdown-total{font-size:12px;color:var(--text-3)}
.acc-stat-row{display:flex;gap:0}
.acc-stat{flex:1;display:flex;flex-direction:column;align-items:center;padding:12px 8px;border-right:1px solid var(--border);transition:background .1s;color:var(--text);cursor:pointer}
.acc-stat:last-child{border-right:none}
.acc-stat:hover{background:var(--row-hover);text-decoration:none}
.acc-stat-num{font-size:22px;font-weight:300;line-height:1}
.acc-stat-lbl{font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-3);margin-top:3px}
.acc-stat-warn .acc-stat-num{color:var(--orange)}
.acc-stat-all{background:rgba(15,98,254,.05)}

/* ── Filter bar ────────────────────────────────────────────────── */
.filter-bar{background:var(--bg-2);border:1px solid var(--border);padding:12px 16px;margin-bottom:12px;border-radius:var(--radius)}
.filter-form{display:flex;align-items:flex-end;gap:10px;flex-wrap:wrap}
.filter-group{display:flex;flex-direction:column;gap:4px}
.filter-search{flex:1;min-width:200px}
.filter-label{font-size:10px;color:var(--text-3);text-transform:uppercase;letter-spacing:.05em}
.filter-select,.filter-input{background:var(--bg-2);border:1px solid var(--border);color:var(--text);padding:7px 10px;border-radius:var(--radius);font-size:13px;font-family:var(--font);min-width:150px}
.filter-input{min-width:220px}
.filter-select:focus,.filter-input:focus{outline:none;border-color:var(--ibm-blue)}

/* ── Table ─────────────────────────────────────────────────────── */
.table-wrap{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);overflow-x:auto}
.cases-table,.accounts-table{width:100%;border-collapse:collapse}
.cases-table th,.accounts-table th{text-align:left;font-size:10px;text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);padding:10px 16px;border-bottom:1px solid var(--border);background:var(--bg-3);white-space:nowrap}
.cases-table td,.accounts-table td{padding:11px 16px;border-bottom:1px solid rgba(82,82,82,.3);vertical-align:middle;font-size:13px}
.case-row:last-child td{border-bottom:none}
.case-row:hover td{background:var(--row-hover)}
.case-num{font-family:var(--mono)}
.case-link{color:var(--cyan);font-weight:500}
.case-title-link{color:var(--text-2)}
.case-title-link:hover{color:var(--text)}
.case-date{color:var(--text-3);font-size:12px;white-space:nowrap}
.account-tag{background:rgba(15,98,254,.15);color:var(--cyan);padding:2px 8px;border-radius:10px;font-size:11px;white-space:nowrap}
.mono{font-family:var(--mono);font-size:12px}

/* ── Pagination ────────────────────────────────────────────────── */
.pagination{display:flex;align-items:center;justify-content:center;gap:12px;padding:14px}
.page-btn{color:var(--ibm-blue);font-size:13px}
.page-info{font-size:12px;color:var(--text-3)}

/* ── Badges ─────────────────────────────────────────────────────── */
.badge{display:inline-block;padding:2px 8px;border-radius:2px;font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}
.badge-open      {background:rgba(51,177,255,.15);color:var(--cyan)}
.badge-inprogress{background:rgba(127,88,255,.15);color:#a78bfa}
.badge-waiting   {background:rgba(241,194,27,.15);color:var(--yellow)}
.badge-resolved  {background:rgba(66,190,101,.15);color:var(--green)}
.badge-closed    {background:rgba(141,141,141,.15);color:var(--text-3)}
.badge-default   {background:var(--bg-3);color:var(--text-3)}
.sev{font-size:12px;white-space:nowrap}

/* ── Section card ───────────────────────────────────────────────── */
.section-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);padding:20px 24px;margin-bottom:14px}
.section-title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);margin-bottom:14px;display:flex;align-items:center;gap:8px}
.count-badge{background:var(--bg-3);color:var(--text-3);padding:1px 7px;border-radius:10px;font-size:11px;font-weight:400}
.info-card{border-top:3px solid var(--cyan)}
.info-card p{font-size:13px;color:var(--text-2);margin-bottom:8px;line-height:1.6}
.resolution-card{border-left:4px solid var(--green)}

/* ── Case meta grid ─────────────────────────────────────────────── */
.case-meta-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(175px,1fr));gap:2px;margin-bottom:14px}
.meta-card{background:var(--bg-2);border:1px solid var(--border);padding:12px 16px}
.meta-label{font-size:10px;color:var(--text-3);text-transform:uppercase;letter-spacing:.05em;margin-bottom:5px}
.meta-val{font-size:13px}

/* ── Activity thread ─────────────────────────────────────────────── */
.activity-thread{display:flex;flex-direction:column;gap:10px}
.activity-item{border-left:3px solid var(--border);padding:12px 16px;background:var(--bg-3);border-radius:0 var(--radius) var(--radius) 0}
.activity-ibm  {border-left-color:var(--ibm-blue)}
.activity-client{border-left-color:var(--green)}
.activity-sent {border-left-color:var(--yellow)}
.activity-header{display:flex;align-items:center;gap:12px;margin-bottom:8px;flex-wrap:wrap}
.activity-author{font-size:12px;font-weight:600}
.activity-time  {font-size:11px;color:var(--text-3)}
.author-email   {font-size:11px;color:var(--text-3);margin-left:4px}
.activity-body  {font-size:13px;color:var(--text-2);line-height:1.75;white-space:pre-wrap;word-break:break-word}
.thread-legend  {display:flex;gap:12px;margin-left:auto;font-size:11px;font-weight:400;text-transform:none;letter-spacing:0;color:var(--text-3)}
.legend-ibm     {color:#74b1ff}
.legend-client  {color:var(--green)}

/* ── Reply form ──────────────────────────────────────────────────── */
.reply-card{border-top:3px solid var(--ibm-blue)}
.reply-textarea{width:100%;background:var(--bg-2);border:1px solid var(--border);color:var(--text);padding:12px;border-radius:var(--radius);font-size:13px;font-family:var(--font);resize:vertical;margin-bottom:10px;line-height:1.6}
.reply-textarea:focus{outline:none;border-color:var(--ibm-blue)}
.reply-actions{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.reply-hint{font-size:11px;color:var(--text-3)}

/* ── Forms ───────────────────────────────────────────────────────── */
.add-account-form{display:flex;flex-direction:column;gap:14px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-group{display:flex;flex-direction:column;gap:5px}
.form-label{font-size:12px;font-weight:600;color:var(--text-2)}
.form-hint{font-size:11px;color:var(--text-3)}
.req{color:var(--red)}
.form-input{background:var(--bg-2);border:1px solid var(--border);color:var(--text);padding:8px 12px;border-radius:var(--radius);font-size:13px;font-family:var(--font);width:100%}
.form-input:focus{outline:none;border-color:var(--ibm-blue)}
.form-input-sm{padding:5px 8px;font-size:12px}
.input-reveal-wrap{display:flex;gap:6px}
code{font-family:var(--mono);font-size:11px;background:var(--bg-3);padding:1px 4px;border-radius:2px}
.account-actions{display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.inline-key-form{width:100%;margin-top:5px}

/* ── Watchlist ───────────────────────────────────────────────────── */
.watchlist-grid{display:flex;flex-wrap:wrap;gap:8px}
.watchlist-item{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius);padding:8px 12px;display:flex;flex-direction:column;gap:2px;min-width:160px}
.watcher-name  {font-size:13px;font-weight:500}
.watcher-email {font-size:11px;color:var(--text-3)}
.watcher-realm {font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--cyan);margin-top:2px}

/* ── Alerts ──────────────────────────────────────────────────────── */
.alert{padding:10px 16px;border-radius:var(--radius);font-size:13px;margin-bottom:14px}
.alert-success{background:rgba(66,190,101,.12);border:1px solid rgba(66,190,101,.3);color:var(--green)}
.alert-warning{background:rgba(241,194,27,.1);border:1px solid rgba(241,194,27,.3);color:var(--yellow)}
.alert-danger  {background:rgba(250,77,86,.1);border:1px solid rgba(250,77,86,.3);color:var(--red)}

/* ── Empty state ─────────────────────────────────────────────────── */
.empty-state{text-align:center;padding:56px 24px}
.empty-icon  {font-size:36px;margin-bottom:12px;opacity:.5}
.empty-title {font-size:18px;font-weight:300;color:var(--text-2);margin-bottom:6px}
.empty-sub   {font-size:13px;color:var(--text-3)}

/* ── Toast ───────────────────────────────────────────────────────── */
.toast{position:fixed;bottom:24px;right:24px;background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius);padding:12px 20px;font-size:13px;color:var(--text);z-index:999;box-shadow:var(--shadow);transition:opacity .3s}
.toast.hidden{display:none}
.toast.success{border-left:3px solid var(--green)}
.toast.error  {border-left:3px solid var(--red)}

/* ── Raw JSON ────────────────────────────────────────────────────── */
.raw-json{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:14px;font-family:var(--mono);font-size:11px;color:var(--text-3);overflow:auto;white-space:pre;max-height:380px}

/* ── Misc ────────────────────────────────────────────────────────── */
.text-muted{color:var(--text-3)}
.case-description{font-size:13px;color:var(--text-2);line-height:1.75;white-space:pre-wrap;word-break:break-word}
.perm-list{padding-left:20px}
.perm-list li{font-size:13px;color:var(--text-2);margin-bottom:6px;line-height:1.6}

/* ── Footer ──────────────────────────────────────────────────────── */
.footer{text-align:center;padding:12px;font-size:11px;color:var(--text-3);border-top:1px solid var(--border);background:var(--nav-bg)}

/* ── Scrollbar ───────────────────────────────────────────────────── */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--bg-3);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--border)}

/* ══ PRINT ══════════════════════════════════════════════════════════ */
@media print {
  .no-print,.nav,.footer,.btn-primary,.btn-ghost,.btn-sync,.reply-card,.filter-bar{display:none!important}
  .print-only{display:block!important}
  body{background:#fff!important;color:#000!important;font-size:11pt}
  .main-content{padding:0;max-width:100%}
  .print-header{border-bottom:2px solid #000;padding-bottom:12pt;margin-bottom:16pt}
  .print-logo{font-size:9pt;color:#555;margin-bottom:4pt}
  .print-case-title{font-size:16pt;font-weight:bold;margin-bottom:4pt}
  .print-meta-line{font-size:9pt;color:#555}
  .case-meta-grid{display:grid!important;grid-template-columns:repeat(4,1fr);gap:6pt;margin-bottom:12pt}
  .meta-card{background:#f5f5f5!important;border:1px solid #ccc!important;padding:6pt 8pt}
  .meta-label{color:#555!important;font-size:8pt}
  .meta-val{color:#000!important;font-size:10pt}
  .section-card{background:#fff!important;border:1px solid #ccc!important;page-break-inside:avoid;margin-bottom:10pt;padding:10pt 12pt}
  .section-title{color:#333!important;border-bottom:1px solid #ccc;padding-bottom:4pt;margin-bottom:8pt}
  .activity-item{background:#f9f9f9!important;border-left:3px solid #aaa!important;page-break-inside:avoid;margin-bottom:6pt}
  .activity-ibm{border-left-color:#0050e6!important}
  .activity-client{border-left-color:#198038!important}
  .activity-body{color:#000!important}
  .activity-header{color:#333!important}
  .badge{border:1px solid #999!important;background:transparent!important;color:#000!important}
  .resolution-card{border-left:4px solid #198038!important}
  .case-description{color:#000!important}
  .print-footer{margin-top:20pt;font-size:8pt;color:#555;text-align:center}
  .activity-thread{page-break-inside:auto}
}
@media screen{.print-only{display:none!important}}

/* ── Responsive ──────────────────────────────────────────────────── */
@media(max-width:768px){
  .main-content{padding:14px}
  .form-row{grid-template-columns:1fr}
  .home-stats-grid{grid-template-columns:repeat(3,1fr)}
  .nav-sub{display:none}
  .acc-stat-lbl{display:none}
}
