/* ================================================================
   SIMPLICITY — App Shell
   Imports design tokens. Defines layout and navigation chrome.
   Component classes live in _content/Simplicity.UI/css/simplicity.css
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,400;0,500;0,600;0,700;0,800;1,400&family=JetBrains+Mono:wght@400;500&display=swap');

/* Design tokens ─────────────────────────────────────── */
:root {
  --primary-50:  #eef8fc;
  --primary-100: #d4eef6;
  --primary-200: #a8dded;
  --primary-300: #74c8e0;
  --primary-400: #46b0d0;
  --primary-500: #2596be;
  --primary-600: #1d7a9d;
  --primary-700: #195f7c;
  --primary-800: #174d65;
  --primary-900: #143f53;
  --primary-950: #0c2836;
  --neutral-0:   #ffffff;
  --neutral-25:  #fafbfc;
  --neutral-50:  #f5f7f9;
  --neutral-100: #eceff3;
  --neutral-200: #dfe3e9;
  --neutral-300: #c5ccd6;
  --neutral-400: #9098a6;
  --neutral-500: #6b7382;
  --neutral-600: #4d5563;
  --neutral-700: #363d49;
  --neutral-800: #232831;
  --neutral-900: #161a21;
  --success-50:  #ecfdf3;
  --success-100: #d1fadf;
  --success-500: #12b76a;
  --success-600: #039855;
  --success-700: #027a48;
  --warning-50:  #fffaeb;
  --warning-100: #fef0c7;
  --warning-500: #f79009;
  --warning-600: #dc6803;
  --warning-700: #b54708;
  --danger-50:   #fef3f2;
  --danger-100:  #fee4e2;
  --danger-500:  #f04438;
  --danger-600:  #d92d20;
  --danger-700:  #b42318;
  --info-50:     #eff8ff;
  --info-100:    #d1e9ff;
  --info-500:    #2e90fa;
  --info-600:    #1570ef;
  --info-700:    #175cd3;
  --bg-app:        var(--neutral-50);
  --bg-surface:    var(--neutral-0);
  --bg-sunken:     var(--neutral-100);
  --bg-hover:      var(--neutral-100);
  --bg-active:     var(--neutral-200);
  --fg-1:          var(--neutral-900);
  --fg-2:          var(--neutral-700);
  --fg-3:          var(--neutral-500);
  --fg-4:          var(--neutral-400);
  --fg-on-primary: #ffffff;
  --fg-link:       var(--primary-600);
  --border-subtle:   var(--neutral-200);
  --border-default:  var(--neutral-300);
  --border-strong:   var(--neutral-400);
  --border-focus:    var(--primary-500);
  --accent:        var(--primary-500);
  --accent-hover:  var(--primary-600);
  --accent-press:  var(--primary-700);
  --accent-soft:   var(--primary-50);
  --font-sans: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --font-mono: 'JetBrains Mono', 'SF Mono', Monaco, Consolas, monospace;
  --text-xs:   12px;
  --text-sm:   13px;
  --text-base: 14px;
  --text-md:   16px;
  --text-lg:   18px;
  --text-xl:   20px;
  --text-2xl:  24px;
  --text-3xl:  30px;
  --text-4xl:  36px;
  --leading-tight:   1.2;
  --leading-snug:    1.35;
  --leading-normal:  1.5;
  --leading-relaxed: 1.7;
  --tracking-tight:  -0.02em;
  --tracking-caps:    0.08em;
  --weight-regular: 400;
  --weight-medium:  500;
  --weight-semi:    600;
  --weight-bold:    700;
  --space-1: 4px; --space-2: 8px; --space-3: 12px; --space-4: 16px;
  --space-5: 20px; --space-6: 24px; --space-8: 32px; --space-10: 40px;
  --space-12: 48px; --space-16: 64px;
  --radius-xs: 4px; --radius-sm: 6px; --radius-md: 8px; --radius-lg: 10px;
  --radius-xl: 14px; --radius-2xl: 20px; --radius-full: 9999px;
  --shadow-xs: 0 1px 2px rgba(16,24,40,.05);
  --shadow-sm: 0 1px 3px rgba(16,24,40,.08), 0 1px 2px rgba(16,24,40,.04);
  --shadow-md: 0 4px 8px -2px rgba(16,24,40,.08), 0 2px 4px -2px rgba(16,24,40,.04);
  --shadow-lg: 0 12px 16px -4px rgba(16,24,40,.08), 0 4px 6px -2px rgba(16,24,40,.03);
  --shadow-xl: 0 20px 24px -4px rgba(16,24,40,.10), 0 8px 8px -4px rgba(16,24,40,.04);
  --shadow-focus: 0 0 0 4px rgba(37,150,190,.20);
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --dur-fast: 120ms; --dur-base: 200ms; --dur-slow: 320ms;
  --sidebar-width: 248px;
  --topbar-height: 60px;

  /* Legacy aliases */
  --sp-color-primary: var(--primary-500);
  --sp-color-primary-hover: var(--primary-600);
  --sp-color-primary-dark: var(--primary-700);
  --sp-color-primary-fg: #fff;
  --sp-color-primary-subtle: var(--primary-50);
  --sp-color-primary-muted: var(--primary-200);
  --sp-color-success: var(--success-500);
  --sp-color-success-bg: var(--success-50);
  --sp-color-warning: var(--warning-500);
  --sp-color-warning-bg: var(--warning-50);
  --sp-color-danger: var(--danger-500);
  --sp-color-danger-bg: var(--danger-50);
  --sp-color-surface-0: var(--neutral-0);
  --sp-color-surface-1: var(--neutral-50);
  --sp-color-surface-2: var(--neutral-100);
  --sp-color-border: var(--border-subtle);
  --sp-color-border-focus: var(--primary-500);
  --sp-color-text-primary: var(--fg-1);
  --sp-color-text-secondary: var(--fg-2);
  --sp-color-text-muted: var(--fg-3);
  --sp-color-text-inverse: #fff;
  --sp-font-sans: var(--font-sans);
  --sp-space-1: var(--space-1); --sp-space-2: var(--space-2); --sp-space-3: var(--space-3);
  --sp-space-4: var(--space-4); --sp-space-5: var(--space-5); --sp-space-6: var(--space-6);
  --sp-space-8: var(--space-8); --sp-space-10: var(--space-10);
  --sp-radius-sm: var(--radius-sm); --sp-radius-md: var(--radius-md);
  --sp-radius-lg: var(--radius-lg); --sp-radius-xl: var(--radius-xl);
  --sp-radius-full: var(--radius-full);
  --sp-shadow-xs: var(--shadow-xs); --sp-shadow-md: var(--shadow-md);
  --sp-shadow-lg: var(--shadow-lg);
  --sp-transition: var(--dur-base) var(--ease-out);
  --sp-transition-fast: var(--dur-fast) var(--ease-out);
  --sp-sidebar-width: var(--sidebar-width);
}

