/* ShakaFlow Settings — refined neutral aesthetic */
:root {
  --accent-h: 252;
  --accent: oklch(0.55 0.18 var(--accent-h));
  --accent-soft: oklch(0.96 0.03 var(--accent-h));
  --accent-ink: oklch(0.35 0.15 var(--accent-h));

  --bg: oklch(0.985 0.004 85);
  --bg-sunk: oklch(0.975 0.005 85);
  --panel: #ffffff;
  --ink-1: oklch(0.22 0.01 80);
  --ink-2: oklch(0.40 0.01 80);
  --ink-3: oklch(0.55 0.01 80);
  --ink-4: oklch(0.72 0.008 80);
  --line: oklch(0.92 0.006 80);
  --line-strong: oklch(0.86 0.008 80);
  --ok: oklch(0.60 0.14 150);
  --ok-soft: oklch(0.96 0.04 150);
  --warn: oklch(0.64 0.16 55);
  --warn-soft: oklch(0.97 0.04 55);
  --info: oklch(0.60 0.15 240);
  --info-soft: oklch(0.96 0.03 240);
  --danger: oklch(0.58 0.19 28);

  --radius: 10px;
  --radius-sm: 6px;
  --radius-lg: 14px;
  --shadow-sm: 0 1px 0 oklch(0.9 0.005 80 / 0.6), 0 1px 2px oklch(0.5 0 0 / 0.04);
  --shadow: 0 1px 0 oklch(0.9 0.005 80 / 0.5), 0 6px 16px oklch(0.5 0 0 / 0.06);
  --shadow-lg: 0 20px 50px oklch(0.3 0 0 / 0.18), 0 4px 8px oklch(0.3 0 0 / 0.08);

  --font-ui: "Inter", ui-sans-serif, system-ui, -apple-system, "Helvetica Neue", sans-serif;
  --font-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
}

[data-density="compact"] {
  --row-py: 10px;
  --card-py: 16px;
  --gap: 10px;
}
[data-density="comfy"] {
  --row-py: 16px;
  --card-py: 22px;
  --gap: 16px;
}
:root { --row-py: 13px; --card-py: 18px; --gap: 13px; }

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background: var(--bg);
  color: var(--ink-1);
  font-family: var(--font-ui);
  font-size: 14px;
  line-height: 1.45;
  -webkit-font-smoothing: antialiased;
  letter-spacing: -0.005em;
}

/* ==== Layout ==== */
.sf-app { display: grid; grid-template-columns: 260px 1fr; min-height: 100vh; }
.sf-sidebar {
  background: var(--bg-sunk);
  border-right: 1px solid var(--line);
  padding: 18px 14px;
  display: flex; flex-direction: column; gap: 6px;
  position: sticky; top: 0; height: 100vh; overflow: auto;
}
.sf-main { display: flex; flex-direction: column; min-width: 0; }

/* ==== Sidebar ==== */
.sf-brand { display: flex; align-items: center; gap: 10px; padding: 4px 8px 14px; }
.sf-brand-mark {
  width: 32px; height: 32px; border-radius: 8px;
  overflow: hidden; display: grid; place-items: center;
  flex-shrink: 0;
}
.sf-brand-mark img { width: 100%; height: 100%; display: block; object-fit: cover; }
.sf-brand-name { font-weight: 600; font-size: 14px; color: var(--ink-1); letter-spacing: -0.01em; }
.sf-brand-sub { font-size: 12px; color: var(--ink-3); }

.sf-workspace-dropdown { position: relative; margin-bottom: 14px; }
.sf-workspace-dropdown[open] > .sf-workspace-switcher { border-color: var(--line-strong); }
.sf-workspace-dropdown[open] > .sf-workspace-switcher > svg { transform: rotate(90deg); }
.sf-workspace-switcher {
  display: flex; align-items: center; gap: 10px; width: 100%;
  background: var(--panel); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 8px 10px;
  cursor: pointer; list-style: none;
  box-shadow: var(--shadow-sm);
  transition: border-color 120ms;
}
.sf-workspace-switcher::-webkit-details-marker { display: none; }
.sf-workspace-switcher--static { margin-bottom: 14px; cursor: default; }
.sf-workspace-switcher:hover { border-color: var(--line-strong); }
.sf-workspace-switcher > svg { transition: transform 140ms; }
.sf-workspace-menu {
  position: absolute; left: 0; right: 0; top: calc(100% + 4px);
  background: var(--panel); border: 1px solid var(--line);
  border-radius: var(--radius); box-shadow: var(--shadow-lg);
  padding: 4px; z-index: 30; max-height: 320px; overflow: auto;
}
.sf-workspace-option {
  display: flex; align-items: center; gap: 10px;
  padding: 7px 8px; border-radius: 7px;
  text-decoration: none; color: var(--ink-1);
  transition: background 100ms;
}
.sf-workspace-option:hover { background: var(--bg-sunk); }
.sf-workspace-option[data-active="true"] { background: var(--accent-soft); color: var(--accent-ink); }
.sf-workspace-option[data-active="true"] > svg { color: var(--accent); margin-left: auto; flex-shrink: 0; }
.sf-ws-avatar {
  width: 28px; height: 28px; border-radius: 6px; display: grid; place-items: center;
  background: oklch(0.94 0.02 252); color: var(--accent-ink); font-weight: 600; font-size: 11px;
}
.sf-ws-meta { flex: 1; text-align: left; min-width: 0; }
.sf-ws-name { font-weight: 550; font-size: 13px; color: var(--ink-1); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sf-ws-sub  { font-size: 11px; color: var(--ink-3); }
.sf-workspace-switcher > svg { color: var(--ink-3); flex-shrink: 0; }

.sf-nav-group { margin-top: 16px; display: flex; flex-direction: column; gap: 2px; }
.sf-nav-group-title {
  font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em;
  color: var(--ink-3); padding: 4px 10px 6px;
}
.sf-nav-item {
  display: flex; align-items: center; gap: 10px;
  padding: 7px 10px; border-radius: 8px;
  color: var(--ink-2); font-size: 13.5px; font-weight: 500;
  cursor: pointer; transition: background 100ms, color 100ms;
}
.sf-nav-item > svg { color: var(--ink-3); flex-shrink: 0; }
.sf-nav-item:hover { background: oklch(0.95 0.005 80); color: var(--ink-1); }
.sf-nav-item:hover > svg { color: var(--ink-2); }
.sf-nav-item[data-active="true"] {
  background: var(--panel); color: var(--ink-1);
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--line);
  padding: 6px 9px;
}
.sf-nav-item[data-active="true"] > svg { color: var(--accent); }
.sf-admin-pill {
  margin-left: auto; font-size: 10px; font-weight: 600;
  padding: 2px 6px; border-radius: 4px;
  background: oklch(0.95 0.01 80); color: var(--ink-3);
  letter-spacing: 0.04em;
}

.sf-sidebar-foot { margin-top: auto; padding-top: 14px; border-top: 1px solid var(--line); }
.sf-role-switcher { display: flex; align-items: center; gap: 8px; padding: 2px 4px; justify-content: space-between; }
.sf-role-label { font-size: 11px; color: var(--ink-3); }
.sf-seg {
  display: inline-flex; background: oklch(0.94 0.005 80); padding: 2px; border-radius: 7px; gap: 2px;
}
.sf-seg button {
  font-family: inherit; font-size: 11px; font-weight: 550;
  padding: 4px 9px; border: none; background: transparent;
  color: var(--ink-3); border-radius: 5px; cursor: pointer;
}
.sf-seg button[data-active="true"] {
  background: var(--panel); color: var(--ink-1);
  box-shadow: var(--shadow-sm);
}

/* ==== Topbar ==== */
.sf-topbar {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 32px; border-bottom: 1px solid var(--line);
  background: var(--bg); position: sticky; top: 0; z-index: 20;
  backdrop-filter: blur(8px);
}
.sf-search {
  flex: 1; max-width: 520px; display: flex; align-items: center; gap: 10px;
  padding: 8px 12px; background: var(--panel); border: 1px solid var(--line);
  border-radius: 8px; color: var(--ink-3); cursor: pointer;
  font-family: inherit; font-size: 13px; transition: border-color 120ms;
}
.sf-search:hover { border-color: var(--line-strong); }
.sf-search > span:nth-of-type(1) { flex: 1; text-align: left; }
.sf-search--disabled { opacity: 0.6; cursor: not-allowed; }
.sf-search--disabled:hover { border-color: var(--line); }
.sf-kbd {
  font-family: var(--font-mono); font-size: 11px; color: var(--ink-3);
  padding: 2px 6px; border: 1px solid var(--line); border-radius: 4px;
  background: var(--bg-sunk);
}
.sf-topbar-right { margin-left: auto; display: flex; align-items: center; gap: 14px; }
.sf-icon-btn {
  width: 32px; height: 32px; display: grid; place-items: center;
  background: transparent; border: none; border-radius: 6px; cursor: pointer;
  color: var(--ink-3);
}
.sf-icon-btn:hover { background: oklch(0.94 0.005 80); color: var(--ink-1); }
.sf-user-chip { display: flex; align-items: center; gap: 10px; }
.sf-avatar {
  width: 32px; height: 32px; border-radius: 50%;
  background: linear-gradient(135deg, oklch(0.7 0.14 40), oklch(0.55 0.18 15));
  color: white; display: grid; place-items: center; font-weight: 600; font-size: 12px;
}
.sf-user-meta { line-height: 1.2; }
.sf-user-name { font-size: 13px; font-weight: 550; color: var(--ink-1); }
.sf-user-sub  { font-size: 11px; color: var(--ink-3); }

