/* =====================================================================
   Cogswell Customer Portal — production stylesheet
   Source of truth: Cogswell Kundenportal SPA design system
   PART 1: SPA tokens, layout, components (verbatim)
   PART 2: Perfex compatibility shims (Bootstrap 3 + Tailwind classes
            mapped to the SPA tokens)
   PART 3: Auth (login/register/forgot/reset) split-screen + MFA
   ===================================================================== */

:root {
  /* Light theme tokens */
  --bg: #FAFAFA;
  --bg-elev: #FFFFFF;
  --surface: #FFFFFF;
  --surface-soft: #F4F4F5;
  --hairline: rgba(15, 15, 20, 0.07);
  --hairline-strong: rgba(15, 15, 20, 0.12);
  --text: #0F0F14;
  --text-muted: #5A5C66;
  --text-faint: #9A9CA6;
  --accent: oklch(0.66 0.16 220);
  --accent-strong: oklch(0.55 0.18 220);
  --accent-soft: oklch(0.95 0.04 220);
  --coral: oklch(0.72 0.16 35);
  --green: oklch(0.7 0.14 155);
  --amber: oklch(0.78 0.15 75);
  --red: oklch(0.65 0.2 25);
  --violet: oklch(0.65 0.18 290);
  --shadow-sm: 0 1px 2px rgba(15,15,20,0.04), 0 0 0 1px rgba(15,15,20,0.04);
  --shadow-md: 0 4px 12px -4px rgba(15,15,20,0.08), 0 1px 3px rgba(15,15,20,0.04), 0 0 0 1px rgba(15,15,20,0.05);
  --shadow-lg: 0 24px 48px -16px rgba(15,15,20,0.18), 0 8px 16px -8px rgba(15,15,20,0.08), 0 0 0 1px rgba(15,15,20,0.05);
  --top-highlight: inset 0 1px 0 rgba(255,255,255,1);
  --glass-bg: rgba(255,255,255,0.72);
  --glass-border: rgba(15,15,20,0.08);
  --aurora-1: oklch(0.85 0.12 220);
  --aurora-2: oklch(0.88 0.1 290);
  --aurora-3: oklch(0.9 0.08 35);
  --easing: cubic-bezier(0.16, 1, 0.3, 1);
  color-scheme: light;
}

[data-theme="dark"] {
  --bg: #0B0B0F;
  --bg-elev: #101015;
  --surface: #15151B;
  --surface-soft: #1B1B23;
  --hairline: rgba(255,255,255,0.07);
  --hairline-strong: rgba(255,255,255,0.14);
  --text: #F4F4F7;
  --text-muted: #9A9CA6;
  --text-faint: #5A5C66;
  --accent: oklch(0.78 0.15 220);
  --accent-strong: oklch(0.85 0.16 220);
  --accent-soft: oklch(0.32 0.08 220);
  --coral: oklch(0.78 0.16 35);
  --green: oklch(0.78 0.14 155);
  --amber: oklch(0.85 0.15 75);
  --red: oklch(0.72 0.2 25);
  --violet: oklch(0.78 0.15 290);
  --shadow-sm: 0 1px 2px rgba(0,0,0,0.4), 0 0 0 1px rgba(255,255,255,0.04);
  --shadow-md: 0 4px 12px -4px rgba(0,0,0,0.5), 0 1px 3px rgba(0,0,0,0.4), 0 0 0 1px rgba(255,255,255,0.05);
  --shadow-lg: 0 24px 48px -16px rgba(0,0,0,0.6), 0 8px 16px -8px rgba(0,0,0,0.4), 0 0 0 1px rgba(255,255,255,0.06);
  --top-highlight: inset 0 1px 0 rgba(255,255,255,0.08);
  --glass-bg: rgba(15,15,20,0.6);
  --glass-border: rgba(255,255,255,0.08);
  --aurora-1: oklch(0.55 0.2 220);
  --aurora-2: oklch(0.5 0.22 290);
  --aurora-3: oklch(0.6 0.18 200);
  color-scheme: dark;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'SF Pro Display', system-ui, sans-serif;
  background: var(--bg);
  color: var(--text);
  font-size: 15px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  font-feature-settings: 'cv11', 'ss01', 'ss03';
  transition: background-color 360ms var(--easing), color 360ms var(--easing);
  min-height: 100vh;
}
.tnum { font-variant-numeric: tabular-nums; }
.mono { font-family: 'JetBrains Mono', monospace; font-size: 12px; letter-spacing: 0; }

a { color: var(--accent-strong); text-decoration: none; transition: color 200ms var(--easing); }
a:hover { color: var(--accent); }

/* ── Layout: Sidebar + Main ── */
.app { display: grid; grid-template-columns: 248px 1fr; min-height: 100vh; }

/* Sidebar */
.sidebar {
  position: sticky; top: 0; height: 100vh;
  border-right: 1px solid var(--hairline);
  padding: 24px 16px;
  display: flex; flex-direction: column; gap: 4px;
  background: var(--bg);
  transition: background-color 360ms var(--easing), border-color 360ms var(--easing);
}
.brand { display: flex; align-items: center; gap: 10px; padding: 4px 10px 24px; }
.brand-mark {
  width: 32px; height: 32px; border-radius: 9px;
  display: grid; place-items: center;
  background-color: rgba(26,183,255,0.08);
  border: 1px solid rgba(26,183,255,0.25);
  box-shadow: 0 0 20px rgba(26,183,255,0.30);
  background-image: url('assets/themes/perfex/img/cogswell-mark.png');
  background-size: 22px;
  background-position: center;
  background-repeat: no-repeat;
  transition: transform 400ms var(--easing);
}
.brand:hover .brand-mark { transform: rotate(8deg) scale(1.08); }
.brand-name { font-weight: 600; font-size: 15px; letter-spacing: -0.01em; }
.brand-sub { font-size: 11px; color: var(--text-faint); margin-top: -2px; letter-spacing: 0.04em; text-transform: uppercase; }

.nav-label { font-size: 11px; color: var(--text-faint); font-weight: 500; padding: 16px 12px 6px; letter-spacing: 0.06em; text-transform: uppercase; }
.nav-item {
  display: flex; align-items: center; gap: 12px;
  padding: 9px 12px; border-radius: 10px;
  color: var(--text-muted); font-size: 14px; font-weight: 500;
  cursor: pointer; user-select: none;
  transition: all 200ms var(--easing);
  position: relative;
  text-decoration: none;
  overflow: hidden;
}
.nav-item:hover { background: var(--surface-soft); color: var(--text); }
.nav-item.active {
  background: var(--surface);
  color: var(--text);
  box-shadow: var(--shadow-sm);
}
.nav-item.active::before {
  content: ''; position: absolute; left: -16px; top: 50%; transform: translateY(-50%);
  width: 3px; height: 18px; border-radius: 2px; background: var(--accent);
}
.nav-item .ic { width: 18px; height: 18px; flex-shrink: 0; opacity: 0.85; }
.nav-item .badge { margin-left: auto; font-size: 11px; padding: 2px 7px; border-radius: 999px; background: var(--surface-soft); color: var(--text-muted); font-weight: 600; }
.nav-item.active .badge { background: var(--accent-soft); color: var(--accent-strong); }
.nav-item::after { content:''; position: absolute; left: 50%; top: 50%; width: 0; height: 0; border-radius: 50%; background: color-mix(in oklab, var(--accent) 20%, transparent); transform: translate(-50%,-50%); transition: width 400ms var(--easing), height 400ms var(--easing); pointer-events: none; }
.nav-item:active::after { width: 200%; height: 200%; transition: width 0s, height 0s; }