/* ── Base ──────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; -webkit-font-smoothing: antialiased; }
body {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  line-height: var(--leading-normal);
  color: var(--fg-1);
  background: var(--bg-app);
  min-height: 100vh;
}
a { color: inherit; text-decoration: none; }
button { font-family: inherit; }

/* ── App Shell ─────────────────────────────────────────────────── */
.sp-shell {
  display: grid;
  grid-template-columns: var(--sidebar-width) 1fr;
  min-height: 100vh;
}

/* ── Sidebar ───────────────────────────────────────────────────── */
.sp-shell__sidebar {
  background: #fff;
  border-right: 1px solid var(--border-subtle);
  display: flex;
  flex-direction: column;
  padding: var(--space-4) var(--space-3);
  position: fixed;
  top: 0; left: 0; bottom: 0;
  width: var(--sidebar-width);
  z-index: 100;
  overflow-y: auto;
}

/* Brand */
.sp-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 4px 10px 18px;
  border-bottom: 1px solid var(--border-subtle);
  margin-bottom: var(--space-3);
}
.sp-brand img  { height: 28px; width: 28px; }
.sp-brand__name {
  font-weight: var(--weight-bold);
  font-size: var(--text-md);
  letter-spacing: -0.02em;
  color: var(--fg-1);
}

/* Nav groups */
.sp-sidenav__section {
  font-size: 11px;
  font-weight: var(--weight-semi);
  text-transform: uppercase;
  letter-spacing: var(--tracking-caps);
  color: var(--fg-3);
  padding: 14px 12px 6px;
}

.sp-sidenav__item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  border-radius: var(--radius-md);
  color: var(--fg-2);
  font-size: var(--text-base);
  font-weight: var(--weight-medium);
  cursor: pointer;
  user-select: none;
  transition: background var(--dur-fast) var(--ease-out),
              color var(--dur-fast) var(--ease-out);
  text-decoration: none;
}
.sp-sidenav__item:hover {
  background: var(--neutral-100);
  color: var(--fg-1);
}
.sp-sidenav__item--active {
  background: var(--primary-50);
  color: var(--primary-700);
}
.sp-sidenav__item--active [data-lucide],
.sp-sidenav__item--active svg {
  color: var(--primary-600);
}
.sp-sidenav__item [data-lucide],
.sp-sidenav__item svg {
  width: 18px; height: 18px;
  flex-shrink: 0;
  stroke-width: 1.75;
}
.sp-sidenav__label { flex: 1; }
.sp-sidenav__count {
  margin-left: auto;
  font-size: 11px; font-weight: var(--weight-semi);
  background: var(--neutral-100); color: var(--fg-3);
  padding: 1px 7px; border-radius: var(--radius-full);
}
.sp-sidenav__item--active .sp-sidenav__count {
  background: var(--primary-100); color: var(--primary-700);
}