.sf-user-menu { position: relative; }
.sf-user-menu > summary {
  list-style: none; cursor: pointer; padding: 4px 8px;
  border-radius: 8px; transition: background-color 120ms;
}
.sf-user-menu > summary::-webkit-details-marker { display: none; }
.sf-user-menu > summary:hover { background: oklch(0.94 0.005 80); }
.sf-user-menu[open] > summary { background: oklch(0.94 0.005 80); }
.sf-user-menu-dropdown {
  position: absolute; right: 0; top: calc(100% + 6px); min-width: 200px;
  background: var(--panel); border: 1px solid var(--line); border-radius: 10px;
  box-shadow: var(--shadow-md); padding: 6px; z-index: 30;
}
.sf-user-menu-item {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 10px; border-radius: 6px; color: var(--ink-1);
  text-decoration: none; font-size: 13px; cursor: pointer;
  background: transparent; border: none; width: 100%; text-align: left;
  font-family: inherit;
}
.sf-user-menu-item:hover { background: oklch(0.96 0.005 80); }
.sf-user-menu-item--danger { color: var(--danger, #b3261e); }
.sf-user-menu-item--danger:hover { background: oklch(0.96 0.03 25); }
.sf-user-menu-sep { height: 1px; background: var(--line); margin: 4px 0; }
.sf-user-menu-form { margin: 0; display: block; }

.sf-provider-icon {
  display: grid; place-items: center; border-radius: 8px; overflow: hidden;
  background: var(--panel); border: 1px solid var(--line); flex-shrink: 0;
  padding: 4px;
}
.sf-provider-icon img { width: 100%; height: 100%; object-fit: contain; }

.sf-status-steps {
  display: flex; align-items: center; gap: 4px; margin: 12px 0; flex-wrap: wrap;
}
.sf-status-step {
  display: flex; align-items: center; gap: 8px; padding: 6px 10px;
  border-radius: 999px; background: var(--bg-sunk); border: 1px solid var(--line);
  font-size: 12px; color: var(--ink-3);
}
.sf-status-step-mark {
  width: 18px; height: 18px; display: grid; place-items: center; border-radius: 50%;
  background: var(--bg-sunk); color: var(--ink-3);
}
.sf-status-step-dot {
  width: 6px; height: 6px; border-radius: 50%; background: currentColor;
}
.sf-status-step--done { background: var(--ok-soft, oklch(0.96 0.05 150)); color: var(--ok, oklch(0.5 0.14 150)); border-color: oklch(0.88 0.07 150); }
.sf-status-step--done .sf-status-step-mark { background: var(--ok, oklch(0.55 0.14 150)); color: white; }
.sf-status-step--active { background: var(--accent-soft); color: var(--accent-ink); border-color: oklch(0.85 0.08 var(--accent-h)); }
.sf-status-step--active .sf-status-step-mark { background: var(--accent, oklch(0.55 0.15 250)); color: white; }
.sf-status-step--pending { background: var(--warn-soft, oklch(0.96 0.06 70)); color: var(--warn, oklch(0.55 0.15 70)); border-color: oklch(0.88 0.08 70); }
.sf-status-step--pending .sf-status-step-mark { background: var(--warn, oklch(0.65 0.15 70)); color: white; }
.sf-status-step--todo { opacity: 0.7; }
.sf-status-step-spinner {
  width: 10px; height: 10px; border-radius: 50%;
  border: 2px solid currentColor; border-top-color: transparent;
  animation: sf-spin 900ms linear infinite;
}
@keyframes sf-spin { to { transform: rotate(360deg); } }
.sf-status-step-connector {
  flex: 0 0 20px; height: 2px; background: var(--line); border-radius: 999px;
}

.sf-dev-login {
  max-width: 720px; margin: 0 auto; padding: 48px 24px;
}
.sf-dev-login-head { margin-bottom: 24px; }
.sf-dev-login-head h1 {
  font-size: 28px; font-weight: 700; letter-spacing: -0.02em; margin: 6px 0 8px;
}
.sf-dev-login-head p { color: var(--ink-3); font-size: 14px; max-width: 520px; }

/* ==== Page header ==== */
.sf-page {
  padding: 36px 48px 64px; max-width: 1080px; margin: 0 auto; width: 100%;
}
.sf-breadcrumbs {
  display: flex; align-items: center; gap: 6px;
  font-size: 12px; color: var(--ink-3); margin-bottom: 10px;
}
.sf-breadcrumbs svg { color: var(--ink-4); }
.sf-crumb { color: var(--ink-3); text-decoration: none; }
.sf-crumb-link { cursor: pointer; transition: color 100ms; }
.sf-crumb-link:hover { color: var(--ink-1); text-decoration: underline; }
.sf-crumb-cur { color: var(--ink-1); font-weight: 500; }
.sf-eyebrow {
  font-size: 11px; font-weight: 600; color: var(--accent);
  text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 6px;
}
.sf-page-head { margin-bottom: 28px; }
.sf-page-head-row { display: flex; align-items: flex-start; justify-content: space-between; gap: 20px; }
.sf-page-title {
  font-size: 26px; font-weight: 600; letter-spacing: -0.02em;
  margin: 0 0 6px; color: var(--ink-1);
}
.sf-page-desc { margin: 0; color: var(--ink-3); font-size: 14px; max-width: 640px; line-height: 1.55; }
.sf-page-actions { display: flex; gap: 8px; flex-shrink: 0; }

/* ==== Cards + rows ==== */
.sf-card {
  background: var(--panel); border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}
.sf-card + .sf-card { margin-top: 20px; }
.sf-card--anchored { scroll-margin-top: 88px; }
.sf-card--anchored:target { box-shadow: 0 0 0 2px var(--accent-soft, oklch(0.96 0.05 250)); }
.sf-card-head {
  display: flex; align-items: flex-start; justify-content: space-between; gap: 16px;
  padding: var(--card-py) 22px; border-bottom: 1px solid var(--line);
}
.sf-card-head-text h3 {
  font-size: 15px; font-weight: 600; color: var(--ink-1); margin: 0 0 2px;
  letter-spacing: -0.01em;
}
.sf-card-head-text p { font-size: 13px; color: var(--ink-3); margin: 0; max-width: 520px; line-height: 1.5; }
.sf-card-body { padding: 14px 18px; }
.sf-card-body--flush { padding: 0; }

.sf-row {
  display: flex; align-items: center; gap: 14px;
  padding: var(--row-py) 16px;
  border-radius: var(--radius);
}
.sf-row + .sf-row { border-top: 1px solid var(--line); border-radius: 0; }
.sf-row--int { cursor: pointer; transition: background 100ms; }
.sf-row--int:hover { background: var(--bg-sunk); }

.sf-row-main { flex: 1; min-width: 0; }
.sf-row-link { text-decoration: none; color: inherit; display: block; border-radius: var(--radius-sm); }
.sf-row-link:hover .sf-row-title { color: var(--accent-ink); }
.sf-row-title { font-size: 14px; font-weight: 550; color: var(--ink-1); display: flex; align-items: center; gap: 8px; }
.sf-row-sub { font-size: 12.5px; color: var(--ink-3); margin-top: 3px; }
.sf-row-mono { font-family: var(--font-mono); font-size: 12px; color: var(--ink-2); }
.sf-row-status { display: flex; justify-content: flex-end; min-width: 120px; flex-shrink: 0; }
.sf-row-actions { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }

@media (max-width: 640px) {
  .sf-row:has(.sf-row-status) { align-items: flex-start; flex-wrap: wrap; }
  .sf-row-status { justify-content: flex-start; min-width: 0; width: 100%; }
}

/* Row leading indicators (provider marks) */
.sf-row-mark {
  width: 34px; height: 34px; border-radius: 8px; display: grid; place-items: center;
  background: var(--bg-sunk); color: var(--ink-2); font-weight: 600; font-size: 12px;
  flex-shrink: 0; border: 1px solid var(--line);
}

/* ==== Buttons ==== */
.sf-btn {
  font-family: inherit; font-weight: 550;
  display: inline-flex; align-items: center; gap: 6px;
  border-radius: 7px; cursor: pointer; border: 1px solid transparent;
  text-decoration: none; white-space: nowrap;
  transition: background 100ms, border-color 100ms, color 100ms;
}
a.sf-btn { text-decoration: none; }
.sf-btn--md { padding: 6px 12px; font-size: 13px; }
.sf-btn--sm { padding: 4px 9px; font-size: 12px; }
.sf-btn--lg { padding: 9px 18px; font-size: 14px; }
.sf-btn--primary, a.sf-btn--primary { background: var(--ink-1); color: #fff; border-color: var(--ink-1); }
.sf-btn--primary:hover, a.sf-btn--primary:hover { background: oklch(0.30 0.01 80); border-color: oklch(0.30 0.01 80); color: #fff; }
.sf-btn--primary:visited { color: #fff; }
.sf-btn--secondary { background: var(--panel); color: var(--ink-1); border-color: var(--line-strong); box-shadow: var(--shadow-sm); }
.sf-btn--secondary:hover { background: var(--bg-sunk); }
.sf-btn--ghost { background: transparent; color: var(--ink-2); }
.sf-btn--ghost:hover { background: var(--bg-sunk); color: var(--ink-1); }
.sf-btn--danger { background: transparent; color: var(--danger); border-color: oklch(0.88 0.06 28); }
.sf-btn--danger:hover { background: oklch(0.97 0.03 28); }
.sf-btn-icon { display: inline-flex; }
.sf-btn:disabled, .sf-btn[disabled] { opacity: 0.55; cursor: not-allowed; }
.sf-btn:disabled:hover, .sf-btn[disabled]:hover { background: var(--ink-1); border-color: var(--ink-1); color: #fff; }
.sf-btn--secondary:disabled:hover, .sf-btn--secondary[disabled]:hover { background: var(--panel); }
.sf-btn--ghost:disabled:hover, .sf-btn--ghost[disabled]:hover { background: transparent; color: var(--ink-2); }
.sf-btn--danger:disabled:hover, .sf-btn--danger[disabled]:hover { background: transparent; }

/* ==== Pills ==== */
.sf-pill {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 11.5px; font-weight: 550;
  padding: 3px 9px 3px 8px; border-radius: 999px;
  border: 1px solid var(--line);
}
.sf-pill-dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.sf-pill--ok { color: var(--ok); background: var(--ok-soft); border-color: oklch(0.9 0.05 150); }
.sf-pill--info { color: var(--info); background: var(--info-soft); border-color: oklch(0.9 0.04 240); }
.sf-pill--warn { color: var(--warn); background: var(--warn-soft); border-color: oklch(0.9 0.05 55); }
.sf-pill--muted { color: var(--ink-3); background: var(--bg-sunk); }

/* ==== Fields / inputs ==== */
.sf-field { display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.sf-field-head { display: flex; align-items: baseline; justify-content: flex-start; gap: 6px; }
.sf-label { font-size: 12.5px; font-weight: 550; color: var(--ink-2); line-height: 1.3; }
.sf-field-badge {
  font-size: 12px; color: var(--ink-4); font-weight: 450; line-height: 1.3;
}
.sf-hint { font-size: 12px; color: var(--ink-3); }
.sf-input, .sf-select, .sf-textarea {
  font-family: inherit; font-size: 13.5px; color: var(--ink-1);
  background: var(--panel); border: 1px solid var(--line-strong);
  border-radius: 7px; padding: 7px 10px; width: 100%;
  transition: border-color 100ms, box-shadow 100ms, background 100ms;
}
.sf-input:hover, .sf-select:hover, .sf-textarea:hover { border-color: oklch(0.80 0.01 80); }
.sf-input:focus, .sf-select:focus, .sf-textarea:focus {
  outline: none; border-color: var(--accent);
  box-shadow: 0 0 0 3px oklch(0.88 0.06 var(--accent-h) / 0.55);
}
.sf-input::placeholder, .sf-textarea::placeholder { color: var(--ink-4); }

.sf-input.is-invalid, .sf-select.is-invalid, .sf-textarea.is-invalid { border-color: var(--danger); }
.sf-input.is-invalid:focus, .sf-select.is-invalid:focus, .sf-textarea.is-invalid:focus {
  border-color: var(--danger);
  box-shadow: 0 0 0 3px oklch(0.88 0.06 28 / 0.55);
}
.sf-field-error { font-size: 12px; color: var(--danger); }
.sf-field:has(> .sf-field-error) > .sf-hint { display: none; }

/* Inline action button aligned with the input row of an adjacent sf-field. */
.sf-field-row { display: flex; gap: 8px; align-items: flex-start; }
.sf-field-row-action { margin-top: calc(1em + 12px); }

.sf-select:not([multiple]) {
  appearance: none; -webkit-appearance: none; -moz-appearance: none;
  background-image:
    linear-gradient(45deg, transparent 50%, var(--ink-3) 50%),
    linear-gradient(135deg, var(--ink-3) 50%, transparent 50%);
  background-position:
    calc(100% - 14px) 50%,
    calc(100% - 9px) 50%;
  background-size: 5px 5px, 5px 5px;
  background-repeat: no-repeat;
  padding-right: 28px; cursor: pointer;
}
.sf-select:not([multiple]):focus {
  background-image:
    linear-gradient(45deg, transparent 50%, var(--accent) 50%),
    linear-gradient(135deg, var(--accent) 50%, transparent 50%);
}
.sf-select[multiple] {
  padding: 6px 8px; background-image: none;
}
.sf-select[multiple] option {
  padding: 5px 8px; border-radius: 4px; margin: 1px 0;
}
.sf-select[multiple] option:checked {
  background: var(--accent-soft) linear-gradient(0deg, var(--accent-soft), var(--accent-soft));
  color: var(--accent-ink);
}

.sf-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
@media (max-width: 760px) { .sf-grid-2 { grid-template-columns: 1fr; } }

/* ==== Toggle ==== */
.sf-toggle { display: inline-flex; align-items: center; gap: 10px; cursor: pointer; user-select: none; }
.sf-toggle input { display: none; }
.sf-toggle-track {
  width: 32px; height: 18px; background: oklch(0.88 0.006 80);
  border-radius: 999px; padding: 2px; transition: background 150ms;
  display: inline-flex;
}
.sf-toggle-thumb {
  width: 14px; height: 14px; background: white; border-radius: 50%;
  box-shadow: 0 1px 2px oklch(0.3 0 0 / 0.3); transition: transform 150ms;
}
.sf-toggle input:checked + .sf-toggle-track { background: var(--accent); }
.sf-toggle input:checked + .sf-toggle-track .sf-toggle-thumb { transform: translateX(14px); }
.sf-toggle-label { font-size: 13px; color: var(--ink-2); }

/* ==== Empty state ==== */
.sf-empty {
  display: flex; flex-direction: column; align-items: center;
  text-align: center; padding: 40px 24px; gap: 8px;
}
.sf-empty-icon {
  width: 40px; height: 40px; border-radius: 10px;
  background: var(--bg-sunk); border: 1px solid var(--line);
  display: grid; place-items: center; color: var(--ink-3);
  margin-bottom: 4px;
}
.sf-empty-title { font-size: 14px; font-weight: 600; color: var(--ink-1); }
.sf-empty-body { font-size: 13px; color: var(--ink-3); max-width: 380px; line-height: 1.5; }
.sf-empty .sf-btn { margin-top: 10px; }

/* ==== Overview cards ==== */
.sf-overview { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
@media (max-width: 900px) { .sf-overview { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .sf-overview { grid-template-columns: 1fr; } }

.sf-ov-card {
  background: var(--panel); border: 1px solid var(--line);
  border-radius: var(--radius-lg); padding: 20px;
  display: flex; flex-direction: column; gap: 12px;
  cursor: pointer; transition: border-color 140ms, transform 140ms, box-shadow 140ms;
  position: relative; min-height: 150px;
}
.sf-ov-card:hover {
  border-color: oklch(0.80 0.05 var(--accent-h));
  box-shadow: 0 4px 16px oklch(0.5 0.05 var(--accent-h) / 0.1);
}
.sf-ov-icon {
  width: 36px; height: 36px; border-radius: 8px;
  background: var(--accent-soft); color: var(--accent-ink);
  display: grid; place-items: center;
}
.sf-ov-title { font-size: 14.5px; font-weight: 600; color: var(--ink-1); }
.sf-ov-body { font-size: 12.5px; color: var(--ink-3); line-height: 1.5; }
.sf-ov-foot { margin-top: auto; display: flex; justify-content: space-between; align-items: center; font-size: 12px; color: var(--ink-3); }
.sf-ov-status { display: flex; gap: 6px; align-items: center; }
.sf-ov-arrow { color: var(--ink-4); transition: transform 140ms, color 140ms; }
.sf-ov-card:hover .sf-ov-arrow { color: var(--accent); transform: translateX(2px); }

/* ==== Callout ==== */
.sf-callout {
  background: var(--accent-soft); border: 1px solid oklch(0.88 0.05 var(--accent-h));
  border-radius: var(--radius-lg); padding: 16px 18px;
  display: flex; gap: 14px; align-items: flex-start;
}
.sf-callout-icon {
  width: 28px; height: 28px; border-radius: 6px;
  background: var(--panel); color: var(--accent);
  display: grid; place-items: center; flex-shrink: 0;
}
.sf-callout h4 { font-size: 13.5px; font-weight: 600; color: var(--ink-1); margin: 0 0 2px; }
.sf-callout p { font-size: 12.5px; color: var(--ink-2); margin: 0; line-height: 1.5; }
.sf-callout a:not(.sf-btn) { color: var(--accent-ink); text-decoration: underline; }

/* ==== Drawer ==== */
.sf-drawer-backdrop {
  position: fixed; inset: 0; background: oklch(0.15 0 0 / 0.35);
  backdrop-filter: blur(2px); z-index: 100;
  animation: sf-fade 150ms ease-out;
}
.sf-drawer {
  position: fixed; top: 0; right: 0; bottom: 0;
  width: min(560px, 94vw); background: var(--panel);
  box-shadow: var(--shadow-lg);
  z-index: 101; display: flex; flex-direction: column;
  animation: sf-slide-in 220ms cubic-bezier(0.2, 0.8, 0.2, 1);
}
@keyframes sf-slide-in { from { transform: translateX(20px); opacity: 0; } to { transform: translateX(0); opacity: 1; } }
@keyframes sf-fade { from { opacity: 0; } to { opacity: 1; } }

.sf-drawer-head {
  display: flex; align-items: flex-start; justify-content: space-between;
  padding: 22px 24px 16px; border-bottom: 1px solid var(--line);
}
.sf-drawer-head h2 { font-size: 18px; margin: 0 0 2px; letter-spacing: -0.01em; font-weight: 600; }
.sf-drawer-head p { font-size: 13px; color: var(--ink-3); margin: 0; }
.sf-drawer-body { padding: 20px 24px; overflow: auto; flex: 1; }
.sf-drawer-foot {
  padding: 16px 24px; border-top: 1px solid var(--line);
  display: flex; justify-content: flex-end; gap: 8px;
  background: var(--bg-sunk);
}

/* ==== Command palette ==== */
.sf-palette-backdrop {
  position: fixed; inset: 0; background: oklch(0.15 0 0 / 0.35);
  backdrop-filter: blur(4px);
  z-index: 200;
  display: flex; align-items: flex-start; justify-content: center;
  padding-top: 15vh;
  animation: sf-fade 140ms ease-out;
}
.sf-palette {
  width: min(560px, 94vw); background: var(--panel);
  border-radius: 14px; box-shadow: var(--shadow-lg); overflow: hidden;
  border: 1px solid var(--line);
  animation: sf-pop 160ms cubic-bezier(0.2, 0.8, 0.2, 1);
}
@keyframes sf-pop { from { transform: translateY(-8px) scale(0.98); opacity: 0; } to { transform: none; opacity: 1; } }
.sf-palette-input {
  width: 100%; border: none; outline: none; padding: 16px 20px;
  font-family: inherit; font-size: 15px; color: var(--ink-1);
  border-bottom: 1px solid var(--line);
  background: transparent;
}
.sf-palette-list { max-height: 360px; overflow: auto; padding: 6px; }
.sf-palette-group-title {
  font-size: 10.5px; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.08em; color: var(--ink-3); padding: 8px 10px 4px;
}
.sf-palette-item {
  display: flex; align-items: center; gap: 12px;
  padding: 9px 10px; border-radius: 7px; cursor: pointer;
  color: var(--ink-1); font-size: 13.5px;
}
.sf-palette-item[data-active="true"],
.sf-palette-item:hover { background: var(--accent-soft); color: var(--accent-ink); }
.sf-palette-item svg { color: var(--ink-3); flex-shrink: 0; }
.sf-palette-item[data-active="true"] svg { color: var(--accent); }
.sf-palette-item-sub { margin-left: auto; font-size: 11px; color: var(--ink-3); }
.sf-palette-foot {
  padding: 10px 16px; border-top: 1px solid var(--line);
  background: var(--bg-sunk); font-size: 11px; color: var(--ink-3);
  display: flex; gap: 18px; justify-content: space-between;
}

/* ==== Toasts ==== */
.sf-toasts {
  position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%);
  z-index: 300; display: flex; flex-direction: column; gap: 8px;
}
.sf-toast {
  background: var(--ink-1); color: white;
  padding: 10px 16px; border-radius: 8px;
  font-size: 13px; display: flex; align-items: center; gap: 10px;
  box-shadow: var(--shadow-lg);
  animation: sf-toast-in 180ms cubic-bezier(0.2, 0.8, 0.2, 1);
}
.sf-toast svg { color: oklch(0.85 0.15 150); }
@keyframes sf-toast-in { from { transform: translateY(10px); opacity: 0; } to { transform: none; opacity: 1; } }

/* ==== Tweaks panel ==== */
.sf-tweaks {
  position: fixed; bottom: 20px; right: 20px; z-index: 400;
  width: 280px; background: var(--panel);
  border: 1px solid var(--line-strong); border-radius: 12px;
  box-shadow: var(--shadow-lg); padding: 14px 16px;
  font-size: 13px;
}
.sf-tweaks-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 10px;
}
.sf-tweaks-head h4 { margin: 0; font-size: 13px; font-weight: 600; }
.sf-tweak-row { display: flex; align-items: center; justify-content: space-between; padding: 6px 0; gap: 10px; }
.sf-tweak-row > span { color: var(--ink-3); font-size: 12px; }
.sf-swatches { display: flex; gap: 6px; }
.sf-swatch { width: 18px; height: 18px; border-radius: 50%; cursor: pointer; border: 2px solid transparent; }
.sf-swatch[data-active="true"] { border-color: var(--ink-1); }

/* ==== Misc ==== */
.sf-mono { font-family: var(--font-mono); }
.sf-secret {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-mono); font-size: 12px; color: var(--ink-2);
  background: var(--bg-sunk); padding: 4px 8px; border-radius: 5px;
  border: 1px solid var(--line);
}
.sf-divider { height: 1px; background: var(--line); margin: 18px 0; }
.sf-stack-sm > * + * { margin-top: 10px; }
.sf-stack > * + * { margin-top: 16px; }

.sf-stat-row { display: flex; gap: 24px; padding: 8px 0; }
.sf-stat { display: flex; flex-direction: column; gap: 2px; }
.sf-stat-val { font-size: 20px; font-weight: 600; color: var(--ink-1); letter-spacing: -0.02em; }
.sf-stat-label { font-size: 11.5px; color: var(--ink-3); text-transform: uppercase; letter-spacing: 0.05em; }
.sf-stat-trend { font-size: 11px; color: var(--ok); font-weight: 600; }

.sf-chip {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 3px 8px; border-radius: 5px; font-size: 12px;
  background: var(--bg-sunk); border: 1px solid var(--line);
  color: var(--ink-2);
}
.sf-chip .sf-chip-x { cursor: pointer; color: var(--ink-3); display: inline-flex; }
.sf-chip .sf-chip-x:hover { color: var(--danger); }

/* Provider marks */
.sf-mark-toggl      { background: oklch(0.96 0.02 20);  color: oklch(0.5 0.18 20); }
.sf-mark-shortcut   { background: oklch(0.96 0.04 260); color: oklch(0.45 0.18 260); }
.sf-mark-jira       { background: oklch(0.96 0.03 240); color: oklch(0.45 0.18 240); }
.sf-mark-linear     { background: oklch(0.96 0.03 280); color: oklch(0.45 0.18 280); }
.sf-mark-fifteen    { background: oklch(0.96 0.03 340); color: oklch(0.45 0.18 340); }
.sf-mark-github     { background: oklch(0.96 0.005 80); color: oklch(0.3 0.005 80); }

/* Switcher row for channel type */
.sf-tabs {
  display: inline-flex; gap: 2px; background: var(--bg-sunk);
  padding: 3px; border-radius: 8px; border: 1px solid var(--line);
}
.sf-tabs button {
  font-family: inherit; font-size: 12.5px; font-weight: 550;
  padding: 5px 12px; border: none; border-radius: 6px; cursor: pointer;
  background: transparent; color: var(--ink-3);
}
.sf-tabs button[data-active="true"] {
  background: var(--panel); color: var(--ink-1);
  box-shadow: var(--shadow-sm);
}

/* --- combobox (channel picker) ---------------------------------- */
.sf-combobox { position: relative; }

.sf-combobox-list {
  position: absolute;
  top: calc(100% + 4px); left: 0; right: 0;
  max-height: 280px; overflow-y: auto;
  background: var(--panel);
  border: 1px solid var(--line-strong);
  border-radius: 8px;
  box-shadow: var(--shadow-lg);
  list-style: none;
  margin: 0; padding: 4px;
  z-index: 50;
}

.sf-combobox-list[hidden] { display: none; }

.sf-combobox-hint {
  padding: 6px 10px 8px;
  font-size: 11.5px; color: var(--ink-3);
  text-transform: uppercase; letter-spacing: 0.04em;
  border-bottom: 1px solid var(--line);
  margin-bottom: 4px;
}

.sf-combobox-option {
  display: flex; align-items: center; gap: 8px;
  padding: 7px 10px; border-radius: 6px;
  cursor: pointer; font-size: 13.5px; color: var(--ink-1);
  user-select: none;
}

.sf-combobox-option:hover,
.sf-combobox-option.is-active {
  background: var(--accent-soft);
  color: var(--accent-ink);
}

.sf-combobox-icon {
  color: var(--ink-3); font-weight: 600;
  min-width: 14px; text-align: center; font-size: 14px;
}

.sf-combobox-option.is-active .sf-combobox-icon,
.sf-combobox-option:hover .sf-combobox-icon { color: var(--accent-ink); }

.sf-combobox-name { flex: 1; }

.sf-combobox-meta {
  font-size: 11.5px; color: var(--ink-3);
}

.sf-combobox-option.is-active .sf-combobox-meta,
.sf-combobox-option:hover .sf-combobox-meta { color: var(--accent-ink); opacity: 0.8; }

.sf-combobox-create {
  border-top: 1px solid var(--line);
  margin-top: 4px; padding-top: 9px;
  font-weight: 500;
}

.sf-combobox-empty {
  padding: 12px 10px;
  text-align: center; font-size: 12.5px; color: var(--ink-3);
}

/* --- multi-select combobox (chips + search) --------------------- */
.sf-multi-combobox {
  position: relative;
}

.sf-multi-combobox-wrapper {
  display: flex; flex-wrap: wrap; gap: 4px;
  padding: 4px 6px;
  background: var(--panel);
  border: 1px solid var(--line-strong);
  border-radius: 7px;
  min-height: 34px;
  cursor: text;
  align-items: center;
  transition: border-color 100ms, box-shadow 100ms;
}

.sf-multi-combobox-wrapper:hover { border-color: oklch(0.80 0.01 80); }

.sf-multi-combobox-wrapper:focus-within {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px oklch(0.88 0.06 var(--accent-h) / 0.55);
}

.sf-combobox-chip {
  display: inline-flex; align-items: center; gap: 4px;
  background: var(--accent-soft);
  color: var(--accent-ink);
  padding: 2px 4px 2px 9px;
  border-radius: 12px;
  font-size: 12px; font-weight: 500;
  line-height: 1.4;
}

.sf-combobox-chip-label {
  max-width: 240px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}

.sf-combobox-chip-remove {
  background: transparent; border: none;
  color: var(--accent-ink); opacity: 0.7;
  cursor: pointer;
  padding: 0 4px;
  font-size: 15px; line-height: 1;
  border-radius: 10px;
}

.sf-combobox-chip-remove:hover { opacity: 1; background: oklch(0.88 0.06 var(--accent-h) / 0.6); }

.sf-combobox-search {
  border: none; outline: none; background: transparent;
  font-family: inherit; font-size: 13.5px; color: var(--ink-1);
  flex: 1; min-width: 100px;
  padding: 3px 4px;
}

.sf-combobox-search::placeholder { color: var(--ink-4); }

.sf-combobox-option.is-selected {
  font-weight: 500;
}

.sf-combobox-option.is-selected::before {
  content: "✓";
  color: var(--accent);
  margin-right: 4px;
  font-weight: 700;
}

.sf-combobox-option.is-selected:not(:hover):not(.is-active)::before { color: var(--accent); }
/* Additional styles for Dashboard, Guides, Prompts */

.sf-stats-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
@media (max-width: 900px) { .sf-stats-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .sf-stats-grid { grid-template-columns: 1fr; } }

.sf-stat-card {
  background: var(--panel); border: 1px solid var(--line);
  border-radius: var(--radius-lg); padding: 18px 20px;
  display: flex; flex-direction: column; gap: 6px; min-height: 110px;
}
.sf-stat-card-head { display: flex; justify-content: space-between; align-items: center; }
.sf-stat-card-label { font-size: 12px; color: var(--ink-3); font-weight: 550; text-transform: uppercase; letter-spacing: 0.04em; }
.sf-stat-card-value { font-size: 28px; font-weight: 600; letter-spacing: -0.02em; color: var(--ink-1); }
.sf-stat-card-sub { font-size: 12.5px; color: var(--ink-3); }
.sf-stat-card--ok   { border-left: 3px solid var(--ok); }
.sf-stat-card--warn { border-left: 3px solid var(--warn); }
.sf-stat-card--danger { border-left: 3px solid var(--danger); }

.sf-panel-summary {
  font-size: 13px; color: var(--ink-2); margin: 0 0 10px;
}
.sf-panel-empty {
  font-size: 13px; color: var(--ink-3); text-align: center;
  padding: 16px 8px; margin: 0;
}

.sf-stat-list {
  display: flex; flex-direction: column; gap: 6px;
  margin-top: 8px; padding-top: 8px; border-top: 1px solid var(--line);
}
.sf-stat-list-item,
.sf-stat-list-row {
  display: grid; gap: 1px; text-decoration: none;
  color: var(--ink-1); border-radius: var(--radius-sm); padding: 5px 6px;
  margin: 0 -6px;
}
.sf-stat-list-item:hover { background: var(--bg-sunk); }
.sf-stat-list-row--danger { border-left: 2px solid var(--danger); padding-left: 8px; }
.sf-stat-list-more { margin-top: 2px; }
.sf-stat-list--nested { margin-top: 4px; padding-top: 4px; }
.sf-stat-list-title {
  font-size: 12.5px; font-weight: 550;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.sf-stat-list-meta { font-size: 11.5px; color: var(--ink-3); }
.sf-meta-emph { font-weight: 600; color: var(--ink-2); }

.sf-progress { height: 6px; background: var(--bg-sunk); border-radius: 3px; overflow: hidden; margin-top: 4px; }
.sf-progress-bar { height: 100%; background: var(--accent); border-radius: 3px; }

/* Two-column panels */
.sf-grid-detail { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 900px) { .sf-grid-detail { grid-template-columns: 1fr; } }

/* Bar chart */
.sf-bars { display: flex; align-items: flex-end; gap: 4px; height: 80px; padding-top: 8px; }
.sf-bar { flex: 1; background: var(--accent-soft); border-radius: 3px 3px 0 0; min-height: 4px; position: relative; }
.sf-bar-fill { position: absolute; inset: auto 0 0 0; background: var(--accent); border-radius: 3px 3px 0 0; }

/* Guides layout */
.sf-guides-layout { display: grid; grid-template-columns: 220px 1fr; gap: 32px; }
@media (max-width: 900px) { .sf-guides-layout { grid-template-columns: 1fr; } }
.sf-guides-toc {
  position: sticky; top: 80px; align-self: start;
  background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius-lg);
  padding: 14px;
}
.sf-toc-title { font-size: 11px; font-weight: 600; color: var(--ink-3); text-transform: uppercase; letter-spacing: 0.06em; padding: 4px 8px 8px; }
.sf-toc-item {
  display: flex; align-items: center; gap: 10px; padding: 6px 8px;
  font-size: 13px; color: var(--ink-2); border-radius: 6px; cursor: pointer; text-decoration: none;
}
.sf-toc-item:hover { background: var(--bg-sunk); color: var(--ink-1); }
.sf-toc-item[data-active="true"] { background: var(--accent-soft); color: var(--accent-ink); }
.sf-toc-mark {
  width: 22px; height: 22px; border-radius: 5px; display: grid; place-items: center;
  font-size: 11px; font-weight: 600;
  background: var(--bg-sunk); border: 1px solid var(--line); color: var(--ink-2);
}
.sf-toc-item[data-active="true"] .sf-toc-mark { background: var(--panel); border-color: oklch(0.88 0.05 var(--accent-h)); color: var(--accent-ink); }
.sf-toc-group { margin: 2px 0 6px 19px; padding-left: 11px; border-left: 1px solid var(--line); display: flex; flex-direction: column; }
.sf-toc-item--child { font-size: 12.5px; }

.sf-guide-card { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius-lg); overflow: hidden; margin-bottom: 20px; }
.sf-guide-head { padding: 18px 22px; border-bottom: 1px solid var(--line); display: flex; gap: 14px; align-items: center; }
.sf-guide-head-mark {
  width: 40px; height: 40px; border-radius: 10px; display: grid; place-items: center;
  font-weight: 600; font-size: 14px;
}
.sf-guide-head h2 { font-size: 17px; font-weight: 600; margin: 0; letter-spacing: -0.01em; }
.sf-guide-head p { font-size: 13px; color: var(--ink-3); margin: 2px 0 0; }
.sf-guide-body { padding: 20px 22px; font-size: 13.5px; line-height: 1.6; color: var(--ink-2); }
.sf-guide-body p { margin: 0 0 12px; }
.sf-guide-body p:last-child { margin: 0; }
.sf-guide-body a:not(.sf-btn) { color: var(--accent-ink); text-decoration: underline; }
.sf-guide-body code {
  font-family: var(--font-mono); font-size: 12px;
  background: var(--bg-sunk); padding: 1px 6px; border-radius: 4px;
  border: 1px solid var(--line);
}
.sf-guide-body .sf-codeblock code { background: transparent; border: none; padding: 0; color: inherit; font-size: inherit; }

.sf-step {
  display: flex; gap: 14px; padding: 14px 0;
  border-top: 1px solid var(--line);
}
.sf-step:first-child { border-top: none; padding-top: 4px; }
.sf-step-num {
  flex-shrink: 0; width: 24px; height: 24px; border-radius: 50%;
  background: var(--ink-1); color: white; font-size: 12px; font-weight: 600;
  display: grid; place-items: center; margin-top: 2px;
}
.sf-step-body { flex: 1; }
.sf-step-title { font-size: 14px; font-weight: 600; color: var(--ink-1); margin-bottom: 6px; }
.sf-step-content { font-size: 13px; color: var(--ink-2); line-height: 1.6; }

.sf-codeblock {
  font-family: var(--font-mono); font-size: 12px;
  background: oklch(0.18 0.005 80); color: oklch(0.98 0 0);
  padding: 12px 14px; border-radius: 8px;
  display: flex; justify-content: space-between; align-items: flex-start; gap: 12px;
  margin-top: 10px; word-break: break-all;
}
.sf-codeblock-copy {
  flex-shrink: 0; background: oklch(0.32 0.01 80); color: oklch(0.98 0 0);
  border: none; padding: 4px 8px; border-radius: 5px; font-family: inherit; font-size: 11px; cursor: pointer;
}
.sf-codeblock-copy:hover { background: oklch(0.42 0.01 80); }

.sf-kvlist { background: var(--bg-sunk); border-radius: 8px; padding: 12px 14px; border: 1px solid var(--line); }
.sf-kvrow { display: flex; gap: 10px; padding: 5px 0; font-size: 12.5px; align-items: flex-start; }
.sf-kvrow + .sf-kvrow { border-top: 1px solid var(--line); }
.sf-kvrow-label { min-width: 90px; color: var(--ink-3); font-weight: 550; }
.sf-kvrow-value { font-family: var(--font-mono); color: var(--ink-1); word-break: break-all; flex: 1; }
.sf-kvrow-value--muted { font-style: italic; color: var(--ink-3); font-family: inherit; }

/* Prompts */
.sf-split { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
@media (max-width: 900px) { .sf-split { grid-template-columns: 1fr; } }
.sf-textarea-code {
  font-family: var(--font-mono); font-size: 12.5px; line-height: 1.6;
  min-height: 240px; resize: vertical; tab-size: 2;
}
.sf-prompt-output {
  background: var(--bg-sunk); border: 1px solid var(--line);
  border-radius: 8px; padding: 14px 16px;
  font-size: 13px; line-height: 1.55;
  min-height: 240px; white-space: pre-wrap; color: var(--ink-2);
  font-family: inherit;
}
.sf-prompt-output--empty { color: var(--ink-3); display: flex; align-items: center; justify-content: center; font-style: italic; }

/* Home (landing) */
.sf-landing {
  min-height: 100vh; display: flex; flex-direction: column;
  background: radial-gradient(circle at 20% 0%, oklch(0.96 0.03 var(--accent-h)), var(--bg) 50%);
}
.sf-landing-nav { display: flex; justify-content: space-between; align-items: center; padding: 20px 40px; }
.sf-landing-hero {
  flex: 1; display: flex; flex-direction: column; align-items: center;
  justify-content: center; text-align: center; padding: 40px 20px;
}
.sf-landing-eyebrow {
  font-size: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--accent-ink); margin-bottom: 18px; padding: 4px 14px;
  border: 1px solid oklch(0.88 0.05 var(--accent-h)); border-radius: 999px;
  background: var(--accent-soft);
}
.sf-landing-title {
  font-size: clamp(40px, 6vw, 64px); font-weight: 600;
  letter-spacing: -0.03em; line-height: 1.02; margin: 0 0 18px;
  color: var(--ink-1);
}
.sf-landing-sub {
  font-size: 17px; color: var(--ink-3); max-width: 560px;
  line-height: 1.55; margin: 0 0 32px;
}
.sf-landing-cta-row {
  display: flex; gap: 12px; align-items: center;
  flex-wrap: wrap; justify-content: center;
}

/* Utility: section title */
.sf-section-title {
  font-size: 13px; font-weight: 600; color: var(--ink-2);
  margin: 28px 0 10px; letter-spacing: -0.005em;
  display: flex; align-items: center; gap: 8px;
}

/* GitHub Performance — inner content */
.sf-metric-section + .sf-metric-section { margin-top: 18px; }
.sf-metric-section-title {
  font-size: 11px; font-weight: 600; color: var(--ink-3);
  text-transform: uppercase; letter-spacing: 0.05em;
  margin: 0 0 8px;
}

.sf-metric-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 10px;
}
.sf-chart-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  margin-bottom: 18px;
}
@media (max-width: 760px) { .sf-chart-grid { grid-template-columns: 1fr; } }

.sf-metric {
  background: var(--bg-sunk); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 12px;
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  text-align: center; position: relative;
}
.sf-metric-head { display: inline-flex; align-items: center; gap: 6px; }
.sf-metric-value {
  font-size: 22px; font-weight: 600; color: var(--ink-1);
  letter-spacing: -0.01em; font-variant-numeric: tabular-nums;
}
.sf-metric-label-row { display: inline-flex; align-items: center; gap: 4px; }
.sf-metric-label { font-size: 12.5px; color: var(--ink-3); }

.sf-trend { font-size: 11px; font-weight: 600; font-variant-numeric: tabular-nums; }
.sf-trend--good { color: var(--ok); }
.sf-trend--bad { color: var(--danger); }

.sf-bench {
  display: inline-block; padding: 2px 8px; margin-top: 2px;
  border: 1px solid transparent; border-radius: 999px;
  font-size: 10.5px; font-weight: 600; letter-spacing: 0.02em;
}
.sf-bench--elite  { background: var(--accent-soft); color: var(--accent-ink); border-color: oklch(0.88 0.05 var(--accent-h)); }
.sf-bench--strong { background: var(--ok-soft); color: var(--ok); border-color: oklch(0.9 0.05 150); }
.sf-bench--fair   { background: var(--warn-soft); color: var(--warn); border-color: oklch(0.9 0.05 55); }
.sf-bench--poor   { background: oklch(0.97 0.03 28); color: var(--danger); border-color: oklch(0.88 0.06 28); }

.sf-info {
  display: inline-flex; align-items: center; color: var(--ink-4);
  cursor: help; position: relative;
}
.sf-info:hover { color: var(--ink-2); }
.sf-info-tooltip {
  position: absolute; bottom: 100%; left: 50%; transform: translateX(-50%);
  margin-bottom: 6px; padding: 4px 8px;
  background: var(--ink-1); color: var(--panel);
  font-size: 11px; white-space: nowrap; border-radius: 4px;
  opacity: 0; visibility: hidden; transition: opacity 120ms;
  pointer-events: none; z-index: 10;
}
.sf-info:hover .sf-info-tooltip { opacity: 1; visibility: visible; }

/* Trend chart wrapper */
.sf-chart {
  background: var(--bg-sunk); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 12px;
}
.sf-chart-empty {
  height: 120px; display: flex; align-items: center; justify-content: center;
  color: var(--ink-4); font-size: 12.5px;
}
.sf-chart-head {
  display: flex; align-items: center; justify-content: center;
  gap: 6px; margin-bottom: 4px;
}
.sf-chart-title { font-size: 12.5px; font-weight: 550; color: var(--ink-2); }

/* Trend chart SVG — sf-shell tokens */
.sf-trend-svg { width: 100%; height: auto; display: block; }

.sf-trend-line {
  fill: none; stroke-width: 2;
  stroke-linecap: round; stroke-linejoin: round;
}
.sf-trend-area { fill-opacity: 0.1; }

.sf-trend-line--accent { stroke: var(--accent); }
.sf-trend-line--ok     { stroke: var(--ok); }
.sf-trend-line--warn   { stroke: var(--warn); }
.sf-trend-line--danger { stroke: var(--danger); }

.sf-trend-area--accent { fill: var(--accent); }
.sf-trend-area--ok     { fill: var(--ok); }
.sf-trend-area--warn   { fill: var(--warn); }
.sf-trend-area--danger { fill: var(--danger); }

.sf-trend-point { cursor: pointer; transition: r 0.15s ease; }
.sf-trend-point:hover { r: 5; }
.sf-trend-point--accent { fill: var(--accent); }
.sf-trend-point--ok     { fill: var(--ok); }
.sf-trend-point--warn   { fill: var(--warn); }
.sf-trend-point--danger { fill: var(--danger); }

.sf-trend-grid { stroke: var(--line); stroke-width: 1; }
.sf-trend-axis-label { font-size: 10px; fill: var(--ink-3); }
.sf-trend-svg-title { font-size: 11px; font-weight: 550; fill: var(--ink-2); }

.sf-trend-tooltip { pointer-events: none; opacity: 0; transition: opacity 0.15s ease; }
.sf-trend-tooltip.visible { opacity: 1; }
.sf-trend-tooltip-bg { fill: var(--ink-1); fill-opacity: 0.9; }
.sf-trend-tooltip-text { fill: var(--panel); font-size: 9px; font-weight: 500; }
.sf-trend-tooltip-text--value { font-size: 10px; font-weight: 600; }

/* Members comparison table */
.sf-table-wrap { overflow-x: auto; margin-top: 12px; }
.sf-table {
  width: 100%; min-width: 100%;
  border-collapse: collapse; font-size: 12.5px;
}
.sf-table th {
  text-align: right; padding: 8px 10px;
  font-weight: 600; color: var(--ink-3);
  border-bottom: 1px solid var(--line);
  white-space: nowrap;
}
.sf-table th.sf-table-th--first {
  text-align: left; position: sticky; left: 0;
  background: var(--panel); z-index: 1;
}
.sf-table th.sf-table-th--last { text-align: left; }
.sf-table td {
  padding: 8px 10px; text-align: right;
  color: var(--ink-1); white-space: nowrap;
  font-variant-numeric: tabular-nums;
}
.sf-table td.sf-table-td--first {
  text-align: left; position: sticky; left: 0;
  background: var(--panel); z-index: 1;
}
.sf-table td.sf-table-td--last { text-align: left; }
.sf-table tbody tr { border-bottom: 1px solid var(--line); }
.sf-table tbody tr:last-child { border-bottom: 0; }

.sf-member-cell { display: flex; align-items: center; gap: 8px; }
.sf-member-name { font-weight: 550; color: var(--ink-1); }

.sf-mini-avatar {
  width: 22px; height: 22px; border-radius: 50%;
  object-fit: cover; flex-shrink: 0;
}
.sf-mini-avatar--initials {
  background: var(--bg-sunk); color: var(--ink-2);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 10px; font-weight: 600;
  border: 1px solid var(--line);
}

.sf-legend {
  display: inline-flex; gap: 8px; margin-top: 2px;
  font-size: 10px; color: var(--ink-4); font-weight: 400;
}
.sf-legend-dot {
  width: 6px; height: 6px; border-radius: 50%; margin-right: 3px;
  display: inline-block;
}
.sf-legend-dot--new { background: var(--ok); }
.sf-legend-dot--refactor { background: var(--accent); }
.sf-legend-dot--rework { background: var(--danger); }

.sf-stack-bar {
  display: flex; width: 80px; height: 6px;
  background: var(--bg-sunk); border-radius: 3px; overflow: hidden;
}
.sf-stack-bar-seg { height: 100%; }
.sf-stack-bar-seg--new { background: var(--ok); }
.sf-stack-bar-seg--refactor { background: var(--accent); }
.sf-stack-bar-seg--rework { background: var(--danger); }

.sf-disclosure-summary {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 12.5px; font-weight: 600; color: var(--ink-3);
  cursor: pointer; list-style: none;
  padding: 4px 0;
}
.sf-disclosure-summary::-webkit-details-marker { display: none; }
.sf-disclosure-summary:hover { color: var(--ink-1); }
.sf-disclosure-chevron {
  display: inline-block; transition: transform 150ms;
  font-size: 9px; color: var(--ink-4);
}
details[open] .sf-disclosure-chevron { transform: rotate(90deg); }

/* GitHub Performance card */
.sf-input--sm {
  font-size: 12.5px; padding: 6px 8px;
  width: auto; min-width: 0;
}
.sf-gh-metrics-form { display: flex; align-items: center; gap: 8px; }
.sf-gh-metrics-form-sep { font-size: 12.5px; color: var(--ink-3); }

.sf-gh-metrics-tabs {
  display: flex; gap: 2px; padding-bottom: 0;
  margin-bottom: 14px;
  border-bottom: 1px solid var(--line);
  overflow-x: auto;
  scrollbar-width: none;
}
.sf-gh-metrics-tabs::-webkit-scrollbar { display: none; }
.sf-gh-metrics-tab-wrap { position: relative; }
.sf-gh-metrics-tab-input {
  position: absolute; opacity: 0; width: 0; height: 0;
  pointer-events: none;
}
.sf-gh-metrics-tab {
  display: inline-block; padding: 8px 14px;
  font-size: 13px; font-weight: 550; color: var(--ink-3);
  white-space: nowrap; cursor: pointer;
  border-bottom: 2px solid transparent; margin-bottom: -1px;
  transition: color 120ms, border-color 120ms;
}
.sf-gh-metrics-tab:hover { color: var(--ink-1); }
.sf-gh-metrics-tab-input:checked + .sf-gh-metrics-tab {
  color: var(--accent-ink); border-bottom-color: var(--accent);
}

.sf-gh-metrics-skeleton { display: flex; flex-direction: column; gap: 12px; }
.sf-gh-metrics-skeleton-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
}
.sf-gh-metrics-skeleton-card,
.sf-gh-metrics-skeleton-bar {
  background: var(--bg-sunk); border-radius: 8px;
  animation: sf-skeleton-pulse 1.6s ease-in-out infinite;
}
.sf-gh-metrics-skeleton-card { height: 120px; }
.sf-gh-metrics-skeleton-bar { height: 60px; }
@keyframes sf-skeleton-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.55; }
}