.sidebar-foot { margin-top: auto; padding-top: 16px; border-top: 1px solid var(--hairline); }
.user-card { display: flex; align-items: center; gap: 10px; padding: 8px 10px; border-radius: 12px; cursor: pointer; transition: background 200ms var(--easing); text-decoration: none; color: inherit; }
.user-card:hover { background: var(--surface-soft); }
.avatar { width: 32px; height: 32px; border-radius: 50%; background: linear-gradient(135deg, var(--accent), var(--violet)); display: grid; place-items: center; color: white; font-weight: 600; font-size: 12px; flex-shrink: 0; transition: transform 300ms var(--easing); }
.avatar:hover { transform: scale(1.08) rotate(-4deg); }
.user-name { font-size: 13px; font-weight: 600; line-height: 1.2; }
.user-role { font-size: 11px; color: var(--text-faint); }

/* Main */
.main { min-width: 0; }
.topbar {
  position: sticky; top: 0; z-index: 50;
  display: flex; align-items: center; gap: 16px;
  padding: 14px 32px;
  background: var(--glass-bg);
  backdrop-filter: blur(20px) saturate(1.4);
  -webkit-backdrop-filter: blur(20px) saturate(1.4);
  border-bottom: 1px solid var(--glass-border);
  transition: background-color 360ms var(--easing), border-color 360ms var(--easing);
  animation: barIn 700ms var(--easing) 0.1s backwards;
}
@keyframes barIn { from { opacity: 0; transform: translateY(-12px);} to { opacity: 1; transform: translateY(0);} }

.crumb { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--text-muted); }
.crumb b { color: var(--text); font-weight: 500; }
.crumb svg { opacity: 0.5; }

.search {
  flex: 1; max-width: 480px; margin-left: auto;
  display: flex; align-items: center; gap: 10px;
  padding: 8px 14px;
  background: var(--surface-soft);
  border: 1px solid transparent;
  border-radius: 12px;
  transition: all 200ms var(--easing);
  cursor: text;
}
.search:hover, .search:focus-within { border-color: var(--hairline-strong); background: var(--surface); }
.search input { flex: 1; background: transparent; border: 0; outline: 0; font: inherit; color: var(--text); font-size: 13px; }
.search input::placeholder { color: var(--text-faint); }
.kbd {
  display: inline-flex; align-items: center; gap: 2px;
  font-family: 'JetBrains Mono', monospace; font-size: 11px;
  padding: 2px 6px; border-radius: 5px;
  background: var(--bg-elev); color: var(--text-muted);
  border: 1px solid var(--hairline); box-shadow: 0 1px 0 var(--hairline);
}

.icon-btn {
  width: 36px; height: 36px; border-radius: 10px;
  display: grid; place-items: center;
  background: transparent; border: 1px solid transparent;
  color: var(--text-muted); cursor: pointer;
  transition: all 200ms var(--easing);
}
.icon-btn:hover { background: var(--surface-soft); color: var(--text); border-color: var(--hairline); }

.theme-toggle {
  width: 64px; height: 32px; border-radius: 999px;
  background: var(--surface-soft); border: 1px solid var(--hairline);
  position: relative; cursor: pointer; padding: 3px;
  transition: all 360ms var(--easing);
}
.theme-toggle .knob {
  position: absolute; top: 3px; left: 3px;
  width: 24px; height: 24px; border-radius: 50%;
  background: var(--bg-elev);
  box-shadow: 0 2px 6px rgba(0,0,0,0.15), inset 0 1px 0 rgba(255,255,255,0.5);
  transition: transform 360ms var(--easing), background 360ms var(--easing);
  display: grid; place-items: center;
}
[data-theme="dark"] .theme-toggle .knob { transform: translateX(32px); }
.theme-toggle .knob svg { transition: opacity 280ms var(--easing), transform 360ms var(--easing); }
.theme-toggle .knob .moon { position: absolute; opacity: 0; transform: rotate(-90deg); }
[data-theme="dark"] .theme-toggle .knob .sun { opacity: 0; transform: rotate(90deg); }
[data-theme="dark"] .theme-toggle .knob .moon { opacity: 1; transform: rotate(0); }

/* Content */
.content { padding: 32px 40px 80px; max-width: 1440px; }

/* Hero */
.hero {
  position: relative; overflow: hidden;
  border-radius: 28px; padding: 40px 44px;
  background: var(--surface);
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--hairline);
  margin-bottom: 28px;
}
.hero .aurora {
  position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(60% 80% at 10% 20%, var(--aurora-1) 0%, transparent 60%),
    radial-gradient(50% 70% at 90% 30%, var(--aurora-2) 0%, transparent 60%),
    radial-gradient(40% 60% at 70% 90%, var(--aurora-3) 0%, transparent 60%);
  opacity: 0.55;
  filter: blur(40px);
  animation: aurora 18s ease-in-out infinite alternate;
}
[data-theme="dark"] .hero .aurora { opacity: 0.35; }
@keyframes aurora {
  0% { transform: translate(0,0) scale(1); }
  50% { transform: translate(-3%, 2%) scale(1.08); }
  100% { transform: translate(2%, -2%) scale(0.96); }
}
.hero-grid { position: relative; display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 48px; align-items: end; }
.hello-eyebrow { display: inline-flex; align-items: center; gap: 8px; font-size: 12px; color: var(--text-muted); padding: 6px 12px; background: var(--surface-soft); border-radius: 999px; border: 1px solid var(--hairline); margin-bottom: 18px; }
.hello-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--green); animation: livePulse 1.8s ease-in-out infinite; }
@keyframes livePulse { 0%,100%{ box-shadow: 0 0 0 0 color-mix(in oklab, var(--green) 35%, transparent);} 50%{ box-shadow: 0 0 0 6px transparent;} }
.hero h1 { font-size: 56px; line-height: 1.02; letter-spacing: -0.04em; font-weight: 700; margin: 0 0 8px; }
.hero h1 .wave { display: inline-block; transform-origin: 70% 70%; animation: wave 2.6s ease-in-out infinite; }
@keyframes wave { 0%,60%,100%{transform:rotate(0)} 10%{transform:rotate(14deg)} 20%{transform:rotate(-8deg)} 30%{transform:rotate(14deg)} 40%{transform:rotate(-4deg)} 50%{transform:rotate(10deg)} }
.hero-sub { font-size: 17px; color: var(--text-muted); max-width: 520px; }
.hero-actions { display: flex; gap: 10px; margin-top: 24px; }

/* Buttons */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 18px; border-radius: 12px;
  font: inherit; font-size: 14px; font-weight: 500;
  border: 1px solid transparent; cursor: pointer;
  transition: transform 200ms var(--easing), box-shadow 200ms var(--easing), background 200ms var(--easing), color 200ms var(--easing);
  white-space: nowrap;
  text-decoration: none;
}
.btn-primary { background: var(--text); color: var(--bg); position: relative; overflow: hidden; }
.btn-primary:hover { transform: translateY(-1px); box-shadow: 0 8px 20px -8px rgba(0,0,0,0.3); color: var(--bg); }
.btn-primary::before { content:''; position: absolute; inset: 0; background: linear-gradient(115deg, transparent 30%, rgba(255,255,255,0.25) 50%, transparent 70%); transform: translateX(-100%); transition: transform 600ms var(--easing); }
.btn-primary:hover::before { transform: translateX(100%); }
.btn-secondary { background: var(--surface); color: var(--text); border-color: var(--hairline-strong); box-shadow: var(--shadow-sm); }
.btn-secondary:hover { transform: translateY(-1px); box-shadow: var(--shadow-md); color: var(--text); }
.btn-ghost { background: transparent; color: var(--text-muted); }
.btn-ghost:hover { background: var(--surface-soft); color: var(--text); }

