/* ==========================================================================
   RippleCore Dashboard — App styles
   Built on DataRipple admin skin. .rc-* prefixes only.
   ========================================================================== */

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; height: 100%; background: var(--bg); color: var(--fg-2); overflow: hidden; }
body { font-family: var(--font-body); }
html.auth-pending body { visibility: hidden; }
a { color: inherit; text-decoration: none; }

/* ------- App grid ------- */
.rc-app { display: grid; grid-template-columns: var(--rc-nav-w, 248px) 1fr; height: 100vh; overflow: hidden; transition: grid-template-columns .25s ease; }
.rc-app[data-nav="rail"] { --rc-nav-w: 64px; }
.rc-app[data-nav="pinned"] { --rc-nav-w: 64px; }

/* ================ SIDEBAR ================ */
.rc-side { background: var(--shell); border-right: 1px solid var(--border); display: flex; flex-direction: column; min-width: 0; min-height: 0; height: 100%; overflow: hidden; position: relative; z-index: 30; }

.rc-brand { display: flex; align-items: center; gap: 10px; padding: 18px 18px 14px; border-bottom: 1px solid var(--shell-rule); }
.rc-brand-logo { display: block; height: 56px; width: auto; max-width: 340px; object-fit: contain; object-position: left center; }
.rc-app[data-nav="rail"] .rc-brand-logo,
.rc-app[data-nav="pinned"] .rc-brand-logo { height: 26px; object-position: center; max-width: 36px; object-fit: cover; }
.rc-app[data-nav="rail"] .rc-brand,
.rc-app[data-nav="pinned"] .rc-brand { justify-content: center; padding: 18px 8px 14px; }

/* workspace */
.rc-ws { padding: 10px 12px; border-bottom: 1px solid var(--shell-rule); }
.rc-ws-btn { width: 100%; display: flex; align-items: center; gap: 10px; padding: 8px 10px; background: var(--surface-1); border: 1px solid var(--border); border-radius: 8px; cursor: pointer; color: var(--fg-2); text-align: left; }
.rc-ws-btn:hover { background: var(--surface-2); }
.rc-ws-avatar { width: 22px; height: 22px; border-radius: 6px; background: var(--orange); color: #fff; font-family: var(--font-heading); font-weight: 700; font-size: 11px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.rc-ws-body { flex: 1; min-width: 0; }
.rc-ws-name { font-family: var(--font-heading); font-weight: 600; font-size: 12px; color: var(--fg-1); line-height: 1.2; }
.rc-ws-role { font-size: 10px; color: var(--fg-dim); letter-spacing: 0.06em; text-transform: uppercase; margin-top: 2px; }
.rc-ws-chev { color: var(--fg-dim); flex-shrink: 0; }
.rc-app[data-nav="rail"] .rc-ws,
.rc-app[data-nav="pinned"] .rc-ws { padding: 10px 8px; }
.rc-app[data-nav="rail"] .rc-ws-body,
.rc-app[data-nav="rail"] .rc-ws-chev,
.rc-app[data-nav="pinned"] .rc-ws-body,
.rc-app[data-nav="pinned"] .rc-ws-chev { display: none; }
.rc-app[data-nav="rail"] .rc-ws-btn,
.rc-app[data-nav="pinned"] .rc-ws-btn { justify-content: center; padding: 6px; }

/* nav list */
.rc-nav { flex: 1; min-height: 0; overflow-y: auto; padding: 10px 8px 20px; scrollbar-width: thin; scrollbar-color: var(--border) transparent; }
.rc-nav::-webkit-scrollbar { width: 6px; }
.rc-nav::-webkit-scrollbar-thumb { background: var(--border); border-radius: 3px; }

.rc-nav-section { margin-top: 14px; }
.rc-nav-section:first-child { margin-top: 4px; }
.rc-nav-section-label { font-family: var(--font-body); font-weight: 700; font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--fg-dim); padding: 0 12px 8px; }
.rc-app[data-nav="rail"] .rc-nav-section-label,
.rc-app[data-nav="pinned"] .rc-nav-section-label { opacity: 0; height: 12px; padding: 0; overflow: hidden; }