/* PR section headings inside the Pull Requests panel */
.sf-pr-section + .sf-pr-section { margin-top: 16px; }
.sf-pr-section-title {
  font-size: 11px; font-weight: 600; color: var(--ink-3);
  text-transform: uppercase; letter-spacing: 0.05em;
  margin: 0 0 6px;
}

/* Inline link in card heads / panels */
.sf-link {
  font-size: 13px; font-weight: 550; color: var(--accent-ink);
  text-decoration: none;
}
.sf-link:hover { text-decoration: underline; }

/* Hero badges (dashboard action chips) */
.sf-hero-badges {
  display: flex; flex-wrap: wrap; gap: 8px;
  margin: 4px 0 8px;
}
.sf-hero-badge {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 7px 14px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--panel);
  text-decoration: none;
  transition: background 120ms, border-color 120ms, transform 120ms;
}
.sf-hero-badge:hover { transform: translateY(-1px); border-color: var(--line-strong); }
.sf-hero-badge-value {
  font-size: 14px; font-weight: 600; color: var(--ink-1);
  font-variant-numeric: tabular-nums;
}
.sf-hero-badge-label { font-size: 12.5px; color: var(--ink-2); }
.sf-hero-badge--warn {
  border-color: oklch(0.88 0.06 55); background: var(--warn-soft);
}
.sf-hero-badge--warn .sf-hero-badge-value { color: var(--warn); }
.sf-hero-badge--warn .sf-hero-badge-label { color: var(--warn); }
.sf-hero-badge--danger {
  border-color: oklch(0.88 0.06 28); background: oklch(0.97 0.03 28);
}
.sf-hero-badge--danger .sf-hero-badge-value { color: var(--danger); }
.sf-hero-badge--danger .sf-hero-badge-label { color: var(--danger); }