/* Hero KPI */
.hero-kpi { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.kpi-tile {
  background: color-mix(in oklab, var(--surface) 70%, transparent);
  backdrop-filter: blur(12px);
  border: 1px solid var(--hairline);
  border-radius: 18px; padding: 18px 18px 16px;
  position: relative; overflow: hidden;
  animation: tileIn 700ms var(--easing) backwards;
  transition: transform 300ms var(--easing), box-shadow 300ms, border-color 300ms;
}
.kpi-tile:nth-child(1) { animation-delay: 0.2s; }
.kpi-tile:nth-child(2) { animation-delay: 0.3s; }
.kpi-tile:nth-child(3) { animation-delay: 0.4s; }
.kpi-tile:nth-child(4) { animation-delay: 0.5s; }
@keyframes tileIn { from { opacity: 0; transform: translateY(16px) scale(0.96);} to { opacity: 1; transform: translateY(0) scale(1);} }
.kpi-tile:hover { transform: translateY(-3px); box-shadow: 0 16px 32px -12px rgba(26,183,255,0.25); border-color: color-mix(in oklab, var(--accent) 40%, var(--hairline)); }
.kpi-label { font-size: 11px; color: var(--text-muted); letter-spacing: 0.06em; text-transform: uppercase; font-weight: 600; }
.kpi-value { font-size: 30px; font-weight: 700; letter-spacing: -0.025em; margin-top: 6px; line-height: 1.1; }
.kpi-meta { font-size: 12px; color: var(--text-faint); margin-top: 4px; display: flex; align-items: center; gap: 6px; }
.spark { position: absolute; right: 12px; bottom: 12px; opacity: 0.7; }
.delta-up { color: var(--green); font-weight: 600; }
.delta-down { color: var(--red); font-weight: 600; }

/* Grids */
.row { display: grid; gap: 20px; margin-bottom: 20px; }
.row-2 { grid-template-columns: 1.4fr 1fr; }
.row-3 { grid-template-columns: repeat(3, 1fr); }
.row-4 { grid-template-columns: repeat(4, 1fr); }

.card {
  background: var(--surface);
  border: 1px solid var(--hairline);
  border-radius: 20px;
  padding: 22px 24px;
  box-shadow: var(--shadow-sm);
  transition: transform 240ms var(--easing), box-shadow 240ms var(--easing), border-color 240ms var(--easing);
}
.card.hoverable { position: relative; }
.card.hoverable:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.card.hoverable::before { content:''; position: absolute; inset: 0; border-radius: 20px; padding: 1px; background: linear-gradient(135deg, color-mix(in oklab, var(--accent) 50%, transparent), transparent 60%); -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0); -webkit-mask-composite: xor; mask-composite: exclude; opacity: 0; transition: opacity 300ms var(--easing); pointer-events: none; }
.card.hoverable:hover::before { opacity: 1; }
.card-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.card-title { font-size: 13px; font-weight: 600; color: var(--text); letter-spacing: -0.005em; }
.card-eyebrow { font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--text-faint); font-weight: 600; }
.card-link { font-size: 12px; color: var(--accent-strong); cursor: pointer; }
.card-link:hover { text-decoration: underline; }

/* Status pills */
.pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 3px 10px; border-radius: 999px;
  font-size: 11px; font-weight: 600; letter-spacing: 0.02em;
  text-transform: uppercase;
}
.pill-dot { width: 5px; height: 5px; border-radius: 50%; }
.pill.green { background: color-mix(in oklab, var(--green) 14%, transparent); color: var(--green); }
.pill.green .pill-dot { background: var(--green); }
.pill.amber { background: color-mix(in oklab, var(--amber) 14%, transparent); color: var(--amber); }
.pill.amber .pill-dot { background: var(--amber); }
.pill.red { background: color-mix(in oklab, var(--red) 14%, transparent); color: var(--red); }
.pill.red .pill-dot { background: var(--red); }
.pill.blue { background: color-mix(in oklab, var(--accent) 14%, transparent); color: var(--accent-strong); }
.pill.blue .pill-dot { background: var(--accent); }
.pill.violet { background: color-mix(in oklab, var(--violet) 14%, transparent); color: var(--violet); }
.pill.violet .pill-dot { background: var(--violet); }
.pill.coral { background: color-mix(in oklab, var(--coral) 14%, transparent); color: var(--coral); }
.pill.coral .pill-dot { background: var(--coral); }

/* Project list */
.proj-row { display: grid; grid-template-columns: 1.2fr 0.8fr 0.6fr 0.4fr; gap: 16px; align-items: center; padding: 14px 0; border-bottom: 1px solid var(--hairline); }
.proj-row:last-child { border-bottom: 0; }
.proj-name { font-weight: 600; font-size: 14px; }
.proj-sub { font-size: 12px; color: var(--text-faint); margin-top: 2px; }
.progress { height: 6px; border-radius: 999px; background: var(--surface-soft); overflow: hidden; position: relative; }
.progress > span { display: block; height: 100%; background: linear-gradient(90deg, var(--accent-strong), var(--accent)); border-radius: 999px; transform-origin: left; animation: progIn 1s var(--easing) both; position: relative; }
@keyframes progIn { from { transform: scaleX(0);} to { transform: scaleX(1);} }
.progress > span::after { content:''; position: absolute; inset: 0; background: linear-gradient(90deg, transparent, rgba(255,255,255,0.4), transparent); transform: translateX(-100%); animation: progShine 2.4s ease-in-out infinite; }
@keyframes progShine { 0%{transform:translateX(-100%);} 60%,100%{transform:translateX(200%);} }
.progress-label { font-size: 12px; color: var(--text-muted); text-align: right; margin-top: 4px; }
.team { display: flex; }
.team .avatar-sm { width: 26px; height: 26px; font-size: 10px; border-radius: 50%; border: 2px solid var(--surface); margin-left: -6px; display: grid; place-items: center; color: white; font-weight: 600; }
.team .avatar-sm:first-child { margin-left: 0; }