/* Sidebar footer */
.sp-sidebar-footer {
  margin-top: auto;
  padding: 10px;
  border-top: 1px solid var(--border-subtle);
  display: flex; align-items: center; gap: 10px;
}
.sp-sidebar-footer .sp-user-av {
  width: 32px; height: 32px; border-radius: var(--radius-md);
  background: var(--primary-100); color: var(--primary-700);
  display: grid; place-items: center;
  font-weight: var(--weight-bold); font-size: 12px;
  flex-shrink: 0;
}
.sp-sidebar-footer .sp-user-info { font-size: var(--text-sm); line-height: 1.3; }
.sp-sidebar-footer .sp-user-role { font-size: 11px; color: var(--fg-3); }

/* ── Main content ──────────────────────────────────────────────── */
.sp-shell__main {
  grid-column: 2;
  margin-left: var(--sidebar-width);
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

/* ── Topbar ────────────────────────────────────────────────────── */
.sp-topbar {
  height: var(--topbar-height);
  background: rgba(255,255,255,0.85);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--border-subtle);
  display: flex; align-items: center;
  padding: 0 28px; gap: var(--space-4);
  position: sticky; top: 0; z-index: 50;
}
.sp-topbar__crumb {
  font-size: var(--text-sm); color: var(--fg-3);
  display: flex; align-items: center; gap: var(--space-2);
  flex: 1;
}
.sp-topbar__crumb .here { color: var(--fg-1); font-weight: var(--weight-medium); }
.sp-topbar__crumb .sep  { color: var(--fg-4); }

.sp-topbar__search {
  position: relative; width: 280px;
}
.sp-topbar__search input {
  width: 100%; padding: 8px 12px 8px 34px;
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  background: #fff; font: var(--text-sm) var(--font-sans);
  outline: none; color: var(--fg-1);
  transition: border-color var(--dur-fast), box-shadow var(--dur-fast);
}
.sp-topbar__search input::placeholder { color: var(--fg-4); }
.sp-topbar__search input:focus {
  border-color: var(--border-focus);
  box-shadow: var(--shadow-focus);
}
.sp-topbar__search [data-lucide],
.sp-topbar__search svg {
  position: absolute; left: 10px; top: 50%;
  transform: translateY(-50%);
  width: 16px; height: 16px; color: var(--fg-3);
  pointer-events: none;
}
.sp-topbar__search .sp-kbd {
  position: absolute; right: 8px; top: 50%;
  transform: translateY(-50%);
  font: 500 10px var(--font-mono);
  padding: 2px 5px;
  border: 1px solid var(--border-default);
  border-radius: var(--radius-xs);
  color: var(--fg-3); background: var(--neutral-50);
}

.sp-icon-btn {
  width: 36px; height: 36px; border-radius: var(--radius-md);
  display: grid; place-items: center;
  cursor: pointer; color: var(--fg-2);
  position: relative; flex-shrink: 0;
  transition: background var(--dur-fast);
}
.sp-icon-btn:hover { background: var(--neutral-100); color: var(--fg-1); }
.sp-icon-btn [data-lucide],
.sp-icon-btn svg { width: 18px; height: 18px; stroke-width: 1.75; }
.sp-icon-btn .sp-notif-dot {
  position: absolute; top: 8px; right: 8px;
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--danger-500); border: 2px solid #fff;
}

.sp-topbar__avatar {
  width: 32px; height: 32px; border-radius: var(--radius-md);
  background: var(--primary-100); color: var(--primary-700);
  display: grid; place-items: center;
  font-weight: var(--weight-bold); font-size: 12px;
  cursor: pointer; flex-shrink: 0;
}

/* ── Content ───────────────────────────────────────────────────── */
.sp-content {
  flex: 1;
  padding: 28px;
  max-width: 1400px;
}

/* ── Page head ─────────────────────────────────────────────────── */
.sp-page-head {
  display: flex; justify-content: space-between;
  align-items: flex-end; margin-bottom: var(--space-6); gap: var(--space-6);
}
.sp-page-head h1 {
  font-size: 28px; font-weight: var(--weight-bold);
  letter-spacing: var(--tracking-tight); margin: 0 0 4px;
}
.sp-page-head .sp-page-sub { font-size: var(--text-base); color: var(--fg-3); }
.sp-page-head .sp-page-actions { display: flex; gap: var(--space-2); align-items: center; }