/* Stimulus-controlled tab states (matches the .sf-tabs data-active styling
   since tabs_controller.js toggles classes rather than data attributes).
   Selectors scoped under .sf-tabs to outweigh the .sf-tabs button reset. */
.sf-tabs .sf-tab-active {
  background: var(--panel);
  color: var(--ink-1);
  box-shadow: var(--shadow-sm);
}
.sf-tabs .sf-tab-inactive {
  background: transparent;
  color: var(--ink-3);
}

/* ==== Misc utilities ==== */
.sf-spinner {
  width: 14px; height: 14px; border-radius: 50%;
  border: 2px solid var(--line); border-top-color: var(--accent);
  animation: sf-spin 800ms linear infinite;
  display: inline-block;
}
@keyframes sf-spin { to { transform: rotate(360deg); } }
.sf-details-summary {
  font-size: 12px; font-weight: 600; color: var(--ink-3);
  cursor: pointer; padding: 4px 0; list-style: none;
}
.sf-details-summary::-webkit-details-marker { display: none; }
.sf-details-summary:hover { color: var(--ink-1); }
.sf-code-dump {
  margin-top: 6px; padding: 10px 12px;
  background: var(--bg-sunk); border: 1px solid var(--line); border-radius: 8px;
  font-family: var(--font-mono); font-size: 11.5px; color: var(--ink-2);
  white-space: pre-wrap; word-break: break-all; max-height: 260px; overflow: auto;
}
.hidden { display: none !important; }