/* Chart */
.chart-wrap { padding: 8px 0 0; height: 240px; position: relative; }
svg.chart { width: 100%; height: 100%; overflow: visible; }
.chart text { fill: var(--text-faint); font-size: 10px; font-family: inherit; }
.chart .grid line { stroke: var(--hairline); }
.bar { transition: opacity 200ms var(--easing); cursor: pointer; }
.bar:hover { opacity: 0.85; }
.line-area { fill: url(#areaGrad); }
.line-stroke { fill: none; stroke: var(--accent); stroke-width: 2.2; }
.dot { fill: var(--bg-elev); stroke: var(--accent); stroke-width: 2; }

/* Activity / tickets */
.list-item { display: grid; grid-template-columns: auto 1fr auto; gap: 14px; padding: 14px 0; align-items: start; border-bottom: 1px solid var(--hairline); }
.list-item:last-child { border-bottom: 0; }
.list-icon { width: 34px; height: 34px; border-radius: 10px; background: var(--surface-soft); display: grid; place-items: center; color: var(--text-muted); flex-shrink: 0; }
.list-title { font-weight: 600; font-size: 14px; }
.list-meta { font-size: 12px; color: var(--text-faint); margin-top: 2px; display: flex; gap: 10px; align-items: center; }
.list-meta .dot { width: 3px; height: 3px; border-radius: 50%; background: currentColor; opacity: 0.5; }
.list-aside { font-size: 12px; color: var(--text-faint); white-space: nowrap; }

/* Tabs */
.tabs { display: inline-flex; padding: 4px; background: var(--surface-soft); border: 1px solid var(--hairline); border-radius: 12px; gap: 2px; margin-bottom: 20px; flex-wrap: wrap; }
.tab { padding: 7px 14px; border-radius: 9px; font-size: 13px; font-weight: 500; color: var(--text-muted); cursor: pointer; transition: all 200ms var(--easing); display: inline-flex; align-items: center; gap: 8px; text-decoration: none; }
.tab:hover { color: var(--text); }
.tab.active { background: var(--surface); color: var(--text); box-shadow: var(--shadow-sm); }
.tab .count { font-size: 11px; padding: 1px 7px; border-radius: 999px; background: var(--bg); color: var(--text-muted); font-weight: 600; }
.tab.active .count { background: var(--accent-soft); color: var(--accent-strong); }

/* Page header */
.page-head { display: flex; align-items: end; justify-content: space-between; margin-bottom: 24px; gap: 20px; flex-wrap: wrap; }
.page-title { font-size: 40px; font-weight: 700; letter-spacing: -0.03em; line-height: 1.05; margin: 0 0 6px; }
.page-sub { font-size: 15px; color: var(--text-muted); }

/* Tables */
.tbl { width: 100%; border-collapse: collapse; }
.tbl th { font-size: 11px; text-transform: uppercase; letter-spacing: 0.06em; font-weight: 600; color: var(--text-faint); text-align: left; padding: 12px 16px; border-bottom: 1px solid var(--hairline); }
.tbl th.right { text-align: right; }
.tbl td { padding: 16px; border-bottom: 1px solid var(--hairline); font-size: 14px; }
.tbl tbody tr { transition: background 180ms var(--easing); }
.tbl tbody tr:hover { background: var(--surface-soft); }
.tbl td.right { text-align: right; }
.tbl td.num { font-variant-numeric: tabular-nums; font-weight: 600; }
.tbl .row-id { font-family: 'JetBrains Mono', monospace; font-size: 12px; color: var(--text-muted); }

/* Project cards page */
.proj-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; }
.pcard { padding: 22px 24px; }
.pcard-head { display: flex; align-items: start; justify-content: space-between; margin-bottom: 18px; }
.pcard-title { font-size: 18px; font-weight: 600; letter-spacing: -0.015em; }
.pcard-id { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-faint); margin-top: 4px; }
.pcard-meta { display: grid; grid-template-columns: 1fr 1fr; gap: 14px 20px; margin-bottom: 18px; }
.pcard-meta-label { font-size: 11px; color: var(--text-faint); letter-spacing: 0.05em; text-transform: uppercase; font-weight: 600; }
.pcard-meta-value { font-size: 15px; font-weight: 600; margin-top: 3px; font-variant-numeric: tabular-nums; }

/* Profile / forms */
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.field { display: flex; flex-direction: column; gap: 6px; }
.field label { font-size: 12px; color: var(--text-muted); font-weight: 500; }
.field input, .field select, .field textarea {
  padding: 10px 14px; border-radius: 10px;
  border: 1px solid var(--hairline-strong);
  background: var(--bg-elev); color: var(--text);
  font: inherit; font-size: 14px;
  transition: border-color 200ms var(--easing), box-shadow 200ms var(--easing);
}
.field input:focus, .field select:focus, .field textarea:focus { outline: 0; border-color: var(--accent); box-shadow: 0 0 0 3px color-mix(in oklab, var(--accent) 18%, transparent); }
.colspan-2 { grid-column: span 2; }

/* Toggle switch */
.switch { width: 38px; height: 22px; border-radius: 999px; background: var(--surface-soft); border: 1px solid var(--hairline-strong); position: relative; cursor: pointer; transition: all 220ms var(--easing); }
.switch::after { content:''; position: absolute; top: 2px; left: 2px; width: 16px; height: 16px; border-radius: 50%; background: var(--bg-elev); box-shadow: 0 1px 2px rgba(0,0,0,0.15); transition: transform 220ms var(--easing); }
.switch.on { background: var(--accent); border-color: var(--accent); }
.switch.on::after { transform: translateX(16px); background: white; }

/* Reveal */
.reveal { opacity: 0; transform: translateY(8px); animation: revealIn 600ms var(--easing) forwards; }
@keyframes revealIn { to { opacity: 1; transform: translateY(0);} }

/* Calendar mini */
.cal { display: grid; grid-template-columns: repeat(7, 1fr); gap: 6px; font-variant-numeric: tabular-nums; }
.cal .h { font-size: 10px; color: var(--text-faint); text-align: center; padding: 4px 0; font-weight: 600; }
.cal .d { aspect-ratio: 1/1; display: grid; place-items: center; font-size: 12px; border-radius: 8px; color: var(--text-muted); cursor: pointer; transition: background 160ms var(--easing); position: relative; }
.cal .d:hover { background: var(--surface-soft); color: var(--text); }
.cal .d.today { background: var(--text); color: var(--bg); font-weight: 600; }
.cal .d.has-event::after { content: ''; position: absolute; bottom: 4px; left: 50%; transform: translateX(-50%); width: 4px; height: 4px; border-radius: 50%; background: var(--accent); }
.cal .d.today.has-event::after { background: var(--bg); }

/* Skeleton */
.skel { background: linear-gradient(90deg, var(--surface-soft) 0%, color-mix(in oklab, var(--surface-soft) 60%, var(--surface)) 50%, var(--surface-soft) 100%); background-size: 200% 100%; animation: shim 1.4s linear infinite; border-radius: 8px; }
@keyframes shim { 0%{background-position: 100% 0;} 100%{background-position: -100% 0;} }

/* Sidebar entry animation */
.sidebar { animation: sideIn 700ms var(--easing) 0.05s backwards; }
@keyframes sideIn { from { opacity: 0; transform: translateX(-16px);} to { opacity: 1; transform: translateX(0);} }

@media (max-width: 1100px) {
  .row-2, .row-3, .row-4, .proj-grid { grid-template-columns: 1fr; }
  .hero-grid { grid-template-columns: 1fr; }
  .app { grid-template-columns: 72px 1fr; }
  .sidebar { padding: 24px 12px; }
  .nav-item span:not(.badge), .brand-name, .brand-sub, .user-name, .user-role { display: none; }
  .nav-item { justify-content: center; }
  .nav-item .badge { display: none; }
  .nav-item.active::before { display: none; }
  .content { padding: 24px 20px 60px; }
  .hero { padding: 28px; }
  .hero h1 { font-size: 40px; }
}

/* =====================================================================
   PART 2 — Perfex compatibility shims
   Maps Bootstrap 3 / Tailwind classes used by existing Perfex views
   onto the new design system.
   ===================================================================== */

body.customers { background: var(--bg); color: var(--text); }
body.customers a { color: var(--accent-strong); }
body.customers a:hover { color: var(--accent); }
body.customers hr { border: none; border-top: 1px solid var(--hairline); margin: 24px 0; }

body.customers .text-muted   { color: var(--text-muted) !important; }
body.customers .text-info    { color: var(--accent-strong) !important; }
body.customers .text-success { color: var(--green) !important; }
body.customers .text-warning { color: var(--amber) !important; }
body.customers .text-danger  { color: var(--red) !important; }

/* Perfex panel_s ≈ .card */
body.customers .panel_s,
body.customers .panel,
body.customers .panel-default {
  background: var(--surface);
  border: 1px solid var(--hairline);
  border-radius: 20px;
  box-shadow: var(--shadow-sm);
  color: var(--text);
}
body.customers .panel_s .panel-heading,
body.customers .panel .panel-heading {
  background: transparent;
  border-bottom: 1px solid var(--hairline);
  color: var(--text);
  font-weight: 600;
  padding: 16px 24px;
  letter-spacing: -0.01em;
}
body.customers .panel-body { color: var(--text); padding: 22px 24px; }
body.customers .panel-footer {
  background: transparent;
  border-top: 1px solid var(--hairline);
  color: var(--text-muted);
  border-radius: 0 0 20px 20px;
  padding: 14px 24px;
  font-size: 13px;
}

