/* ============================================================
   AAU CRM Center — App component & layout layer (Polaris)
   Loads after polaris.css (tokens).
   ============================================================ */

* { margin: 0; padding: 0; box-sizing: border-box; }
html, body, #root { height: 100%; }
body {
  font-family: var(--p-font);
  background: var(--p-bg);
  color: var(--p-text);
  font-size: 14px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  line-height: 1.45;
}
a { color: inherit; text-decoration: none; }
button { font-family: inherit; }
::selection { background: #cfe6ff; }

/* scrollbars */
*::-webkit-scrollbar { width: 10px; height: 10px; }
*::-webkit-scrollbar-thumb { background: #d4d4d4; border-radius: 999px; border: 2px solid transparent; background-clip: content-box; }
*::-webkit-scrollbar-thumb:hover { background: #b9b9b9; background-clip: content-box; }

/* ── App shell ── */
.app { display: grid; grid-template-columns: var(--nav-width) 1fr; grid-template-rows: var(--topbar-height) 1fr; height: 100vh; overflow: hidden; }
.topbar { grid-column: 1 / -1; background: var(--p-fill-brand); display: flex; align-items: center; gap: 14px; padding: 0 16px; color: #fff; z-index: 30; }
.topbar .brand { display: flex; align-items: center; gap: 10px; width: calc(var(--nav-width) - 16px); }
.topbar .brand .mark { width: 30px; height: 30px; border-radius: 7px; background: linear-gradient(135deg,#00c389,#008060); display: grid; place-items: center; font-weight: 700; font-size: 15px; flex-shrink: 0; }
.topbar .brand .bt { font-size: 14px; font-weight: 650; letter-spacing: -0.01em; }
.topbar .brand .bs { font-size: 11px; color: rgba(255,255,255,0.55); }
.topbar .search { flex: 1; max-width: 520px; display: flex; align-items: center; gap: 8px; background: rgba(255,255,255,0.13); border-radius: var(--p-radius-200); padding: 7px 12px; color: rgba(255,255,255,0.85); cursor: text; }
.topbar .search input { background: none; border: none; outline: none; color: #fff; font-size: 13px; flex: 1; }
.topbar .search input::placeholder { color: rgba(255,255,255,0.5); }

/* ── Command search (typeahead → feature) ── */
.topbar .search.cmd { position: relative; flex: 1; max-width: 520px; background: none; border-radius: 0; padding: 0; }
.topbar .search.cmd .search-box { display: flex; align-items: center; gap: 8px; background: rgba(255,255,255,0.13); border-radius: var(--p-radius-200); padding: 7px 12px; color: rgba(255,255,255,0.7); cursor: text; transition: background .12s; }
.topbar .search.cmd.open .search-box { background: rgba(255,255,255,0.20); box-shadow: 0 0 0 2px rgba(255,255,255,0.18); }
.topbar .search.cmd .search-box input { background: none; border: none; outline: none; color: #fff; font-size: 13px; flex: 1; }
.topbar .search.cmd .search-box input::placeholder { color: rgba(255,255,255,0.5); }
.cmd-panel { position: absolute; top: calc(100% + 7px); left: 0; right: 0; background: var(--p-bg-surface); border-radius: var(--p-radius-300); box-shadow: var(--p-shadow-popover); overflow: hidden; z-index: 60; animation: cmdIn .12s ease; }
@keyframes cmdIn { from { opacity: 0; transform: translateY(-4px); } to { opacity: 1; transform: none; } }
.cmd-cap { font-size: 10.5px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; color: var(--p-text-subdued); padding: 11px 14px 6px; }
.cmd-empty { padding: 18px 14px 22px; font-size: 13px; color: var(--p-text-secondary); }
.cmd-list { max-height: 360px; overflow-y: auto; padding: 2px 6px 6px; }
.cmd-item { display: flex; align-items: center; gap: 11px; padding: 8px 9px; border-radius: var(--p-radius-200); color: var(--p-text); text-decoration: none; cursor: pointer; }
.cmd-item.active { background: var(--p-bg-surface-selected); }
.cmd-ic { width: 30px; height: 30px; flex-shrink: 0; display: grid; place-items: center; border-radius: 7px; background: var(--p-bg-surface-secondary); color: var(--p-text-secondary); }
.cmd-item.active .cmd-ic { background: #fff; color: var(--p-fill-brand); }
.cmd-txt { display: flex; flex-direction: column; gap: 1px; min-width: 0; flex: 1; }
.cmd-label { font-size: 13.5px; font-weight: 550; display: flex; align-items: center; gap: 7px; }
.cmd-group { font-size: 11.5px; color: var(--p-text-subdued); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cmd-badge { font-size: 10px; font-weight: 700; background: #ff6b5e; color: #fff; border-radius: 999px; padding: 0 6px; line-height: 16px; }
.cmd-enter { color: var(--p-text-disabled); opacity: 0; }
.cmd-item.active .cmd-enter { opacity: 1; color: var(--p-text-subdued); }
.cmd-foot { display: flex; gap: 16px; padding: 8px 14px; border-top: 1px solid var(--p-border-secondary); background: var(--p-bg-surface-secondary); font-size: 11px; color: var(--p-text-subdued); }
.cmd-sec { font-size: 10px; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; color: var(--p-text-subdued); padding: 9px 9px 4px; }
.cmd-sec:first-child { padding-top: 3px; }
.cmd-meta { font-size: 11px; font-weight: 600; color: var(--p-text-subdued); }
.cmd-enter { font-size: 11px; font-weight: 600; white-space: nowrap; }
/* per-kind icon tint so result types read at a glance */
.cmd-item.k-lead .cmd-ic { background: #eef4ff; color: #3a5bd9; }
.cmd-item.k-conv .cmd-ic { background: #fef0ee; color: #c4320a; }
.cmd-item.k-course .cmd-ic { background: #eafaf2; color: #0a8a57; }
.cmd-item.k-class .cmd-ic { background: #fff4e6; color: #b66400; }
.cmd-item.k-instructor .cmd-ic { background: #f3eefe; color: #6d28d9; }
.cmd-item.active .cmd-ic { background: #fff; color: var(--p-fill-brand); }
.cmd-foot kbd { display: inline-block; min-width: 16px; text-align: center; font-family: inherit; font-size: 10px; background: #fff; border: 1px solid var(--p-border); border-radius: 4px; padding: 1px 4px; margin-right: 3px; color: var(--p-text-secondary); }
.topbar .spacer { flex: 1; }
.topbar .tb-actions { display: flex; align-items: center; gap: 4px; }
.topbar .tb-btn { width: 34px; height: 34px; border-radius: var(--p-radius-200); display: grid; place-items: center; color: rgba(255,255,255,0.8); background: none; border: none; cursor: pointer; position: relative; }
.topbar .tb-btn:hover { background: rgba(255,255,255,0.13); color: #fff; }
.topbar .tb-btn .ndot { position: absolute; top: 6px; right: 7px; width: 8px; height: 8px; background: #ff6b5e; border-radius: 50%; border: 2px solid var(--p-fill-brand); }
.topbar .tenant { display: flex; align-items: center; gap: 8px; background: rgba(255,255,255,0.10); padding: 5px 10px 5px 8px; border-radius: var(--p-radius-200); cursor: pointer; font-size: 12.5px; }
.topbar .tenant:hover { background: rgba(255,255,255,0.16); }
.topbar .user { display: flex; align-items: center; gap: 9px; padding-left: 8px; cursor: pointer; }
.topbar .viewas { display: flex; align-items: center; gap: 7px; background: rgba(255,255,255,0.10); padding: 4px 8px; border-radius: var(--p-radius-200); color: rgba(255,255,255,0.9); }
.topbar .viewas:hover { background: rgba(255,255,255,0.16); }
.topbar .viewas-lbl { color: rgba(255,255,255,0.6); }
.topbar .viewas-sel { background: none; border: none; outline: none; color: #fff; font-size: 12px; font-weight: 600; cursor: pointer; max-width: 190px; }
.topbar .viewas-sel option { color: #1a1a1a; }
.access-note { display: flex; align-items: center; gap: 10px; padding: 10px 12px; border-radius: 11px; background: var(--p-bg-surface-secondary); border: 1px solid var(--p-border-secondary); }
.assign-opt { display: flex; align-items: center; gap: 10px; padding: 9px 11px; border-radius: 10px; border: 1px solid var(--p-border); background: #fff; cursor: pointer; }
.assign-opt:hover { border-color: #b9c4d0; }
.assign-opt.on { background: var(--p-success-bg); border-color: #9fd3b6; }
.topbar .user .av { width: 30px; height: 30px; border-radius: 50%; background: linear-gradient(135deg,#7c9cff,#5b6cff); display: grid; place-items: center; font-size: 12px; font-weight: 600; }

/* ── Nav ── */
.nav { background: var(--p-bg-surface); border-right: 1px solid var(--p-border); overflow-y: auto; padding: 10px 10px 30px; }
.nav-group { margin-top: 14px; }
.nav-group:first-child { margin-top: 4px; }
.nav-group .gl { display: flex; align-items: center; width: 100%; gap: 6px; font-size: 10.5px; font-weight: 700; letter-spacing: 0.07em; text-transform: uppercase; color: var(--p-text-subdued); padding: 6px 10px; background: none; border: 0; cursor: pointer; text-align: left; border-radius: var(--p-radius-200); font-family: inherit; }
.nav-group .gl:hover { color: var(--p-text-secondary); background: var(--p-bg-surface-tertiary); }
.nav-group .gl .gl-chev { margin-left: auto; transition: transform 0.18s ease; opacity: 0.6; transform: rotate(90deg); }
.nav-group.collapsed .gl .gl-chev { transform: rotate(0deg); }
.nav-item { display: flex; align-items: center; gap: 10px; padding: 7px 10px; border-radius: var(--p-radius-200); color: var(--p-text-secondary); font-size: 13.5px; font-weight: 500; cursor: pointer; user-select: none; }
.nav-item:hover { background: var(--p-bg-surface-tertiary); color: var(--p-text); }
.nav-item.active { background: var(--p-bg-surface-selected); color: #1a4fa3; font-weight: 600; }
.nav-item .ni-ic { display: grid; place-items: center; width: 18px; height: 18px; flex-shrink: 0; color: currentColor; opacity: 0.9; }
.nav-item .chev { margin-left: auto; transition: transform 0.18s ease; opacity: 0.5; }
.nav-item.open .chev { transform: rotate(90deg); }
.nav-item .ni-badge { margin-left: auto; background: #ff6b5e; color: #fff; font-size: 10.5px; font-weight: 700; padding: 0 6px; border-radius: 999px; min-width: 18px; text-align: center; }
.nav-children { overflow: hidden; }
.nav-child { display: flex; align-items: center; gap: 8px; padding: 6px 10px 6px 38px; border-radius: var(--p-radius-200); color: var(--p-text-secondary); font-size: 13px; cursor: pointer; }
.nav-child:hover { background: var(--p-bg-surface-tertiary); color: var(--p-text); }
.nav-child.active { color: #1a4fa3; font-weight: 600; }
.nav-child .ni-badge { margin-left: auto; }

/* ── Main / page ── */
.main { overflow-y: auto; overflow-x: hidden; min-width: 0; }
.main.flush { overflow-x: auto; overflow-y: hidden; min-width: 0; }
.page { padding: 22px 28px 64px; max-width: 1400px; }
.page.wide { max-width: none; }
.breadcrumb { display: flex; align-items: center; gap: 6px; font-size: 12.5px; color: var(--p-text-subdued); margin-bottom: 12px; }
.breadcrumb a:hover { color: var(--p-text); }
.breadcrumb .sep { opacity: 0.5; }
.page-head { display: flex; align-items: flex-start; gap: 16px; margin-bottom: 20px; }
.page-head .pt { font-size: 22px; font-weight: 680; letter-spacing: -0.02em; }
.page-head .ps { font-size: 13.5px; color: var(--p-text-secondary); margin-top: 3px; max-width: 720px; }
.page-head .actions { margin-left: auto; display: flex; gap: 8px; align-items: center; }

/* ── Card ── */
.card { background: var(--p-bg-surface); border-radius: var(--p-radius-300); box-shadow: var(--p-shadow-card); }
.card.pad { padding: 18px; }
.card-head { display: flex; align-items: center; gap: 10px; padding: 14px 18px; border-bottom: 1px solid var(--p-border-secondary); }
.card-head .ct { font-size: 14.5px; font-weight: 640; }
.card-head .cs { font-size: 12.5px; color: var(--p-text-subdued); }
.card-head .ca { margin-left: auto; display: flex; gap: 6px; align-items: center; }
.card-body { padding: 18px; }

/* grid utils */
.row { display: flex; gap: 12px; }
.col { display: flex; flex-direction: column; gap: 12px; }
.wrap { flex-wrap: wrap; }
.aic { align-items: center; } .aie { align-items: flex-end; } .ais { align-items: flex-start; }
.jcsb { justify-content: space-between; } .jcc { justify-content: center; } .jce { justify-content: flex-end; }
.g2{gap:2px;} .g4{gap:4px;} .g6{gap:6px;} .g8{gap:8px;} .g10{gap:10px;} .g12{gap:12px;} .g14{gap:14px;} .g16{gap:16px;} .g20{gap:20px;} .g24{gap:24px;}
.plan-step{width:26px;height:26px;border-radius:7px;border:1px solid var(--p-border);background:var(--p-bg-surface-tertiary);color:var(--p-text);display:grid;place-items:center;cursor:pointer;flex-shrink:0;transition:background .12s,border-color .12s;}
.plan-step:hover{background:var(--p-interactive);border-color:var(--p-interactive);color:#fff;}
.plan-step:active{transform:scale(.94);}
.plan-range{-webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:99px;background:rgba(255,255,255,.3);outline:none;cursor:pointer;}
.plan-range::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:#fff;cursor:pointer;box-shadow:0 1px 4px rgba(0,0,0,.3);}
.plan-range::-moz-range-thumb{width:20px;height:20px;border:none;border-radius:50%;background:#fff;cursor:pointer;box-shadow:0 1px 4px rgba(0,0,0,.3);}
.num-input{border:1px solid var(--p-border);border-radius:7px;padding:4px 7px;font-size:12.5px;font-weight:600;text-align:right;background:var(--p-bg-surface);color:var(--p-text);font-family:inherit;-moz-appearance:textfield;}
.num-input::-webkit-outer-spin-button,.num-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}
.num-input:focus{outline:none;border-color:var(--p-interactive);box-shadow:0 0 0 2px var(--p-magic-bg);}
.txt-input{border:1px solid transparent;border-radius:7px;padding:4px 7px;font-size:12.5px;font-weight:600;background:transparent;color:var(--p-text);font-family:inherit;min-width:0;}
.txt-input:hover{border-color:var(--p-border-secondary);}
.txt-input:focus{outline:none;border-color:var(--p-interactive);background:var(--p-bg-surface);box-shadow:0 0 0 2px var(--p-magic-bg);}
.add-row{display:flex;align-items:center;gap:6px;justify-content:center;padding:8px;border-radius:10px;border:1px dashed var(--p-border);background:transparent;color:var(--p-text-secondary);font-size:12.5px;font-weight:600;cursor:pointer;font-family:inherit;}
.add-row:hover{border-color:var(--p-interactive);color:var(--p-interactive);background:var(--p-bg-surface-tertiary);}
.dot-ovr{width:6px;height:6px;border-radius:50%;background:#b06f00;flex-shrink:0;}
.link-btn{background:none;border:none;color:var(--p-interactive);cursor:pointer;padding:0;font-family:inherit;font-weight:600;}
.plan-detail td{background:var(--p-bg-surface-tertiary);}
.jce{justify-content:flex-end;}
.chip-x{display:inline-grid;place-items:center;width:15px;height:15px;margin-left:4px;border:none;border-radius:50%;background:rgba(0,0,0,.08);color:var(--p-text-secondary);cursor:pointer;vertical-align:middle;}
.chip-x:hover{background:var(--p-critical-bg);color:var(--p-critical-text);}
.mtm-snap{padding:13px 14px;border:1px solid var(--p-border);border-radius:12px;background:var(--p-bg-surface);}
.mtm-info{display:grid;grid-template-columns:1fr 1fr;gap:11px 18px;}
.mtm-info .input,.mtm-info .select{padding:4px 8px;font-size:12.5px;width:100%;}
.mtm-hist{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:8px;background:var(--p-bg-surface-tertiary);}
.f1{flex:1;} .grow{flex:1 1 auto;} .mla{margin-left:auto;}
.grid { display: grid; gap: 14px; }
.gc2{grid-template-columns:repeat(2,1fr);} .gc3{grid-template-columns:repeat(3,1fr);} .gc4{grid-template-columns:repeat(4,1fr);} .gc5{grid-template-columns:repeat(5,1fr);}
.muted{color:var(--p-text-secondary);} .subtle{color:var(--p-text-subdued);}
.tnum{font-variant-numeric:tabular-nums;}
.t11{font-size:11px;} .t12{font-size:12px;} .t13{font-size:13px;} .t15{font-size:15px;} .t17{font-size:17px;} .t20{font-size:20px;} .t24{font-size:24px;} .t28{font-size:28px;}
.fw5{font-weight:500;} .fw6{font-weight:600;} .fw7{font-weight:700;}
.mt4{margin-top:4px;} .mt8{margin-top:8px;} .mt12{margin-top:12px;} .mt16{margin-top:16px;} .mt20{margin-top:20px;} .mt24{margin-top:24px;}
.mb4{margin-bottom:4px;} .mb8{margin-bottom:8px;} .mb12{margin-bottom:12px;} .mb16{margin-bottom:16px;} .mb20{margin-bottom:20px;}
.mt10{margin-top:10px;}
.aife{align-items:flex-end;}
.center{display:grid;place-items:center;}

/* Exec dashboard — pillar health strip */
.pillar-grid{display:grid;gap:12px;grid-template-columns:repeat(6,1fr);}
.pillar-card{transition:border-color .15s, box-shadow .15s, transform .15s;}
.pillar-card:hover{border-color:var(--p-border-hover);transform:translateY(-2px);box-shadow:0 4px 14px rgba(0,0,0,.07);}
.alert-row{transition:background .12s;}
.alert-row:hover{background:var(--p-bg-surface-selected,#f1f5fb);}
/* Flow map — support engine rail + conveyor nodes */
.engine-grid{display:grid;gap:12px;grid-template-columns:repeat(4,1fr);}
.flow-node{transition:border-color .15s, box-shadow .15s, transform .15s;}
.flow-node:hover{border-color:var(--p-border-hover);transform:translateY(-2px);box-shadow:0 4px 14px rgba(0,0,0,.07);}
@media (max-width:1180px){.pillar-grid{grid-template-columns:repeat(3,1fr);} .engine-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:720px){.pillar-grid{grid-template-columns:repeat(2,1fr);} .engine-grid{grid-template-columns:1fr;}}

/* ── Button ── */
.btn { display: inline-flex; align-items: center; gap: 7px; font-size: 13px; font-weight: 600; padding: 7px 13px; border-radius: var(--p-radius-200); border: 1px solid transparent; cursor: pointer; white-space: nowrap; transition: background 0.12s, box-shadow 0.12s; line-height: 1.3; }
.btn svg { width: 16px; height: 16px; }
.btn-primary { background: var(--p-fill-brand); color: #fff; box-shadow: var(--p-shadow-button-primary); }
.btn-primary:hover { background: var(--p-fill-brand-hover); }
.btn-secondary { background: #fff; color: var(--p-text); border-color: #babfc3; box-shadow: var(--p-shadow-button); }
.btn-secondary:hover { background: var(--p-bg-surface-hover); border-color: #8a8f94; }
.btn-plain { background: none; color: #1a4fa3; padding: 7px 8px; font-weight: 600; }
.btn-plain:hover { background: var(--p-bg-surface-tertiary); }
.btn-success { background: var(--p-green); color: #fff; box-shadow: var(--p-shadow-button-primary); }
.btn-success:hover { background: var(--p-green-hover); }
.btn-critical { background: #d72c0d; color: #fff; }
.btn-critical:hover { background: #b42407; }
.btn-sm { padding: 4px 9px; font-size: 12px; }
.btn-icon { padding: 7px; }
.btn:disabled { opacity: 0.5; cursor: not-allowed; }

/* ── Badge / Tag ── */
.badge { display: inline-flex; align-items: center; gap: 5px; font-size: 11.5px; font-weight: 600; padding: 2px 8px; border-radius: var(--p-radius-full); line-height: 1.55; white-space: nowrap; }
.badge .dot { width: 7px; height: 7px; border-radius: 50%; background: currentColor; }
.badge.info{background:var(--p-info-bg);color:var(--p-info-text);}
.badge.success{background:var(--p-success-bg);color:var(--p-success-text);}
.badge.warning{background:var(--p-warning-bg);color:var(--p-warning-text);}
.badge.critical{background:var(--p-critical-bg);color:var(--p-critical-text);}
.badge.magic{background:var(--p-magic-bg);color:var(--p-magic-text);}
.badge.neutral{background:var(--p-neutral-bg);color:var(--p-neutral-text);}
.tag { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 500; padding: 3px 9px; border-radius: var(--p-radius-200); background: var(--p-bg-surface-tertiary); color: var(--p-text-secondary); border: 1px solid var(--p-border); }
.tag .x { cursor: pointer; opacity: 0.5; } .tag .x:hover { opacity: 1; }

/* ── Source report table ── */
.src-tbl { width: 100%; border-collapse: collapse; font-size: 13px; }
.src-tbl th { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.03em; color: var(--p-text-subtle); text-align: right; padding: 0 12px 9px; border-bottom: 1px solid var(--p-border); white-space: nowrap; }
.src-tbl td { padding: 11px 12px; border-bottom: 1px solid var(--p-border-secondary); vertical-align: middle; }
.src-tbl tbody tr:last-child td { border-bottom: none; }
.src-tbl tbody tr:hover { background: var(--p-bg-surface-hover); }

/* ── Avatar ── */
.avatar { border-radius: 50%; display: grid; place-items: center; color: #fff; font-weight: 600; flex-shrink: 0; overflow: hidden; }

/* ── Field ── */
.field { display: flex; flex-direction: column; gap: 5px; }
.field > label { font-size: 12.5px; font-weight: 500; color: var(--p-text); }
.input, .select, textarea.input { font-family: inherit; font-size: 13.5px; color: var(--p-text); background: #fff; border: 1px solid #8a8f94; border-radius: var(--p-radius-200); padding: 7px 11px; outline: none; width: 100%; box-shadow: var(--p-shadow-bevel); }
.input:focus, .select:focus, textarea.input:focus { border-color: var(--p-border-focus); box-shadow: 0 0 0 2px #b6d8ff; }
.input::placeholder { color: var(--p-text-subdued); }
.input-wrap { position: relative; display: flex; align-items: center; }
.input-wrap svg { position: absolute; left: 10px; width: 16px; height: 16px; color: var(--p-icon-secondary); pointer-events: none; }
.input-wrap .input { padding-left: 32px; }
.select { appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%238a8a8a' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 9px center; padding-right: 30px; cursor: pointer; }
.seg { display: inline-flex; background: var(--p-bg-surface-tertiary); border-radius: var(--p-radius-200); padding: 2px; gap: 2px; }
.seg button { border: none; background: none; font-size: 12.5px; font-weight: 500; color: var(--p-text-secondary); padding: 5px 12px; border-radius: 6px; cursor: pointer; white-space: nowrap; }
.seg button.on { background: #fff; color: var(--p-text); font-weight: 600; box-shadow: var(--p-shadow-card); }
.switch { position: relative; width: 36px; height: 20px; border-radius: 999px; background: #c9ccd0; cursor: pointer; transition: background 0.15s; flex-shrink: 0; }
.switch.on { background: var(--p-green); }
.switch::after { content: ""; position: absolute; top: 2px; left: 2px; width: 16px; height: 16px; border-radius: 50%; background: #fff; transition: transform 0.15s; box-shadow: 0 1px 2px rgba(0,0,0,0.2); }
.switch.on::after { transform: translateX(16px); }
.check { width: 18px; height: 18px; border-radius: 4px; border: 1.5px solid #8a8f94; background: #fff; cursor: pointer; display: grid; place-items: center; flex-shrink: 0; }
.check.on { background: var(--p-fill-brand); border-color: var(--p-fill-brand); }
.check.on svg { width: 13px; height: 13px; color: #fff; }

/* ── Tabs ── */
.tabs { display: flex; gap: 2px; border-bottom: 1px solid var(--p-border); }
.tabs button { border: none; background: none; font-size: 13.5px; font-weight: 550; color: var(--p-text-secondary); padding: 10px 14px; cursor: pointer; position: relative; border-radius: 8px 8px 0 0; }
.tabs button:hover { background: var(--p-bg-surface-tertiary); color: var(--p-text); }
.tabs button.on { color: var(--p-text); font-weight: 650; }
.tabs button.on::after { content: ""; position: absolute; left: 10px; right: 10px; bottom: -1px; height: 3px; background: var(--p-fill-brand); border-radius: 3px 3px 0 0; }

/* ── Table (IndexTable) ── */
.tbl-wrap { width: 100%; overflow-x: auto; }
table.tbl { width: 100%; border-collapse: collapse; font-size: 13px; }
table.tbl th { text-align: left; font-size: 11.5px; font-weight: 600; color: var(--p-text-secondary); padding: 10px 12px; border-bottom: 1px solid var(--p-border); background: var(--p-bg-surface-secondary); white-space: nowrap; position: sticky; top: 0; }
table.tbl th.num, table.tbl td.num { text-align: right; font-variant-numeric: tabular-nums; }
table.tbl td { padding: 11px 12px; border-bottom: 1px solid var(--p-border-secondary); vertical-align: middle; }
table.tbl tbody tr:hover { background: var(--p-bg-surface-hover); }
table.tbl tbody tr.clickable { cursor: pointer; }
table.tbl tbody tr.sel { background: var(--p-bg-surface-selected); }
.th-sort { cursor: pointer; user-select: none; display: inline-flex; align-items: center; gap: 4px; }
.tbl-toolbar { display: flex; align-items: center; gap: 10px; padding: 12px 14px; border-bottom: 1px solid var(--p-border-secondary); flex-wrap: wrap; }
.bulkbar { display: flex; align-items: center; gap: 10px; padding: 10px 14px; background: var(--p-bg-surface-selected); border-bottom: 1px solid var(--p-border); }
.pagination { display: flex; align-items: center; gap: 8px; padding: 12px 14px; justify-content: flex-end; font-size: 12.5px; color: var(--p-text-secondary); }

/* ── KPI ── */
.kpi { background: var(--p-bg-surface); border-radius: var(--p-radius-300); box-shadow: var(--p-shadow-card); padding: 16px 18px; }
.kpi .kl { font-size: 12.5px; color: var(--p-text-secondary); font-weight: 500; display: flex; align-items: center; gap: 6px; }
.kpi .kv { font-size: 27px; font-weight: 700; letter-spacing: -0.02em; margin-top: 7px; }
.kpi .kd { font-size: 12px; font-weight: 600; margin-top: 6px; display: inline-flex; align-items: center; gap: 3px; }
.kpi .kd.up { color: #0e7c4a; } .kpi .kd.down { color: #c4320a; } .kpi .kd.flat { color: var(--p-text-subdued); }
.kpi .ksub { font-size: 11.5px; color: var(--p-text-subdued); margin-top: 2px; }

/* ── Progress ── */
.prog { height: 7px; border-radius: 999px; background: var(--p-bg-surface-tertiary); overflow: hidden; }
.prog > span { display: block; height: 100%; border-radius: 999px; background: var(--p-fill-brand); }

/* ── Drawer / Modal ── */
.scrim { position: fixed; inset: 0; background: rgba(0,0,0,0.32); z-index: 50; display: flex; }
.scrim.right { justify-content: flex-end; }
.scrim.center { align-items: center; justify-content: center; }
.drawer { width: 480px; max-width: 92vw; background: var(--p-bg-surface); height: 100%; display: flex; flex-direction: column; box-shadow: -8px 0 30px rgba(0,0,0,0.16); animation: slidein 0.18s ease; }
@keyframes slidein { from { transform: translateX(20px); opacity: 0.6; } to { transform: none; opacity: 1; } }
.modal { width: 520px; max-width: 92vw; max-height: 88vh; background: var(--p-bg-surface); border-radius: var(--p-radius-400); display: flex; flex-direction: column; box-shadow: var(--p-shadow-popover); overflow: hidden; animation: pop 0.16s ease; }
@keyframes pop { from { transform: scale(0.97); opacity: 0.7; } to { transform: none; opacity: 1; } }
.sheet-head { display: flex; align-items: center; gap: 12px; padding: 16px 20px; border-bottom: 1px solid var(--p-border-secondary); }
.sheet-head .st { font-size: 16px; font-weight: 640; }
.sheet-body { padding: 20px; overflow-y: auto; flex: 1; }
.sheet-foot { display: flex; gap: 8px; justify-content: flex-end; padding: 14px 20px; border-top: 1px solid var(--p-border-secondary); }
.iconbtn { width: 30px; height: 30px; border-radius: var(--p-radius-200); display: grid; place-items: center; border: none; background: none; color: var(--p-icon); cursor: pointer; }
.iconbtn:hover { background: var(--p-bg-surface-tertiary); }

/* ── Empty / skeleton ── */
.empty { display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 56px 20px; text-align: center; color: var(--p-text-secondary); }
.empty .ei { width: 56px; height: 56px; border-radius: 14px; background: var(--p-bg-surface-tertiary); display: grid; place-items: center; margin-bottom: 14px; color: var(--p-icon-secondary); }
.empty .et { font-size: 15px; font-weight: 600; color: var(--p-text); }
.empty .ed { font-size: 13px; margin-top: 4px; max-width: 360px; }
.skel { background: linear-gradient(90deg,#eee,#f5f5f5,#eee); background-size: 200% 100%; animation: sh 1.2s infinite; border-radius: 6px; }
@keyframes sh { from { background-position: 200% 0; } to { background-position: -200% 0; } }

/* ── Misc helpers ── */
.divider { height: 1px; background: var(--p-border-secondary); }
.vdivider { width: 1px; background: var(--p-border-secondary); align-self: stretch; }
.dot-sep::before { content: "·"; margin: 0 6px; color: var(--p-text-subdued); }
.pill-tab { display: inline-flex; gap: 6px; }
.pill-tab button { border: 1px solid var(--p-border); background: #fff; font-size: 12.5px; font-weight: 500; color: var(--p-text-secondary); padding: 5px 12px; border-radius: 999px; cursor: pointer; }
.pill-tab button.on { background: var(--p-fill-brand); color: #fff; border-color: var(--p-fill-brand); }
.linkish { color: #1a4fa3; font-weight: 600; cursor: pointer; }
.linkish:hover { text-decoration: underline; }
.hot { color: #c4320a; }
.sla-ok { color: #0e7c4a; } .sla-warn { color: #b06f00; } .sla-bad { color: #c4320a; }

/* ============================================================
   Sales CRM — Playbook screens (Work Queue / Kanban / MAKE THE MOVE)
   ============================================================ */
.mt2 { margin-top: 2px; }
.ellip { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; min-width: 0; }
.stage-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }

/* ── playbook helper chips ── */
.sig-badge { display: inline-flex; align-items: center; gap: 5px; font-size: 11px; font-weight: 700; padding: 2px 8px; border-radius: 999px; line-height: 1.5; white-space: nowrap; max-width: 260px; overflow: hidden; text-overflow: ellipsis; }
.sig-dot { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; }
.script-tag { display: inline-flex; align-items: center; font-size: 10.5px; font-weight: 800; letter-spacing: 0.04em; padding: 2px 7px; border-radius: 6px; border: 1px solid; text-transform: uppercase; }
.branch-tag { display: inline-grid; place-items: center; width: 18px; height: 18px; font-size: 11px; font-weight: 800; border-radius: 5px; border: 1px solid; }
.lane-tag { display: inline-flex; align-items: center; font-size: 10.5px; font-weight: 700; padding: 1px 7px; border-radius: 999px; }

/* ── Work Queue ── */
.wq-list { display: flex; flex-direction: column; }
.wq-row { display: flex; align-items: stretch; gap: 12px; padding: 12px 14px 12px 0; border-bottom: 1px solid var(--p-border-secondary); cursor: pointer; position: relative; }
.wq-list .wq-row:last-child { border-bottom: none; }
.wq-row:hover { background: var(--p-bg-surface-hover); }
.wq-rail { width: 4px; border-radius: 0 3px 3px 0; flex-shrink: 0; }
.wq-main { flex: 1; min-width: 0; }
.wq-action { font-size: 11.5px; color: var(--p-text-secondary); margin-top: 7px; display: flex; align-items: center; gap: 5px; }
.wq-action svg { color: #b06f00; flex-shrink: 0; }
.wq-side { display: flex; flex-direction: column; align-items: flex-end; justify-content: center; gap: 6px; flex-shrink: 0; padding-right: 4px; }
.wq-prio { font-size: 11px; font-weight: 800; color: var(--p-text-subdued); font-variant-numeric: tabular-nums; background: var(--p-bg-surface-tertiary); padding: 1px 7px; border-radius: 6px; }
.wq-col { background: var(--p-bg-surface-secondary); border: 1px solid var(--p-border-secondary); border-radius: var(--p-radius-300); padding: 10px; }
.wq-col-head { display: flex; align-items: center; gap: 8px; padding: 2px 4px 10px; border-bottom: 2px solid; margin-bottom: 10px; }
.wq-col .wq-row { background: #fff; border: 1px solid var(--p-border-secondary); border-radius: 10px; padding: 10px 12px 10px 0; box-shadow: var(--p-shadow-card); }
.wq-col .wq-row:hover { border-color: #b9c4d0; }
.wq-sec-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 12px 16px; border-bottom: 1px solid var(--p-border-secondary); }

/* ── Daily routine rail ── */
.dr-list { display: flex; flex-direction: column; gap: 4px; }
.dr-block { display: flex; gap: 10px; padding: 9px 8px; border-radius: 9px; }
.dr-block.active { background: var(--p-bg-surface-selected); }
.dr-time { width: 78px; flex-shrink: 0; font-size: 11px; font-weight: 700; color: var(--p-text-secondary); font-variant-numeric: tabular-nums; }
.dr-dur { display: block; font-size: 10px; font-weight: 500; color: var(--p-text-subdued); margin-top: 2px; }
.dr-block.active .dr-time { color: #1a4fa3; }
.dr-items { list-style: none; margin: 6px 0 0; padding: 0; display: flex; flex-direction: column; gap: 3px; }
.dr-items li { font-size: 11.5px; color: var(--p-text-secondary); padding-left: 12px; position: relative; }
.dr-items li::before { content: ""; position: absolute; left: 2px; top: 7px; width: 4px; height: 4px; border-radius: 50%; background: #c2c8d0; }

/* ── Kanban ── */
.kb-fnum { font-size: 18px; font-weight: 800; color: var(--p-text-subdued); }
.kb-scroll { display: flex; gap: 12px; overflow-x: auto; padding-bottom: 10px; }
.kb-col { width: 246px; flex-shrink: 0; }
.kb-col-head { display: flex; align-items: center; gap: 7px; padding: 0 4px 4px; }
.kb-col-sub { padding: 0 4px 8px; min-height: 20px; }
.kb-drop { position: relative; display: flex; flex-direction: column; gap: 8px; min-height: 80px; padding: 8px; border-radius: 12px; background: var(--p-bg-surface-secondary); border: 1px solid var(--p-border-secondary); transition: background 0.1s; overflow-y: auto; overscroll-behavior: contain; }
.kb-drop.over { background: var(--p-bg-surface-selected); border-color: #90b8ff; }
.kb-drop::-webkit-scrollbar { width: 8px; }
.kb-drop::-webkit-scrollbar-track { background: transparent; }
.kb-drop::-webkit-scrollbar-thumb { background: var(--p-border); border-radius: 8px; border: 2px solid var(--p-bg-surface-secondary); }
.kb-drop:hover::-webkit-scrollbar-thumb { background: #b9c4d0; }
.kb-addbtn { display: flex; align-items: center; justify-content: center; gap: 6px; width: 100%; padding: 8px; border: 1px dashed var(--p-border); border-radius: 10px; background: transparent; color: var(--p-text-subdued); font-size: 12px; font-weight: 600; cursor: pointer; transition: all 0.1s; }
.kb-addbtn:hover { border-color: #90b8ff; color: var(--p-action-primary, #2c6ecb); background: #fff; }
.kb-col-foot { padding-top: 8px; }
.kb-morehint { text-align: center; font-size: 10.5px; font-weight: 600; color: var(--p-text-subdued); padding: 4px 0 0; }
.kb-card { position: relative; background: #fff; border: 1px solid var(--p-border); border-radius: 10px; padding: 11px 11px 11px 14px; cursor: grab; box-shadow: var(--p-shadow-card); }
.kb-card:hover { border-color: #b9c4d0; }
.kb-card:active { cursor: grabbing; }
.kb-card-rail { position: absolute; left: 0; top: 8px; bottom: 8px; width: 4px; border-radius: 3px; }

/* ── MAKE THE MOVE drawer ── */
.mtm-hero { padding: 14px; border-radius: 12px; background: var(--p-bg-surface-secondary); border: 1px solid var(--p-border-secondary); }
.mtm-signal { padding: 12px 14px; border-radius: 12px; background: #fdf1ec; border: 1px solid #f6cdbd; }
.mtm-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.mtm-k { font-size: 10.5px; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; color: var(--p-text-subdued); margin-bottom: 3px; display: flex; align-items: center; gap: 4px; }
.mtm-meta { display: inline-flex; align-items: center; gap: 4px; }
.mtm-script { padding: 14px; border-radius: 12px; background: #f7f8fb; border: 1px solid var(--p-border-secondary); }
.mtm-line { font-size: 12.5px; line-height: 1.5; color: var(--p-text); padding: 8px 10px; border-radius: 8px; background: #fff; border: 1px solid var(--p-border-secondary); }
.mtm-qualify { padding: 14px; border-radius: 12px; border: 1px solid var(--p-border-secondary); }
.mtm-next { display: flex; align-items: center; gap: 10px; padding: 10px 12px; border-radius: 10px; border: 1px solid var(--p-border); background: #fff; cursor: pointer; transition: border-color 0.1s, background 0.1s; }
.mtm-next:hover { border-color: #1a4fa3; background: var(--p-bg-surface-selected); }
.mtm-next svg { color: var(--p-icon-secondary); flex-shrink: 0; }
.mtm-confirm { padding: 14px; border-radius: 12px; background: var(--p-bg-surface-secondary); border: 1px solid var(--p-border-secondary); }
.mtm-num { display: inline-grid; place-items: center; min-width: 26px; height: 26px; padding: 0 6px; border-radius: 7px; background: var(--p-fill-brand); color: #fff; font-size: 12px; font-weight: 800; flex-shrink: 0; }

/* ── Qualify gate ── */
.qgate { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.qgate-item { display: flex; align-items: center; gap: 8px; padding: 9px 11px; border-radius: 9px; border: 1px solid var(--p-border); background: #fff; }
.qgate-item.on { background: var(--p-success-bg); border-color: #9fd3b6; }
.qgate-ic { display: grid; place-items: center; width: 22px; height: 22px; border-radius: 50%; background: #e3e3e3; color: #8a8a8a; flex-shrink: 0; }
.qgate-item.on .qgate-ic { background: #0e7c4a; color: #fff; }

/* ── Playbook config / activity ── */
.pb-note { display: flex; align-items: flex-start; gap: 10px; padding: 12px 14px; border-radius: 10px; background: var(--p-info-bg); font-size: 12.5px; color: #1a3a5c; line-height: 1.5; }
.pb-note svg { flex-shrink: 0; margin-top: 1px; }
.flow-block { display: flex; gap: 12px; padding: 11px; border-radius: 10px; border: 1px solid var(--p-border-secondary); }
.flow-block.active { background: var(--p-bg-surface-selected); border-color: #b6d0f0; }
.flow-time { width: 96px; flex-shrink: 0; display: flex; flex-direction: column; gap: 5px; align-items: flex-start; }
.flow-items { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 4px; }
.flow-items li { font-size: 12px; color: var(--p-text-secondary); padding-left: 14px; position: relative; line-height: 1.45; }
.flow-items li::before { content: ""; position: absolute; left: 3px; top: 7px; width: 4px; height: 4px; border-radius: 50%; background: #b9c0c9; }
.report-row { display: flex; flex-direction: column; gap: 2px; padding: 9px 11px; border-radius: 8px; background: var(--p-bg-surface-tertiary); }
.report-k { font-size: 12.5px; font-weight: 700; }
.prio-row { display: flex; align-items: center; gap: 10px; padding: 8px 10px; border-radius: 9px; border: 1px solid var(--p-border-secondary); }
.prio-n { font-size: 12px; font-weight: 800; color: var(--p-text-subdued); font-variant-numeric: tabular-nums; flex-shrink: 0; }

/* ── Marketing hub ── */
.mktbar { flex-wrap: nowrap; }
.mktbar .seg, .mktbar .select { flex-shrink: 0; }
.mkt-date { padding: 5px 8px; font-size: 12.5px; width: 140px; }

/* ── Flexible period navigator (PeriodNav) ── */
.pnav { flex-wrap: nowrap; }
.pnav .seg, .pnav .select { flex-shrink: 0; }
.pnav-date { padding: 5px 8px; font-size: 12.5px; width: 138px; }
.pnav-step { position: relative; display: inline-flex; align-items: center; background: var(--p-bg-surface); border: 1px solid var(--p-border); border-radius: var(--p-radius-200); overflow: visible; flex-shrink: 0; }
.pnav-arrow { display: inline-flex; align-items: center; justify-content: center; width: 28px; height: 30px; border: none; background: none; color: var(--p-text-secondary); cursor: pointer; }
.pnav-arrow:hover { background: var(--p-bg-surface-hover); color: var(--p-text); }
.pnav-arrow:disabled { color: var(--p-border-hover); cursor: default; background: none; }
.pnav-cur { display: inline-flex; align-items: center; gap: 6px; height: 30px; padding: 0 10px; border: none; border-left: 1px solid var(--p-border-secondary); border-right: 1px solid var(--p-border-secondary); background: none; font-size: 12.5px; font-weight: 600; color: var(--p-text); cursor: pointer; white-space: nowrap; }
.pnav-cur:hover { background: var(--p-bg-surface-hover); }
.pnav-cur .pnav-lbl { letter-spacing: -0.01em; }
.pnav-cur svg:first-child { color: var(--p-text-subdued); }
.pnav-pop { position: absolute; top: calc(100% + 6px); left: 50%; transform: translateX(-50%); min-width: 232px; background: #fff; border: 1px solid var(--p-border); border-radius: 12px; box-shadow: var(--p-shadow-popover, 0 8px 28px rgba(0,0,0,0.14)); padding: 6px; z-index: 60; }
.pnav-pop-h { font-size: 11px; font-weight: 700; letter-spacing: 0.03em; text-transform: uppercase; color: var(--p-text-subdued); padding: 6px 10px 8px; }
.pnav-pop-i { display: flex; align-items: center; justify-content: space-between; gap: 8px; width: 100%; text-align: left; border: none; background: none; font-size: 12.5px; font-weight: 500; color: var(--p-text); padding: 8px 10px; border-radius: 8px; cursor: pointer; }
.pnav-pop-i:hover { background: var(--p-bg-surface-tertiary); }
.pnav-pop-i.on { background: var(--p-fill-brand-subtle, #e8f0ff); color: var(--p-fill-brand, #1f5eff); font-weight: 600; }
.pnav-pop-i.on svg { color: var(--p-fill-brand, #1f5eff); }
.pnav-tag { font-size: 10.5px; font-weight: 700; color: #0e7c4a; background: #e3f5ec; padding: 1px 7px; border-radius: 999px; }
.pnav-reset { display: inline-flex; align-items: center; gap: 5px; height: 30px; padding: 0 11px; border: 1px solid var(--p-border); border-radius: 999px; background: var(--p-bg-surface); font-size: 12px; font-weight: 600; color: var(--p-text-secondary); cursor: pointer; white-space: nowrap; flex-shrink: 0; }
.pnav-reset:hover { background: var(--p-bg-surface-hover); color: var(--p-text); }
.sync-chip { padding: 5px 10px; border: 1px solid var(--p-border); border-radius: 999px; background: var(--p-bg-surface); white-space: nowrap; flex-shrink: 0; }

/* sync button */
.sync-btn { display: inline-flex; align-items: center; gap: 6px; padding: 6px 12px; border: 1px solid var(--p-border); border-radius: 8px; background: var(--p-bg-surface); font-size: 12.5px; font-weight: 500; color: var(--p-text); cursor: pointer; white-space: nowrap; flex-shrink: 0; }
.sync-btn:hover { background: var(--p-bg-surface-hover); }
.sync-btn:disabled { cursor: default; opacity: 0.85; }
.sync-btn .sync-time { color: var(--p-text-subdued); font-weight: 400; }
.sync-btn.realtime { border-color: #92e6b5; }
.sync-btn .sync-dot { width: 7px; height: 7px; border-radius: 50%; background: #0e7c4a; box-shadow: 0 0 0 0 rgba(14,124,74,0.5); animation: pulse 1.6s infinite; }
@keyframes pulse { 0% { box-shadow: 0 0 0 0 rgba(14,124,74,0.45); } 70% { box-shadow: 0 0 0 6px rgba(14,124,74,0); } 100% { box-shadow: 0 0 0 0 rgba(14,124,74,0); } }
.spin { animation: spin360 0.9s linear infinite; }
@keyframes spin360 { to { transform: rotate(360deg); } }
.mkt-alert { display: flex; align-items: center; gap: 10px; padding: 10px 14px; border-radius: 10px; }
.splitbar { display: flex; height: 8px; border-radius: 999px; overflow: hidden; background: #eee; }
.splitbar > span { height: 100%; }
.callout-soft { display: flex; align-items: center; gap: 8px; font-size: 12.5px; color: var(--p-text-secondary); background: var(--p-bg-surface-secondary); padding: 9px 12px; border-radius: 9px; }
.ci-row { transition: background .12s; }
.ci-row:hover { background: var(--p-bg-surface-hover); }

/* summary table totals row */
.sum-tbl tbody tr.sum-total td { border-top: 2px solid var(--p-border); font-weight: 700; background: var(--p-bg-surface-secondary); }
.tbl tr.row-warn td { background: var(--p-warning-bg); }
.tbl tr.row-dim td { opacity: 0.6; }

/* posting heatmap */
.heatgrid { display: grid; gap: 4px; }
.heat-cell { display: grid; place-items: center; height: 34px; border-radius: 6px; font-size: 11.5px; font-weight: 600; font-variant-numeric: tabular-nums; }
.heat-h { color: var(--p-text-subdued); font-weight: 600; font-size: 11px; }
.heat-d { color: var(--p-text-secondary); justify-content: flex-start; }
.heat-corner { background: transparent; }

/* integration cards */
.integ-card { border: 1px solid var(--p-border); border-radius: var(--p-radius-300); padding: 14px; background: var(--p-bg-surface); }
.integ-ic { width: 36px; height: 36px; border-radius: 9px; background: var(--p-bg-surface-secondary); color: var(--p-text); }

/* per-channel funnel cards */
.chfunnel { border: 1px solid var(--p-border); border-radius: var(--p-radius-300); padding: 14px; }
.chfunnel .clickable:hover { opacity: 0.7; }

/* config rows */
.cfg-row { padding: 12px 0; border-bottom: 1px solid var(--p-border-secondary); }
.cfg-row:last-child { border-bottom: none; }
.cfg-prev { padding: 10px 12px; border-radius: 9px; background: var(--p-bg-surface-secondary); }
.path-row { padding: 10px 12px; border-radius: 9px; background: var(--p-bg-surface-secondary); }

/* content calendar */
.cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 6px; }
.cal-head { margin-bottom: 6px; }
.cal-dow { text-align: center; font-size: 11.5px; font-weight: 600; color: var(--p-text-subdued); padding: 4px 0; }
.cal-cell { min-height: 116px; border: 1px solid var(--p-border-secondary); border-radius: 9px; padding: 6px; background: var(--p-bg-surface); }
.cal-cell.cal-empty { background: transparent; border: none; }
.cal-cell.cal-today { border-color: #0084ff; box-shadow: inset 0 0 0 1px #0084ff; }
.cal-day { font-size: 12px; font-weight: 600; color: var(--p-text-secondary); margin-bottom: 6px; display: flex; align-items: center; justify-content: space-between; }
.cal-now { font-size: 9.5px; font-weight: 700; color: #fff; background: #0084ff; border-radius: 999px; padding: 1px 6px; }
.cal-ev { display: flex; align-items: center; gap: 5px; padding: 3px 5px; border-radius: 5px; border-left: 3px solid #0084ff; font-size: 11px; background: var(--p-bg-surface-secondary); }
.cal-ev-t { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cal-ev.posted { opacity: 0.62; }
.cal-ev.scheduled { background: #e7f1ff; }
.cal-ev.draft { background: repeating-linear-gradient(45deg, #f4f4f4, #f4f4f4 5px, #ececec 5px, #ececec 10px); }
.cal-key { width: 12px; height: 12px; border-radius: 3px; display: inline-block; }
.cal-key.posted { background: #cfcfcf; }
.cal-key.scheduled { background: #9cc4ff; }
.cal-key.draft { background: repeating-linear-gradient(45deg, #f4f4f4, #f4f4f4 3px, #d8d8d8 3px, #d8d8d8 6px); }

/* print / export report */
@media print {
  .topbar, .nav, .page-head .actions, .mkt-alert .btn, .tbl-toolbar, .pagination { display: none !important; }
  .app { display: block !important; }
  .main { position: static !important; overflow: visible !important; height: auto !important; }
  .page { max-width: none !important; padding: 0 !important; }
  .card, .kpi { box-shadow: none !important; border: 1px solid #e3e3e3 !important; break-inside: avoid; }
  body { background: #fff !important; }
}

/* ── Operations: courses / classes / calendar ── */
.center { display: grid; place-items: center; }
.crow { cursor: pointer; transition: background .12s; }
.crow:hover { background: var(--p-bg-surface-hover); }
.fillbar { height: 6px; border-radius: 999px; background: #ececec; overflow: hidden; }
.fillbar > span { display: block; height: 100%; border-radius: 999px; }
.web-chip { display: inline-flex; align-items: center; gap: 4px; font-size: 11px; font-weight: 600; color: #0e7c4a; background: var(--p-success-bg); padding: 2px 8px; border-radius: 999px; }
.mini-class { border: 1px solid var(--p-border); border-radius: 10px; padding: 9px 11px; }
.mini-class:hover { border-color: var(--p-border-hover); background: var(--p-bg-surface-hover); }
.sess-row { display: grid; grid-template-columns: 34px 92px 1fr auto; gap: 12px; align-items: center; padding: 10px 0; border-top: 1px solid var(--p-border-secondary); }
.sess-row:first-child { border-top: none; }
.sess-n { width: 30px; height: 30px; border-radius: 8px; display: grid; place-items: center; font-weight: 700; font-size: 12.5px; }

.cal-head, .cal-week { display: grid; grid-template-columns: repeat(7, 1fr); gap: 8px; }
.cal-dow { text-align: center; font-size: 11.5px; font-weight: 700; color: var(--p-text-subdued); padding-bottom: 6px; }
.cal-cell { min-height: 104px; border: 1px solid var(--p-border-secondary); border-radius: 10px; padding: 6px; background: var(--p-bg-surface); display: flex; flex-direction: column; gap: 4px; }
.cal-cell.empty { background: transparent; border: none; }
.cal-cell.today { border-color: var(--p-border-focus); box-shadow: 0 0 0 1px var(--p-border-focus) inset; }
.cal-cell.conflict { background: #fff7ed; border-color: #f5c451; }
.cal-date { font-size: 12px; font-weight: 700; color: var(--p-text-secondary); }
.cal-chip { font-size: 10.5px; font-weight: 600; line-height: 1.25; padding: 3px 6px; border-radius: 6px; color: #fff; cursor: pointer; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cal-chip.warn { outline: 1.5px solid #b45309; outline-offset: -1.5px; }