/* ==== Form layout ==== */
.sf-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
@media (max-width: 900px) { .sf-grid-3 { grid-template-columns: 1fr; } }
.sf-stack-md > * + * { margin-top: 18px; }
.sf-select[multiple] { min-height: 140px; }
.sf-select[multiple].sf-select--sm { min-height: 110px; }
.sf-mapping-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; align-items: center; }
@media (max-width: 760px) { .sf-mapping-grid { grid-template-columns: 1fr; } }
.sf-mapping-label { font-size: 13px; color: var(--ink-2); }

/* ==== Onboarding checklist ==== */
.sf-onboarding { display: flex; flex-direction: column; gap: 16px; }
.sf-onboarding-progress { display: flex; align-items: center; gap: 12px; }
.sf-onboarding-bar {
  flex: 1; height: 6px; background: var(--bg-sunk);
  border-radius: 999px; overflow: hidden;
}
.sf-onboarding-bar-fill {
  height: 100%; background: var(--accent);
  transition: width 200ms ease;
}
.sf-onboarding-count { font-size: 12px; color: var(--ink-3); font-variant-numeric: tabular-nums; }
.sf-onboarding-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.sf-onboarding-step {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 12px; border: 1px solid var(--line); border-radius: 8px;
  background: var(--panel); transition: background 120ms, border-color 120ms, transform 120ms;
}
.sf-onboarding-step-link {
  display: flex; align-items: center; gap: 12px; flex: 1;
  color: inherit; text-decoration: none;
}
.sf-onboarding-step:not(.sf-onboarding-step--done):hover {
  background: var(--accent-soft); border-color: oklch(0.85 0.08 var(--accent-h)); cursor: pointer;
}
.sf-onboarding-step:not(.sf-onboarding-step--done):hover .sf-onboarding-step-arrow { transform: translateX(3px); color: var(--accent-ink); }
.sf-onboarding-step-arrow { color: var(--ink-3); transition: transform 120ms, color 120ms; margin-left: auto; flex-shrink: 0; }
.sf-onboarding-step--done { background: var(--ok-soft); border-color: oklch(0.9 0.05 150); }
.sf-onboarding-mark {
  width: 22px; height: 22px; border-radius: 999px;
  display: flex; align-items: center; justify-content: center;
  background: var(--bg-sunk); color: var(--ok); flex-shrink: 0;
}
.sf-onboarding-step--done .sf-onboarding-mark { background: var(--ok); color: white; }
.sf-onboarding-dot {
  width: 8px; height: 8px; border-radius: 999px;
  background: var(--ink-3);
}
.sf-onboarding-title { font-size: 13px; font-weight: 550; color: var(--ink-1); }
.sf-onboarding-hint { font-size: 12px; color: var(--ink-3); margin-top: 2px; }