/* Perfex form-control */
body.customers label,
body.customers .control-label {
  color: var(--text-muted);
  font-weight: 500;
  font-size: 12px;
  display: block; margin-bottom: 6px;
}
body.customers .form-control {
  background: var(--bg-elev);
  border: 1px solid var(--hairline-strong);
  color: var(--text);
  border-radius: 10px;
  height: 42px; padding: 10px 14px;
  font-size: 14px; font-family: inherit;
  outline: none;
  transition: border-color 200ms var(--easing), box-shadow 200ms var(--easing);
  width: 100%;
}
body.customers .form-control::placeholder { color: var(--text-faint); }
body.customers .form-control:focus { border-color: var(--accent); box-shadow: 0 0 0 3px color-mix(in oklab, var(--accent) 18%, transparent); }
body.customers textarea.form-control { height: auto; min-height: 110px; resize: vertical; }
body.customers .has-error .form-control { border-color: var(--red); }
body.customers .has-error .help-block,
body.customers .has-error .control-label { color: var(--red); }
body.customers .input-group-addon { background: var(--surface-soft); border: 1px solid var(--hairline-strong); color: var(--text); }

/* Perfex .btn family */
body.customers .btn {
  border-radius: 12px;
  font-weight: 500; font-size: 14px;
  padding: 10px 18px;
  border: 1px solid transparent;
  display: inline-flex; align-items: center; gap: 8px; justify-content: center;
}
body.customers .btn-primary { background: var(--text); color: var(--bg); }
body.customers .btn-primary:hover, body.customers .btn-primary:focus {
  transform: translateY(-1px); box-shadow: 0 8px 20px -8px rgba(0,0,0,0.3); color: var(--bg);
}
body.customers .btn-default {
  background: var(--surface) !important;
  color: var(--text) !important;
  border: 1px solid var(--hairline-strong) !important;
  box-shadow: var(--shadow-sm) !important;
  height: auto;
}
body.customers .btn-default:hover { transform: translateY(-1px); box-shadow: var(--shadow-md) !important; }
body.customers .btn-info    { background: color-mix(in oklab, var(--accent) 14%, transparent); color: var(--accent-strong); border-color: color-mix(in oklab, var(--accent) 30%, transparent); }
body.customers .btn-success { background: color-mix(in oklab, var(--green) 14%, transparent); color: var(--green); border-color: color-mix(in oklab, var(--green) 30%, transparent); }
body.customers .btn-danger  { background: color-mix(in oklab, var(--red) 14%, transparent); color: var(--red); border-color: color-mix(in oklab, var(--red) 30%, transparent); }
body.customers .btn-warning { background: color-mix(in oklab, var(--amber) 14%, transparent); color: var(--amber); border-color: color-mix(in oklab, var(--amber) 30%, transparent); }

/* Tables */
body.customers .table { color: var(--text); border-color: var(--hairline); }
body.customers .table > thead > tr > th {
  border-bottom: 1px solid var(--hairline);
  color: var(--text-faint); font-weight: 600; font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.06em;
  padding: 12px 16px;
}
body.customers .table > tbody > tr > td,
body.customers .table > tbody > tr > th { border-top: 1px solid var(--hairline); padding: 16px; color: var(--text); }
body.customers .table-striped > tbody > tr:nth-of-type(odd) { background: color-mix(in oklab, var(--surface-soft) 50%, transparent); }
body.customers .table-hover > tbody > tr:hover { background: var(--surface-soft); }

body.customers .dataTables_wrapper .dataTables_paginate .paginate_button {
  color: var(--text-muted) !important; border: 1px solid var(--hairline-strong) !important;
  background: var(--surface) !important; border-radius: 10px !important;
  margin: 0 2px; padding: 4px 12px !important;
}
body.customers .dataTables_wrapper .dataTables_paginate .paginate_button:hover,
body.customers .dataTables_wrapper .dataTables_paginate .paginate_button.current {
  color: var(--bg) !important; background: var(--text) !important; border-color: var(--text) !important;
}
body.customers .dataTables_filter input,
body.customers .dataTables_length select {
  background: var(--bg-elev) !important; color: var(--text) !important;
  border: 1px solid var(--hairline-strong) !important; border-radius: 10px !important;
}

/* Alerts */
body.customers .alert { border-radius: 12px; border: 1px solid var(--hairline); padding: 14px 16px; background: var(--surface); color: var(--text); }
body.customers .alert-success { background: color-mix(in oklab, var(--green) 10%, transparent); border-color: color-mix(in oklab, var(--green) 30%, transparent); color: var(--green); }
body.customers .alert-danger  { background: color-mix(in oklab, var(--red) 10%, transparent);   border-color: color-mix(in oklab, var(--red) 30%, transparent);   color: var(--red); }
body.customers .alert-warning { background: color-mix(in oklab, var(--amber) 10%, transparent); border-color: color-mix(in oklab, var(--amber) 30%, transparent); color: var(--amber); }
body.customers .alert-info    { background: color-mix(in oklab, var(--accent) 10%, transparent);border-color: color-mix(in oklab, var(--accent) 30%, transparent);color: var(--accent-strong); }

/* Badges */
body.customers .badge, body.customers .label {
  border-radius: 999px; padding: 3px 10px;
  font-weight: 600; font-size: 11px; letter-spacing: 0.02em; text-transform: uppercase;
}
body.customers .label-primary, body.customers .badge { background: color-mix(in oklab, var(--accent) 14%, transparent); color: var(--accent-strong); }
body.customers .label-success { background: color-mix(in oklab, var(--green) 14%, transparent); color: var(--green); }
body.customers .label-warning { background: color-mix(in oklab, var(--amber) 14%, transparent); color: var(--amber); }
body.customers .label-danger  { background: color-mix(in oklab, var(--red) 14%, transparent); color: var(--red); }
body.customers .label-default { background: var(--surface-soft); color: var(--text-muted); }

/* Modals */
body.customers .modal-content {
  background: var(--surface); border: 1px solid var(--hairline);
  border-radius: 20px; box-shadow: var(--shadow-lg); color: var(--text);
}
body.customers .modal-header { border-bottom: 1px solid var(--hairline); }
body.customers .modal-footer { border-top: 1px solid var(--hairline); }
body.customers .close { color: var(--text-muted); opacity: 0.7; text-shadow: none; }
body.customers .close:hover { color: var(--text); opacity: 1; }
body.customers .modal-backdrop.in { opacity: 0.5; background: var(--text); }

/* Tabs */
body.customers .nav-tabs { border-bottom: 1px solid var(--hairline); }
body.customers .nav-tabs > li > a {
  color: var(--text-muted); border: none; border-radius: 0;
  background: transparent; padding: 12px 16px; margin-right: 4px; font-weight: 500;
}
body.customers .nav-tabs > li > a:hover { background: transparent; color: var(--text); border: none; }
body.customers .nav-tabs > li.active > a,
body.customers .nav-tabs > li.active > a:focus,
body.customers .nav-tabs > li.active > a:hover {
  color: var(--text); background: transparent; border: none;
  border-bottom: 2px solid var(--accent);
}