.rc-nav-item { position: relative; }
.rc-nav-btn {
  width: 100%; display: flex; align-items: center; gap: 11px; padding: 9px 12px; background: transparent; border: none; border-radius: 8px; cursor: pointer;
  font-family: var(--font-heading); font-weight: 500; font-size: 13px; color: var(--fg-3); text-align: left; transition: background .15s, color .15s;
}
.rc-nav-btn:hover { background: var(--surface-2); color: var(--fg-1); }
.rc-nav-btn.active { background: var(--teal-subtle); color: var(--teal); }
.rc-nav-btn.active-parent { color: var(--fg-1); }
.rc-nav-btn svg { flex-shrink: 0; stroke-width: 2; }
.rc-nav-btn svg,
.rc-nav-sub-btn svg,
.rc-iconbtn svg,
.rc-aichat-icon svg,
.rc-aichat-send svg,
.rc-card-icon svg {
  width: 17px;
  height: 17px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.rc-nav-btn .rc-nav-label { flex: 1; min-width: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.rc-nav-btn .rc-nav-badge { font-family: var(--font-mono); font-size: 10px; padding: 2px 6px; background: var(--orange); color: #fff; border-radius: 99px; font-weight: 700; line-height: 1; }
.rc-nav-btn .rc-nav-chev { color: var(--fg-dim); transition: transform .2s; flex-shrink: 0; }
.rc-nav-btn.open .rc-nav-chev { transform: rotate(90deg); color: var(--fg-2); }

.rc-nav-sub { overflow: hidden; max-height: 0; transition: max-height .25s ease; }
.rc-nav-sub.open { max-height: 500px; }
.rc-nav-sub-inner { padding: 4px 0 6px 32px; position: relative; }
.rc-nav-sub-inner::before { content: ""; position: absolute; left: 20px; top: 4px; bottom: 6px; width: 1px; background: var(--border); }
.rc-nav-sub-btn {
  width: 100%; display: flex; align-items: center; gap: 8px; padding: 6px 10px; background: transparent; border: none; border-radius: 6px; cursor: pointer;
  font-family: var(--font-body); font-size: 12px; font-weight: 500; color: var(--fg-4); text-align: left; position: relative;
}
.rc-nav-sub-btn:hover { color: var(--fg-1); background: var(--surface-2); }
.rc-nav-sub-btn.active { color: var(--teal); background: var(--teal-subtle); }
.rc-nav-sub-btn.active::before { content: ""; position: absolute; left: -12px; top: 50%; width: 1px; height: 14px; background: var(--teal); transform: translateY(-50%); }
.rc-nav-sub-btn .dot { width: 5px; height: 5px; border-radius: 50%; background: var(--fg-dim); flex-shrink: 0; }
.rc-nav-sub-btn.active .dot { background: var(--teal); }
.rc-nav-sub-btn .rc-nav-sub-meta { margin-left: auto; font-family: var(--font-mono); font-size: 10px; color: var(--fg-dim); }
.rc-nav-sub-btn.active .rc-nav-sub-meta { color: var(--teal); }

/* collapsed rail: hide labels and subs */
.rc-app[data-nav="rail"] .rc-nav-label,
.rc-app[data-nav="rail"] .rc-nav-chev,
.rc-app[data-nav="rail"] .rc-nav-sub,
.rc-app[data-nav="pinned"] .rc-nav-label,
.rc-app[data-nav="pinned"] .rc-nav-chev,
.rc-app[data-nav="pinned"] .rc-nav-sub { display: none; }
.rc-app[data-nav="rail"] .rc-nav-btn,
.rc-app[data-nav="pinned"] .rc-nav-btn { justify-content: center; padding: 10px 0; }

/* nav footer */
.rc-nav-foot { padding: 12px; border-top: 1px solid var(--shell-rule); }
.rc-app[data-nav="rail"] .rc-nav-foot-item-label,
.rc-app[data-nav="pinned"] .rc-nav-foot-item-label { display: none; }

/* pinned flyout panel */
.rc-flyout { position: fixed; top: 0; left: 64px; bottom: 0; width: 280px; background: var(--shell); border-right: 1px solid var(--border); z-index: 20; transform: translateX(-100%); opacity: 0; pointer-events: none; transition: transform .25s ease, opacity .25s ease; padding: 18px 16px; overflow-y: auto; }
.rc-flyout.open { transform: translateX(0); opacity: 1; pointer-events: auto; box-shadow: 20px 0 50px rgba(0,0,0,0.5); }
.rc-flyout-head { display: flex; align-items: center; gap: 10px; padding-bottom: 12px; border-bottom: 1px solid var(--shell-rule); margin-bottom: 10px; }
.rc-flyout-title { font-family: var(--font-heading); font-weight: 700; font-size: 14px; color: var(--fg-1); }
.rc-flyout-sub { font-size: 11px; color: var(--fg-dim); letter-spacing: 0.06em; text-transform: uppercase; }

/* ================ TOPBAR ================ */
.rc-main { display: flex; flex-direction: column; min-width: 0; min-height: 0; height: 100vh; background: var(--bg); }

.rc-topbar {
  display: flex; align-items: center; gap: 16px;
  padding: 12px 24px; border-bottom: 1px solid var(--border); background: var(--shell-glass); backdrop-filter: blur(10px);
  flex-shrink: 0; z-index: 10;
}
.rc-tb-left { display: flex; align-items: center; gap: 10px; min-width: 0; overflow: hidden; }
.rc-tb-crumbs { display: flex; align-items: center; gap: 8px; font-size: 12px; color: var(--fg-dim); min-width: 0; overflow: hidden; white-space: nowrap; }
.rc-tb-crumbs > span { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.rc-tb-crumbs .c-sep { color: var(--border-strong); }
.rc-tb-crumbs .c-cur { color: var(--fg-1); font-family: var(--font-heading); font-weight: 600; font-size: 13px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

.rc-aichat {
  display: flex; align-items: center; gap: 10px; padding: 8px 14px;
  background: linear-gradient(135deg, rgba(10,191,188,0.07) 0%, rgba(14,165,233,0.05) 100%);
  border: 1px solid var(--teal-soft); border-radius: 10px; min-width: 0; flex: 1;
}
.rc-aichat-icon { width: 26px; height: 26px; border-radius: 7px; background: var(--grad-cta); display: flex; align-items: center; justify-content: center; color: #fff; flex-shrink: 0; box-shadow: 0 0 12px rgba(10,191,188,0.4); }
.rc-aichat-input { flex: 1; background: transparent; border: none; outline: none; color: var(--fg-1); font-family: var(--font-body); font-size: 13px; min-width: 0; }
.rc-aichat-input::placeholder { color: var(--fg-4); }
.rc-aichat-kbd { font-family: var(--font-mono); font-size: 10px; color: var(--fg-dim); padding: 2px 6px; background: var(--surface-2); border: 1px solid var(--border); border-radius: 4px; flex-shrink: 0; }
.rc-aichat-send { width: 26px; height: 26px; display: flex; align-items: center; justify-content: center; background: transparent; border: none; color: var(--teal); cursor: pointer; border-radius: 6px; flex-shrink: 0; }
.rc-aichat-send:hover { background: var(--teal-subtle); }

.rc-tb-right { display: flex; align-items: center; gap: 8px; justify-content: flex-end; }
.rc-iconbtn { width: 34px; height: 34px; display: flex; align-items: center; justify-content: center; background: transparent; border: 1px solid transparent; border-radius: 8px; color: var(--fg-3); cursor: pointer; position: relative; transition: all .15s; }
.rc-iconbtn:hover { background: var(--surface-2); color: var(--fg-1); border-color: var(--border); }
.rc-iconbtn .rc-dot { position: absolute; top: 7px; right: 7px; width: 7px; height: 7px; border-radius: 50%; background: var(--orange); border: 2px solid var(--dot-ring); }
.rc-user-wrap { position: relative; display: flex; align-items: center; }
.rc-tb-user { height: 34px; display: inline-flex; align-items: center; gap: 8px; padding: 3px 8px 3px 3px; background: var(--surface-1); border: 1px solid var(--border); border-radius: 99px; cursor: pointer; color: var(--fg-2); white-space: nowrap; flex-shrink: 0; }
.rc-tb-user:hover { background: var(--surface-2); }
.rc-tb-user .av-img,
.rc-user-menu-head .av-img { width: 28px; height: 28px; border-radius: 50%; background: var(--grad-cta); display: inline-flex; align-items: center; justify-content: center; color: #fff; font-family: var(--font-heading); font-weight: 700; font-size: 11px; line-height: 1; flex: 0 0 28px; }
.rc-tb-user .u-name { display: inline-block; font-family: var(--font-heading); font-size: 12px; line-height: 1; font-weight: 600; color: var(--fg-2); max-width: 110px; overflow: hidden; text-overflow: ellipsis; }
.rc-tb-user svg { width: 14px; height: 14px; flex-shrink: 0; }
.rc-user-menu { position: absolute; right: 0; top: calc(100% + 8px); width: 240px; z-index: 80; padding: 8px; border: 1px solid var(--border); border-radius: 10px; background: var(--card); box-shadow: var(--shadow-lg); }
.rc-user-menu[hidden] { display: none; }
.rc-user-menu-head { display: grid; grid-template-columns: 28px 1fr; gap: 10px; align-items: center; padding: 8px 8px 10px; border-bottom: 1px solid var(--border); margin-bottom: 6px; }
.rc-user-menu-head strong { display: block; color: var(--fg-1); font-family: var(--font-heading); font-size: 13px; line-height: 1.2; }
.rc-user-menu-head span { display: block; color: var(--fg-dim); font-size: 11px; margin-top: 2px; }
.rc-user-menu-item { width: 100%; display: flex; align-items: center; gap: 9px; padding: 9px 10px; border: 1px solid transparent; border-radius: 8px; background: transparent; color: var(--fg-3); font-family: var(--font-heading); font-size: 12px; font-weight: 600; text-align: left; cursor: pointer; }
.rc-user-menu-item:hover { background: var(--surface-2); color: var(--fg-1); border-color: var(--border); }
.rc-user-menu-item.danger { color: var(--danger); }
.rc-user-menu-item svg { width: 15px; height: 15px; flex-shrink: 0; }

/* ================ MAIN CONTENT ================ */
.rc-content { flex: 1; overflow-y: auto; padding: 24px 32px 60px; scrollbar-width: thin; scrollbar-color: var(--border) transparent; }
.rc-content::-webkit-scrollbar { width: 8px; }
.rc-content::-webkit-scrollbar-thumb { background: var(--border); border-radius: 4px; }

.rc-page-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 20px; margin-bottom: 44px; flex-wrap: wrap; }
.rc-page-head-l { min-width: 0; }
.rc-page-eyebrow { font-size: 10px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--fg-dim); display: flex; align-items: center; gap: 8px; margin-bottom: 6px; }
.rc-page-eyebrow::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--teal); }
.rc-page-title { font-family: var(--font-heading); font-size: 24px; font-weight: 700; color: var(--fg-1); margin: 0 0 4px; letter-spacing: -0.015em; }
.rc-page-sub { font-size: 13px; color: var(--fg-3); line-height: 1.55; max-width: 640px; }
.rc-page-head-r { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }

/* ================ UI PRIMITIVES (shared) ================ */
.rc-btn { display: inline-flex; align-items: center; gap: 7px; padding: 9px 14px; border-radius: 8px; font-family: var(--font-heading); font-weight: 600; font-size: 12px; border: 1px solid transparent; cursor: pointer; transition: all .15s; white-space: nowrap; line-height: 1; letter-spacing: 0.01em; }
.rc-btn:focus-visible { box-shadow: var(--focus-ring); outline: none; }
.rc-btn svg { width: 14px; height: 14px; stroke-width: 2; }
.rc-btn-primary { background: var(--orange); color: #fff; box-shadow: var(--shadow-cta); }
.rc-btn-primary:hover { background: var(--orange-dark); transform: translateY(-1px); box-shadow: var(--shadow-cta-h); }
.rc-btn-secondary { background: var(--teal); color: #fff; }
.rc-btn-secondary:hover { background: var(--teal-secondary); }
.rc-btn-ghost { background: var(--surface-2); color: var(--fg-2); border-color: var(--border); }
.rc-btn-ghost:hover { background: var(--surface-3); color: var(--fg-1); border-color: var(--border-strong); }
.rc-btn-gradient { background: var(--grad-cta); color: #fff; }
.rc-btn-gradient:hover { background: var(--grad-cta-hover); }
.rc-btn-sm { padding: 6px 10px; font-size: 11px; }
.rc-btn-sm svg { width: 12px; height: 12px; }
.rc-btn-link { background: transparent; color: var(--teal); padding: 4px 2px; border: none; }
.rc-btn-link:hover { color: var(--teal-secondary); }

.rc-card { background: var(--card); border: 1px solid var(--border); border-radius: 12px; overflow: hidden; }
.rc-card-ghost { background: var(--card-2); }
.rc-card-sunken { background: var(--card-3); }
.rc-card-head { display: flex; align-items: flex-start; gap: 12px; padding: 14px 18px; border-bottom: 1px solid var(--border); }
.rc-card-head.tight { padding: 12px 16px; }
.rc-card-icon { width: 36px; height: 36px; border-radius: 8px; background: var(--teal-subtle); border: 1px solid var(--teal-soft); color: var(--teal); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.rc-card-icon.orange { background: rgba(234,84,40,0.08); border-color: rgba(234,84,40,0.22); color: var(--orange); }
.rc-card-icon.blue { background: rgba(14,165,233,0.10); border-color: rgba(14,165,233,0.25); color: var(--sky); }
.rc-card-icon.amber { background: var(--warning-soft); border-color: var(--warning-strong); color: var(--warning); }
.rc-card-icon.violet { background: var(--violet-soft); border-color: rgba(167,139,250,0.3); color: var(--violet); }
.rc-card-icon.danger { background: var(--danger-soft); border-color: var(--danger-strong); color: var(--danger); }
.rc-card-icon.success { background: var(--success-soft); border-color: var(--success-strong); color: var(--success); }
.rc-card-title { font-family: var(--font-heading); font-size: 14px; font-weight: 700; color: var(--fg-1); line-height: 1.3; margin: 0 0 2px; }
.rc-card-sub { font-size: 12px; color: var(--fg-3); font-weight: 400; margin: 0; line-height: 1.45; }
.rc-card-body { padding: 16px 18px; overflow-x: auto; }
.rc-card-body.tight { padding: 12px 16px; }
.rc-card-foot { padding: 10px 18px; border-top: 1px solid var(--border); background: var(--surface-1); display: flex; align-items: center; justify-content: space-between; gap: 10px; }

.rc-section-grid { display: grid; gap: 18px; }
.rc-section-grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.rc-section-grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.rc-section-tile { cursor: pointer; padding: 24px 16px; min-height: 144px; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; gap: 10px; transition: border-color .15s, transform .15s, background .15s; }
.rc-section-tile:hover { border-color: var(--border-strong); background: var(--card-2); transform: translateY(-1px); }
.rc-section-tile .rc-card-icon { width: 40px; height: 40px; }

.rc-dashboard-grid { display: flex; flex-wrap: wrap; justify-content: center; gap: 18px; margin: 96px auto 0; max-width: 960px; }
.rc-dashboard-grid .rc-section-tile { flex: 0 0 calc((100% - 36px) / 3); min-height: 144px; padding: 24px 16px; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; gap: 10px; }
.rc-dashboard-grid .rc-section-tile h2 { margin: 0; font-family: var(--font-heading); font-weight: 700; font-size: 13px; color: var(--fg-1); }
.rc-dashboard-grid .rc-section-tile p { margin: 0; font-size: 11px; color: var(--fg-3); line-height: 1.5; max-width: 180px; }
.rc-stat-strip { display: flex; align-items: center; justify-content: space-between; background: var(--surface-1); border: 1px solid var(--border); border-radius: 8px; padding: 10px 16px; margin-bottom: 32px; gap: 12px; flex-wrap: wrap; }
.rc-stat-strip-item { display: flex; align-items: center; gap: 8px; min-width: 0; }
.rc-stat-strip-item span { font-size: 11px; color: var(--fg-dim); text-transform: uppercase; letter-spacing: 0.04em; font-weight: 700; }
.rc-stat-strip-item strong { font-family: var(--font-heading); font-weight: 700; font-size: 16px; color: var(--fg-1); }
.rc-stat-strip-item em { font-style: normal; font-size: 11px; color: var(--fg-dim); font-weight: 500; }
.rc-stat-strip > i { width: 1px; height: 22px; background: var(--border); }
.rc-rowline { display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; padding: 10px 0; border-bottom: 1px solid rgba(47,60,78,0.3); }
.rc-rowline.rc-rowline-last { border-bottom: 0; }
.rc-rowline { cursor: default; border-radius: 7px; }
.rc-rowline:hover { background: rgba(255,255,255,0.025); }
.rc-rowline.is-selected { background: var(--teal-subtle); box-shadow: inset 3px 0 0 var(--teal); padding-left: 10px; padding-right: 10px; }
.rc-rowline.is-complete,
.rc-table tr.is-complete { opacity: .56; }
.rc-rowline.is-complete strong,
.rc-table tr.is-complete .tname { text-decoration: line-through; }
.rc-rowline strong { display: block; font-family: var(--font-heading); font-size: 12px; color: var(--fg-1); line-height: 1.4; margin-bottom: 2px; }
.rc-rowline span { display: block; font-size: 11px; color: var(--fg-3); line-height: 1.45; }
.rc-chip-row { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 14px; }
.rc-template-grid, .rc-media-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(120px, 1fr)); gap: 10px; margin-bottom: 14px; }
.rc-template-grid span, .rc-media-grid span { min-height: 94px; border-radius: 10px; border: 1px solid var(--border); background: linear-gradient(135deg, rgba(10,74,92,0.75), rgba(10,191,188,0.52)); color: #fff; display: flex; align-items: flex-end; padding: 10px; font-size: 11px; font-weight: 700; }
.rc-media-grid span { background: var(--surface-1); color: var(--fg-2); min-height: 120px; }
.rc-template-grid span.is-selected,
.rc-media-grid span.is-selected { outline: 2px solid var(--orange); outline-offset: 2px; }
.rc-calendar-toolbar { display: flex; gap: 6px; align-items: center; }
.rc-calendar-weekdays,
.rc-calendar-grid { display: grid; grid-template-columns: repeat(7, minmax(0, 1fr)); gap: 4px; }
.rc-calendar-weekdays { margin-bottom: 6px; color: var(--fg-dim); font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; }
.rc-calendar-weekdays span { padding: 0 6px; }
.rc-calendar-day { min-height: 102px; padding: 7px; background: var(--surface-1); border: 1px solid var(--border); border-radius: 7px; outline: 0; }
.rc-calendar-day:hover,
.rc-calendar-day:focus { border-color: var(--border-strong); background: var(--surface-2); }
.rc-calendar-day.is-outside-month { opacity: .42; }
.rc-calendar-day.is-today { border-color: var(--orange); box-shadow: inset 0 0 0 1px var(--orange); }
.rc-calendar-day.is-selected { background: var(--teal-subtle); border-color: var(--teal); }
.rc-calendar-day.is-drag-over { outline: 2px dashed var(--teal); outline-offset: -4px; background: var(--teal-subtle); }
.rc-calendar-day b { display: block; font-family: var(--font-mono); font-size: 10px; color: var(--fg-dim); margin-bottom: 6px; }
.rc-calendar-events { display: grid; gap: 4px; }
.rc-calendar-event { display: grid; gap: 1px; width: 100%; border: 1px solid var(--border); border-radius: 5px; background: var(--card); color: var(--fg-2); padding: 4px 6px; text-align: left; cursor: grab; }
.rc-calendar-event span,
.rc-calendar-event em { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.rc-calendar-event span { font-size: 10px; font-weight: 700; }
.rc-calendar-event em { font-size: 9px; font-style: normal; color: var(--fg-dim); }
.rc-calendar-event.tone-orange { border-color: rgba(234,84,40,.38); }
.rc-calendar-event.tone-violet { border-color: rgba(139,92,246,.4); }
.rc-calendar-event.tone-sky { border-color: rgba(14,165,233,.42); }
.rc-calendar-event.tone-teal { border-color: rgba(10,191,188,.42); }
.rc-calendar-event.is-selected { border-color: var(--orange); box-shadow: 0 0 0 1px var(--orange); }
.rc-social-preview { background: #000; border-radius: 10px; overflow: hidden; border: 1px solid var(--border); color: #e3e3e5; }
.rc-social-preview > div { padding: 12px; display: flex; flex-direction: column; border-bottom: 1px solid #222; }
.rc-social-preview > div b { color: #fff; font-size: 12px; }
.rc-social-preview > div span { color: #888; font-size: 10px; }
.rc-social-preview section { aspect-ratio: 1; background: linear-gradient(135deg, #0A4A5C, #0ABFBC 60%, #EA5428); display: flex; flex-direction: column; align-items: center; justify-content: center; color: #fff; padding: 20px; text-align: center; }
.rc-social-preview section strong { font-family: var(--font-heading); font-size: 22px; line-height: 1.2; max-width: 280px; }
.rc-social-preview section span { margin-top: 8px; font-size: 12px; opacity: .85; }
.rc-social-preview p { padding: 12px; margin: 0; font-size: 12px; line-height: 1.55; }
.rc-social-preview-actions { display: flex; gap: 6px; margin-top: 12px; }
.rc-social-preview-actions .rc-btn { flex: 1; }
.rc-modal-preview .rc-social-preview { max-width: 360px; margin: 0 auto; }
.rc-media-large { aspect-ratio: 16 / 10; border-radius: 10px; border: 1px solid var(--border); background: linear-gradient(135deg, rgba(10,74,92,0.84), rgba(10,191,188,0.56)); display: flex; align-items: flex-end; padding: 18px; color: #fff; font-family: var(--font-heading); font-weight: 700; }
.rc-draft-box { padding: 16px; background: var(--surface-1); border: 1px solid var(--border); border-radius: 10px; font-size: 13px; color: var(--fg-2); line-height: 1.65; }
.rc-draft-box strong, .rc-draft-box h3, .rc-draft-box h4 { color: var(--fg-1); font-family: var(--font-heading); margin-top: 0; }
.rc-kanban { display: grid; grid-template-columns: repeat(4, minmax(190px, 1fr)); gap: 12px; overflow-x: auto; }
.rc-kanban-col { background: var(--surface-1); border: 1px solid var(--border); border-radius: 10px; padding: 10px; min-width: 190px; }
.rc-kanban-col h3 { margin: 0 0 10px; font-family: var(--font-heading); font-size: 13px; color: var(--fg-1); }
.rc-kanban-card { background: var(--card); border: 1px solid var(--border); border-radius: 8px; padding: 10px; margin-bottom: 8px; }
.rc-kanban-card { cursor: grab; }
.rc-kanban-card:active { cursor: grabbing; }
.rc-kanban-card.is-dragging { opacity: .55; transform: rotate(1deg); }
.rc-kanban-card strong { display: block; font-size: 12px; color: var(--fg-1); line-height: 1.4; margin-bottom: 4px; }
.rc-kanban-card span { display: block; font-size: 10px; color: var(--fg-dim); margin-bottom: 8px; }
.rc-kanban-dropzone { min-height: 96px; border-radius: 8px; }
.rc-kanban-dropzone.is-drag-over { outline: 2px dashed var(--teal); outline-offset: -4px; background: var(--teal-subtle); }
.rc-kanban-add { width: 100%; justify-content: center; margin-top: 4px; }
.rc-section-tile h2 { font-family: var(--font-heading); font-weight: 700; font-size: 13px; color: var(--fg-1); margin: 0; }
.rc-section-tile p { font-size: 11px; color: var(--fg-3); line-height: 1.5; max-width: 210px; margin: 0; }

.rc-simple-stack { display: grid; gap: 18px; }
.rc-page-actions { display: flex; gap: 8px; flex-wrap: wrap; }
.rc-settings-form { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.rc-settings-form .rc-form-grid { display: contents; }
.rc-form-actions { grid-column: 1 / -1; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.rc-settings-form label { display: grid; gap: 5px; }
.rc-settings-form label span { font-family: var(--font-heading); font-size: 12px; color: var(--fg-2); font-weight: 600; }
.rc-settings-form label.full { grid-column: 1 / -1; }
@media (max-width: 760px) {
  .rc-settings-form { grid-template-columns: 1fr; }
}
.rc-ops-page { display: grid; gap: 18px; }
.rc-ops-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 18px;
  align-items: center;
  padding: 20px 22px;
  border-radius: 12px;
  background: var(--surface-1);
  border: 1px solid color-mix(in srgb, var(--border) 55%, transparent);
}
.rc-ops-kicker {
  display: block;
  margin-bottom: 6px;
  font-family: var(--font-heading);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--fg-dim);
}
.rc-ops-hero strong {
  display: block;
  font-family: var(--font-heading);
  font-size: 28px;
  line-height: 1.1;
  color: var(--fg-1);
}
.rc-ops-hero p,
.rc-ops-section-head p,
.rc-ops-checklist p {
  margin: 5px 0 0;
  color: var(--fg-3);
  font-size: 12px;
  line-height: 1.5;
}
.rc-ops-actions { display: flex; gap: 8px; flex-wrap: wrap; justify-content: flex-end; }
.rc-ops-layout { display: grid; grid-template-columns: minmax(0, 1fr) 340px; gap: 18px; align-items: start; }
.rc-ops-panel {
  min-width: 0;
  padding: 18px;
  border-radius: 12px;
  background: var(--card);
  border: 1px solid color-mix(in srgb, var(--border) 55%, transparent);
}
.rc-ops-panel-soft { background: var(--surface-1); border-color: transparent; }
.rc-ops-section-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 16px;
}
.rc-ops-section-head h3 {
  margin: 0;
  font-family: var(--font-heading);
  color: var(--fg-1);
  font-size: 15px;
  line-height: 1.25;
}
.rc-ops-inline-status {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 18px;
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid color-mix(in srgb, var(--border) 45%, transparent);
}
.rc-ops-inline-status span {
  color: var(--fg-3);
  font-size: 11px;
}
.rc-ops-inline-status b {
  color: var(--fg-1);
  font-family: var(--font-heading);
  font-weight: 700;
}
.rc-ops-checklist {
  display: grid;
  gap: 12px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.rc-ops-checklist li {
  display: grid;
  grid-template-columns: 10px minmax(0, 1fr);
  gap: 10px;
  align-items: start;
}
.rc-ops-checklist li > span {
  width: 8px;
  height: 8px;
  margin-top: 5px;
  border-radius: 99px;
  background: var(--success);
}
.rc-ops-checklist li.is-pending > span { background: var(--warning); }
.rc-ops-checklist strong {
  display: block;
  color: var(--fg-1);
  font-family: var(--font-heading);
  font-size: 12px;
}
@media (max-width: 980px) {
  .rc-ops-layout,
  .rc-ops-hero { grid-template-columns: 1fr; }
  .rc-ops-actions { justify-content: flex-start; }
}
.rc-settings-layout { display: grid; grid-template-columns: 260px minmax(0, 1fr); gap: 18px; align-items: start; }
.rc-settings-menu { position: sticky; top: 0; display: grid; gap: 8px; align-self: start; padding: 10px; border: 1px solid var(--border); border-radius: 10px; background: var(--surface-1); }
.rc-settings-company { display: grid; grid-template-columns: 34px 1fr; gap: 10px; align-items: center; padding: 8px 8px 12px; border-bottom: 1px solid var(--border); margin-bottom: 4px; }
.rc-settings-company .rc-ws-avatar { width: 34px; height: 34px; border-radius: 8px; }
.rc-settings-company strong { display: block; color: var(--fg-1); font-family: var(--font-heading); font-size: 13px; line-height: 1.2; }
.rc-settings-company em { display: block; color: var(--fg-dim); font-style: normal; font-size: 10px; text-transform: uppercase; letter-spacing: .06em; margin-top: 3px; }
.rc-settings-menu-btn { display: grid; grid-template-columns: 28px 1fr; gap: 9px; align-items: center; width: 100%; padding: 9px; border: 1px solid transparent; border-radius: 8px; background: transparent; color: var(--fg-3); text-align: left; cursor: pointer; }
.rc-settings-menu-btn:hover { background: var(--surface-2); color: var(--fg-1); }
.rc-settings-menu-btn.active { background: var(--teal-subtle); border-color: var(--teal-soft); color: var(--teal); }
.rc-settings-menu-btn .rc-card-icon { width: 28px; height: 28px; border-radius: 7px; }
.rc-settings-menu-btn span { display: block; color: inherit; font-family: var(--font-heading); font-size: 12px; font-weight: 700; }
.rc-settings-menu-btn em { display: block; grid-column: 2; color: var(--fg-dim); font-style: normal; font-size: 11px; margin-top: -3px; }
.rc-settings-stage { min-width: 0; }
.rc-settings-panel[hidden] { display: none; }
.rc-settings-panel.active { display: block; }
.rc-integration-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
.rc-integration-item { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 10px; align-items: start; padding: 12px; border: 1px solid var(--border); border-radius: 10px; background: var(--surface-1); }
.rc-integration-item strong { display: block; color: var(--fg-1); font-family: var(--font-heading); font-size: 13px; margin-bottom: 4px; }
.rc-integration-item span { display: block; color: var(--fg-3); font-size: 12px; line-height: 1.45; }
.rc-integration-item .rc-btn { grid-column: 1 / -1; justify-content: center; }
.rc-account-avatar-row { display: grid; grid-template-columns: 56px minmax(0, 1fr) auto; gap: 12px; align-items: center; padding: 12px; border: 1px solid var(--border); border-radius: 10px; background: var(--surface-1); }
.rc-account-avatar { width: 56px; height: 56px; border-radius: 50%; background: var(--grad-cta); display: flex; align-items: center; justify-content: center; color: #fff; font-family: var(--font-heading); font-weight: 800; font-size: 17px; }
.rc-account-avatar-row strong { display: block; color: var(--fg-1); font-family: var(--font-heading); font-size: 13px; margin-bottom: 3px; }
.rc-account-avatar-row span { display: block; color: var(--fg-3); font-size: 12px; line-height: 1.45; }
@media (max-width: 1180px) {
  .rc-settings-layout { grid-template-columns: 1fr; }
  .rc-settings-menu { position: static; grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .rc-settings-company { grid-column: 1 / -1; }
}
@media (max-width: 760px) {
  .rc-settings-menu,
  .rc-integration-grid { grid-template-columns: 1fr; }
  .rc-account-avatar-row { grid-template-columns: 56px 1fr; }
  .rc-account-avatar-row .rc-btn { grid-column: 1 / -1; justify-content: center; }
}
/* stat */
.rc-stat { background: var(--card); border: 1px solid var(--border); border-radius: 12px; padding: 14px 16px 14px; position: relative; overflow: hidden; min-height: 108px; }
.rc-stat-label { font-size: 10px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-dim); margin-bottom: 8px; display: flex; align-items: center; gap: 6px; position: relative; z-index: 2; }
.rc-stat-value { font-family: var(--font-heading); font-size: 24px; font-weight: 700; color: var(--fg-1); line-height: 1; letter-spacing: -0.015em; position: relative; z-index: 2; }
.rc-stat-value .unit { font-size: 13px; color: var(--fg-3); font-weight: 400; margin-left: 3px; }
.rc-stat-delta { font-family: var(--font-mono); font-size: 11px; color: var(--success); margin-top: 6px; display: inline-flex; align-items: center; gap: 3px; position: relative; z-index: 2; }
.rc-stat-delta.down { color: var(--danger); }
.rc-stat-delta.flat { color: var(--fg-dim); }
.rc-stat-spark { display: none; }

/* table */
.rc-table-wrap { border-radius: 12px; overflow-x: auto; overflow-y: hidden; border: 1px solid var(--border); background: var(--card); -webkit-overflow-scrolling: touch; }
.rc-table-wrap::-webkit-scrollbar { height: 8px; }
.rc-table-wrap::-webkit-scrollbar-thumb { background: var(--border); border-radius: 4px; }
.rc-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.rc-table th { text-align: left; padding: 10px 14px; font-family: var(--font-heading); font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--fg-dim); background: var(--surface-2); border-bottom: 1px solid var(--border); white-space: nowrap; }
.rc-table td { padding: 11px 14px; border-bottom: 1px solid rgba(47,60,78,0.4); color: var(--fg-2); vertical-align: middle; }
.rc-table tbody tr:last-child td { border-bottom: none; }
.rc-table tbody tr:hover { background: var(--surface-1); }
.rc-table .tname { color: var(--fg-1); font-weight: 600; font-family: var(--font-heading); }
.rc-table .tmuted { color: var(--fg-dim); font-size: 12px; }
.rc-table .num { font-family: var(--font-mono); text-align: right; }

/* badge */
.rc-badge { display: inline-flex; align-items: center; gap: 4px; font-family: var(--font-body); font-size: 10px; font-weight: 700; padding: 2px 8px; border-radius: 20px; letter-spacing: 0.04em; white-space: nowrap; text-transform: uppercase; }
.rc-badge.teal { background: var(--teal-subtle); color: var(--teal); border: 1px solid var(--teal-soft); }
.rc-badge.sky { background: rgba(14,165,233,0.1); color: var(--sky); border: 1px solid rgba(14,165,233,0.25); }
.rc-badge.orange { background: rgba(234,84,40,0.1); color: var(--orange-light); border: 1px solid rgba(234,84,40,0.35); }
.rc-badge.success { background: var(--success-soft); color: var(--success); border: 1px solid var(--success-strong); }
.rc-badge.warn { background: var(--warning-soft); color: var(--warning); border: 1px solid var(--warning-strong); }
.rc-badge.danger { background: var(--danger-soft); color: var(--danger); border: 1px solid var(--danger-strong); }
.rc-badge.violet { background: var(--violet-soft); color: var(--violet); border: 1px solid rgba(167,139,250,0.25); }
.rc-badge.ghost { background: var(--surface-2); color: var(--fg-3); border: 1px solid var(--border); }
.rc-badge .dot { width: 5px; height: 5px; border-radius: 50%; background: currentColor; }

/* progress */
.rc-prog { width: 100%; height: 5px; background: var(--surface-3); border-radius: 99px; overflow: hidden; }
.rc-prog > div { height: 100%; background: var(--teal); border-radius: inherit; transition: width .3s; }
.rc-prog.orange > div { background: var(--orange); }
.rc-prog.sky > div { background: var(--sky); }
.rc-prog.gradient > div { background: var(--grad-cta); }
.rc-prog.success > div { background: var(--success); }
.rc-prog.warn > div { background: var(--warning); }
.rc-prog.danger > div { background: var(--danger); }

/* avatar */
.rc-av { width: 26px; height: 26px; border-radius: 50%; background: var(--violet-soft); color: var(--violet); font-family: var(--font-heading); font-size: 10px; font-weight: 700; display: inline-flex; align-items: center; justify-content: center; border: 1px solid rgba(167,139,250,0.3); flex-shrink: 0; }
.rc-av.t { background: var(--teal-subtle); color: var(--teal); border-color: var(--teal-soft); }
.rc-av.o { background: rgba(234,84,40,0.1); color: var(--orange-light); border-color: rgba(234,84,40,0.3); }
.rc-av.s { background: var(--success-soft); color: var(--success); border-color: var(--success-strong); }
.rc-av.sky { background: rgba(14,165,233,0.1); color: var(--sky); border-color: rgba(14,165,233,0.25); }
.rc-av.lg { width: 36px; height: 36px; font-size: 12px; }
.rc-av-stack { display: inline-flex; }
.rc-av-stack .rc-av { margin-left: -8px; box-shadow: 0 0 0 2px var(--card); }
.rc-av-stack .rc-av:first-child { margin-left: 0; }

/* label-caps */
.rc-label-caps { font-family: var(--font-body); font-size: 10px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-dim); }

/* tabs */
.rc-tabs { display: inline-flex; gap: 2px; background: var(--bg); border: 1px solid var(--border); border-radius: 10px; padding: 4px; flex-wrap: wrap; }
.rc-tab { padding: 7px 12px; border-radius: 7px; font-family: var(--font-heading); font-size: 11px; font-weight: 600; color: var(--fg-3); background: transparent; border: none; cursor: pointer; letter-spacing: 0.02em; white-space: nowrap; }
.rc-tab.active { background: var(--card); color: var(--fg-1); box-shadow: var(--shadow-sm); }
.rc-tab:not(.active):hover { color: var(--fg-2); }

.rc-tabs-u { display: flex; gap: 24px; border-bottom: 1px solid var(--border); margin-bottom: 40px; flex-wrap: wrap; }
.rc-tab-u { padding: 12px 2px; border-bottom: 2px solid transparent; font-family: var(--font-heading); font-size: 12px; font-weight: 600; color: var(--fg-4); background: transparent; border-left: none; border-right: none; border-top: none; cursor: pointer; margin-bottom: -1px; letter-spacing: 0.02em; white-space: nowrap; display: inline-flex; align-items: center; gap: 6px; }
.rc-tab-u.active { color: var(--fg-1); border-bottom-color: var(--teal); }
.rc-tab-u:hover { color: var(--fg-2); }
.rc-tab-u .rc-tab-count { font-family: var(--font-mono); font-size: 10px; background: var(--surface-3); color: var(--fg-3); padding: 1px 6px; border-radius: 99px; font-weight: 500; }
.rc-tab-u.active .rc-tab-count { background: var(--teal-subtle); color: var(--teal); }

/* grid helpers */
.rc-grid { display: grid; gap: 28px; }
.rc-g-2 { grid-template-columns: 1fr 1fr; }
.rc-g-3 { grid-template-columns: repeat(3, 1fr); }
.rc-g-4 { grid-template-columns: repeat(4, 1fr); }
.rc-g-5 { grid-template-columns: repeat(5, 1fr); }
.rc-g-6 { grid-template-columns: repeat(6, 1fr); }

/* divider */
.rc-div { height: 1px; background: rgba(47,60,78,0.4); margin: 14px 0; }

/* callout */
.rc-callout { padding: 12px 16px; background: var(--teal-subtle); border-left: 3px solid var(--teal); border-radius: 6px; font-size: 12px; color: var(--fg-2); line-height: 1.55; display: flex; gap: 10px; align-items: flex-start; }
.rc-callout.orange { background: rgba(234,84,40,0.06); border-color: var(--orange); }
.rc-callout.warn { background: var(--warning-soft); border-color: var(--warning); }
.rc-callout.success { background: var(--success-soft); border-color: var(--success); }
.rc-callout b { color: var(--fg-1); font-weight: 700; }
.rc-callout svg { flex-shrink: 0; color: inherit; margin-top: 2px; }
.rc-callout.teal svg, .rc-callout svg { color: var(--teal); }
.rc-callout.orange svg { color: var(--orange); }
.rc-callout.warn svg { color: var(--warning); }
.rc-callout.success svg { color: var(--success); }

/* ================ notification panel ================ */
.rc-notif {
  position: absolute; top: 56px; right: 24px; width: 380px; background: #0f1828; border: 1px solid var(--border); border-radius: 12px;
  box-shadow: var(--shadow-lg); z-index: 50; overflow: hidden; max-height: 520px; display: flex; flex-direction: column;
}
.rc-notif-head { display: flex; align-items: center; justify-content: space-between; padding: 12px 16px; border-bottom: 1px solid var(--border); }
.rc-notif-title { font-family: var(--font-heading); font-weight: 700; font-size: 13px; color: var(--fg-1); }
.rc-notif-summary { font-size: 11px; color: var(--fg-dim); }
.rc-notif-actions { display: flex; gap: 4px; align-items: center; }
.rc-notif-body { overflow-y: auto; padding: 6px 6px; flex: 1; }
.rc-notif-foot { padding: 10px; border-top: 1px solid var(--border); text-align: center; }
.rc-notif-settings { width: 100%; justify-content: center; }
.rc-notif[hidden] { display: none; }
.rc-notif-item { width: 100%; border: 0; background: transparent; text-align: left; display: flex; gap: 10px; padding: 10px 12px; border-radius: 8px; cursor: pointer; transition: background .15s; }
.rc-notif-item:hover { background: var(--surface-2); }
.rc-notif-item.unread { background: rgba(10,191,188,0.04); }
.rc-notif-item .n-icon { width: 30px; height: 30px; border-radius: 8px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.rc-notif-item .n-icon svg { width: 14px; height: 14px; }
.rc-notif-item .n-body { flex: 1; min-width: 0; }
.rc-notif-item .n-title,
.rc-notif-item .n-sub,
.rc-notif-item .n-time { display: block; }
.rc-notif-item .n-title { font-family: var(--font-heading); font-weight: 600; font-size: 12px; color: var(--fg-1); line-height: 1.4; margin-bottom: 2px; }
.rc-notif-item .n-sub { font-size: 11px; color: var(--fg-3); line-height: 1.45; }
.rc-notif-item .n-time { font-size: 10px; color: var(--fg-dim); margin-top: 4px; font-family: var(--font-mono); }
.rc-notif-pref-grid { display: grid; gap: 8px; }
.rc-notif-pref-row { display: grid; grid-template-columns: minmax(220px, 1fr) repeat(3, 86px); gap: 10px; align-items: center; padding: 10px 0; border-bottom: 1px solid rgba(47,60,78,0.3); }
.rc-notif-pref-row:last-child { border-bottom: 0; }
.rc-notif-pref-row.head { color: var(--fg-dim); font-size: 10px; text-transform: uppercase; letter-spacing: .08em; font-weight: 700; }
.rc-notif-pref-row strong { display: block; color: var(--fg-1); font-family: var(--font-heading); font-size: 12px; margin-bottom: 2px; }
.rc-notif-pref-row span { color: var(--fg-3); font-size: 11px; line-height: 1.4; }
@media (max-width: 760px) {
  .rc-notif { right: 12px; left: 12px; width: auto; }
  .rc-notif-pref-row { grid-template-columns: 1fr; }
  .rc-notif-pref-row.head { display: none; }
}

/* sparkline/chart helpers */
.rc-sparkline { width: 100%; height: 100%; }
.rc-chart-card { padding: 18px 20px; }
.rc-chart-head { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 14px; gap: 14px; flex-wrap: wrap; }
.rc-chart-h-l .rc-label-caps { margin-bottom: 4px; }
.rc-chart-value { font-family: var(--font-heading); font-size: 26px; font-weight: 700; color: var(--fg-1); letter-spacing: -0.015em; line-height: 1; }
.rc-chart-value .unit { font-size: 13px; color: var(--fg-3); font-weight: 400; margin-left: 3px; }

/* keyword pill */
.rc-kpill { display: inline-flex; align-items: center; gap: 6px; padding: 4px 10px; border-radius: 99px; background: var(--surface-2); border: 1px solid var(--border); font-size: 11px; color: var(--fg-2); font-family: var(--font-mono); }
.rc-kpill.won { background: var(--success-soft); color: var(--success); border-color: var(--success-strong); }
.rc-kpill.lost { background: var(--danger-soft); color: var(--danger); border-color: var(--danger-strong); }

/* empty-state placeholder boxes */
.rc-placeholder { background: repeating-linear-gradient(135deg, rgba(47,60,78,0.2), rgba(47,60,78,0.2) 10px, transparent 10px, transparent 20px); border: 1px dashed var(--border); border-radius: 10px; display: flex; flex-direction: column; align-items: center; justify-content: center; color: var(--fg-dim); padding: 24px; font-size: 12px; gap: 6px; }
.rc-placeholder[hidden],
[hidden] { display: none !important; }

/* scrollbar utility */
.rc-scroll { overflow-y: auto; scrollbar-width: thin; scrollbar-color: var(--border) transparent; }
.rc-scroll::-webkit-scrollbar { width: 6px; }
.rc-scroll::-webkit-scrollbar-thumb { background: var(--border); border-radius: 3px; }

/* input */
.rc-input { width: 100%; padding: 9px 12px; background: var(--bg); border: 1px solid var(--border); border-radius: 8px; color: var(--fg-1); font-size: 13px; font-family: var(--font-body); outline: none; transition: border-color .15s, box-shadow .15s; }
.rc-input:focus { border-color: var(--teal); box-shadow: var(--focus-ring); }
.rc-input::placeholder { color: var(--fg-dim); }
.rc-textarea { min-height: 80px; resize: vertical; line-height: 1.55; }
.rc-select { appearance: none; background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%235a7a9a' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>"); background-repeat: no-repeat; background-position: right 12px center; padding-right: 32px; cursor: pointer; }
.rc-label { display: block; font-family: var(--font-heading); font-size: 12px; font-weight: 600; color: var(--fg-2); margin-bottom: 5px; }
.rc-form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.rc-form-grid .full-width { grid-column: 1 / -1; }
.rc-field { display: grid; gap: 5px; }
.rc-field span { font-family: var(--font-heading); font-size: 12px; color: var(--fg-2); font-weight: 600; }
.rc-dialog { width: min(720px, calc(100vw - 32px)); border: 0; padding: 0; border-radius: 12px; background: var(--card); color: var(--fg-2); box-shadow: var(--shadow-lg); }
.rc-dialog::backdrop { background: rgba(4, 12, 20, .58); }
.rc-dialog-panel { margin: 0; }
.rc-config-layout { display: grid; grid-template-columns: minmax(0, 1fr) minmax(300px, 360px); gap: 14px; align-items: start; }
.rc-config-layout > .rc-card:nth-child(1),
.rc-config-layout > .rc-card:nth-child(2) { grid-column: 1; }
.rc-config-layout > .rc-card:nth-child(3) { grid-column: 2; grid-row: 1; }
.rc-config-layout > aside { grid-column: 2; grid-row: 2; position: sticky; top: 18px; }
.rc-capability-row { width: 100%; border: 0; text-align: left; background: transparent; cursor: pointer; }
.rc-capability-row:hover { background: var(--surface-2); }
@media (max-width: 760px) {
  .rc-form-grid { grid-template-columns: 1fr; }
}

/* switch */
.rc-switch { position: relative; display: inline-flex; width: 36px; height: 20px; border-radius: 12px; background: rgba(47,60,78,0.8); cursor: pointer; border: none; vertical-align: middle; transition: background .2s; flex-shrink: 0; }
.rc-switch.on { background: var(--teal); }
.rc-switch .knob { position: absolute; top: 2px; left: 2px; width: 16px; height: 16px; border-radius: 50%; background: #fff; box-shadow: var(--shadow-sm); transition: transform .2s; }
.rc-switch.on .knob { transform: translateX(16px); }

/* check */
.rc-check { display: inline-flex; align-items: center; gap: 8px; cursor: pointer; user-select: none; font-size: 12px; color: var(--fg-2); }
.rc-check .box { width: 16px; height: 16px; border-radius: 4px; border: 1.5px solid var(--border-strong); background: var(--bg); display: inline-flex; align-items: center; justify-content: center; transition: all .15s; flex-shrink: 0; }
.rc-check.on .box { background: var(--teal); border-color: var(--teal); }
.rc-check.on .box::after { content: ""; width: 8px; height: 5px; border-left: 2px solid #fff; border-bottom: 2px solid #fff; transform: rotate(-45deg) translate(1px,-1px); }

/* command/hotkey hint */
.rc-hotkey { font-family: var(--font-mono); font-size: 10px; color: var(--fg-dim); padding: 2px 6px; background: var(--surface-2); border: 1px solid var(--border); border-radius: 4px; }

/* focus rings on inputs + buttons */
button:focus-visible, a:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible { outline: none; box-shadow: var(--focus-ring); }

/* interactive prototype layer */
.rc-modal-root { position: fixed; inset: 0; z-index: 1000; display: grid; place-items: center; padding: 24px; opacity: 0; pointer-events: none; transition: opacity .15s ease; }
.rc-modal-root.show { opacity: 1; pointer-events: auto; }
.rc-modal-backdrop { position: absolute; inset: 0; background: rgba(3,7,12,.72); backdrop-filter: blur(8px); }
.rc-modal { position: relative; width: min(620px, 100%); max-height: min(760px, calc(100vh - 48px)); overflow: auto; background: var(--card); border: 1px solid var(--border-strong); border-radius: 12px; box-shadow: 0 30px 90px rgba(0,0,0,.45); transform: translateY(8px); transition: transform .15s ease; }
.rc-modal-root.show .rc-modal { transform: translateY(0); }
.rc-modal-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 16px; padding: 16px 18px; border-bottom: 1px solid var(--border); }
.rc-modal-head h2 { margin: 0 0 4px; font-family: var(--font-heading); color: var(--fg-1); font-size: 18px; }
.rc-modal-head p { margin: 0; color: var(--fg-3); font-size: 12px; line-height: 1.5; }
.rc-modal-head .rc-iconbtn { font-size: 18px; line-height: 1; }
.rc-modal-body { padding: 18px; }
.rc-modal-foot { padding: 12px 18px; border-top: 1px solid var(--border); display: flex; justify-content: flex-end; gap: 8px; background: var(--surface-1); }
.rc-modal-form { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.rc-modal-form label { display: grid; gap: 5px; }
.rc-modal-form label.full { grid-column: 1 / -1; }
.rc-modal-form label span { font-family: var(--font-heading); font-size: 12px; color: var(--fg-2); font-weight: 600; }
.rc-modal-summary { display: grid; gap: 8px; }
.rc-modal-summary > div { display: flex; justify-content: space-between; gap: 14px; padding: 10px 12px; border: 1px solid var(--border); border-radius: 8px; background: var(--surface-1); }
.rc-modal-summary span { color: var(--fg-dim); font-size: 11px; text-transform: uppercase; letter-spacing: .06em; }
.rc-modal-summary strong { color: var(--fg-1); text-align: right; font-size: 12px; }
.rc-toast-root { position: fixed; right: 20px; bottom: 20px; z-index: 1200; display: grid; gap: 8px; }
.rc-toast { transform: translateY(8px); opacity: 0; transition: all .18s ease; padding: 10px 12px; border-radius: 8px; background: var(--card); border: 1px solid var(--border); color: var(--fg-1); box-shadow: var(--shadow-lg); font-size: 12px; }
.rc-toast.show { transform: translateY(0); opacity: 1; }
.rc-toast.teal { border-color: var(--teal-soft); color: var(--teal); }
.rc-toast.danger { border-color: var(--danger-strong); color: var(--danger); }
.rc-worker-error { padding: 14px 16px; border-color: var(--danger-strong); background: var(--danger-soft); color: var(--fg-1); }
.rc-worker-error strong { display: block; color: var(--danger); font-size: 13px; margin-bottom: 4px; }
.rc-worker-error p { margin: 0; color: var(--fg-2); font-size: 13px; line-height: 1.45; }
.rc-audio-mock { display: grid; grid-template-columns: 1fr auto auto auto; gap: 10px; align-items: center; padding: 14px; border: 1px solid var(--border); border-radius: 10px; background: var(--surface-1); }
.rc-audio-mock > div { height: 6px; border-radius: 99px; background: linear-gradient(90deg, var(--teal) 0 42%, var(--surface-3) 42%); }
.rc-audio-mock span { color: var(--fg-dim); font-family: var(--font-mono); font-size: 11px; }
.rc-contact-list-head { align-items: flex-end; gap: 16px; }
.rc-card-head-main { display: flex; align-items: center; gap: 12px; min-width: 0; flex: 1; }
.rc-contact-actions { display: flex; align-items: flex-end; gap: 10px; flex-wrap: wrap; justify-content: flex-end; }
.rc-contact-search { display: grid; gap: 5px; width: min(360px, 42vw); min-width: 260px; }
.rc-contact-search span { color: var(--fg-dim); font-size: 10px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.rc-contact-search .rc-input { height: 34px; padding: 7px 10px; }
.rc-contact-table tbody tr { cursor: pointer; }
.rc-contact-table tbody tr.active { background: var(--teal-subtle); box-shadow: inset 3px 0 0 var(--teal); }
.rc-contact-table td span { display: block; color: var(--fg-dim); font-size: 11px; margin-top: 2px; }
.rc-contact-workspace { display: grid; grid-template-columns: minmax(320px, 420px) minmax(0, 1fr); gap: 14px; margin-top: 14px; align-items: start; }
.rc-contact-hero { display: flex; gap: 12px; align-items: center; margin-bottom: 14px; }
.rc-contact-hero h2 { margin: 0 0 3px; font-family: var(--font-heading); color: var(--fg-1); font-size: 20px; }
.rc-contact-hero p { margin: 0; color: var(--fg-3); font-size: 12px; }
.rc-contact-value { padding: 13px 14px; border-radius: 10px; background: var(--teal-subtle); color: var(--teal); font-family: var(--font-heading); font-weight: 700; font-size: 18px; margin-bottom: 14px; }
.rc-contact-value span { display: block; color: var(--fg-3); font-family: var(--font-body); font-size: 11px; font-weight: 500; margin-top: 3px; }
.rc-contact-fields { display: grid; gap: 8px; margin-bottom: 14px; }
.rc-contact-fields > div { padding: 10px 12px; border: 1px solid var(--border); border-radius: 8px; background: var(--surface-1); }
.rc-contact-fields span { display: block; color: var(--fg-dim); font-size: 10px; text-transform: uppercase; letter-spacing: .08em; font-weight: 700; margin-bottom: 4px; }
.rc-contact-fields strong { color: var(--fg-1); font-size: 12px; line-height: 1.4; }
.rc-contact-tags { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 14px; }
.rc-contact-tags span { padding: 3px 8px; border-radius: 99px; border: 1px solid var(--border); background: var(--surface-2); color: var(--fg-3); font-size: 10px; text-transform: uppercase; letter-spacing: .05em; font-weight: 700; }
.rc-comm-timeline { display: grid; gap: 10px; }
.rc-comm-item { width: 100%; border: 1px solid var(--border); background: var(--surface-1); border-radius: 10px; padding: 12px; display: grid; grid-template-columns: 38px 1fr; gap: 12px; text-align: left; cursor: pointer; }
.rc-comm-item:hover { border-color: var(--border-strong); background: var(--surface-2); }
.rc-comm-icon { width: 38px; height: 38px; border-radius: 10px; display: flex; align-items: center; justify-content: center; background: var(--teal-subtle); color: var(--teal); font-family: var(--font-heading); font-size: 11px; font-weight: 700; }
.rc-comm-item.call .rc-comm-icon { background: rgba(234,84,40,0.1); color: var(--orange); }
.rc-comm-item.email .rc-comm-icon { background: rgba(14,165,233,0.1); color: var(--sky); }
.rc-comm-item.sms .rc-comm-icon { background: var(--success-soft); color: var(--success); }
.rc-comm-item.note .rc-comm-icon { background: var(--surface-3); color: var(--fg-2); }
.rc-comm-body, .rc-comm-body > span { display: block; min-width: 0; }
.rc-comm-top { display: flex !important; align-items: baseline; justify-content: space-between; gap: 12px; margin-bottom: 4px; }
.rc-comm-top strong { color: var(--fg-1); font-family: var(--font-heading); font-size: 13px; }
.rc-comm-top em { color: var(--fg-dim); font-style: normal; font-family: var(--font-mono); font-size: 10px; white-space: nowrap; }
.rc-comm-body > span:not(.rc-comm-top) { color: var(--fg-3); font-size: 12px; line-height: 1.5; }
.rc-comm-body small { display: block; color: var(--fg-dim); font-size: 10px; font-family: var(--font-mono); margin-top: 6px; }
@media (max-width: 1100px) {
  .rc-contact-workspace { grid-template-columns: 1fr; }
  .rc-contact-list-head { align-items: stretch; }
  .rc-card-head-main,
  .rc-contact-actions,
  .rc-contact-search { width: 100%; }
  .rc-contact-actions { justify-content: flex-start; }
}

.rc-table td > span { display: block; color: var(--fg-dim); font-size: 11px; margin-top: 3px; line-height: 1.4; }
.rc-table td > small { display: block; color: var(--fg-dim); font-family: var(--font-mono); font-size: 10px; margin-top: 3px; }
.rc-project-detail { display: grid; grid-template-columns: minmax(0, 1fr) minmax(300px, 360px); gap: 14px; align-items: start; }
.rc-project-board-layout { display: grid; grid-template-columns: 260px minmax(0, 1fr); gap: 28px; align-items: start; }
.rc-project-board-sidebar { padding: 14px; }
.rc-project-board-sidebar .rc-rowline { width: 100%; border-top: 0; border-left: 0; border-right: 0; background: transparent; color: inherit; text-align: left; cursor: pointer; }
.rc-project-board-sidebar .rc-rowline:last-child { border-bottom: 0; }
.rc-project-manager-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 28px; }
.rc-project-manager-grid .rc-rowline { width: 100%; border-top: 0; border-left: 0; border-right: 0; background: transparent; color: inherit; text-align: left; }
.rc-productivity-approvals-grid { display: grid; grid-template-columns: minmax(0, 2fr) minmax(280px, 1fr); gap: 28px; align-items: start; }
.rc-productivity-approvals-grid .rc-rowline { width: 100%; border-top: 0; border-left: 0; border-right: 0; background: transparent; color: inherit; text-align: left; }
.rc-project-detail > .rc-card:nth-child(2),
.rc-project-detail > .rc-card:nth-child(3) { grid-column: 1; }
.rc-project-detail > aside { grid-column: 2; grid-row: 1 / span 3; }
.rc-project-fields { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
.rc-project-fields > div { min-width: 0; padding: 12px; border: 1px solid var(--border); border-radius: 8px; background: var(--surface-1); }
.rc-project-fields > div:last-child { grid-column: 1 / -1; }
.rc-project-fields span { display: block; color: var(--fg-dim); font-size: 10px; text-transform: uppercase; letter-spacing: .08em; font-weight: 700; margin-bottom: 5px; }
.rc-project-fields strong { display: block; color: var(--fg-1); font-size: 13px; line-height: 1.45; }
.rc-project-fields em { display: block; margin-top: 4px; color: var(--fg-3); font-style: normal; font-size: 11px; line-height: 1.4; }
.rc-project-media-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; }
.rc-project-media { position: relative; min-height: 150px; border: 1px solid var(--border); border-radius: 10px; padding: 12px; overflow: hidden; text-align: left; cursor: pointer; background: linear-gradient(135deg, rgba(16,185,129,.22), rgba(14,165,233,.14)); display: flex; flex-direction: column; justify-content: flex-end; gap: 4px; }
.rc-project-media.video { background: linear-gradient(135deg, rgba(234,84,40,.22), rgba(14,165,233,.16)); }
.rc-project-media:hover { border-color: var(--border-strong); transform: translateY(-1px); }
.rc-project-media::before { content: ""; position: absolute; inset: 0; background: repeating-linear-gradient(45deg, rgba(255,255,255,.08), rgba(255,255,255,.08) 8px, transparent 8px, transparent 16px); opacity: .35; }
.rc-project-media span,
.rc-project-media strong,
.rc-project-media em,
.rc-project-media i { position: relative; z-index: 1; }
.rc-project-media span { align-self: flex-start; padding: 3px 7px; border-radius: 99px; background: rgba(0,0,0,.32); color: #fff; font-family: var(--font-mono); font-size: 10px; }
.rc-project-media strong { color: var(--fg-1); font-family: var(--font-heading); font-size: 13px; }
.rc-project-media em { color: var(--fg-2); font-style: normal; font-size: 11px; line-height: 1.35; }
.rc-project-media i { position: absolute; top: 10px; right: 12px; color: rgba(255,255,255,.45); font-family: var(--font-heading); font-style: normal; font-size: 26px; font-weight: 800; }
.rc-project-timeline { display: grid; gap: 10px; }
.rc-project-event { position: relative; display: grid; grid-template-columns: 94px 160px minmax(0, 1fr); gap: 12px; align-items: start; width: 100%; border: 1px solid var(--border); background: var(--surface-1); border-radius: 10px; padding: 12px; text-align: left; cursor: pointer; }
.rc-project-event:hover { border-color: var(--border-strong); background: var(--surface-2); }
.rc-project-event span { color: var(--fg-dim); font-family: var(--font-mono); font-size: 10px; }
.rc-project-event strong { color: var(--fg-1); font-family: var(--font-heading); font-size: 13px; }
.rc-project-event em { color: var(--fg-3); font-style: normal; font-size: 12px; line-height: 1.45; }

/* Quiet dense work surfaces for contractor-facing pages. */
.rc-contact-workspace > .rc-card,
.rc-project-detail > .rc-card,
.rc-project-detail > aside > .rc-card {
  border-color: transparent;
  background: var(--surface-1);
}
.rc-contact-workspace .rc-card-head,
.rc-project-detail .rc-card-head {
  border-bottom-color: transparent;
  padding-bottom: 8px;
}
.rc-contact-workspace .rc-card-body,
.rc-project-detail .rc-card-body {
  padding-top: 8px;
}
.rc-contact-fields { gap: 0; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.rc-contact-fields > div {
  border: 0;
  border-bottom: 1px solid color-mix(in srgb, var(--border) 65%, transparent);
  border-radius: 0;
  background: transparent;
  padding: 11px 0;
}
.rc-contact-fields > div:last-child { border-bottom: 0; }
.rc-contact-value {
  border-radius: 8px;
  background: color-mix(in srgb, var(--teal-subtle) 70%, transparent);
}
.rc-contact-tags span {
  border-color: transparent;
  background: var(--surface-1);
}
.rc-contact-workspace .rc-draft-box,
.rc-project-detail .rc-draft-box {
  border-color: transparent;
  background: var(--surface-1);
}
.rc-comm-timeline { gap: 4px; }
.rc-comm-item {
  border: 0;
  border-radius: 8px;
  background: transparent;
  padding: 10px 8px;
}
.rc-comm-item:hover {
  background: var(--surface-2);
}
.rc-comm-icon {
  width: 32px;
  height: 32px;
  border-radius: 8px;
}
.rc-project-fields { gap: 0; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.rc-project-fields > div {
  border: 0;
  border-bottom: 1px solid color-mix(in srgb, var(--border) 65%, transparent);
  border-radius: 0;
  background: transparent;
  padding: 12px 0;
}
.rc-project-fields > div:last-child,
.rc-project-fields > div:nth-last-child(2):nth-child(odd) { border-bottom: 0; }
.rc-project-event {
  border: 0;
  border-radius: 8px;
  background: transparent;
  padding: 10px 8px;
}
.rc-project-event:hover {
  background: var(--surface-2);
}
.rc-kanban {
  gap: 14px;
}
.rc-kanban-col {
  border: 0;
  background: var(--surface-1);
  border-radius: 12px;
  padding: 12px;
}
.rc-kanban-col h3 {
  margin-bottom: 12px;
  color: var(--fg-2);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.rc-kanban-card {
  border: 0;
  background: var(--card);
  border-radius: 10px;
  padding: 12px;
  margin-bottom: 10px;
  box-shadow: var(--shadow-sm);
}
.rc-kanban-card .rc-badge,
.rc-kanban-card > .rc-badge {
  margin-top: 2px;
}
.rc-kanban-add {
  border-color: transparent;
  background: transparent;
  color: var(--fg-dim);
}
.rc-kanban-add:hover {
  background: var(--surface-2);
  color: var(--fg-2);
  border-color: transparent;
}
.rc-rowline {
  border-bottom-color: color-mix(in srgb, var(--border) 55%, transparent);
}
.rc-table td {
  border-bottom-color: color-mix(in srgb, var(--border) 55%, transparent);
}
.rc-call-detail { display: grid; grid-template-columns: 340px minmax(0, 1fr); gap: 14px; align-items: start; }
.rc-call-detail > .rc-card:nth-child(3) { grid-column: 2; }
.rc-call-detail > aside { grid-row: 1 / span 2; }
.rc-transcript { display: grid; gap: 10px; margin-top: 14px; padding: 4px 0; }
.rc-transcript p { margin: 0; padding: 10px 0; border-bottom: 1px solid color-mix(in srgb, var(--border) 55%, transparent); color: var(--fg-2); font-size: 13px; line-height: 1.6; }
.rc-transcript p:last-child { border-bottom: 0; }
.rc-transcript strong { color: var(--fg-1); font-family: var(--font-heading); }
.rc-faq-editor { display: grid; grid-template-columns: 300px minmax(0, 1fr); gap: 14px; align-items: start; }
.rc-editor-toolbar { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 12px; padding-bottom: 10px; border-bottom: 1px solid var(--border); }
.rc-wysiwyg { min-height: 520px; padding: 22px; border-radius: 10px; background: var(--surface-1); color: var(--fg-2); line-height: 1.7; outline: none; }
.rc-wysiwyg:focus { box-shadow: var(--focus-ring); }
.rc-wysiwyg h2,
.rc-wysiwyg h3 { color: var(--fg-1); font-family: var(--font-heading); margin: 0 0 12px; }
.rc-wysiwyg h3 { margin-top: 22px; }
.rc-wysiwyg p,
.rc-wysiwyg ul { margin: 0 0 14px; }
.rc-skill-workspace { display: grid; grid-template-columns: minmax(260px, 360px) minmax(0, 1fr); gap: 14px; align-items: start; }
.rc-skill-tree-panel { position: sticky; top: 18px; max-height: calc(100vh - 60px); overflow: hidden; }
.rc-skill-tree-panel .rc-card-body { max-height: calc(100vh - 170px); overflow: auto; }
.rc-skill-tree { display: grid; gap: 12px; margin-top: 14px; }
.rc-skill-category { display: grid; gap: 4px; }
.rc-skill-category-label { font-family: var(--font-heading); font-size: 11px; font-weight: 700; color: var(--fg-3); text-transform: uppercase; letter-spacing: .06em; padding: 8px 8px 3px; }
.rc-skill-node { display: grid; gap: 2px; }
.rc-skill-tree-item { width: 100%; min-height: 36px; display: grid; grid-template-columns: 16px minmax(0, 1fr) auto auto; align-items: center; gap: 7px; padding: 7px 8px 7px calc(8px + (var(--skill-depth, 0) * 18px)); border: 0; border-radius: 8px; background: transparent; color: var(--fg-2); text-align: left; cursor: pointer; }
.rc-skill-tree-item:hover,
.rc-skill-tree-item.active { background: var(--surface-2); color: var(--fg-1); }
.rc-skill-tree-item.is-template { opacity: .9; }
.rc-skill-branch { color: var(--fg-3); font-family: var(--font-mono); }
.rc-skill-name { min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-weight: 700; }
.rc-skill-key { max-width: 110px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--fg-3); font-size: 11px; font-family: var(--font-mono); }
.rc-skill-children { display: grid; gap: 2px; }
.rc-skill-editor-card .rc-card-head { align-items: flex-start; }
.rc-skill-empty-state { min-height: 420px; display: grid; place-items: center; align-content: center; gap: 10px; text-align: center; color: var(--fg-2); }
.rc-skill-empty-state strong { color: var(--fg-1); font-family: var(--font-heading); font-size: 18px; }
.rc-skill-empty-state span { max-width: 440px; }
.rc-skill-form { display: grid; gap: 18px; }
.rc-skill-feedback { padding: 10px 12px; border-radius: 8px; border: 1px solid var(--border); background: var(--surface-2); color: var(--fg-2); }
.rc-skill-feedback[data-type="error"] { border-color: var(--danger-strong); background: var(--danger-soft); color: var(--danger); }
.rc-skill-feedback[data-type="info"] { border-color: var(--teal-strong); background: var(--teal-soft); color: var(--teal); }
.rc-skill-prompt-section { display: grid; gap: 10px; }
.rc-skill-editor-head { display: flex; justify-content: space-between; gap: 16px; align-items: flex-end; }
.rc-skill-wysiwyg { min-height: 460px; white-space: pre-wrap; border: 1px solid var(--border); }
.rc-chat-panel { max-width: 980px; margin: 0 auto; }
.rc-chat-thread { display: grid; gap: 12px; min-height: 360px; max-height: 58vh; overflow-y: auto; padding: 4px; scrollbar-width: thin; scrollbar-color: var(--border) transparent; }
.rc-chat-message { max-width: 760px; padding: 14px 16px; border: 1px solid transparent; border-radius: 10px; background: var(--surface-1); box-shadow: var(--shadow-sm); }
.rc-chat-message.assistant { justify-self: start; }
.rc-chat-message.user { justify-self: end; background: var(--teal-subtle); border-color: var(--teal-soft); }
.rc-chat-message.danger { border-color: var(--danger-strong); background: var(--danger-soft); }
.rc-chat-message strong { display: block; margin-bottom: 6px; color: var(--fg-1); font-family: var(--font-heading); font-size: 12px; }
.rc-chat-message p { margin: 0; color: var(--fg-2); font-size: 13px; line-height: 1.6; white-space: pre-wrap; }
.rc-chat-message span { display: block; margin-top: 8px; color: var(--fg-dim); font-size: 11px; }
.rc-chat-message span:empty { display: none; }
.rc-chat-form { display: grid; gap: 12px; margin-top: 18px; padding-top: 18px; border-top: 1px solid var(--border); }
.rc-chat-form textarea:disabled { opacity: .72; cursor: wait; }
@media (max-width: 1180px) {
  .rc-project-detail, .rc-project-board-layout, .rc-project-manager-grid, .rc-productivity-approvals-grid { grid-template-columns: 1fr; }
  .rc-project-detail > aside,
  .rc-project-detail > .rc-card:nth-child(2),
  .rc-project-detail > .rc-card:nth-child(3) { grid-column: 1; grid-row: auto; }
  .rc-project-media-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .rc-call-detail,
  .rc-faq-editor,
  .rc-skill-workspace,
  .rc-config-layout { grid-template-columns: 1fr; }
  .rc-config-layout > .rc-card:nth-child(1),
  .rc-config-layout > .rc-card:nth-child(2),
  .rc-config-layout > .rc-card:nth-child(3),
  .rc-config-layout > aside { grid-column: 1; grid-row: auto; position: static; }
  .rc-skill-tree-panel { position: static; max-height: none; }
  .rc-skill-tree-panel .rc-card-body { max-height: none; }
  .rc-call-detail > .rc-card:nth-child(3),
  .rc-call-detail > aside { grid-column: 1; grid-row: auto; }
}
@media (max-width: 760px) {
  .rc-project-fields,
  .rc-project-media-grid,
  .rc-project-event { grid-template-columns: 1fr; }
}

/* ================ RESPONSIVE DESKTOP LAYOUT HELPERS ================ */
/* Three-column: fixed-left, flex-middle, fixed-right.
   Below 1280px the right panel reflows under the left+middle row.
   Below 1100px everything stacks. */
.rc-split-3 {
  display: grid;
  grid-template-columns: minmax(0, var(--rc-l, 320px)) minmax(0, 1fr) minmax(0, var(--rc-r, 340px));
  gap: 14px;
}
.rc-split-3 > * { min-width: 0; }
@media (max-width: 1280px) {
  .rc-split-3 { grid-template-columns: minmax(0, var(--rc-l, 320px)) minmax(0, 1fr); }
  .rc-split-3 > :nth-child(3) { grid-column: 1 / -1; }
}
@media (max-width: 1100px) {
  .rc-split-3 { grid-template-columns: minmax(0, 1fr); }
  .rc-split-3 > * { grid-column: 1 / -1; }
}

/* Two-column with fixed left. Stacks below 1100px. */
.rc-split-2-l {
  display: grid;
  grid-template-columns: minmax(0, var(--rc-l, 320px)) minmax(0, 1fr);
  gap: 14px;
}
.rc-split-2-l > * { min-width: 0; }
@media (max-width: 1100px) {
  .rc-split-2-l { grid-template-columns: minmax(0, 1fr); }
}

/* Two-column with fixed right. Stacks below 1100px. */
.rc-split-2-r {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, var(--rc-r, 340px));
  gap: 14px;
}
.rc-split-2-r > * { min-width: 0; }
@media (max-width: 1100px) {
  .rc-split-2-r { grid-template-columns: minmax(0, 1fr); }
}

/* Stat grids: auto-fit at narrower desktop widths so labels don't crush. */
@media (max-width: 1340px) {
  .rc-g-5 { grid-template-columns: repeat(auto-fit, minmax(170px, 1fr)); }
}
@media (max-width: 1180px) {
  .rc-g-4 { grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); }
  .rc-g-3 { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }
}

/* Slightly tighter content padding on smaller desktops for breathing room. */
@media (max-width: 1280px) {
  .rc-content { padding: 22px 24px 60px; }
}
@media (max-width: 1100px) {
  .rc-content { padding: 18px 18px 60px; }
}