/* ==== Chip multi-select ==== */
.sf-chipset {
  display: flex; flex-wrap: wrap; gap: 6px;
  padding: 8px; min-height: 44px;
  background: var(--panel); border: 1px solid var(--line); border-radius: 8px;
}
.sf-chipset--compact { min-height: 40px; }
.sf-chipset-empty {
  font-size: 12px; color: var(--ink-3); padding: 6px 4px;
}
.sf-chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 12px; border: 1px solid var(--line-strong); border-radius: 999px;
  background: var(--bg-sunk); color: var(--ink-2);
  font-size: 12.5px; cursor: pointer;
  user-select: none;
  transition: background 120ms, color 120ms, border-color 120ms;
}
.sf-chip:hover { border-color: var(--ink-3); color: var(--ink-1); }
.sf-chip:has(.sf-chip-input:checked) {
  background: var(--accent);
  color: white;
  border-color: var(--accent);
}
.sf-chip-input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
  pointer-events: none;
}

/* ==== Day toggle (typical days off) ==== */
.sf-day-toggle-group {
  display: flex;
  gap: 6px;
  padding: 4px;
  background: var(--bg-sunk);
  border: 1px solid var(--line);
  border-radius: 10px;
}
.sf-day-toggle {
  flex: 1;
  justify-content: center;
  padding: 8px 6px;
  background: var(--panel);
  color: var(--ink-2);
  border: 1px solid var(--line-strong);
  border-radius: 6px;
  cursor: pointer;
  font-weight: 500;
  transition: background 120ms, color 120ms, border-color 120ms, box-shadow 120ms;
}
.sf-day-toggle:hover { border-color: var(--ink-3); color: var(--ink-1); }
.sf-day-toggle:has(.sf-day-toggle-input:checked) {
  background: var(--accent);
  color: white;
  border-color: var(--accent);
  box-shadow: 0 1px 2px oklch(0 0 0 / 0.1);
}
.sf-day-toggle-input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
  width: 0;
  height: 0;
}