/* Tailwind class fallbacks */
body.customers .tw-text-neutral-700,
body.customers .tw-text-neutral-800,
body.customers .tw-text-neutral-900 { color: var(--text) !important; }
body.customers .tw-text-neutral-500,
body.customers .tw-text-neutral-600 { color: var(--text-muted) !important; }
body.customers .tw-text-primary-600, body.customers .tw-text-primary-700, body.customers .tw-text-primary-500 { color: var(--accent-strong) !important; }
body.customers .tw-bg-white { background: var(--surface) !important; }
body.customers .tw-bg-neutral-50 { background: var(--surface-soft) !important; }
body.customers .tw-bg-neutral-100 { background: var(--surface-soft) !important; }
body.customers .tw-border-neutral-200, body.customers .tw-border-neutral-300 { border-color: var(--hairline) !important; }
body.customers pre, body.customers code, body.customers kbd {
  background: var(--surface-soft); color: var(--text);
  border: 1px solid var(--hairline); border-radius: 6px;
}

/* Hide Perfex's old top navbar — replaced by sidebar */
body.customers .navbar.header,
body.customers .navbar-default.header { display: none !important; }
body.customers footer.footer { display: none !important; }

/* Perfex wrapper/content reset (sidebar layout takes over) */
body.customers #wrapper { background: transparent; }
body.customers #content { padding: 0; }
body.customers #content > .container { max-width: none; padding: 0; }
body.customers #content > .container > .row { margin: 0; }
body.customers #content > .container > .row > * { padding: 0; }

/* Submenu pill that Perfex adds (calendar/files quick row) */
body.customers .submenu.customer-top-submenu {
  list-style: none; padding: 4px;
  margin: 0 0 24px;
  background: var(--surface-soft);
  border: 1px solid var(--hairline);
  border-radius: 12px;
  display: inline-flex; gap: 2px; flex-wrap: wrap;
}
body.customers .submenu.customer-top-submenu li { display: inline-flex; }
body.customers .submenu.customer-top-submenu a {
  color: var(--text-muted); padding: 7px 14px; border-radius: 9px;
  font-weight: 500; font-size: 13px; text-decoration: none;
  transition: background 200ms var(--easing), color 200ms var(--easing);
}
body.customers .submenu.customer-top-submenu a:hover { background: var(--surface); color: var(--text); }

/* =====================================================================
   PART 3 — Auth pages (login/register/forgot/reset/two_factor)
   Split-screen with aurora — does NOT use sidebar layout
   ===================================================================== */

body.customers.cog-auth { background: var(--bg); overflow-x: hidden; }
body.customers.cog-auth .navbar.header,
body.customers.cog-auth footer.footer { display: none !important; }
body.customers.cog-auth #wrapper #content { padding: 0; }
body.customers.cog-auth #wrapper #content > .container:first-child:not(:only-child) { display: none; }
body.customers.cog-auth #wrapper #content > .container { padding: 0; max-width: none; width: 100%; }
body.customers.cog-auth #wrapper #content > .container > .row { margin: 0; }
body.customers.cog-auth #wrapper #content > .container > .row > * { padding: 0; }

.cog-auth-shell {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  min-height: 100vh;
  width: 100%;
  background: var(--bg);
}

.cog-auth-left {
  background: var(--bg);
  display: flex; align-items: center; justify-content: center;
  padding: 56px 48px;
  position: relative; overflow: hidden;
}
.cog-auth-left .aurora {
  position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(60% 80% at 10% 20%, var(--aurora-1) 0%, transparent 60%),
    radial-gradient(50% 70% at 90% 30%, var(--aurora-2) 0%, transparent 60%),
    radial-gradient(40% 60% at 70% 90%, var(--aurora-3) 0%, transparent 60%);
  opacity: 0.30;
  filter: blur(40px);
  animation: aurora 18s ease-in-out infinite alternate;
}
[data-theme="dark"] .cog-auth-left .aurora { opacity: 0.20; }

.cog-auth-form-card { width: 100%; max-width: 440px; position: relative; z-index: 1; }

.cog-auth-brand { display: inline-flex; align-items: center; gap: 12px; margin-bottom: 56px; text-decoration: none; }
.cog-auth-brand img { height: 36px; width: auto; }
.cog-auth-brand .brand-mark-lg {
  width: 40px; height: 40px; border-radius: 11px;
  background-color: rgba(26,183,255,0.08);
  border: 1px solid rgba(26,183,255,0.25);
  box-shadow: 0 0 24px rgba(26,183,255,0.30);
  background-image: url('assets/themes/perfex/img/cogswell-mark.png');
  background-size: 26px; background-position: center; background-repeat: no-repeat;
}
.cog-auth-brand .brand-text { font-weight: 700; font-size: 18px; letter-spacing: -0.02em; color: var(--text); }

.cog-auth-title {
  font-size: clamp(28px, 4vw, 44px);
  font-weight: 700; color: var(--text); letter-spacing: -0.04em;
  margin: 0 0 14px; line-height: 1.05;
}
.cog-auth-subtitle {
  color: var(--text-muted); font-size: 15px; line-height: 1.55;
  margin: 0 0 36px; max-width: 400px;
}