/* ── Landing Page ──────────────────────────────────────────────── */
.sp-landing {
  min-height: 100vh;
  background: var(--neutral-0);
  display: flex; flex-direction: column;
}
.sp-landing__nav {
  display: flex; align-items: center;
  justify-content: space-between;
  padding: var(--space-5) var(--space-8);
  border-bottom: 1px solid var(--border-subtle);
}
.sp-landing__logo {
  display: flex; align-items: center; gap: 10px; text-decoration: none;
}
.sp-landing__logo-name {
  font-size: var(--text-xl);
  font-weight: var(--weight-bold);
  color: var(--fg-1);
  letter-spacing: -0.02em;
}
.sp-landing__nav-actions { display: flex; align-items: center; gap: var(--space-3); }

.sp-landing__hero {
  flex: 1; display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  text-align: center;
  padding: var(--space-16) var(--space-8);
  background: radial-gradient(ellipse 80% 60% at 50% 0%, #e0f3fa 0%, transparent 70%);
}
.sp-landing__badge {
  display: inline-flex; align-items: center; gap: var(--space-2);
  padding: 4px 12px;
  background: var(--primary-50);
  border: 1px solid var(--primary-200);
  border-radius: var(--radius-full);
  font-size: var(--text-xs); font-weight: var(--weight-semi);
  color: var(--primary-700);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  margin-bottom: var(--space-6);
}
.sp-landing__badge-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--primary-500);
}
.sp-landing__title {
  font-size: clamp(2.2rem, 5.5vw, 3.5rem);
  font-weight: var(--weight-bold);
  color: var(--fg-1);
  letter-spacing: var(--tracking-tight);
  line-height: var(--leading-tight);
  max-width: 680px;
  margin-bottom: var(--space-5);
}
.sp-landing__title span { color: var(--primary-500); }
.sp-landing__subtitle {
  font-size: var(--text-lg); color: var(--fg-3);
  max-width: 500px; line-height: var(--leading-relaxed);
  margin-bottom: var(--space-8);
}
.sp-landing__actions {
  display: flex; align-items: center; gap: var(--space-3);
  flex-wrap: wrap; justify-content: center;
}
.sp-landing__features {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
  padding: var(--space-10) var(--space-8);
  max-width: 960px; margin: 0 auto; width: 100%;
}
.sp-landing__feature {
  background: var(--neutral-0);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
  display: flex; flex-direction: column; gap: var(--space-3);
}
.sp-landing__feature:hover {
  box-shadow: var(--shadow-md);
  border-color: var(--border-default);
}
.sp-landing__feature-icon {
  width: 44px; height: 44px; border-radius: var(--radius-lg);
  background: var(--primary-50);
  display: flex; align-items: center; justify-content: center;
  color: var(--primary-600);
}
.sp-landing__feature-icon [data-lucide],
.sp-landing__feature-icon svg { width: 20px; height: 20px; }
.sp-landing__feature-title { font-size: var(--text-base); font-weight: var(--weight-semi); color: var(--fg-1); }
.sp-landing__feature-desc  { font-size: var(--text-sm);  color: var(--fg-3); line-height: var(--leading-relaxed); }
.sp-landing__footer {
  padding: var(--space-6) var(--space-8);
  border-top: 1px solid var(--border-subtle);
  text-align: center; font-size: var(--text-xs); color: var(--fg-3);
}

/* ── Landing buttons ───────────────────────────────────────────── */
.sp-btn-landing-primary {
  display: inline-flex; align-items: center; gap: var(--space-2);
  padding: 10px 22px;
  background: var(--accent); color: #fff;
  font: var(--weight-semi) var(--text-base) var(--font-sans);
  border-radius: var(--radius-md); border: none;
  cursor: pointer; text-decoration: none;
  transition: background var(--dur-fast);
}
.sp-btn-landing-primary:hover { background: var(--accent-hover); }
.sp-btn-landing-secondary {
  display: inline-flex; align-items: center; gap: var(--space-2);
  padding: 10px 22px;
  background: transparent; color: var(--fg-1);
  font: var(--weight-medium) var(--text-base) var(--font-sans);
  border-radius: var(--radius-md);
  border: 1px solid var(--border-default);
  cursor: pointer; text-decoration: none;
  transition: background var(--dur-fast), border-color var(--dur-fast);
}
.sp-btn-landing-secondary:hover { background: var(--neutral-50); border-color: var(--neutral-400); }

/* ── Blazor error UI ───────────────────────────────────────────── */
#blazor-error-ui .reload  { font-weight: var(--weight-semi); }
#blazor-error-ui .dismiss:hover { opacity: 1; }

/* ── Spinner keyframe (used inside buttons, cards, etc.) ──────── */
@keyframes sp-spin { to { transform: rotate(360deg); } }