/* ==== Checkbox cards (for workflow toggles) ==== */
.sf-check-card {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 10px 12px; border: 1px solid var(--line); border-radius: 8px;
  cursor: pointer; transition: border-color 120ms;
}
.sf-check-card:hover { border-color: var(--line-strong); }
.sf-check-card input { margin-top: 2px; }
.sf-check-card-title { font-size: 13px; font-weight: 550; color: var(--ink-1); }
.sf-check-card-desc  { font-size: 12px; color: var(--ink-3); margin-top: 2px; }

/* ==== Project mapping rows ==== */
.sf-mapping-row {
  display: flex; align-items: center; gap: 8px; margin-top: 4px;
  flex-wrap: nowrap; overflow: hidden;
}
.sf-mapping-row > svg { flex-shrink: 0; color: var(--ink-4); }
.sf-chip--provider { flex-shrink: 0; gap: 6px; }
.sf-chip--warn { color: var(--warn); border-color: oklch(0.88 0.06 55); background: var(--warn-soft); }
.sf-chip-mark {
  width: 16px; height: 16px; border-radius: 4px;
  display: grid; place-items: center; font-size: 10px; font-weight: 600;
  flex-shrink: 0;
}

/* ==== Prefix chip list ==== */
.sf-prefix-add {
  display: flex; gap: 6px; align-items: center;
}
.sf-prefix-add .sf-input { flex: 1; min-width: 0; }
.sf-prefix-list {
  display: flex; flex-wrap: wrap; gap: 6px; margin-top: 8px;
}
.sf-prefix-list:empty { display: none; }
.sf-prefix-chip {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 4px 4px 4px 10px; border: 1px solid var(--line-strong); border-radius: 999px;
  background: var(--bg-sunk); color: var(--ink-1);
  font-size: 12.5px; font-family: var(--font-mono, monospace);
}
.sf-prefix-chip[data-default="true"] {
  background: var(--accent-soft, oklch(0.96 0.05 255));
  border-color: var(--accent);
  color: var(--accent);
}
.sf-prefix-chip-text { padding-right: 2px; }
.sf-prefix-chip-btn {
  display: inline-grid; place-items: center;
  width: 22px; height: 22px; border-radius: 999px;
  border: 0; background: transparent; color: var(--ink-3); cursor: pointer;
  transition: background 120ms, color 120ms;
}
.sf-prefix-chip-btn:hover { background: var(--panel); color: var(--ink-1); }
.sf-prefix-chip-btn--x:hover { color: var(--danger); }
.sf-prefix-chip[data-default="true"] .sf-prefix-chip-btn--star { color: var(--accent); }
.sf-prefix-list-empty { font-size: 12px; color: var(--ink-3); }