.cog-sso-btn {
  width: 100%; height: 48px;
  background: var(--surface);
  border: 1px solid var(--hairline-strong);
  color: var(--text); border-radius: 12px;
  font-weight: 500; font-size: 14px;
  display: inline-flex; align-items: center; justify-content: center; gap: 12px;
  margin-bottom: 10px;
  transition: transform 200ms var(--easing), box-shadow 200ms var(--easing), border-color 200ms var(--easing);
  text-decoration: none; cursor: pointer;
  box-shadow: var(--shadow-sm);
}
.cog-sso-btn:hover { transform: translateY(-1px); box-shadow: var(--shadow-md); color: var(--text); }
.cog-sso-btn svg { width: 20px; height: 20px; }
.cog-sso-btn .ms-tile { display: inline-grid; grid-template-columns: 1fr 1fr; grid-gap: 1px; width: 18px; height: 18px; }
.cog-sso-btn .ms-tile span:nth-child(1) { background: #F25022; }
.cog-sso-btn .ms-tile span:nth-child(2) { background: #7FBA00; }
.cog-sso-btn .ms-tile span:nth-child(3) { background: #00A4EF; }
.cog-sso-btn .ms-tile span:nth-child(4) { background: #FFB900; }

.cog-divider { display: flex; align-items: center; gap: 16px; color: var(--text-faint); font-size: 12px; margin: 26px 0; }
.cog-divider::before, .cog-divider::after {
  content: ""; flex: 1; height: 1px;
  background: linear-gradient(90deg, transparent, var(--hairline-strong), transparent);
}

.cog-auth-form-card .form-group { margin-bottom: 16px; }
.cog-auth-form-card label {
  color: var(--text-muted); font-weight: 500; font-size: 12px;
  margin-bottom: 6px; display: block;
}
.cog-auth-form-card .form-control {
  background: var(--bg-elev); border: 1px solid var(--hairline-strong); color: var(--text);
  border-radius: 12px; height: 48px; padding: 12px 14px;
  font-size: 14px; width: 100%; font-family: inherit;
  outline: none; transition: border-color 200ms var(--easing), box-shadow 200ms var(--easing);
}
.cog-auth-form-card .form-control:focus { border-color: var(--accent); box-shadow: 0 0 0 3px color-mix(in oklab, var(--accent) 18%, transparent); }
.cog-auth-form-card .row-between { display: flex; align-items: center; justify-content: space-between; margin-bottom: 6px; }
.cog-auth-form-card .row-between a { font-size: 12px; color: var(--text-muted); }
.cog-auth-form-card .row-between a:hover { color: var(--text); }

.cog-checkbox {
  display: inline-flex; align-items: center; gap: 10px;
  color: var(--text-muted); font-size: 13px; cursor: pointer;
  margin-bottom: 24px; user-select: none;
}
.cog-checkbox input {
  appearance: none; -webkit-appearance: none;
  width: 18px; height: 18px;
  border: 1px solid var(--hairline-strong); background: var(--bg-elev);
  border-radius: 5px; cursor: pointer;
  display: grid; place-items: center; margin: 0;
  transition: background 200ms var(--easing), border-color 200ms var(--easing);
}
.cog-checkbox input:checked { background: var(--accent); border-color: var(--accent); }
.cog-checkbox input:checked::after {
  content: ""; width: 5px; height: 9px;
  border-right: 2px solid white; border-bottom: 2px solid white;
  transform: rotate(45deg) translate(-1px, -1px);
}

/* Submit button — uses .btn-primary semantics (dark-on-light / light-on-dark) */
.cog-btn-submit {
  width: 100%; height: 48px;
  background: var(--text); color: var(--bg);
  border: 1px solid transparent; border-radius: 12px;
  font-weight: 600; font-size: 14px;
  cursor: pointer; font-family: inherit;
  transition: transform 200ms var(--easing), box-shadow 200ms var(--easing);
  position: relative; overflow: hidden;
}
.cog-btn-submit:hover { transform: translateY(-1px); box-shadow: 0 8px 20px -8px rgba(0,0,0,0.3); }
.cog-btn-submit::before { content:''; position: absolute; inset: 0; background: linear-gradient(115deg, transparent 30%, rgba(255,255,255,0.25) 50%, transparent 70%); transform: translateX(-100%); transition: transform 600ms var(--easing); }
.cog-btn-submit:hover::before { transform: translateX(100%); }

.cog-auth-footer-link { display: block; text-align: center; margin-top: 24px; color: var(--text-muted); font-size: 13px; }
.cog-auth-footer-link a { color: var(--text); font-weight: 600; }
.cog-auth-footer-link a:hover { color: var(--accent); }

.cog-auth-right {
  position: relative;
  background:
    radial-gradient(60% 80% at 30% 30%, var(--aurora-1) 0%, transparent 55%),
    radial-gradient(50% 70% at 80% 90%, var(--aurora-2) 0%, transparent 55%),
    radial-gradient(40% 60% at 70% 20%, var(--aurora-3) 0%, transparent 55%),
    var(--surface);
  overflow: hidden;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 56px 48px;
  border-left: 1px solid var(--hairline);
}
[data-theme="dark"] .cog-auth-right {
  background:
    radial-gradient(60% 80% at 30% 30%, color-mix(in oklab, var(--accent) 18%, transparent) 0%, transparent 60%),
    radial-gradient(50% 70% at 80% 90%, color-mix(in oklab, var(--violet) 16%, transparent) 0%, transparent 60%),
    var(--bg-elev);
}
.cog-auth-right::before {
  content: ""; position: absolute; inset: 0;
  background-image:
    linear-gradient(var(--hairline) 1px, transparent 1px),
    linear-gradient(90deg, var(--hairline) 1px, transparent 1px);
  background-size: 40px 40px;
  mask-image: radial-gradient(ellipse at center, #000 30%, transparent 75%);
  -webkit-mask-image: radial-gradient(ellipse at center, #000 30%, transparent 75%);
  pointer-events: none;
}

.cog-floating-cards { position: relative; width: 100%; max-width: 460px; height: 380px; margin-bottom: 40px; }

@keyframes cogFloat { 0%,100%{transform:translateY(0) rotate(var(--rot,0))} 50%{transform:translateY(-8px) rotate(var(--rot,0))} }

.cog-fc {
  position: absolute;
  background: color-mix(in oklab, var(--surface) 80%, transparent);
  backdrop-filter: blur(14px);
  border: 1px solid var(--hairline);
  border-radius: 18px; padding: 18px 20px;
  box-shadow: var(--shadow-lg);
  width: 260px; color: var(--text);
  overflow: hidden;
  animation: cogFloat 7s ease-in-out infinite;
}
.cog-fc h4 { font-size: 14px; font-weight: 600; margin: 0 0 4px; color: var(--text); letter-spacing: -0.01em; }
.cog-fc p { font-size: 12px; color: var(--text-muted); line-height: 1.5; margin: 0; }
.cog-fc .cog-fc-progress { margin-top: 12px; height: 4px; background: var(--surface-soft); border-radius: 999px; overflow: hidden; }
.cog-fc .cog-fc-progress > span { display: block; height: 100%; width: 60%; background: linear-gradient(90deg, var(--accent-strong), var(--accent)); border-radius: 999px; }
.cog-fc-1 { top: 0; left: 0; --rot: -4deg; transform: rotate(-4deg); animation-delay: 0s; }
.cog-fc-2 { top: 110px; right: 0; --rot: 5deg; transform: rotate(5deg); animation-delay: -2.5s; }
.cog-fc-3 { top: 210px; left: 50px; --rot: -2deg; transform: rotate(-2deg); animation-delay: -5s; }

.cog-app-icon {
  width: 44px; height: 44px; border-radius: 12px;
  display: inline-flex; align-items: center; justify-content: center;
  margin-bottom: 14px; position: relative; overflow: hidden;
  box-shadow: 0 1px 0 0 rgba(255,255,255,0.25) inset, 0 6px 16px rgba(0,0,0,0.20);
}
.cog-app-icon::before { content:''; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(255,255,255,0.30), rgba(255,255,255,0) 60%); pointer-events: none; }
.cog-app-icon svg { width: 22px; height: 22px; position: relative; z-index: 1; color: white; }
.cog-icon-chart    { background: linear-gradient(180deg, oklch(0.65 0.18 235), oklch(0.45 0.20 240)); }
.cog-icon-calendar { background: linear-gradient(180deg, oklch(0.70 0.18 25), oklch(0.55 0.22 25)); }
.cog-icon-bot      { background: linear-gradient(180deg, var(--accent), var(--accent-strong)); }
.cog-icon-day {
  position: absolute; left: 0; right: 0; bottom: 5px; text-align: center;
  font-weight: 700; font-size: 13px; color: #fff; z-index: 2;
}
.cog-icon-calendar svg { margin-top: -8px; }

.cog-auth-tagline { text-align: center; color: var(--text); position: relative; z-index: 1; }
.cog-auth-tagline h2 { font-size: clamp(24px, 3vw, 32px); font-weight: 700; letter-spacing: -0.03em; margin: 0 0 8px; color: var(--text); }
.cog-auth-tagline p { color: var(--text-muted); font-size: 14px; margin: 0; }

.cog-auth-form-card .alert { margin-bottom: 18px; }

@media (max-width: 992px) {
  .cog-auth-shell { grid-template-columns: 1fr; }
  .cog-auth-right { display: none; }
  .cog-auth-left { padding: 40px 24px; min-height: 100vh; }
  .cog-auth-brand { margin-bottom: 32px; }
}
body.customers.cog-auth.cog-auth-wide .cog-auth-shell { grid-template-columns: 1fr; }
body.customers.cog-auth.cog-auth-wide .cog-auth-left { padding: 56px 24px; }
body.customers.cog-auth.cog-auth-wide .cog-auth-form-card { max-width: 880px; }

/* MFA-specific */
.cog-2fa-code-input {
  font-family: 'JetBrains Mono', ui-monospace, monospace !important;
  font-size: 22px !important; letter-spacing: 0.4em !important;
  text-align: center !important; height: 64px !important;
}
.cog-backup-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 8px;
}
.cog-backup-code {
  display: block; background: var(--surface-soft); border: 1px solid var(--hairline-strong);
  color: var(--text); padding: 14px 16px; border-radius: 10px;
  font-family: 'JetBrains Mono', monospace; font-size: 15px; text-align: center;
}

/* Floating help / chat button (Cogswell chatbot widget anchor) */
#cogswell-chatbot-launcher,
.cogswell-chatbot-widget { z-index: 1040 !important; }

/* When inside the auth pages and showing in light theme, hairlines need to be darker for visibility */
[data-theme="light"] .cog-fc { background: rgba(255,255,255,0.85); }

/* =====================================================================
   PART 4 — Netflix-style intro overlay (post-login wow effect)
   Logo heartbeat, expanding rings, particles, wordmark, app entry
   Path note: cogswell-app.js sets --cog-logo-url at runtime so the
   shine mask works on both preview and production paths.
   ===================================================================== */

.intro {
  position: fixed; inset: 0; z-index: 9999;
  background: #05050a;
  display: grid; place-items: center;
  overflow: hidden; pointer-events: auto;
}
.intro.done { animation: introOut 700ms cubic-bezier(0.16,1,0.3,1) forwards; }
@keyframes introOut { to { opacity: 0; transform: scale(1.04); pointer-events: none; visibility: hidden; } }

.intro-bg {
  position: absolute; inset: -20%;
  background:
    radial-gradient(50% 50% at 50% 50%, oklch(0.55 0.22 220 / 0.5), transparent 60%),
    radial-gradient(40% 40% at 30% 70%, oklch(0.5 0.22 290 / 0.35), transparent 60%),
    radial-gradient(40% 40% at 70% 30%, oklch(0.6 0.18 200 / 0.35), transparent 60%);
  filter: blur(60px);
  animation: bgPulse 4s ease-in-out infinite alternate;
}
@keyframes bgPulse { from { transform: scale(1); opacity: 0.6;} to { transform: scale(1.15); opacity: 1;} }

.intro-rings { position: absolute; inset: 0; display: grid; place-items: center; }
.intro-rings span {
  position: absolute; width: 200px; height: 200px; border-radius: 50%;
  border: 1px solid #1ab7ff; opacity: 0;
  animation: ring 2.6s cubic-bezier(0.16,1,0.3,1) infinite;
}
.intro-rings span:nth-child(1) { animation-delay: 0s; }
.intro-rings span:nth-child(2) { animation-delay: 0.5s; }
.intro-rings span:nth-child(3) { animation-delay: 1s; }
.intro-rings span:nth-child(4) { animation-delay: 1.5s; }
@keyframes ring { 0% { transform: scale(0.4); opacity: 0.7; border-width: 2px; } 100% { transform: scale(3.5); opacity: 0; border-width: 1px; } }

.intro-particles { position: absolute; inset: 0; pointer-events: none; }
.intro-particles i {
  position: absolute; width: 3px; height: 3px; border-radius: 50%;
  background: #1ab7ff; box-shadow: 0 0 8px #1ab7ff;
  opacity: 0; animation: particle 3.8s ease-out infinite;
}
@keyframes particle { 0% { transform: translate(0,0) scale(0); opacity: 0; } 20% { opacity: 1; } 100% { transform: translate(var(--tx), var(--ty)) scale(1); opacity: 0; } }

.intro-stage {
  position: relative; width: 240px; height: 240px;
  display: grid; place-items: center;
  animation: stageIn 1.2s cubic-bezier(0.16,1,0.3,1) both;
}
@keyframes stageIn {
  from { transform: scale(0.2) rotate(-12deg); opacity: 0; filter: blur(20px); }
  60%  { filter: blur(0); }
  to   { transform: scale(1) rotate(0); opacity: 1; }
}

.intro-glow {
  position: absolute; inset: -60px; border-radius: 50%;
  background: radial-gradient(50% 50% at 50% 50%, #1ab7ff 0%, transparent 65%);
  filter: blur(30px);
  animation: glowPulse 1.6s cubic-bezier(0.4,0,0.6,1) infinite;
  opacity: 0.7;
}
@keyframes glowPulse { 0%,100%{transform: scale(0.85); opacity:0.45;} 50%{transform: scale(1.15); opacity:0.95;} }

.intro-logo {
  position: relative; width: 160px; height: auto;
  filter: drop-shadow(0 0 20px rgba(26,183,255,0.6)) drop-shadow(0 0 40px rgba(26,183,255,0.4));
  animation: logoBeat 1.6s cubic-bezier(0.4,0,0.6,1) infinite;
  z-index: 2;
}
@keyframes logoBeat {
  0%,100% { transform: scale(1); }
  25% { transform: scale(1.08); }
  50% { transform: scale(0.97); }
  75% { transform: scale(1.06); }
}

.intro-shine {
  position: absolute; inset: 0;
  background: linear-gradient(115deg, transparent 30%, rgba(255,255,255,0.6) 50%, transparent 70%);
  mix-blend-mode: overlay;
  animation: shineSweep 2.4s ease-in-out infinite;
  pointer-events: none; z-index: 3;
  /* logo-shaped mask — JS injects var(--cog-logo-url) so paths work on both preview and Perfex */
  mask: var(--cog-logo-url, none) center / 160px no-repeat;
  -webkit-mask: var(--cog-logo-url, none) center / 160px no-repeat;
}
@keyframes shineSweep { 0% { transform: translateX(-100%);} 60%,100% { transform: translateX(100%);} }

.intro-wordmark {
  position: absolute; bottom: 30%; left: 50%; transform: translateX(-50%);
  display: flex; gap: 14px;
  font-family: 'Inter', sans-serif; font-weight: 800;
  font-size: 28px; letter-spacing: 0.5em; color: #fff;
}
.intro-wordmark span {
  display: inline-block; opacity: 0; transform: translateY(20px);
  animation: letterIn 600ms cubic-bezier(0.16,1,0.3,1) forwards;
  text-shadow: 0 0 20px rgba(26,183,255,0.5);
}
.intro-wordmark span:nth-child(1){animation-delay:0.8s}
.intro-wordmark span:nth-child(2){animation-delay:0.88s}
.intro-wordmark span:nth-child(3){animation-delay:0.96s}
.intro-wordmark span:nth-child(4){animation-delay:1.04s}
.intro-wordmark span:nth-child(5){animation-delay:1.12s}
.intro-wordmark span:nth-child(6){animation-delay:1.2s}
.intro-wordmark span:nth-child(7){animation-delay:1.28s}
.intro-wordmark span:nth-child(8){animation-delay:1.36s}
@keyframes letterIn { to { opacity: 1; transform: translateY(0);} }

.intro-tag {
  position: absolute; bottom: 24%; left: 50%; transform: translateX(-50%);
  font-size: 11px; letter-spacing: 0.4em; text-transform: uppercase;
  color: rgba(255,255,255,0.5);
  opacity: 0; animation: tagIn 600ms ease 1.6s forwards;
}
@keyframes tagIn { to { opacity: 1; } }

.intro-skip {
  position: fixed; top: 24px; right: 24px;
  padding: 8px 14px; border-radius: 999px;
  background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.12);
  color: rgba(255,255,255,0.7); font: inherit; font-size: 12px;
  cursor: pointer; backdrop-filter: blur(10px);
  transition: all 200ms;
  opacity: 0; animation: tagIn 400ms ease 0.5s forwards;
}
.intro-skip:hover { background: rgba(255,255,255,0.14); color: white; }

/* App entry (after intro fades) */
.app.intro-pending { opacity: 0; }
.app.entered { animation: appIn 900ms cubic-bezier(0.16,1,0.3,1) forwards; }
@keyframes appIn {
  from { opacity: 0; transform: scale(0.98); filter: blur(8px);}
  to   { opacity: 1; transform: scale(1); filter: blur(0);}
}