/* ==== LLM keys rows ==== */
.sf-llm-row { gap: 14px; }
.sf-llm-form { display: flex; gap: 6px; flex-shrink: 0; align-items: center; }
.sf-llm-masked { display: flex; gap: 6px; align-items: center; }
.sf-llm-mask { font-family: var(--font-mono); color: var(--ink-3); letter-spacing: 2px; padding: 0 8px; }
.sf-llm-form-inner { display: flex; gap: 6px; align-items: center; }
.sf-llm-form .sf-input { min-width: 240px; max-width: 280px; }
@media (max-width: 760px) {
  .sf-llm-row { flex-wrap: wrap; }
  .sf-llm-form { width: 100%; margin-top: 6px; }
  .sf-llm-form .sf-input { min-width: 0; flex: 1; max-width: none; }
}

/* ==== Bucket rows (Focus Journal) ==== */
.sf-bucket-edit-form { display: flex; gap: 6px; align-items: center; width: 100%; }
.sf-bucket-edit-form .sf-input { flex: 1; min-width: 0; }

/* ==== Icon-only buttons ==== */
.sf-btn--icon-only {
  padding: 0; width: 28px; height: 28px;
  justify-content: center; flex-shrink: 0;
}
.sf-btn--danger-hover:hover { color: var(--danger); background: oklch(0.97 0.03 28); }

/* Inline button_to forms (keep button flush inline) */
.sf-inline-form { display: inline-flex; margin: 0; }
.submission-page * {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

.submission-page {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  color: #2d3748;
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}

.submission-page .container {
  background: white;
  border-radius: 12px;
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.1);
  max-width: 600px;
  width: 100%;
  padding: 40px 30px;
  text-align: center;
}

.submission-page h1 {
  color: #2d3748;
  font-size: 24px;
  margin-bottom: 8px;
  font-weight: 600;
}

.submission-page .subtitle {
  color: #718096;
  font-size: 16px;
  margin-bottom: 20px;
}

.submission-page .hint {
  font-size: 12px;
  color: #718096;
  margin-top: 4px;
}

.submission-page .required-label {
  font-size: 12px;
  color: #e53e3e;
  font-weight: normal;
}

.submission-page .optional-label {
  font-size: 12px;
  color: #718096;
  font-weight: normal;
}

.submission-page .form-group {
  margin-bottom: 20px;
  text-align: left;
}

.submission-page label {
  display: block;
  font-size: 14px;
  font-weight: 500;
  margin-bottom: 4px;
  margin-top: 8px;
}

.submission-page input[type="text"],
.submission-page input[type="password"] {
  width: 100%;
  padding: 12px 16px;
  border: 2px solid #e2e8f0;
  border-radius: 8px;
  font-size: 16px;
  transition: border-color 0.2s ease;
  font-family: 'SF Mono', Monaco, 'Cascadia Code', 'Roboto Mono', Consolas, 'Courier New', monospace;
}

.submission-page input[type="text"]:focus,
.submission-page input[type="password"]:focus {
  outline: none;
  border-color: #667eea;
  box-shadow: 0 0 0 3px rgba(102, 126, 234, 0.1);
}

.submission-page input[type="text"]:disabled,
.submission-page input[type="password"]:disabled {
  cursor: not-allowed;
}

.submission-page .input-with-copy {
  display: flex;
  gap: 12px;
  align-items: center;
}

.submission-page .input-with-copy input[type="text"] {
  flex: 1;
}

.submission-page .input-with-copy .copy-btn {
  width: auto;
  flex: 0 0 auto;
  white-space: nowrap;
  min-width: 110px;
}

.submission-page .btn {
  padding: 12px 24px;
  border-radius: 8px;
  font-size: 16px;
  font-weight: 500;
  cursor: pointer;
  transition: background-color 0.2s ease, border-color 0.2s ease;
  flex: 1;
  text-align: center;
  text-decoration: none;
  display: inline-block;
  border: 2px solid transparent;
  background: #667eea;
  color: white;
  width: 100%;
}

.submission-page .btn:hover {
  background: #5a67d8;
}

.submission-page .btn:disabled {
  background: #a0aec0;
  cursor: not-allowed;
}

.submission-page .btn-primary {
  background: #667eea;
  color: white;
}

.submission-page .btn-primary:hover {
  background: #5a67d8;
}

.submission-page .btn-secondary {
  background: white;
  color: #667eea;
  border-color: #667eea;
}

.submission-page .btn-secondary:hover {
  background: #f7fafc;
  border-color: #5a67d8;
  color: #5a67d8;
}

.submission-page .button-group {
  display: flex;
  gap: 12px;
  justify-content: center;
}

.submission-page .generate-button-group {
  margin-top: 12px;
}

.submission-page .error {
  background: #fed7d7;
  border: 1px solid #feb2b2;
  border-radius: 6px;
  padding: 12px;
  color: #c53030;
  font-size: 14px;
  margin-bottom: 20px;
}

.submission-page .warning-box {
  background: #fefcbf;
  border: 1px solid #ecc94b;
  border-radius: 6px;
  padding: 12px;
  color: #744210;
  font-size: 14px;
  margin: 16px 0;
  text-align: left;
}

.submission-page .masked-token {
  font-family: 'SF Mono', Monaco, 'Cascadia Code', 'Roboto Mono', Consolas, 'Courier New', monospace;
  background: #f7fafc;
  padding: 8px 12px;
  border-radius: 4px;
  border: 1px solid #e2e8f0;
  margin: 8px 0;
  font-size: 14px;
  word-wrap: break-word;
  color: #2d3748;
}

.submission-page .instructions {
  border: 1px solid #e2e8f0;
  border-radius: 6px;
  padding: 16px;
  font-size: 14px;
  margin-bottom: 20px;
  text-align: left;
}

.submission-page .instructions a {
  color: #667eea;
  text-decoration: none;
  word-wrap: break-word;
}

.submission-page .instructions a:hover {
  text-decoration: underline;
}

.submission-page .instructions h4 {
  font-weight: 600;
  margin-bottom: 8px;
}

.submission-page .instructions ul {
  padding-left: 20px;
}

.submission-page .instructions ol {
  padding-left: 20px;
  margin-bottom: 12px;
}

.submission-page .instructions li {
  margin-bottom: 4px;
  line-height: 1.5;
}

.submission-page .webhook-url-section {
  background: #f7fafc;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  padding: 16px;
  margin-bottom: 20px;
  text-align: left;
}

.submission-page .webhook-url-section h4 {
  font-weight: 600;
  margin-bottom: 8px;
  color: #2d3748;
}

.submission-page .webhook-url {
  font-family: 'SF Mono', Monaco, 'Cascadia Code', 'Roboto Mono', Consolas, 'Courier New', monospace;
  background: #edf2f7;
  padding: 12px;
  border-radius: 6px;
  font-size: 13px;
  word-break: break-all;
  color: #4a5568;
  margin-top: 8px;
  user-select: all;
}

.submission-page .success-note {
  font-size: 14px;
  margin-top: 20px;
  color: #718096;
}

@media (max-width: 480px) {
  .submission-page .container {
    padding: 30px 20px;
  }

  .submission-page h1 {
    font-size: 20px;
  }
}
/*
 * This is a manifest file that'll be compiled into application.css, which will include all the files
 * listed below.
 *
 * Any CSS (and SCSS, if configured) file within this directory, lib/assets/stylesheets, or any plugin's
 * vendor/assets/stylesheets directory can be referenced here using a relative path.
 *
 * You're free to add application-wide styles to this file and they'll appear at the bottom of the
 * compiled file so the styles you add here take precedence over styles defined in any other CSS
 * files in this directory. Styles in this file should be added after the last require_* statement.
 * It is generally better to create a new file per style scope.
 *


 */
