/* ============================================================
   SETTERAI - DESIGN SYSTEM
   ============================================================ */

/* Tokens */
:root {
  --ink:            #15201c;
  --ink-muted:      #61706a;
  --ink-subtle:     #8fa09a;
  --line:           #dbe3de;
  --line-strong:    #c5d3ce;
  --paper:          #f6f4ee;
  --panel:          #ffffff;
  --night:          #101917;
  --night-2:        #172822;
  --night-3:        #1e3028;
  --accent:         #1f8f66;
  --accent-strong:  #126647;
  --accent-light:   #e6f4ed;
  --accent-glow:    rgba(31,143,102,.18);
  --warning:        #b07121;
  --error:          #c0392b;

  --sidebar-w:      252px;
  --topbar-h:       62px;

  --shadow-sm:  0 1px 3px rgba(21,32,28,.07), 0 1px 2px rgba(21,32,28,.05);
  --shadow-md:  0 4px 16px rgba(21,32,28,.11), 0 2px 6px rgba(21,32,28,.07);
  --shadow-lg:  0 16px 48px rgba(21,32,28,.15), 0 6px 18px rgba(21,32,28,.09);
  --shadow-xl:  0 28px 90px rgba(21,32,28,.18), 0 12px 32px rgba(21,32,28,.10);

  --radius-xs:  4px;
  --radius-sm:  8px;
  --radius:     12px;
  --radius-lg:  16px;
  --radius-xl:  24px;

  --ease: cubic-bezier(.22,.68,0,1.2);
  --dur:  .2s;
}

/* Reset */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
body {
  color: var(--ink);
  background: var(--paper);
  font-family: 'Inter', ui-sans-serif, system-ui, -apple-system, sans-serif;
  font-size: .9375rem;
  line-height: 1.55;
}
a { color: inherit; text-decoration: none; }
img, svg { display: block; }
button { font-family: inherit; }

/* Typography */
h1,h2,h3,h4,h5,h6 { font-weight: 700; line-height: 1.1; letter-spacing: -.02em; }

.eyebrow {
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--accent);
}

/* Flash */
.flash-stack {
  position: fixed;
  right: 24px;
  top: 80px;
  z-index: 9999;
  display: grid;
  gap: 10px;
  max-width: 360px;
  pointer-events: none;
}
.flash {
  padding: 14px 18px;
  border-radius: var(--radius-sm);
  background: var(--panel);
  box-shadow: var(--shadow-lg);
  font-size: .88rem;
  border-left: 3px solid var(--line-strong);
  animation: flash-in .3s var(--ease);
  pointer-events: all;
}
.flash.error   { border-left-color: var(--error);  color: var(--error); }
.flash.success { border-left-color: var(--accent); color: var(--accent-strong); }
.flash.warning { border-left-color: #f59e0b; color: #92400e; }
@keyframes flash-in {
  from { opacity:0; transform: translateX(16px); }
  to   { opacity:1; transform: translateX(0); }
}

/* Buttons */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  padding: 0 18px;
  min-height: 42px;
  border: 1.5px solid transparent;
  border-radius: var(--radius-sm);
  font: inherit;
  font-size: .875rem;
  font-weight: 600;
  cursor: pointer;
  transition: all var(--dur) ease;
  text-decoration: none;
  white-space: nowrap;
  line-height: 1;
  letter-spacing: -.01em;
}
.btn:disabled { opacity: .5; cursor: not-allowed; }

.btn-primary {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
  box-shadow: 0 3px 12px rgba(31,143,102,.3);
}
.btn-primary:hover:not(:disabled) {
  background: var(--accent-strong);
  border-color: var(--accent-strong);
  box-shadow: 0 6px 20px rgba(31,143,102,.38);
  transform: translateY(-1px);
}
.btn-primary:active { transform: none; }

.btn-secondary {
  background: transparent;
  color: var(--ink);
  border-color: var(--line-strong);
}
.btn-secondary:hover:not(:disabled) {
  background: var(--paper);
  border-color: var(--ink-subtle);
}

.btn-ghost {
  background: transparent;
  color: var(--ink-muted);
  border-color: transparent;
}
.btn-ghost:hover:not(:disabled) { background: var(--paper); color: var(--ink); }

.btn-danger {
  background: #fee2e2;
  color: var(--error);
  border-color: #fca5a5;
}
.btn-danger:hover:not(:disabled) { background: #fecaca; }

.btn-sm   { min-height: 32px; padding: 0 12px; font-size: .8rem; border-radius: 6px; }
.btn-lg   { min-height: 52px; padding: 0 28px; font-size: .975rem; }
.btn-full { width: 100%; }
.btn-icon { width: 17px; height: 17px; }

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 44px;
  padding: 0 18px;
  border-radius: var(--radius-sm);
  border: 1.5px solid transparent;
  font-size: .9rem;
  font-weight: 700;
  transition: all var(--dur) ease;
}
.button-primary {
  background: var(--accent);
  color: #fff;
  box-shadow: 0 12px 28px rgba(31,143,102,.28);
}
.button-primary:hover { background: var(--accent-strong); transform: translateY(-1px); }
.button-secondary {
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.22);
  color: #fff;
}
.button-secondary:hover { background: rgba(255,255,255,.14); }

/* Forms */
.form-group { margin-bottom: 16px; }
.form-group label {
  display: block;
  font-size: .82rem;
  font-weight: 600;
  color: var(--ink);
  margin-bottom: 6px;
  letter-spacing: -.01em;
}
.form-group input,
.form-group select,
.form-group textarea {
  display: block;
  width: 100%;
  padding: 11px 14px;
  border: 1.5px solid var(--line);
  border-radius: var(--radius-sm);
  background: #fff;
  font: inherit;
  font-size: .9rem;
  color: var(--ink);
  transition: border-color var(--dur) ease, box-shadow var(--dur) ease;
  outline: none;
  -webkit-appearance: none;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-glow);
}
.form-group input::placeholder { color: var(--ink-subtle); }
.form-group textarea { resize: vertical; min-height: 100px; }
.form-group select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2361706a' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 36px;
}

.form-hint { font-size: .76rem; color: var(--ink-subtle); margin-top: 5px; }
.form-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }

.input-wrap { position: relative; }
.input-wrap .input-icon {
  position: absolute;
  left: 13px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--ink-subtle);
  pointer-events: none;
  width: 16px;
  height: 16px;
}
.input-wrap input { padding-left: 40px; }

.toggle-row {
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  font-size: .875rem;
  font-weight: 500;
}
.toggle-row input[type=checkbox] {
  width: 18px;
  height: 18px;
  border-radius: 4px;
  accent-color: var(--accent);
  cursor: pointer;
}

/* Cards */
.card {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}
.card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid var(--line);
  background: #fafaf9;
}
.card-header h3 {
  font-size: .9rem;
  font-weight: 700;
  letter-spacing: -.02em;
}
.card-body { padding: 20px; }

/* Stat cards */
.stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 14px;
}
.stat-card {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 18px 20px;
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--dur) ease, transform var(--dur) ease;
  cursor: default;
}
.stat-card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.stat-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
}
.stat-label {
  font-size: .72rem;
  font-weight: 700;
  color: var(--ink-muted);
  text-transform: uppercase;
  letter-spacing: .05em;
}
.stat-icon {
  width: 34px; height: 34px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .95rem;
}
.si-green  { background: var(--accent-light); }
.si-blue   { background: #eff6ff; }
.si-purple { background: #f3e8ff; }
.si-amber  { background: #fffbeb; }
.stat-value {
  font-size: 2rem;
  font-weight: 800;
  letter-spacing: -.04em;
  line-height: 1;
  margin-bottom: 4px;
}
.stat-sub {
  font-size: .76rem;
  color: var(--ink-subtle);
}
.stat-sub.up   { color: var(--accent); }
.stat-sub.down { color: var(--error); }

/* Tables */
.table-wrap { overflow-x: auto; }
.dashboard-recent-table { padding: 14px 18px 18px; }
.data-table { width: 100%; border-collapse: collapse; }
.data-table th {
  padding: 11px 16px;
  text-align: left;
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--ink-muted);
  border-bottom: 1px solid var(--line);
  background: #fafaf9;
  white-space: nowrap;
}
.data-table td {
  padding: 13px 16px;
  border-bottom: 1px solid var(--line);
  font-size: .875rem;
  vertical-align: middle;
}
.data-table tr:last-child td { border-bottom: none; }
.data-table tbody tr { transition: background var(--dur) ease; }
.data-table tbody tr:hover { background: #fafaf8; }
.data-table .actions { display: flex; gap: 6px; }

/* Badges */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 9px;
  border-radius: 99px;
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .02em;
}
.badge-green  { background: #dcfce7; color: #15803d; }
.badge-red    { background: #fee2e2; color: #b91c1c; }
.badge-yellow { background: #fef9c3; color: #a16207; }
.badge-blue   { background: #dbeafe; color: #1d4ed8; }
.badge-gray   { background: #f4f4f5; color: #71717a; }
.badge-purple { background: #f3e8ff; color: #7c3aed; }
.badge-teal   { background: var(--accent-light); color: var(--accent-strong); }

/* Empty state */
.empty-state {
  padding: 56px 24px;
  text-align: center;
  color: var(--ink-muted);
}
.empty-state .empty-icon { font-size: 2.4rem; margin-bottom: 14px; }
.empty-state p { font-size: .9rem; line-height: 1.6; }
.empty-state .btn { margin-top: 20px; }

/* Auth pages */
.auth-root {
  min-height: 100svh;
  display: grid;
  grid-template-columns: 1fr 1fr;
}

.auth-brand {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 44px 48px;
  background: var(--night);
  color: #f8fbf8;
  overflow: hidden;
}
.auth-brand::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 25% 20%,  rgba(31,143,102,.35), transparent 50%),
    radial-gradient(circle at 75% 85%,  rgba(31,143,102,.18), transparent 42%);
  pointer-events: none;
}
.auth-brand::after {
  content: '';
  position: absolute;
  bottom: -180px;
  right: -180px;
  width: 500px;
  height: 500px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(31,143,102,.12), transparent 65%);
  pointer-events: none;
}

.auth-brand-logo {
  position: relative;
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 1rem;
  font-weight: 800;
  letter-spacing: -.02em;
}
.logo-mark {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: var(--accent);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .85rem;
  flex-shrink: 0;
  box-shadow: 0 4px 14px rgba(31,143,102,.5);
}

.auth-brand-body {
  position: relative;
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 40px 0;
}
.auth-headline {
  font-size: clamp(2.2rem,3.8vw,3.4rem);
  line-height: 1.06;
  letter-spacing: -.03em;
  color: #fff;
  margin: 16px 0 18px;
}
.auth-headline em { font-style: normal; color: #63c89a; }
.auth-desc {
  font-size: 1rem;
  color: rgba(248,251,248,.62);
  line-height: 1.65;
  max-width: 340px;
}

.auth-stats {
  position: relative;
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 12px;
  margin-top: 36px;
}
.auth-stat {
  padding: 16px;
  border-radius: var(--radius-sm);
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.09);
  backdrop-filter: blur(8px);
}
.auth-stat-val {
  font-size: 1.8rem;
  font-weight: 800;
  letter-spacing: -.03em;
  color: #fff;
  line-height: 1;
}
.auth-stat-lbl { font-size: .72rem; color: rgba(248,251,248,.45); margin-top: 4px; }

.auth-testimonial {
  position: relative;
  margin-top: 28px;
  padding: 20px;
  border-radius: var(--radius-sm);
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.09);
}
.auth-testimonial p {
  font-size: .88rem;
  color: rgba(248,251,248,.72);
  line-height: 1.65;
  font-style: italic;
}
.auth-t-author {
  margin-top: 14px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.t-avatar {
  width: 30px; height: 30px;
  border-radius: 50%;
  background: var(--accent);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .76rem;
  font-weight: 700;
  color: #fff;
  flex-shrink: 0;
}
.t-info strong { display: block; font-size: .8rem; color: rgba(248,251,248,.88); }
.t-info span   { font-size: .72rem; color: rgba(248,251,248,.42); }

.auth-brand-foot {
  position: relative;
  font-size: .74rem;
  color: rgba(248,251,248,.26);
}

.auth-form-panel {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 52px 44px;
  background: var(--panel);
  overflow-y: auto;
}
.auth-form-inner { width: 100%; max-width: 410px; }

.auth-form-head { margin-bottom: 32px; }
.auth-form-head h1,
.auth-form-head h2 {
  font-size: 1.7rem;
  letter-spacing: -.03em;
  margin: 8px 0 8px;
}
.auth-form-head p { color: var(--ink-muted); font-size: .875rem; }
.auth-form-head a { color: var(--accent); font-weight: 600; }
.auth-form-head a:hover { color: var(--accent-strong); }

.auth-mini-nav {
  display: flex;
  justify-content: flex-end;
  gap: 6px;
  margin-bottom: 42px;
}
.auth-mini-nav a {
  min-height: 34px;
  display: inline-flex;
  align-items: center;
  border-radius: 7px;
  padding: 0 11px;
  color: var(--ink-muted);
  font-size: .82rem;
  font-weight: 600;
}
.auth-mini-nav a:hover { background: var(--paper); color: var(--ink); }

.login-panel { animation: rise-in .45s ease both; }
.auth-form { display: grid; gap: 2px; }
.label-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 6px;
}
.label-row label { margin-bottom: 0; }
.label-row a {
  color: var(--accent);
  font-size: .78rem;
  font-weight: 700;
}
.label-row a:hover { color: var(--accent-strong); }
.login-options {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin: 2px 0 18px;
}
.secure-note {
  color: var(--ink-subtle);
  font-size: .75rem;
  font-weight: 700;
}
.auth-secondary {
  display: flex;
  justify-content: center;
  gap: 7px;
  margin-top: 22px;
  color: var(--ink-muted);
  font-size: .86rem;
}
.auth-secondary a {
  color: var(--accent);
  font-weight: 800;
}
.login-assurance {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-top: 30px;
}
.login-assurance div {
  border-top: 1px solid var(--line);
  padding-top: 14px;
}
.login-assurance strong {
  display: block;
  font-size: .78rem;
  letter-spacing: -.01em;
}
.login-assurance span {
  display: block;
  margin-top: 4px;
  color: var(--ink-muted);
  font-size: .76rem;
  line-height: 1.45;
}

.register-panel {
  animation: rise-in .45s ease both;
}
.register-head {
  margin-bottom: 18px;
}
.register-head h1 {
  font-size: clamp(1.7rem, 3vw, 2.15rem);
}
.register-steps {
  position: relative;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin: 0 0 24px;
}
.register-step {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: #fafaf9;
  color: var(--ink-subtle);
}
.register-step span {
  width: 22px;
  height: 22px;
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: #fff;
  border: 1px solid var(--line-strong);
  font-size: .72rem;
  font-weight: 800;
}
.register-step strong {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: .74rem;
  font-weight: 800;
}
.register-step.is-active {
  border-color: rgba(31,143,102,.32);
  background: var(--accent-light);
  color: var(--accent-strong);
}
.register-step.is-active span {
  border-color: var(--accent);
  background: var(--accent);
  color: #fff;
}
.register-form {
  gap: 0;
}
.password-meter {
  height: 6px;
  overflow: hidden;
  border-radius: 999px;
  background: var(--line);
  margin: 2px 0 5px;
}
.password-meter span {
  display: block;
  width: 0;
  height: 100%;
  border-radius: inherit;
  background: var(--error);
  transition: width .22s ease, background .22s ease;
}
.password-meter span[data-level="ok"] { background: var(--warning); }
.password-meter span[data-level="good"] { background: var(--accent); }
.register-consent {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 13px 0 18px;
  color: var(--ink-muted);
  font-size: .78rem;
  line-height: 1.45;
  cursor: pointer;
}
.register-consent input {
  width: 17px;
  height: 17px;
  margin-top: 2px;
  flex: 0 0 auto;
  accent-color: var(--accent);
}
.register-assurance {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-top: 26px;
}
.register-assurance div {
  border-top: 1px solid var(--line);
  padding-top: 14px;
}
.register-assurance strong {
  display: block;
  font-size: .78rem;
  letter-spacing: -.01em;
}
.register-assurance span {
  display: block;
  margin-top: 4px;
  color: var(--ink-muted);
  font-size: .76rem;
  line-height: 1.45;
}

.divider {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 20px 0;
  font-size: .78rem;
  color: var(--ink-subtle);
}
.divider::before,
.divider::after { content: ''; flex: 1; height: 1px; background: var(--line); }

/* App layout */
.app-root { display: flex; min-height: 100svh; }

.app-sidebar {
  position: fixed;
  top: 0; left: 0; bottom: 0;
  width: var(--sidebar-w);
  background: var(--night);
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  z-index: 100;
  border-right: 1px solid rgba(255,255,255,.05);
}

.sidebar-logo {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 18px 18px 16px;
  border-bottom: 1px solid rgba(255,255,255,.06);
  flex-shrink: 0;
}
.sidebar-logo-text { line-height: 1.25; }
.sidebar-logo-name {
  font-size: .92rem;
  font-weight: 800;
  color: #fff;
  letter-spacing: -.02em;
}
.sidebar-logo-sub {
  font-size: .66rem;
  color: rgba(255,255,255,.35);
  display: block;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 156px;
}

.sidebar-nav {
  flex: 1;
  padding: 14px 10px;
  display: flex;
  flex-direction: column;
  gap: 2px;
  overflow-y: auto;
}
.sidebar-sec {
  font-size: .62rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(255,255,255,.22);
  padding: 14px 8px 6px;
}
.sidebar-link {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 10px;
  border-radius: 7px;
  color: rgba(255,255,255,.52);
  font-size: .855rem;
  font-weight: 500;
  transition: all var(--dur) ease;
  position: relative;
  cursor: pointer;
  border: none;
  background: transparent;
  text-align: left;
  width: 100%;
  font-family: inherit;
  letter-spacing: -.01em;
}
.sidebar-link:hover { background: rgba(255,255,255,.06); color: rgba(255,255,255,.88); }
.sidebar-link.active {
  background: rgba(31,143,102,.2);
  color: #63c89a;
}
.sidebar-link.active::before {
  content: '';
  position: absolute;
  left: 0; top: 50%;
  transform: translateY(-50%);
  width: 3px; height: 60%;
  border-radius: 0 2px 2px 0;
  background: var(--accent);
}
.sl-icon { width: 16px; height: 16px; flex-shrink: 0; opacity: .85; }
.sl-badge {
  margin-left: auto;
  padding: 2px 7px;
  border-radius: 99px;
  background: rgba(31,143,102,.28);
  color: #63c89a;
  font-size: .64rem;
  font-weight: 700;
}

.sidebar-footer {
  padding: 10px;
  border-top: 1px solid rgba(255,255,255,.06);
  flex-shrink: 0;
}
.sidebar-user {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  border-radius: 7px;
  cursor: default;
}
.u-avatar {
  width: 30px; height: 30px;
  border-radius: 50%;
  background: var(--accent);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .76rem;
  font-weight: 700;
  color: #fff;
  flex-shrink: 0;
}
.u-info strong {
  display: block;
  font-size: .8rem;
  font-weight: 600;
  color: rgba(255,255,255,.82);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 148px;
}
.u-info span { font-size: .68rem; color: rgba(255,255,255,.32); }

.app-topbar {
  position: sticky;
  top: 0;
  z-index: 50;
  height: var(--topbar-h);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 26px;
  background: rgba(246,244,238,.9);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid var(--line);
  flex-shrink: 0;
}
.topbar-title {
  font-size: .975rem;
  font-weight: 700;
  letter-spacing: -.02em;
}
.topbar-right { display: flex; align-items: center; gap: 8px; }
.inline-form { display: inline-flex; margin: 0; }
.topbar-notification {
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: rgba(255,255,255,.64);
  color: var(--ink-muted);
  transition: background var(--dur) ease, color var(--dur) ease, border-color var(--dur) ease;
}
.topbar-notification:hover {
  border-color: var(--line-strong);
  background: #fff;
  color: var(--ink);
}
.topbar-notification svg {
  width: 17px;
  height: 17px;
}
.topbar-avatar {
  width: 32px; height: 32px;
  border-radius: 50%;
  background: var(--accent);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .76rem;
  font-weight: 700;
  color: #fff;
  cursor: default;
}

.app-content {
  margin-left: var(--sidebar-w);
  flex: 1;
  min-width: 0;
  min-height: 100svh;
  display: flex;
  flex-direction: column;
}
.page-body {
  flex: 1;
  padding: 26px 28px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

/* Conversation */
.conv-feed {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 20px;
  max-height: 540px;
  overflow-y: auto;
}
.msg-row { display: flex; }
.msg-row.out { justify-content: flex-end; }
.msg-bubble {
  max-width: 70%;
  padding: 11px 15px;
  border-radius: 14px;
  font-size: .875rem;
  line-height: 1.55;
  background: var(--paper);
  border: 1px solid var(--line);
  color: var(--ink);
}
.msg-row.out .msg-bubble {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}
.msg-meta {
  font-size: .68rem;
  color: var(--ink-subtle);
  margin-top: 3px;
  padding: 0 4px;
}
.msg-row.out .msg-meta { text-align: right; color: rgba(255,255,255,.55); }

/* Landing */
.site-header {
  position: sticky;
  top: 0; z-index: 20;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  min-height: 70px;
  padding: 0 clamp(18px,4vw,54px);
  border-bottom: 1px solid rgba(21,32,28,.09);
  background: rgba(246,244,238,.88);
  backdrop-filter: blur(18px);
}
.brand {
  display: flex; align-items: center; gap: 9px;
  font-size: 1.05rem; font-weight: 800; letter-spacing: -.02em;
}
.header-nav { display: flex; gap: 4px; align-items: center; }
.header-nav a,
.header-cta {
  min-height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 7px;
  padding: 0 13px;
  font-size: .875rem;
  transition: background var(--dur) ease, color var(--dur) ease;
}
.header-nav a { color: var(--ink-muted); }
.header-nav a:hover { background: #e8eee9; color: var(--ink); }
.header-cta {
  justify-self: end;
  color: #fff;
  background: var(--night);
  font-weight: 700;
  font-size: .84rem;
  padding: 0 18px;
}
.header-cta:hover { background: #1d2e28; }

.landing-hero {
  min-height: calc(100svh - 70px);
  display: grid;
  grid-template-columns: minmax(300px,.85fr) minmax(420px,1.15fr);
  gap: clamp(32px,5vw,80px);
  align-items: center;
  padding: clamp(48px,7vw,88px) clamp(18px,5vw,68px);
  color: #f8fbf8;
  background:
    radial-gradient(circle at 72% 18%, rgba(31,143,102,.34), transparent 30%),
    linear-gradient(135deg, #111b18 0%, #172822 52%, #24352c 100%);
  overflow: hidden;
}
.hero-copy { max-width: 600px; animation: rise-in .65s ease both; }
.hero-copy h1 {
  max-width: 11ch;
  font-size: clamp(3.2rem,8vw,7.4rem);
  line-height: .98;
  color: #fff;
}
.hero-copy h1 span { color: #63c89a; }
.hero-text {
  max-width: 520px;
  margin: 26px 0 0;
  color: rgba(248,251,248,.72);
  font-size: clamp(1rem,1.7vw,1.25rem);
  line-height: 1.6;
}
.hero-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 32px; }
.hero-btn-primary {
  min-height: 50px; padding: 0 26px;
  border-radius: var(--radius-sm);
  background: var(--accent); color: #fff;
  font-weight: 800; font-size: .95rem;
  box-shadow: 0 14px 36px rgba(31,143,102,.35);
  transition: all var(--dur) ease;
  display: inline-flex; align-items: center; gap: 8px;
}
.hero-btn-primary:hover { background: var(--accent-strong); transform: translateY(-2px); }
.hero-btn-secondary {
  min-height: 50px; padding: 0 26px;
  border-radius: var(--radius-sm);
  color: #f8fbf8; border: 1.5px solid rgba(248,251,248,.26);
  background: rgba(248,251,248,.07);
  font-weight: 600; font-size: .95rem;
  transition: all var(--dur) ease;
  display: inline-flex; align-items: center; gap: 8px;
}
.hero-btn-secondary:hover { background: rgba(248,251,248,.13); }

.product-shot {
  border: 1px solid rgba(248,251,248,.13);
  border-radius: var(--radius);
  background: rgba(248,251,248,.07);
  box-shadow: 0 28px 100px rgba(0,0,0,.32);
  overflow: hidden;
  transform: perspective(1200px) rotateY(-7deg) rotateX(3deg);
  animation: product-in .75s .1s ease both;
}
.product-topbar {
  height: 50px; display: flex; align-items: center; gap: 8px;
  padding: 0 16px;
  border-bottom: 1px solid rgba(248,251,248,.11);
  background: rgba(255,255,255,.07);
}
.product-topbar span,
.dot { width: 9px; height: 9px; border-radius: 50%; background: rgba(248,251,248,.3); }
.product-topbar strong { margin-left: 10px; color: rgba(248,251,248,.7); font-size: .82rem; }
.product-layout {
  min-height: 500px; display: grid; grid-template-columns: 150px 1fr;
}
.product-layout > aside,
.product-aside {
  padding: 22px 14px; border-right: 1px solid rgba(248,251,248,.09);
}
.product-layout > aside b,
.product-aside b { display: block; margin-bottom: 16px; color: rgba(248,251,248,.5); font-size: .74rem; }
.product-layout > aside p,
.product-aside p {
  margin: 5px 0; padding: 8px 10px; border-radius: 6px;
  color: rgba(248,251,248,.5); font-size: .8rem;
}
.product-layout > aside .is-active,
.product-aside .is-active { color: #fff; background: rgba(31,143,102,.26); }
.product-main { display: grid; align-content: start; gap: 16px; padding: 20px; }
.metric-row,
.metrics { display: grid; grid-template-columns: repeat(3,1fr); gap: 10px; }
.metric-row > div,
.metric {
  min-height: 90px; padding: 14px;
  border: 1px solid rgba(248,251,248,.11);
  border-radius: 8px; background: rgba(255,255,255,.06);
}
.metric-row span,
.metric span { display: block; color: rgba(248,251,248,.5); font-size: .76rem; }
.metric-row strong,
.metric strong { display: block; margin-top: 14px; font-size: 1.8rem; font-weight: 800; }
.conversation-preview {
  display: grid;
  gap: 10px;
  padding: 14px;
  border: 1px solid rgba(248,251,248,.1);
  border-radius: 8px;
  background: rgba(0,0,0,.12);
}
.message {
  max-width: 76%;
  padding: 10px 12px;
  border-radius: 12px;
  color: rgba(248,251,248,.84);
  background: rgba(255,255,255,.08);
  font-size: .82rem;
  line-height: 1.45;
}
.message.outbound {
  justify-self: end;
  background: var(--accent);
  color: #fff;
}
.message.short { max-width: 42%; }
.lead-table {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 0;
  overflow: hidden;
  border: 1px solid rgba(248,251,248,.1);
  border-radius: 8px;
}
.lead-table span,
.lead-table b {
  padding: 11px 12px;
  border-bottom: 1px solid rgba(248,251,248,.08);
  font-size: .8rem;
}
.lead-table span { color: rgba(248,251,248,.72); }
.lead-table b {
  color: #63c89a;
  text-align: right;
  font-weight: 700;
}
.lead-table span:nth-last-child(2),
.lead-table b:last-child { border-bottom: none; }

.landing-band {
  display: grid; grid-template-columns: .9fr 1.1fr;
  gap: clamp(28px,5vw,72px);
  padding: clamp(56px,9vw,120px) clamp(18px,5vw,68px);
  background: #fdfcf8;
}
.landing-band h2 { font-size: clamp(1.8rem,3.5vw,3.6rem); letter-spacing: -.03em; margin-top: 12px; }
.value-list { display: grid; border-top: 1px solid var(--line); margin-top: 20px; }
.value-item {
  display: grid; grid-template-columns: 150px 1fr; gap: 20px;
  padding: 22px 0; border-bottom: 1px solid var(--line);
}
.value-item strong { font-size: .95rem; }
.value-item span { color: var(--ink-muted); line-height: 1.6; font-size: .9rem; }

.landing-cta {
  display: flex; align-items: center; justify-content: space-between; gap: 28px;
  padding: clamp(44px,7vw,80px) clamp(18px,5vw,68px);
  color: #fff; background: var(--night);
}
.landing-cta h2 { max-width: 780px; font-size: clamp(2rem,4vw,4.4rem); letter-spacing: -.03em; }
.landing-cta .btn-secondary {
  min-height: 50px;
  padding: 0 26px;
  color: #f8fbf8;
  border-color: rgba(248,251,248,.72);
  background: rgba(248,251,248,.06);
  font-size: .95rem;
  font-weight: 700;
}
.landing-cta .btn-secondary:hover:not(:disabled) {
  color: #fff;
  border-color: #f8fbf8;
  background: rgba(248,251,248,.13);
}

/* Keyframes */
@keyframes rise-in {
  from { opacity:0; transform: translateY(18px); }
  to   { opacity:1; transform: translateY(0); }
}
@keyframes product-in {
  from { opacity:0; transform: perspective(1200px) rotateY(-2deg) rotateX(1deg) translateX(22px); }
  to   { opacity:1; transform: perspective(1200px) rotateY(-7deg) rotateX(3deg); }
}

/* Responsive base */
@media (max-width:1100px) {
  .auth-root { grid-template-columns: 1fr; }
  .auth-brand { display: none; }
  .auth-form-panel { padding: 44px 28px; }
}
@media (max-width:900px) {
  .app-sidebar { transform: translateX(-100%); transition: transform .28s var(--ease); }
  .app-sidebar.open { transform: translateX(0); }
  .app-content { margin-left: 0; }
  .app-topbar, .page-body { min-width: 0; width: 100%; }
  .page-body { padding: 18px 16px; }
  .form-grid-2 { grid-template-columns: 1fr; }
  .landing-hero, .landing-band { grid-template-columns: 1fr; }
  .landing-hero { min-height: auto; padding-bottom: 52px; }
  .product-shot { transform: none; }
  .product-layout { grid-template-columns: 1fr; }
  .product-layout > aside,
  .product-aside { display: none; }
  .landing-cta { flex-direction: column; align-items: flex-start; }
}
@media (max-width:600px) {
  .app-topbar { padding: 0 14px; gap: 10px; }
  .topbar-title { min-width: 0; font-size: .9rem; }
  .topbar-right { min-width: 0; gap: 6px; }
  .topbar-avatar,
  .topbar-notification { display: none; }
  .topbar-right .btn-ghost { display: none; }
  .auth-form-panel { padding: 36px 22px; }
  .auth-form-head h2 { font-size: 1.5rem; }
  .auth-form-head h1 { font-size: 1.5rem; }
  .stats-grid { grid-template-columns: 1fr 1fr; }
  .auth-mini-nav { margin-bottom: 30px; }
  .login-assurance { grid-template-columns: 1fr; }
  .register-assurance { grid-template-columns: 1fr; }
  .register-steps { gap: 6px; }
  .register-step { padding: 9px 7px; gap: 6px; }
  .register-step span { width: 20px; height: 20px; }
  .register-step strong { font-size: .68rem; }
}
@media (max-width:480px) {
  .stats-grid { grid-template-columns: 1fr; }
  .metric-row,
  .metrics { grid-template-columns: 1fr; }
}

/* Page header */
.page-head {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--line);
}
.page-head-text h1 {
  font-size: 1.6rem;
  letter-spacing: -.03em;
  margin-bottom: 6px;
}
.page-head-text p {
  color: var(--ink-muted);
  font-size: .9rem;
  max-width: 640px;
  line-height: 1.55;
}
.page-head-actions {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}

/* AI Config */
.config-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 24px;
  align-items: start;
}

.config-layout-single {
  grid-template-columns: minmax(0, 1fr);
}

.config-main {
  display: flex;
  flex-direction: column;
  gap: 20px;
  min-width: 0;
}

.config-mode-panel {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 14px 16px;
  margin-bottom: 18px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel);
  box-shadow: var(--shadow-sm);
}
.config-mode-copy {
  display: grid;
  gap: 3px;
}
.config-mode-copy strong {
  font-size: .94rem;
  letter-spacing: -.01em;
}
.config-mode-copy span {
  color: var(--ink-muted);
  font-size: .8rem;
  line-height: 1.45;
}
.config-mode-toggle {
  display: inline-flex;
  gap: 4px;
  padding: 4px;
  border: 1px solid var(--line);
  border-radius: 9px;
  background: var(--paper);
  flex: 0 0 auto;
}
.config-mode-toggle button {
  min-height: 34px;
  padding: 0 14px;
  border: 0;
  border-radius: 7px;
  background: transparent;
  color: var(--ink-muted);
  font: inherit;
  font-size: .82rem;
  font-weight: 700;
  cursor: pointer;
}
.config-mode-toggle button.is-active {
  background: var(--night);
  color: #fff;
  box-shadow: 0 4px 14px rgba(21,32,28,.16);
}
#advanced-config-ui,
body.is-simple-config #advanced-config-ui,
body.is-advanced-config #simple-config-ui {
  display: none;
}
body.is-advanced-config #advanced-config-ui {
  display: block;
}
.simple-config-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 340px;
  gap: 22px;
  align-items: start;
}
.simple-config-primary,
.simple-config-side {
  display: grid;
  gap: 18px;
}
.simple-block {
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fff;
}
.simple-block-head {
  display: grid;
  gap: 3px;
  margin-bottom: 10px;
}
.simple-block-head label {
  font-size: .82rem;
  font-weight: 700;
}
.simple-block-head span {
  color: var(--ink-muted);
  font-size: .76rem;
}
.simple-textarea {
  width: 100%;
  padding: 14px 16px;
  border: 1.5px solid var(--line);
  border-radius: var(--radius-sm);
  background: #fafaf9;
  font: inherit;
  font-size: .9rem;
  line-height: 1.6;
  color: var(--ink);
  resize: vertical;
  outline: none;
  transition: all var(--dur) ease;
}
.simple-textarea:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-glow);
  background: #fff;
}
.simple-side-card {
  display: grid;
  gap: 12px;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fff;
  box-shadow: var(--shadow-sm);
}
.simple-side-card h3 {
  margin: 0 0 2px;
  font-size: .95rem;
  letter-spacing: -.02em;
}
.simple-side-card .form-group {
  margin-bottom: 0;
}
.simple-mini-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.simple-tone-grid {
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
}

.config-tabs {
  position: sticky;
  top: var(--topbar-h);
  z-index: 30;
  background: var(--paper);
  display: flex;
  gap: 4px;
  padding: 8px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  overflow-x: auto;
  scrollbar-width: none;
}
.config-tabs::-webkit-scrollbar { display: none; }
.config-tab {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 14px;
  border-radius: 8px;
  font-size: .82rem;
  font-weight: 600;
  color: var(--ink-muted);
  cursor: pointer;
  border: none;
  background: transparent;
  transition: all var(--dur) ease;
  white-space: nowrap;
}
.config-tab:hover { background: var(--paper); color: var(--ink); }
.config-tab.is-active {
  background: var(--night);
  color: #fff;
  box-shadow: 0 4px 14px rgba(21,32,28,.18);
}
.config-tab .tab-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
  opacity: .35;
}
.config-tab.is-active .tab-dot { opacity: 1; }

.config-section {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  scroll-margin-top: calc(var(--topbar-h) + 80px);
}
.config-section-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 20px 22px;
  border-bottom: 1px solid var(--line);
  background: #fafaf9;
}
.config-section-head h2 {
  font-size: 1rem;
  letter-spacing: -.02em;
  margin-bottom: 4px;
}
.config-section-head p {
  font-size: .82rem;
  color: var(--ink-muted);
  max-width: 480px;
  line-height: 1.55;
}
.config-section-body { padding: 22px; }

.config-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
}
.config-row.cols-1 { grid-template-columns: 1fr; }
.config-row.cols-3 { grid-template-columns: repeat(3, 1fr); }
.config-row + .config-row { margin-top: 18px; }

.comment-automation-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}
.comment-rule-card {
  display: grid;
  align-content: start;
  gap: 14px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fff;
  box-shadow: var(--shadow-sm);
}
.comment-rule-head {
  display: grid;
  gap: 4px;
  padding-bottom: 4px;
}
.comment-rule-kicker {
  color: var(--accent);
  font-size: .7rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.comment-rule-head h3 {
  margin: 0;
  font-size: 1rem;
}
.comment-rule-head p {
  margin: 0;
  color: var(--ink-muted);
  font-size: .82rem;
  line-height: 1.45;
}
.media-picker-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
}
.comment-inline-switch {
  min-height: auto;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
}
.media-picker-modal {
  width: min(760px, calc(100vw - 32px));
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel);
  box-shadow: var(--shadow-xl);
  padding: 0;
}
.media-picker-modal::backdrop { background: rgba(16,25,23,.42); }
.media-picker-modal-head {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding: 18px 20px;
  border-bottom: 1px solid var(--line);
}
.media-picker-modal-head h3 { margin: 0 0 4px; font-size: 1rem; }
.media-picker-modal-head p { margin: 0; color: var(--ink-muted); font-size: .82rem; }
.media-picker-status {
  padding: 14px 20px;
  color: var(--ink-muted);
  font-size: .84rem;
}
.media-picker-list {
  display: grid;
  gap: 0;
  max-height: 520px;
  overflow-y: auto;
  padding: 0 12px 12px;
}
.media-picker-item {
  display: grid;
  grid-template-columns: 20px 64px minmax(0, 1fr);
  align-items: center;
  gap: 12px;
  padding: 10px 8px;
  border-top: 1px solid var(--line);
}
.media-picker-item input { width: 16px; height: 16px; accent-color: var(--accent); }
.media-picker-thumb {
  width: 64px;
  height: 64px;
  border-radius: 8px;
  object-fit: cover;
  background: var(--paper);
}
.media-picker-thumb-empty {
  display: grid;
  place-items: center;
  color: var(--ink-muted);
  font-size: .66rem;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.media-picker-copy {
  min-width: 0;
  display: grid;
  gap: 4px;
}
.media-picker-copy strong {
  overflow: hidden;
  color: var(--ink);
  font-size: .86rem;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.media-picker-copy span {
  color: var(--ink-muted);
  font-size: .74rem;
}
.media-picker-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  padding: 12px 20px 18px;
  border-top: 1px solid var(--line);
}

.model-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 12px;
}
.model-card {
  position: relative;
  border: 1.5px solid var(--line);
  border-radius: var(--radius);
  padding: 16px 16px 18px;
  background: #fff;
  cursor: pointer;
  transition: all var(--dur) ease;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.model-card:hover {
  border-color: var(--ink-subtle);
  box-shadow: var(--shadow-sm);
}
.model-card input { position: absolute; opacity: 0; pointer-events: none; }
.model-card.is-selected,
.model-card:has(input:checked) {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-glow);
  background: linear-gradient(180deg, #f5fbf8, #fff);
}
.model-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}
.model-name {
  font-size: .95rem;
  font-weight: 700;
  letter-spacing: -.02em;
}
.model-tag {
  font-size: .64rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: 3px 7px;
  border-radius: 99px;
  background: var(--accent-light);
  color: var(--accent-strong);
}
.model-desc { font-size: .78rem; color: var(--ink-muted); line-height: 1.5; }
.model-meta {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: .72rem;
  color: var(--ink-subtle);
  margin-top: 2px;
}
.model-meta span { display: inline-flex; align-items: center; gap: 4px; }
.model-meta strong { color: var(--ink); font-weight: 700; }

.tone-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
  gap: 10px;
}
.tone-card {
  position: relative;
  padding: 12px 14px;
  border: 1.5px solid var(--line);
  border-radius: var(--radius-sm);
  cursor: pointer;
  background: #fff;
  transition: all var(--dur) ease;
}
.tone-card:hover { border-color: var(--ink-subtle); }
.tone-card input { position: absolute; opacity: 0; pointer-events: none; }
.tone-card:has(input:checked) {
  border-color: var(--accent);
  background: var(--accent-light);
  box-shadow: 0 0 0 3px var(--accent-glow);
}
.tone-card strong {
  display: block;
  font-size: .88rem;
  font-weight: 700;
  margin-bottom: 3px;
}
.tone-card span {
  display: block;
  font-size: .75rem;
  color: var(--ink-muted);
  line-height: 1.45;
}

.slider-control {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.slider-control-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.slider-control-head label {
  font-size: .82rem;
  font-weight: 600;
  color: var(--ink);
}
.slider-control-value {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 52px;
  height: 28px;
  padding: 0 10px;
  border-radius: 7px;
  background: var(--night);
  color: #fff;
  font-size: .8rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}
.slider-control input[type=range] {
  -webkit-appearance: none;
  width: 100%;
  height: 6px;
  border-radius: 99px;
  background: linear-gradient(90deg, var(--accent) 0%, var(--accent) var(--val,50%), var(--line) var(--val,50%));
  outline: none;
}
.slider-control input[type=range]::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 18px; height: 18px;
  border-radius: 50%;
  background: #fff;
  border: 2px solid var(--accent);
  cursor: pointer;
  box-shadow: 0 2px 8px rgba(31,143,102,.4);
  transition: transform .12s ease;
}
.slider-control input[type=range]::-moz-range-thumb {
  width: 18px; height: 18px;
  border-radius: 50%;
  background: #fff;
  border: 2px solid var(--accent);
  cursor: pointer;
}
.slider-control input[type=range]:hover::-webkit-slider-thumb { transform: scale(1.1); }
.slider-foot {
  display: flex;
  justify-content: space-between;
  font-size: .7rem;
  color: var(--ink-subtle);
}

.switch {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: #fff;
  cursor: pointer;
  transition: all var(--dur) ease;
}
.switch:hover { border-color: var(--ink-subtle); }
.switch input { position: absolute; opacity: 0; pointer-events: none; }
.switch .switch-pill {
  position: relative;
  flex-shrink: 0;
  width: 36px;
  height: 20px;
  border-radius: 99px;
  background: var(--line-strong);
  transition: background var(--dur) ease;
  margin-top: 2px;
}
.switch .switch-pill::after {
  content: '';
  position: absolute;
  top: 2px; left: 2px;
  width: 16px; height: 16px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 1px 3px rgba(0,0,0,.2);
  transition: transform var(--dur) ease;
}
.switch:has(input:checked) { border-color: var(--accent); background: var(--accent-light); }
.switch:has(input:checked) .switch-pill { background: var(--accent); }
.switch:has(input:checked) .switch-pill::after { transform: translateX(16px); }
.switch-info strong {
  display: block;
  font-size: .87rem;
  font-weight: 700;
  letter-spacing: -.01em;
}
.switch-info span {
  display: block;
  margin-top: 3px;
  font-size: .76rem;
  color: var(--ink-muted);
  line-height: 1.5;
}

.prompt-textarea {
  width: 100%;
  min-height: 180px;
  padding: 14px 16px;
  border: 1.5px solid var(--line);
  border-radius: var(--radius-sm);
  background: #fafaf9;
  font-family: 'JetBrains Mono', 'SFMono-Regular', Menlo, monospace;
  font-size: .82rem;
  line-height: 1.6;
  color: var(--ink);
  resize: vertical;
  outline: none;
  transition: all var(--dur) ease;
}
.prompt-textarea:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-glow);
  background: #fff;
}
.prompt-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 8px;
  font-size: .76rem;
  color: var(--ink-muted);
}
.prompt-count {
  font-variant-numeric: tabular-nums;
  color: var(--ink-subtle);
}

.chip-field {
  border: 1.5px solid var(--line);
  border-radius: var(--radius-sm);
  padding: 8px;
  background: #fff;
  min-height: 48px;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  cursor: text;
}
.chip-field:focus-within {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-glow);
}
.chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 99px;
  background: var(--accent-light);
  color: var(--accent-strong);
  font-size: .78rem;
  font-weight: 600;
}
.chip button {
  border: none;
  background: none;
  color: var(--accent-strong);
  cursor: pointer;
  font-size: .9rem;
  line-height: 1;
  opacity: .65;
  padding: 0;
}
.chip button:hover { opacity: 1; }
.chip-field input {
  flex: 1;
  min-width: 120px;
  border: none;
  outline: none;
  font: inherit;
  font-size: .85rem;
  background: transparent;
  padding: 4px 6px;
}

.config-preview {
  position: sticky;
  top: calc(var(--topbar-h) + 76px);
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-md);
  overflow: hidden;
  max-height: calc(100svh - var(--topbar-h) - 92px);
  display: flex;
  flex-direction: column;
}
.preview-head {
  padding: 14px 18px;
  border-bottom: 1px solid var(--line);
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: linear-gradient(180deg, #fafaf9, #fff);
}
.preview-head strong {
  font-size: .92rem;
  letter-spacing: -.02em;
}
.preview-head .preview-status {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: .72rem;
  font-weight: 700;
  color: var(--accent-strong);
}
.preview-head .preview-status::before {
  content: '';
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-glow);
  animation: pulse 1.6s ease-in-out infinite;
}
@keyframes pulse {
  0%,100% { opacity: 1; }
  50% { opacity: .35; }
}
.preview-body {
  padding: 16px;
  flex: 1;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 10px;
  background: var(--paper);
}
.preview-bubble {
  max-width: 88%;
  padding: 10px 13px;
  border-radius: 14px;
  font-size: .84rem;
  line-height: 1.5;
}
.preview-bubble.in {
  background: #fff;
  border: 1px solid var(--line);
  color: var(--ink);
  align-self: flex-start;
  border-bottom-left-radius: 4px;
}
.preview-bubble.out {
  background: var(--accent);
  color: #fff;
  align-self: flex-end;
  border-bottom-right-radius: 4px;
  box-shadow: 0 4px 14px rgba(31,143,102,.28);
}
.preview-foot {
  padding: 12px 14px;
  border-top: 1px solid var(--line);
  background: var(--panel);
  display: flex;
  gap: 8px;
}
.preview-foot input {
  flex: 1;
  padding: 9px 12px;
  border: 1.5px solid var(--line);
  border-radius: 7px;
  font: inherit;
  font-size: .82rem;
  outline: none;
}
.preview-foot input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-glow);
}

.preview-stats {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 8px;
  padding: 12px 14px;
  border-top: 1px solid var(--line);
  background: #fafaf9;
}
.preview-stats > div {
  text-align: center;
  padding: 6px 4px;
}
.preview-stats strong {
  display: block;
  font-size: .92rem;
  font-weight: 800;
  letter-spacing: -.02em;
  color: var(--ink);
}
.preview-stats span {
  display: block;
  margin-top: 2px;
  font-size: .68rem;
  color: var(--ink-subtle);
  text-transform: uppercase;
  letter-spacing: .04em;
  font-weight: 700;
}

.config-savebar {
  position: sticky;
  bottom: 14px;
  margin-top: 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 16px;
  background: var(--night);
  color: #fff;
  border-radius: var(--radius);
  box-shadow: var(--shadow-lg);
  z-index: 20;
}
.config-savebar .savebar-info {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: .85rem;
  color: rgba(255,255,255,.78);
}
.config-savebar .savebar-info .dot-live {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: #f59e0b;
  box-shadow: 0 0 0 3px rgba(245,158,11,.25);
}
.config-savebar.is-clean .savebar-info .dot-live { background: var(--accent); box-shadow: 0 0 0 3px var(--accent-glow); }
.config-savebar .savebar-actions { display: flex; gap: 8px; align-items: center; }

.override-card {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}
.override-empty {
  padding: 28px;
  text-align: center;
  color: var(--ink-muted);
}

@media (max-width: 1180px) {
  .config-layout { grid-template-columns: 1fr; }
  .config-preview { position: static; max-height: none; }
  .comment-automation-grid { grid-template-columns: 1fr; }
  .simple-config-grid { grid-template-columns: 1fr; }
  .simple-config-side { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 700px) {
  .config-row, .config-row.cols-3 { grid-template-columns: 1fr; }
  .media-picker-row { grid-template-columns: 1fr; }
  .config-section-body { padding: 16px; }
  .config-section-head { padding: 16px; }
  .config-mode-panel { align-items: stretch; flex-direction: column; }
  .config-mode-toggle, .config-mode-toggle button { width: 100%; }
  .config-mode-toggle button { justify-content: center; }
  .simple-config-side, .simple-mini-grid { grid-template-columns: 1fr; }
}

/* Profile */
.profile-shell { display: grid; gap: 22px; }

.profile-hero {
  display: flex;
  align-items: stretch;
  justify-content: space-between;
  gap: 24px;
  padding: 24px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--radius);
  background:
    linear-gradient(135deg, rgba(31,143,102,.16), transparent 42%),
    var(--night);
  color: #fff;
  box-shadow: var(--shadow-md);
}

.profile-identity {
  display: flex;
  align-items: center;
  gap: 18px;
  min-width: 0;
}

.profile-avatar-xl {
  width: 76px;
  height: 76px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  border-radius: 18px;
  background: var(--accent);
  color: #fff;
  font-size: 2rem;
  font-weight: 800;
  box-shadow: 0 14px 34px rgba(31,143,102,.35);
}

.profile-identity h1 {
  margin: 8px 0 6px;
  font-size: clamp(1.8rem, 3vw, 2.7rem);
  letter-spacing: -.04em;
}

.profile-identity p {
  color: rgba(248,251,248,.62);
  font-size: .95rem;
}

.profile-status-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(120px, 1fr));
  align-self: stretch;
  min-width: min(100%, 470px);
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.09);
  border-radius: var(--radius-sm);
  background: rgba(255,255,255,.05);
}

.profile-status-grid > div {
  display: grid;
  align-content: center;
  gap: 5px;
  padding: 16px;
  border-right: 1px solid rgba(255,255,255,.08);
  min-width: 0;
}

.profile-status-grid > div:last-child { border-right: 0; }

.profile-status-grid span {
  color: rgba(248,251,248,.46);
  font-size: .7rem;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.profile-status-grid strong {
  overflow: hidden;
  color: rgba(248,251,248,.92);
  font-size: .88rem;
  font-weight: 700;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.profile-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 340px;
  gap: 22px;
  align-items: start;
}

.profile-main,
.profile-side { display: grid; gap: 18px; min-width: 0; }

.profile-panel {
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel);
  box-shadow: var(--shadow-sm);
}

.profile-panel-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 20px 22px;
  border-bottom: 1px solid var(--line);
  background: #fafaf9;
}

.profile-panel-head h2 { margin-bottom: 5px; font-size: 1rem; letter-spacing: -.02em; }
.profile-panel-head p { max-width: 560px; color: var(--ink-muted); font-size: .82rem; line-height: 1.55; }

.profile-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  padding: 22px;
}
.profile-form-grid.cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.profile-form-grid .form-group { margin-bottom: 0; }
.profile-panel.compact .profile-panel-head { display: block; }

.profile-checklist { display: grid; padding: 8px 18px 18px; }
.profile-checklist > div { display: flex; align-items: center; gap: 10px; padding: 13px 0; border-bottom: 1px solid var(--line); }
.profile-checklist > div:last-child { border-bottom: 0; }
.profile-checklist span { width: 18px; height: 18px; flex: 0 0 auto; border: 2px solid var(--line-strong); border-radius: 50%; }
.profile-checklist strong { color: var(--ink-muted); font-size: .86rem; font-weight: 700; }
.profile-checklist .is-done span { border-color: var(--accent); background: radial-gradient(circle at center, var(--accent) 42%, transparent 45%); }
.profile-checklist .is-done strong { color: var(--ink); }

.preference-list { display: grid; padding: 8px 18px 18px; }
.preference-list > div { display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 13px 0; border-bottom: 1px solid var(--line); }
.preference-list > div:last-child { border-bottom: 0; }
.preference-list span { color: var(--ink-muted); font-size: .82rem; }
.preference-list strong { font-size: .82rem; font-weight: 800; text-align: right; }

@media (max-width: 1180px) {
  .profile-hero { flex-direction: column; }
  .profile-status-grid { min-width: 0; }
  .profile-layout { grid-template-columns: 1fr; }
}
@media (max-width: 760px) {
  .profile-hero { padding: 18px; }
  .profile-identity { align-items: flex-start; }
  .profile-avatar-xl { width: 58px; height: 58px; border-radius: 14px; font-size: 1.45rem; }
  .profile-status-grid,
  .profile-form-grid,
  .profile-form-grid.cols-3 { grid-template-columns: 1fr; }
  .profile-status-grid > div { border-right: 0; border-bottom: 1px solid rgba(255,255,255,.08); }
  .profile-status-grid > div:last-child { border-bottom: 0; }
  .profile-panel-head { flex-direction: column; padding: 16px; }
  .profile-form-grid { padding: 16px; }
}

/* Admin Overview */
.admin-overview { display: grid; gap: 18px; }

.admin-command {
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 24px;
  min-height: 224px;
  padding: 28px;
  border-radius: var(--radius);
  background:
    linear-gradient(115deg, rgba(16,25,23,.96) 0%, rgba(23,40,34,.94) 54%, rgba(31,143,102,.78) 100%),
    radial-gradient(circle at 82% 16%, rgba(255,255,255,.18), transparent 32%);
  color: #fff;
  box-shadow: var(--shadow-md);
}

.admin-command::after {
  content: '';
  position: absolute;
  inset: auto 0 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.46), transparent);
}

.admin-command-copy { position: relative; max-width: 620px; z-index: 1; }
.admin-command .eyebrow { color: #79d6a9; }
.admin-command h1 { margin-top: 10px; font-size: clamp(2rem, 4vw, 4.1rem); letter-spacing: -.04em; }
.admin-command p { max-width: 560px; margin-top: 14px; color: rgba(255,255,255,.72); font-size: 1rem; }

.admin-command-status {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 260px;
  padding: 14px 16px;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: var(--radius-sm);
  background: rgba(255,255,255,.08);
}

.system-dot {
  width: 10px;
  height: 10px;
  flex: 0 0 auto;
  border-radius: 50%;
  background: var(--warning);
  box-shadow: 0 0 0 5px rgba(176,113,33,.16);
}
.system-dot.is-good { background: #68d391; box-shadow: 0 0 0 5px rgba(104,211,145,.16); }
.system-dot.is-risk { background: #fb7185; box-shadow: 0 0 0 5px rgba(251,113,133,.16); }

.admin-command-status strong, .admin-command-status span { display: block; }
.admin-command-status strong { font-size: .86rem; letter-spacing: -.01em; }
.admin-command-status span { margin-top: 2px; color: rgba(255,255,255,.58); font-size: .75rem; }

.admin-metrics {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}
.admin-metrics > div { padding: 18px 20px; border-right: 1px solid var(--line); }
.admin-metrics > div:last-child { border-right: 0; }
.admin-metrics span, .admin-metrics small { display: block; }
.admin-metrics span { color: var(--ink-muted); font-size: .72rem; font-weight: 800; letter-spacing: .06em; text-transform: uppercase; }
.admin-metrics strong { display: block; margin-top: 8px; font-size: 2.25rem; line-height: 1; letter-spacing: -.04em; }
.admin-metrics small { margin-top: 8px; color: var(--ink-subtle); font-size: .76rem; }

.admin-grid { display: grid; grid-template-columns: minmax(0, 1.25fr) minmax(340px, .75fr); gap: 18px; }
.admin-grid.lower { grid-template-columns: repeat(2, minmax(0, 1fr)); }

.admin-panel { min-width: 0; border: 1px solid var(--line); border-radius: var(--radius); background: var(--panel); box-shadow: var(--shadow-sm); overflow: hidden; }
.admin-panel-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; padding: 18px 20px; border-bottom: 1px solid var(--line); background: #fafaf9; }
.admin-panel-head h2 { font-size: 1rem; letter-spacing: -.02em; }
.admin-panel-head p { margin-top: 5px; color: var(--ink-muted); font-size: .8rem; }

.health-list, .review-stack, .tenant-list, .activity-list { display: grid; }
.health-row, .tenant-row, .activity-row, .review-action { display: flex; align-items: center; gap: 14px; padding: 16px 20px; border-bottom: 1px solid var(--line); }
.health-row:last-child, .tenant-row:last-child, .activity-row:last-child, .review-action:last-child { border-bottom: 0; }

.health-indicator { width: 9px; height: 9px; flex: 0 0 auto; border-radius: 50%; background: var(--line-strong); }
.health-indicator.is-good { background: var(--accent); }
.health-indicator.is-warn { background: var(--warning); }
.health-indicator.is-risk { background: var(--error); }

.health-row div, .tenant-row div, .activity-row div, .review-action div { min-width: 0; flex: 1; }
.health-row strong, .tenant-row strong, .activity-row strong, .review-action strong { display: block; font-size: .88rem; letter-spacing: -.01em; }
.health-row small, .tenant-row span, .activity-row small, .review-action small { display: block; margin-top: 3px; color: var(--ink-muted); font-size: .78rem; line-height: 1.4; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.health-status, .tenant-status { flex: 0 0 auto; padding: 4px 9px; border-radius: 999px; background: var(--paper); color: var(--ink-muted); font-size: .7rem; font-weight: 800; }
.review-action { color: inherit; transition: background var(--dur) ease; }
.review-action:hover { background: #fafaf8; }
.review-action > span { display: grid; place-items: center; width: 42px; height: 42px; flex: 0 0 auto; border-radius: var(--radius-sm); background: var(--accent-light); color: var(--accent-strong); font-weight: 900; font-size: 1.05rem; }

.tenant-avatar { display: grid; place-items: center; width: 38px; height: 38px; flex: 0 0 auto; border-radius: 10px; background: var(--night); color: #fff; font-weight: 800; }
.activity-row > span { width: 8px; height: 8px; flex: 0 0 auto; border-radius: 50%; background: var(--accent); box-shadow: 0 0 0 5px var(--accent-glow); }
.activity-row time { flex: 0 0 auto; color: var(--ink-subtle); font-size: .74rem; font-variant-numeric: tabular-nums; }

.admin-empty { padding: 28px 20px; color: var(--ink-muted); font-size: .86rem; }

@media (max-width: 1180px) {
  .admin-grid, .admin-grid.lower { grid-template-columns: 1fr; }
  .admin-metrics { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .admin-metrics > div:nth-child(2) { border-right: 0; }
  .admin-metrics > div:nth-child(-n+2) { border-bottom: 1px solid var(--line); }
}
@media (max-width: 760px) {
  .admin-command { align-items: stretch; flex-direction: column; min-height: 0; padding: 22px; }
  .admin-command h1 { font-size: 2.2rem; }
  .admin-command-status { min-width: 0; }
  .admin-metrics { grid-template-columns: 1fr; }
  .admin-metrics > div { border-right: 0; border-bottom: 1px solid var(--line); }
  .admin-metrics > div:last-child { border-bottom: 0; }
  .admin-panel-head { flex-direction: column; }
  .health-status, .tenant-status, .activity-row time { display: none; }
}

/* Error pages */
.error-shell {
  min-height: 100svh;
  padding: 24px;
  background:
    linear-gradient(120deg, rgba(16,25,23,.97), rgba(24,45,38,.94) 54%, rgba(31,143,102,.72)),
    var(--night);
  color: #fff;
}

.error-shell::before {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(255,255,255,.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.045) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: linear-gradient(to bottom, rgba(0,0,0,.85), transparent 82%);
}

.error-nav,
.error-stage {
  position: relative;
  z-index: 1;
  width: min(1180px, 100%);
  margin: 0 auto;
}

.error-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  min-height: 52px;
}

.error-brand,
.error-nav-actions {
  display: flex;
  align-items: center;
  gap: 12px;
}

.error-brand {
  font-weight: 800;
  letter-spacing: -.03em;
}

.error-brand-mark {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 9px;
  background: #fff;
  color: var(--accent-strong);
  box-shadow: 0 12px 32px rgba(0,0,0,.18);
}

.error-nav-actions a {
  color: rgba(255,255,255,.66);
  font-size: .86rem;
  font-weight: 700;
  transition: color var(--dur) ease;
}

.error-nav-actions a:hover { color: #fff; }

.error-stage {
  display: grid;
  grid-template-columns: minmax(0, .95fr) minmax(360px, .7fr);
  gap: clamp(32px, 8vw, 96px);
  align-items: center;
  min-height: calc(100svh - 100px);
  padding: 46px 0 72px;
}

.error-copy {
  max-width: 690px;
}

.error-copy .eyebrow {
  color: #8ee3b9;
}

.error-copy h1 {
  margin-top: 14px;
  max-width: 760px;
  font-size: clamp(2.8rem, 8vw, 7.25rem);
  line-height: .92;
  letter-spacing: -.06em;
}

.error-copy p {
  max-width: 560px;
  margin-top: 22px;
  color: rgba(255,255,255,.68);
  font-size: clamp(1rem, 2vw, 1.15rem);
  line-height: 1.55;
}

.error-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 30px;
}

.error-actions .btn-secondary {
  border-color: rgba(255,255,255,.24);
  color: #fff;
}

.error-actions .btn-secondary:hover {
  border-color: rgba(255,255,255,.42);
  background: rgba(255,255,255,.08);
}

.error-console {
  position: relative;
  min-height: 420px;
  border: 1px solid rgba(255,255,255,.13);
  border-radius: var(--radius);
  background:
    linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.055)),
    rgba(255,255,255,.04);
  box-shadow: 0 32px 90px rgba(0,0,0,.24);
  overflow: hidden;
}

.error-console::before {
  content: '';
  position: absolute;
  inset: 18px;
  border: 1px solid rgba(255,255,255,.09);
  border-radius: var(--radius-sm);
}

.error-code {
  position: absolute;
  right: -12px;
  top: 26px;
  color: rgba(255,255,255,.18);
  font-size: clamp(8rem, 18vw, 14rem);
  font-weight: 800;
  line-height: .78;
  letter-spacing: -.09em;
}

.error-console-panel {
  position: absolute;
  inset: auto 24px 24px;
  display: grid;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: var(--radius-sm);
  background: rgba(16,25,23,.74);
  backdrop-filter: blur(18px);
}

.error-console-panel div {
  display: grid;
  gap: 5px;
  padding: 16px;
  border-bottom: 1px solid rgba(255,255,255,.08);
}

.error-console-panel div:last-child { border-bottom: 0; }

.error-console-panel span {
  color: rgba(255,255,255,.44);
  font-size: .7rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.error-console-panel strong {
  overflow: hidden;
  color: rgba(255,255,255,.88);
  font-size: .9rem;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.error-shell-500 {
  background:
    linear-gradient(120deg, rgba(16,25,23,.97), rgba(47,38,28,.93) 54%, rgba(176,113,33,.72)),
    var(--night);
}

.error-shell-500 .error-copy .eyebrow { color: #f1c27a; }
.error-shell-500 .btn-primary { background: var(--warning); border-color: var(--warning); box-shadow: 0 12px 28px rgba(176,113,33,.3); }
.error-shell-500 .btn-primary:hover { background: #8d591a; border-color: #8d591a; }

@media (max-width: 880px) {
  .error-shell { padding: 18px; }
  .error-nav { align-items: flex-start; }
  .error-nav-actions { flex-wrap: wrap; justify-content: flex-end; }
  .error-stage {
    grid-template-columns: 1fr;
    min-height: 0;
    padding-top: 56px;
  }
  .error-console { min-height: 300px; }
}

@media (max-width: 560px) {
  .error-nav {
    align-items: flex-start;
    flex-direction: column;
  }
  .error-nav-actions { justify-content: flex-start; }
  .error-copy h1 { font-size: 3.25rem; }
  .error-actions { display: grid; }
  .error-actions .btn { width: 100%; }
}

/* Public pricing */
.pricing-header {
  background: rgba(253,252,248,.92);
  backdrop-filter: blur(18px);
}

.pricing-page {
  background: #fdfcf8;
}

.pricing-hero {
  display: grid;
  grid-template-columns: minmax(0, .95fr) minmax(360px, .62fr);
  gap: clamp(34px, 7vw, 108px);
  align-items: center;
  min-height: calc(100svh - 70px);
  padding: clamp(54px, 8vw, 112px) clamp(18px, 6vw, 76px) clamp(42px, 7vw, 86px);
  background:
    radial-gradient(circle at 92% 12%, rgba(31,143,102,.16), transparent 28%),
    linear-gradient(180deg, #fdfcf8, #f5f0e7);
}

.pricing-copy {
  max-width: 790px;
}

.pricing-copy h1 {
  margin-top: 16px;
  font-size: clamp(3rem, 7.6vw, 7.4rem);
  line-height: .9;
  letter-spacing: -.065em;
}

.pricing-copy p {
  max-width: 610px;
  margin-top: 24px;
  color: var(--ink-muted);
  font-size: clamp(1rem, 2vw, 1.18rem);
  line-height: 1.65;
}

.pricing-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  align-items: center;
  margin-top: 32px;
}

.pricing-link {
  color: var(--ink-muted);
  font-weight: 800;
  transition: color var(--dur) ease;
}

.pricing-link:hover {
  color: var(--accent-strong);
}

.pricing-snapshot {
  display: grid;
  gap: 18px;
  padding: 22px;
  border: 1px solid rgba(21,32,28,.1);
  border-radius: var(--radius);
  background: rgba(255,255,255,.72);
  box-shadow: var(--shadow-xl);
}

.snapshot-head,
.snapshot-meter div,
.snapshot-queue {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.snapshot-head {
  padding-bottom: 14px;
  border-bottom: 1px solid var(--line);
}

.snapshot-head span,
.snapshot-meter span,
.snapshot-queue span {
  color: var(--ink-muted);
  font-size: .8rem;
  font-weight: 700;
}

.snapshot-head strong,
.snapshot-meter strong,
.snapshot-queue strong {
  font-size: .92rem;
}

.snapshot-meter {
  display: grid;
  gap: 10px;
}

.snapshot-meter i {
  position: relative;
  height: 9px;
  overflow: hidden;
  border-radius: 999px;
  background: var(--line);
}

.snapshot-meter i::after {
  content: '';
  position: absolute;
  inset: 0 auto 0 0;
  width: var(--value);
  border-radius: inherit;
  background: var(--accent);
}

.snapshot-queue {
  padding: 16px;
  border-radius: var(--radius-sm);
  background: var(--night);
  color: #fff;
}

.snapshot-queue span {
  color: rgba(255,255,255,.56);
}

.pricing-plans {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  padding: 0 clamp(18px, 6vw, 76px) clamp(64px, 9vw, 112px);
  background: #f5f0e7;
}

.public-plan {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 26px;
  min-height: 560px;
  padding: 30px;
  border: 1px solid rgba(21,32,28,.11);
  border-radius: var(--radius);
  background: rgba(255,255,255,.72);
  box-shadow: var(--shadow-sm);
}

.public-plan.featured {
  background: var(--night);
  color: #fff;
  box-shadow: var(--shadow-xl);
}

.plan-ribbon {
  position: absolute;
  top: 18px;
  right: 18px;
  padding: 6px 10px;
  border-radius: 999px;
  background: var(--accent);
  color: #fff;
  font-size: .7rem;
  font-weight: 900;
}

.plan-kicker {
  display: block;
  color: var(--accent-strong);
  font-size: .74rem;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.featured .plan-kicker {
  color: #8ee3b9;
}

.public-plan h2 {
  margin-top: 12px;
  font-size: clamp(2.3rem, 4vw, 3.8rem);
  letter-spacing: -.055em;
}

.public-plan h2::after {
  content: ' / mes';
  color: var(--ink-subtle);
  font-size: .92rem;
  font-weight: 700;
  letter-spacing: 0;
}

.featured h2::after {
  color: rgba(255,255,255,.48);
}

.public-plan p {
  margin-top: 12px;
  color: var(--ink-muted);
  line-height: 1.55;
}

.featured p {
  color: rgba(255,255,255,.66);
}

.public-plan ul {
  display: grid;
  gap: 12px;
  margin-top: auto;
  padding: 0;
  list-style: none;
}

.public-plan li {
  position: relative;
  padding-left: 22px;
  color: var(--ink-muted);
  font-size: .92rem;
}

.public-plan li::before {
  content: '';
  position: absolute;
  left: 0;
  top: .55em;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--accent);
}

.featured li {
  color: rgba(255,255,255,.72);
}

.pricing-proof {
  display: grid;
  grid-template-columns: .72fr 1fr;
  gap: clamp(30px, 6vw, 78px);
  padding: clamp(62px, 9vw, 118px) clamp(18px, 6vw, 76px);
  background: #fdfcf8;
}

.pricing-proof h2 {
  margin-top: 12px;
  max-width: 560px;
  font-size: clamp(2rem, 4.2vw, 4.2rem);
  letter-spacing: -.045em;
}

.proof-grid {
  display: grid;
  border-top: 1px solid var(--line);
}

.proof-grid div {
  display: grid;
  grid-template-columns: 210px 1fr;
  gap: 24px;
  padding: 24px 0;
  border-bottom: 1px solid var(--line);
}

.proof-grid strong {
  font-size: .94rem;
}

.proof-grid span {
  color: var(--ink-muted);
  line-height: 1.62;
}

.pricing-final {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
  padding: clamp(42px, 7vw, 76px) clamp(18px, 6vw, 76px);
  background: var(--night);
  color: #fff;
}

.pricing-final h2 {
  max-width: 680px;
  font-size: clamp(2rem, 4vw, 4rem);
}

.pricing-final p {
  max-width: 560px;
  margin-top: 12px;
  color: rgba(255,255,255,.62);
}

@media (max-width: 980px) {
  .pricing-hero,
  .pricing-proof {
    grid-template-columns: 1fr;
  }

  .pricing-hero {
    min-height: 0;
  }

  .pricing-plans {
    grid-template-columns: 1fr;
  }

  .public-plan {
    min-height: 0;
  }
}

@media (max-width: 660px) {
  .pricing-actions,
  .pricing-final {
    align-items: stretch;
    flex-direction: column;
  }

  .pricing-actions a,
  .pricing-final a {
    width: 100%;
    justify-content: center;
  }

  .pricing-copy h1 {
    font-size: 3.05rem;
  }

  .proof-grid div {
    grid-template-columns: 1fr;
    gap: 8px;
  }
}

/* Lead Detail */
.lead-detail { display: grid; gap: 18px; }

.lead-hero {
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 24px;
  min-height: 230px;
  padding: 28px;
  border-radius: var(--radius);
  background:
    linear-gradient(115deg, rgba(16,25,23,.98) 0%, rgba(23,40,34,.94) 58%, rgba(31,143,102,.72) 100%),
    radial-gradient(circle at 82% 14%, rgba(255,255,255,.18), transparent 30%);
  color: #fff;
  box-shadow: var(--shadow-md);
}

.lead-hero::after {
  content: '';
  position: absolute;
  right: -80px;
  bottom: -120px;
  width: 360px;
  height: 360px;
  border: 1px solid rgba(255,255,255,.13);
  border-radius: 50%;
}

.lead-identity {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  gap: 18px;
  min-width: 0;
}

.lead-avatar {
  width: 76px;
  height: 76px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  border-radius: 18px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.16);
  color: #fff;
  font-size: 2rem;
  font-weight: 800;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.18);
}

.lead-identity .eyebrow { color: #79d6a9; }
.lead-identity h1 {
  max-width: 720px;
  margin: 8px 0 6px;
  overflow-wrap: anywhere;
  font-size: clamp(2rem, 4vw, 4rem);
  letter-spacing: -.04em;
}
.lead-identity p { color: rgba(255,255,255,.68); font-size: .95rem; }
.lead-badges { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 12px; }

.lead-score-dial {
  --angle: calc(var(--score) * 3.6deg);
  position: relative;
  z-index: 1;
  width: 142px;
  height: 142px;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  border-radius: 50%;
  background:
    radial-gradient(circle at center, var(--night) 0 57%, transparent 58%),
    conic-gradient(#79d6a9 var(--angle), rgba(255,255,255,.14) 0);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.10), 0 18px 44px rgba(0,0,0,.22);
}
.lead-score-dial span { display: block; font-size: 2.4rem; font-weight: 800; line-height: 1; }
.lead-score-dial small { display: block; margin-top: 5px; color: rgba(255,255,255,.58); font-size: .72rem; font-weight: 700; text-transform: uppercase; }

.lead-kpi-strip {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel);
  box-shadow: var(--shadow-sm);
}
.lead-kpi-strip > div { min-width: 0; padding: 18px 20px; border-right: 1px solid var(--line); }
.lead-kpi-strip > div:last-child { border-right: 0; }
.lead-kpi-strip span,
.lead-kpi-strip small { display: block; }
.lead-kpi-strip span { color: var(--ink-muted); font-size: .72rem; font-weight: 800; letter-spacing: .06em; text-transform: uppercase; }
.lead-kpi-strip strong { display: block; margin-top: 8px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-size: 1.4rem; letter-spacing: -.03em; }
.lead-kpi-strip small { margin-top: 7px; overflow: hidden; color: var(--ink-subtle); font-size: .76rem; text-overflow: ellipsis; white-space: nowrap; }

.lead-layout { display: grid; grid-template-columns: minmax(0, 1fr) 360px; gap: 18px; align-items: start; }
.lead-main,
.lead-side { display: grid; gap: 18px; min-width: 0; }

.lead-panel {
  min-width: 0;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel);
  box-shadow: var(--shadow-sm);
}
.lead-panel-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 18px 20px;
  border-bottom: 1px solid var(--line);
  background: #fafaf9;
}
.lead-panel-head.compact { display: block; }
.lead-panel-head h2 { font-size: 1rem; letter-spacing: -.02em; }
.lead-panel-head p { max-width: 620px; margin-top: 5px; color: var(--ink-muted); font-size: .82rem; line-height: 1.5; }

.lead-chat {
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-height: 680px;
  overflow-y: auto;
  padding: 20px;
  background: linear-gradient(180deg, rgba(246,244,238,.38), transparent);
}
.lead-message { display: flex; justify-content: flex-start; }
.lead-message.is-outbound { justify-content: flex-end; }
.lead-message.is-internal { justify-content: center; }
.lead-message-bubble {
  max-width: min(74%, 620px);
  padding: 13px 15px 11px;
  border: 1px solid var(--line);
  border-radius: 14px 14px 14px 4px;
  background: #fff;
  box-shadow: var(--shadow-sm);
}
.lead-message.is-outbound .lead-message-bubble {
  border-color: rgba(31,143,102,.28);
  border-radius: 14px 14px 4px 14px;
  background: var(--accent-light);
}
.lead-message.is-internal .lead-message-bubble {
  border-style: dashed;
  border-radius: var(--radius-sm);
  background: #fafaf9;
}
.lead-message-bubble p { color: var(--ink); font-size: .91rem; line-height: 1.55; }
.lead-message-bubble footer {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin-top: 9px;
  color: var(--ink-subtle);
  font-size: .68rem;
  font-weight: 700;
  text-transform: uppercase;
}

.lead-timeline { display: grid; padding: 8px 20px 20px; }
.lead-timeline article {
  position: relative;
  display: grid;
  grid-template-columns: 16px minmax(0, 1fr);
  gap: 12px;
  padding: 14px 0;
  border-bottom: 1px solid var(--line);
}
.lead-timeline article:last-child { border-bottom: 0; }
.timeline-dot {
  width: 10px;
  height: 10px;
  margin-top: 6px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 0 4px var(--accent-light);
}
.timeline-dot.is-alert { background: var(--warning); box-shadow: 0 0 0 4px #fef3c7; }
.lead-timeline strong { display: block; font-size: .88rem; }
.lead-timeline p { margin-top: 3px; color: var(--ink-muted); font-size: .82rem; }
.lead-timeline time { display: block; margin-top: 6px; color: var(--ink-subtle); font-size: .72rem; font-weight: 700; }

.lead-score-list,
.lead-ai-runs,
.lead-notes { display: grid; padding: 8px 18px 18px; }
.lead-score-row { display: grid; gap: 9px; padding: 13px 0; border-bottom: 1px solid var(--line); }
.lead-score-row:last-child { border-bottom: 0; }
.lead-score-row > div:first-child { display: flex; justify-content: space-between; gap: 12px; color: var(--ink); font-size: .84rem; }
.lead-score-row span { color: var(--ink-muted); font-weight: 700; }
.lead-score-bar { height: 8px; overflow: hidden; border-radius: 99px; background: #edf2ef; }
.lead-score-bar span { display: block; height: 100%; border-radius: inherit; background: linear-gradient(90deg, var(--accent), #79d6a9); }

.lead-ai-runs article,
.lead-notes > div {
  display: grid;
  gap: 4px;
  padding: 13px 0;
  border-bottom: 1px solid var(--line);
}
.lead-ai-runs article:last-child,
.lead-notes > div:last-child { border-bottom: 0; }
.lead-ai-runs strong,
.lead-notes span { font-size: .84rem; font-weight: 800; }
.lead-ai-runs span,
.lead-ai-runs small,
.lead-notes p { color: var(--ink-muted); font-size: .8rem; line-height: 1.5; }
.lead-ai-runs small.is-error { color: var(--error); }

.lead-empty {
  display: grid;
  gap: 5px;
  padding: 28px;
  color: var(--ink-muted);
  text-align: center;
}
.lead-empty.compact { padding: 18px 0 0; text-align: left; }
.lead-empty strong { color: var(--ink); font-size: .9rem; }
.lead-empty span { font-size: .82rem; }

@media (max-width: 1180px) {
  .lead-layout { grid-template-columns: 1fr; }
  .lead-side { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .lead-side .lead-panel:last-child { grid-column: 1 / -1; }
}

@media (max-width: 840px) {
  .lead-hero { align-items: flex-start; flex-direction: column; min-height: 0; padding: 22px; }
  .lead-identity { align-items: flex-start; }
  .lead-avatar { width: 58px; height: 58px; border-radius: 14px; font-size: 1.45rem; }
  .lead-score-dial { width: 112px; height: 112px; }
  .lead-score-dial span { font-size: 1.9rem; }
  .lead-kpi-strip,
  .lead-side { grid-template-columns: 1fr; }
  .lead-kpi-strip > div { border-right: 0; border-bottom: 1px solid var(--line); }
  .lead-kpi-strip > div:last-child { border-bottom: 0; }
  .lead-panel-head { flex-direction: column; padding: 16px; }
  .lead-chat { padding: 16px; }
  .lead-message-bubble { max-width: 94%; }
}

/* Team */
.team-shell { display: grid; gap: 18px; }

.team-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 390px;
  gap: 24px;
  align-items: stretch;
  min-height: 320px;
  padding: 28px;
  overflow: hidden;
  border-radius: var(--radius);
  background:
    linear-gradient(116deg, rgba(16,25,23,.98), rgba(25,44,38,.94) 58%, rgba(31,143,102,.7)),
    radial-gradient(circle at 86% 18%, rgba(255,255,255,.16), transparent 30%);
  color: #fff;
  box-shadow: var(--shadow-md);
}

.team-hero > div:first-child {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  max-width: 780px;
}

.team-hero .eyebrow { color: #8ee3b9; }
.team-hero h1 {
  margin-top: 14px;
  font-size: clamp(2.35rem, 5.4vw, 5.6rem);
  line-height: .94;
  letter-spacing: -.055em;
}
.team-hero p {
  max-width: 560px;
  margin-top: 18px;
  color: rgba(255,255,255,.66);
  font-size: 1rem;
  line-height: 1.62;
}

.team-invite-panel {
  display: grid;
  align-content: start;
  gap: 14px;
  padding: 20px;
  border: 1px solid rgba(255,255,255,.13);
  border-radius: var(--radius);
  background: rgba(255,255,255,.09);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
  backdrop-filter: blur(16px);
}
.team-invite-panel .form-group { margin-bottom: 0; }
.team-invite-panel label { color: rgba(255,255,255,.8); }
.team-invite-panel input,
.team-invite-panel select,
.team-invite-panel textarea {
  border-color: rgba(255,255,255,.14);
  background-color: rgba(255,255,255,.92);
}

.team-invite-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}
.team-invite-head span {
  display: block;
  color: rgba(255,255,255,.52);
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.team-invite-head strong { display: block; margin-top: 3px; color: #fff; font-size: 1.05rem; }

.team-metrics {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel);
  box-shadow: var(--shadow-sm);
}
.team-metrics > div {
  min-width: 0;
  padding: 18px 20px;
  border-right: 1px solid var(--line);
}
.team-metrics > div:last-child { border-right: 0; }
.team-metrics span,
.team-metrics small { display: block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.team-metrics span {
  color: var(--ink-muted);
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.team-metrics strong {
  display: block;
  margin-top: 8px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 1.55rem;
  letter-spacing: -.04em;
}
.team-metrics small { margin-top: 6px; color: var(--ink-subtle); font-size: .76rem; }

.team-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 18px;
  align-items: start;
}
.team-main,
.team-side { display: grid; gap: 18px; min-width: 0; }

.team-panel {
  min-width: 0;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel);
  box-shadow: var(--shadow-sm);
}
.team-panel-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 18px 20px;
  border-bottom: 1px solid var(--line);
  background: #fafaf9;
}
.team-panel-head h2 { font-size: 1rem; letter-spacing: -.02em; }
.team-panel-head p { max-width: 620px; margin-top: 5px; color: var(--ink-muted); font-size: .82rem; line-height: 1.5; }

.team-member-list,
.team-invite-list { display: grid; }

.team-member-row,
.team-invite-row {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr) auto auto;
  gap: 14px;
  align-items: center;
  padding: 16px 20px;
  border-bottom: 1px solid var(--line);
}
.team-invite-row { grid-template-columns: minmax(0, 1fr) auto auto; }
.team-member-row:last-child,
.team-invite-row:last-child { border-bottom: 0; }

.team-avatar {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 11px;
  background: var(--accent-light);
  color: var(--accent-strong);
  font-weight: 900;
}
.team-member-main,
.team-invite-row div { min-width: 0; }
.team-member-main strong,
.team-invite-row strong {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: .92rem;
}
.team-member-main span,
.team-invite-row span {
  display: block;
  margin-top: 3px;
  overflow: hidden;
  color: var(--ink-muted);
  font-size: .8rem;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.team-role {
  padding: 5px 9px;
  border-radius: 999px;
  background: #f0f4f2;
  color: var(--ink-muted);
  font-size: .7rem;
  font-weight: 800;
  white-space: nowrap;
}

.role-matrix,
.team-readiness { display: grid; padding: 8px 18px 18px; }
.role-matrix article {
  display: grid;
  gap: 8px;
  padding: 14px 0;
  border-bottom: 1px solid var(--line);
}
.role-matrix article:last-child { border-bottom: 0; }
.role-matrix strong { font-size: .92rem; }
.role-matrix p { color: var(--ink-muted); font-size: .82rem; line-height: 1.5; }
.role-matrix article div { display: flex; flex-wrap: wrap; gap: 6px; }
.role-matrix article span {
  padding: 4px 8px;
  border-radius: 999px;
  background: var(--accent-light);
  color: var(--accent-strong);
  font-size: .68rem;
  font-weight: 800;
}

.team-readiness { gap: 0; }
.team-readiness > div {
  display: grid;
  grid-template-columns: 18px minmax(0, 1fr);
  gap: 10px;
  padding: 13px 0;
  border-bottom: 1px solid var(--line);
}
.team-readiness > div:last-child { border-bottom: 0; }
.team-readiness > div > span {
  width: 12px;
  height: 12px;
  margin-top: 5px;
  border-radius: 50%;
  background: var(--line-strong);
  box-shadow: 0 0 0 4px #eef2ef;
}
.team-readiness > div.is-done > span {
  background: var(--accent);
  box-shadow: 0 0 0 4px var(--accent-light);
}
.team-readiness strong,
.team-readiness small { display: block; }
.team-readiness strong { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-size: .84rem; }
.team-readiness small { margin-top: 3px; color: var(--ink-muted); font-size: .76rem; }

.team-empty {
  display: grid;
  gap: 5px;
  padding: 28px;
  color: var(--ink-muted);
  text-align: center;
}
.team-empty strong { color: var(--ink); font-size: .9rem; }
.team-empty p { font-size: .82rem; }

@media (max-width: 1080px) {
  .team-hero,
  .team-layout { grid-template-columns: 1fr; }
  .team-side { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 760px) {
  .team-hero { min-height: 0; padding: 22px; }
  .team-metrics { grid-template-columns: 1fr; }
  .team-metrics > div { border-right: 0; border-bottom: 1px solid var(--line); }
  .team-metrics > div:last-child { border-bottom: 0; }
  .team-side { grid-template-columns: 1fr; }
  .team-panel-head,
  .team-invite-head { flex-direction: column; align-items: flex-start; }
  .team-member-row,
  .team-invite-row { grid-template-columns: 1fr; align-items: start; }
  .team-avatar { display: none; }
}

/* ============================================================
   CRM / LEADS — Full redesign
   ============================================================ */

/* KPI strip */
.crm-kpi-strip {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 12px;
  margin-bottom: 20px;
}
.crm-kpi {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 16px 20px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  transition: box-shadow .15s;
}
.crm-kpi:hover { box-shadow: var(--shadow-sm); }
.crm-kpi-value {
  font-size: 1.7rem;
  font-weight: 700;
  letter-spacing: -.02em;
  color: var(--ink);
  line-height: 1;
}
.crm-kpi-label {
  font-size: .72rem;
  color: var(--ink-subtle);
  text-transform: uppercase;
  letter-spacing: .04em;
}
.crm-kpi--blue  .crm-kpi-value { color: var(--accent); }
.crm-kpi--green .crm-kpi-value { color: #16a34a; }
.crm-kpi--yellow .crm-kpi-value { color: #d97706; }
.crm-kpi--purple .crm-kpi-value { color: #7c3aed; }

/* Toolbar */
.crm-toolbar {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
  flex-wrap: wrap;
}
.crm-search-wrap { flex: 1; min-width: 220px; }
.crm-search-field {
  position: relative;
  display: flex;
  align-items: center;
}
.crm-search-icon {
  position: absolute;
  left: 10px;
  color: var(--ink-subtle);
  pointer-events: none;
}
.crm-search-input {
  width: 100%;
  padding: 8px 34px 8px 34px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  color: var(--ink);
  font-size: .85rem;
  transition: border-color .15s, box-shadow .15s;
}
.crm-search-input:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-glow, rgba(79,70,229,.12));
}
.crm-search-clear {
  position: absolute;
  right: 10px;
  color: var(--ink-subtle);
  font-size: .75rem;
  text-decoration: none;
  padding: 2px 4px;
  border-radius: 4px;
}
.crm-search-clear:hover { color: var(--ink); background: var(--line); }
.crm-filter-group { display: flex; gap: 8px; flex-shrink: 0; }
.crm-select {
  padding: 7px 28px 7px 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  color: var(--ink);
  font-size: .82rem;
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 8px center;
}
.crm-select:focus { outline: none; border-color: var(--accent); }
.crm-help {
  position: relative;
  flex: 0 0 auto;
}
.crm-help summary { list-style: none; }
.crm-help summary::-webkit-details-marker { display: none; }
.crm-help-trigger {
  gap: 7px;
  user-select: none;
}
.crm-help-icon {
  width: 16px;
  height: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--accent-light);
  color: var(--accent-strong);
  font-size: .68rem;
  font-weight: 800;
  line-height: 1;
}
.crm-help[open] .crm-help-trigger {
  border-color: var(--accent);
  color: var(--accent-strong);
  background: var(--accent-light);
}
.crm-help-panel {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  z-index: 80;
  width: min(760px, calc(100vw - 48px));
  max-height: min(72vh, 560px);
  overflow-y: auto;
  display: grid;
  grid-template-columns: minmax(280px, 1fr) minmax(260px, .9fr);
  gap: 22px;
  padding: 20px;
  border: 1.5px solid var(--line-strong);
  border-radius: var(--radius);
  background: var(--panel);
  box-shadow: var(--shadow-lg);
}
.crm-help-section h3 {
  margin: 0 0 10px;
  color: var(--ink);
  font-size: .82rem;
  letter-spacing: .02em;
  text-transform: uppercase;
}
.crm-help-list {
  display: grid;
  gap: 10px;
}
.crm-help-list div {
  display: grid;
  grid-template-columns: minmax(130px, .48fr) minmax(0, 1fr);
  gap: 12px;
  padding: 0 0 10px;
  border-bottom: 1px solid var(--line);
}
.crm-help-list div:last-child {
  padding-bottom: 0;
  border-bottom: 0;
}
.crm-help-list dt {
  color: var(--ink);
  font-size: .78rem;
  font-weight: 800;
  line-height: 1.35;
}
.crm-help-list dd {
  margin: 0;
  color: var(--ink-muted);
  font-size: .78rem;
  line-height: 1.45;
}

/* Status tabs */
.crm-tabs {
  display: flex;
  gap: 2px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 0;
  overflow-x: auto;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}
.crm-tabs::-webkit-scrollbar { display: none; }
.crm-tab {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 9px 14px;
  font-size: .8rem;
  font-weight: 500;
  color: var(--ink-muted);
  text-decoration: none;
  border-bottom: 2px solid transparent;
  white-space: nowrap;
  transition: color .15s, border-color .15s;
  margin-bottom: -1px;
}
.crm-tab:hover { color: var(--ink); }
.crm-tab.active {
  color: var(--accent);
  border-bottom-color: var(--accent);
}
.crm-tab-count {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 1px 6px;
  font-size: .7rem;
  font-weight: 600;
  color: var(--ink-muted);
}
.crm-tab.active .crm-tab-count {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}

/* Table shell */
.crm-table-shell {
  background: var(--surface);
  border: 1px solid var(--line);
  border-top: 0;
  border-radius: 0 0 var(--radius) var(--radius);
  overflow: hidden;
}

/* Bulk action bar */
.crm-bulk-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  background: var(--accent-light, rgba(79,70,229,.06));
  border-bottom: 1px solid var(--line);
  flex-wrap: wrap;
}
.crm-bulk-label {
  font-size: .82rem;
  font-weight: 600;
  color: var(--accent);
  margin-right: 4px;
}

/* CRM Table overrides */
.crm-table { width: 100%; }
.crm-table thead th { background: var(--bg); font-size: .72rem; text-transform: uppercase; letter-spacing: .04em; color: var(--ink-subtle); }
.th-check, .td-check { width: 36px; padding-left: 16px !important; }
.crm-check { cursor: pointer; accent-color: var(--accent); width: 14px; height: 14px; }
.crm-table tbody tr.crm-row:hover { background: var(--bg); }
.crm-table td { vertical-align: middle; }

/* Lead cell */
.crm-lead-cell { display: flex; align-items: center; gap: 10px; }
.crm-avatar {
  width: 34px; height: 34px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: .85rem; font-weight: 700;
  flex-shrink: 0;
}
.crm-avatar.score-high { background: #dcfce7; color: #15803d; }
.crm-avatar.score-mid  { background: #fef9c3; color: #a16207; }
.crm-avatar.score-low  { background: var(--bg); color: var(--ink-muted); }
.crm-lead-info { display: flex; flex-direction: column; gap: 1px; }
.crm-lead-name {
  font-size: .85rem; font-weight: 600;
  color: var(--ink);
  text-decoration: none;
  white-space: nowrap;
}
.crm-lead-name:hover { color: var(--accent); }
.crm-lead-sub { font-size: .75rem; color: var(--ink-muted); }
.crm-lead-summary { font-size: .73rem; color: var(--ink-subtle); max-width: 220px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* Score bar (temperature) */
.td-temp { min-width: 120px; }
.crm-score-bar-wrap {
  height: 5px;
  background: var(--line);
  border-radius: 3px;
  overflow: hidden;
  margin-bottom: 3px;
  width: 80px;
}
.crm-score-bar {
  height: 100%;
  border-radius: 3px;
  transition: width .4s ease;
}
.crm-score-bar.bar-high { background: #16a34a; }
.crm-score-bar.bar-mid  { background: #d97706; }
.crm-score-bar.bar-low  { background: #6b7280; }
.crm-score-num { font-size: .72rem; color: var(--ink-muted); font-weight: 600; }

/* Score ring (avg) */
.td-score { min-width: 90px; }
.crm-score-ring {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px; height: 34px;
}
.ring-svg { width: 34px; height: 34px; transform: rotate(-90deg); }
.ring-bg   { fill: none; stroke: var(--line); stroke-width: 4; }
.ring-fill { fill: none; stroke-width: 4; stroke-linecap: round; transition: stroke-dasharray .5s ease; }
.score-high .ring-fill { stroke: #16a34a; }
.score-mid  .ring-fill { stroke: #d97706; }
.score-low  .ring-fill { stroke: #9ca3af; }
.ring-label {
  position: absolute;
  font-size: .58rem;
  font-weight: 700;
  color: var(--ink-muted);
}
.crm-score-breakdown {
  display: flex; flex-direction: column; gap: 1px;
  font-size: .65rem; color: var(--ink-subtle);
  margin-left: 4px;
}
.td-score { display: flex; align-items: center; gap: 4px; }

/* Control badge */
.crm-control {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: .75rem;
  font-weight: 500;
  padding: 3px 8px;
  border-radius: 20px;
  white-space: nowrap;
}
.crm-ctrl-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}
.crm-control--bot  { background: rgba(20,184,166,.1); color: #0f766e; }
.crm-control--bot  .crm-ctrl-dot { background: #0f766e; box-shadow: 0 0 0 2px rgba(20,184,166,.25); }
.crm-control--human { background: rgba(124,58,237,.1); color: #6d28d9; }
.crm-control--human .crm-ctrl-dot { background: #7c3aed; animation: pulse-dot 1.6s infinite; }

.setter-status {
  display: inline-flex;
  align-items: center;
  max-width: 150px;
  padding: 3px 8px;
  border-radius: 20px;
  overflow: hidden;
  font-size: .72rem;
  font-weight: 700;
  line-height: 1.25;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.setter-status--waiting { background: rgba(100,116,139,.1); color: #475569; }
.setter-status--working { background: rgba(37,99,235,.1); color: #1d4ed8; }
.setter-status--ok { background: rgba(22,163,74,.1); color: #15803d; }
.setter-status--error { background: rgba(220,38,38,.1); color: #b91c1c; }
.setter-status--human { background: rgba(124,58,237,.1); color: #6d28d9; }
.td-setter .setter-countdown {
  display: block;
  margin-top: 4px;
  color: var(--ink-subtle);
  font-size: .68rem;
  font-weight: 700;
  white-space: nowrap;
}
.lead-kpi-strip .setter-countdown {
  display: inline;
  color: var(--ink-subtle);
  font-size: .76rem;
  font-weight: 600;
  letter-spacing: 0;
  text-transform: none;
}
.setter-countdown.is-due { color: #b45309; }

@keyframes pulse-dot {
  0%, 100% { box-shadow: 0 0 0 0 rgba(124,58,237,.4); }
  50%       { box-shadow: 0 0 0 4px rgba(124,58,237,.0); }
}

/* Timestamp */
.crm-time { font-size: .78rem; color: var(--ink-muted); white-space: nowrap; }
.crm-time--created { color: var(--ink-subtle); }
.crm-time-empty { color: var(--ink-subtle); }

/* Row actions */
.td-actions .crm-row-actions { display: flex; gap: 4px; align-items: center; }
.crm-btn-view { min-width: 42px; }

/* Pagination */
.crm-pagination {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 20px;
  border-top: 1px solid var(--line);
  flex-wrap: wrap;
  gap: 10px;
}
.crm-pag-info { font-size: .78rem; color: var(--ink-muted); }
.crm-pag-nav  { display: flex; align-items: center; gap: 4px; }
.crm-pag-link {
  min-width: 32px; height: 32px;
  display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  font-size: .8rem;
  color: var(--ink-muted);
  text-decoration: none;
  transition: background .12s, border-color .12s;
}
.crm-pag-link:hover { background: var(--bg); border-color: var(--accent); color: var(--accent); }
.crm-pag-cur {
  min-width: 32px; height: 32px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--accent);
  color: #fff;
  border-radius: var(--radius);
  font-size: .8rem;
  font-weight: 700;
}
.crm-pag-ellipsis { color: var(--ink-subtle); padding: 0 4px; }

/* Empty state */
.crm-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 60px 40px;
  text-align: center;
  gap: 12px;
}
.crm-empty .empty-icon { font-size: 2.8rem; line-height: 1; }
.crm-empty h3 { font-size: 1.1rem; font-weight: 700; color: var(--ink); margin: 0; }
.crm-empty p  { color: var(--ink-muted); font-size: .88rem; margin: 0; max-width: 360px; }

/* Badge extras for new statuses */
.badge-indigo { background: rgba(99,102,241,.12); color: #4338ca; }
.badge-violet { background: rgba(139,92,246,.12); color: #7c3aed; }
.badge-red    { background: rgba(239,68,68,.12);  color: #dc2626; }

/* ---------- Responsive ---------- */
@media (max-width: 1100px) {
  .crm-kpi-strip { grid-template-columns: repeat(3, 1fr); }
  .crm-kpi-strip .crm-kpi:nth-child(4),
  .crm-kpi-strip .crm-kpi:nth-child(5) { display: none; }
  .crm-score-bar-wrap { width: 60px; }
  .crm-lead-summary { display: none; }
}
@media (max-width: 820px) {
  .crm-kpi-strip { grid-template-columns: repeat(2, 1fr); }
  .crm-kpi-strip .crm-kpi:nth-child(3),
  .crm-kpi-strip .crm-kpi:nth-child(4),
  .crm-kpi-strip .crm-kpi:nth-child(5) { display: none; }
  .crm-help { position: static; }
  .crm-help-panel {
    left: 16px;
    right: 16px;
    width: auto;
    grid-template-columns: 1fr;
  }
  .td-temp, .td-score, .crm-score-breakdown { display: none; }
  .crm-lead-sub { display: none; }
}
@media (max-width: 560px) {
  .crm-kpi-strip { grid-template-columns: 1fr 1fr; }
  .crm-kpi-strip .crm-kpi:nth-child(n+3) { display: none; }
  .crm-toolbar { flex-direction: column; align-items: stretch; }
  .crm-filter-group { justify-content: flex-end; }
  .crm-help-trigger { width: 100%; }
  .crm-help-panel { left: 12px; right: 12px; }
  .crm-help-list div { grid-template-columns: 1fr; gap: 3px; }
  .td-time, .td-status { display: none; }
  .crm-pagination { flex-direction: column; align-items: center; }
}

/* ============================================================
   ACCOUNTS page KPI strip
   ============================================================ */
.acct-kpi-row {
  display: flex;
  gap: 12px;
  margin-bottom: 20px;
}
.acct-kpi {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 16px 20px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex: 1;
}
.acct-kpi-num {
  font-size: 1.6rem;
  font-weight: 700;
  letter-spacing: -.02em;
  color: var(--ink);
  line-height: 1;
}
.acct-kpi-label {
  font-size: .72rem;
  color: var(--ink-subtle);
  text-transform: uppercase;
  letter-spacing: .04em;
}
.acct-kpi--green .acct-kpi-num { color: #16a34a; }
.acct-kpi--amber .acct-kpi-num { color: #d97706; }
.card-header-sub { font-size: .78rem; color: var(--ink-subtle); }
@media (max-width: 560px) {
  .acct-kpi-row { flex-direction: column; }
}

/* ============================================================
   SETTINGS global preferences
   ============================================================ */
.settings-shell { display: grid; gap: 20px; }

.settings-hero {
  display: flex;
  align-items: stretch;
  justify-content: space-between;
  gap: 22px;
  min-height: 180px;
  padding: 28px;
  border-radius: calc(var(--radius) + 2px);
  background:
    linear-gradient(135deg, rgba(15,23,42,.95), rgba(22,78,99,.9)),
    var(--ink);
  color: #fff;
  overflow: hidden;
}

.settings-hero-copy {
  display: flex;
  flex-direction: column;
  justify-content: center;
  max-width: 660px;
}

.settings-hero .eyebrow { color: #93e0c4; }

.settings-hero h1 {
  max-width: 620px;
  margin: 8px 0 10px;
  font-size: clamp(1.8rem, 3vw, 3.2rem);
  line-height: .98;
  letter-spacing: -.04em;
}

.settings-hero p {
  max-width: 580px;
  color: rgba(255,255,255,.72);
  font-size: .95rem;
  line-height: 1.55;
}

.settings-readiness {
  align-self: center;
  min-width: 180px;
  padding: 20px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: var(--radius);
  background: rgba(255,255,255,.07);
}

.settings-readiness span,
.settings-readiness small {
  display: block;
  color: rgba(255,255,255,.62);
  font-size: .76rem;
  text-transform: uppercase;
  letter-spacing: .06em;
}

.settings-readiness strong {
  display: block;
  margin: 8px 0 4px;
  color: #fff;
  font-size: 2.5rem;
  line-height: 1;
}

.settings-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 340px;
  gap: 18px;
  align-items: start;
}

.settings-main,
.settings-side { display: grid; gap: 18px; min-width: 0; }

.settings-side {
  position: sticky;
  top: 88px;
}

.settings-panel {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}

.settings-panel-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  padding: 18px 20px;
  border-bottom: 1px solid var(--line);
}

.settings-panel-head h2 {
  margin: 0 0 5px;
  font-size: 1rem;
  letter-spacing: -.02em;
}

.settings-panel-head p {
  max-width: 620px;
  margin: 0;
  color: var(--ink-muted);
  font-size: .82rem;
  line-height: 1.5;
}

.settings-form-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  padding: 20px;
}

.settings-form-grid .form-group { margin-bottom: 0; }
.settings-wide { grid-column: 1 / -1; }

.settings-toggle-list { display: grid; padding: 6px 20px 12px; }

.settings-toggle-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 16px 0;
  border-bottom: 1px solid var(--line);
  cursor: pointer;
}

.settings-toggle-row:last-child { border-bottom: 0; }

.settings-toggle-row span {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.settings-toggle-row strong {
  color: var(--ink);
  font-size: .9rem;
}

.settings-toggle-row small {
  color: var(--ink-muted);
  font-size: .78rem;
  line-height: 1.45;
}

.settings-toggle-row input {
  width: 44px;
  height: 24px;
  flex: 0 0 auto;
  appearance: none;
  border-radius: 999px;
  background: var(--line-strong);
  position: relative;
  cursor: pointer;
  transition: background .16s var(--ease);
}

.settings-toggle-row input::after {
  content: "";
  position: absolute;
  top: 3px;
  left: 3px;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 2px 5px rgba(15,23,42,.22);
  transition: transform .16s var(--ease);
}

.settings-toggle-row input:checked { background: var(--accent); }
.settings-toggle-row input:checked::after { transform: translateX(20px); }

.settings-checklist { display: grid; padding: 8px 18px 18px; }

.settings-checklist > div {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 13px 0;
  border-bottom: 1px solid var(--line);
}

.settings-checklist > div:last-child { border-bottom: 0; }

.settings-checklist span {
  width: 18px;
  height: 18px;
  flex: 0 0 auto;
  border: 2px solid var(--line-strong);
  border-radius: 50%;
}

.settings-checklist strong {
  overflow: hidden;
  color: var(--ink-muted);
  font-size: .84rem;
  font-weight: 700;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.settings-checklist .is-done span {
  border-color: var(--accent);
  background: radial-gradient(circle at center, var(--accent) 42%, transparent 45%);
}

.settings-checklist .is-done strong { color: var(--ink); }

.settings-impact-list { display: grid; padding: 6px 18px 16px; }

.settings-impact-list > div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 12px 0;
  border-bottom: 1px solid var(--line);
}

.settings-impact-list > div:last-child { border-bottom: 0; }
.settings-impact-list span { color: var(--ink-subtle); font-size: .78rem; }
.settings-impact-list strong { color: var(--ink); font-size: .84rem; text-align: right; }

.settings-save {
  width: 100%;
  justify-content: center;
  min-height: 44px;
}

@media (max-width: 1020px) {
  .settings-layout { grid-template-columns: 1fr; }
  .settings-side {
    position: static;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .settings-save { grid-column: 1 / -1; }
}

@media (max-width: 720px) {
  .settings-hero { flex-direction: column; padding: 22px; }
  .settings-readiness { align-self: stretch; }
  .settings-form-grid { grid-template-columns: 1fr; padding: 16px; }
  .settings-side { grid-template-columns: 1fr; }
  .settings-panel-head { padding: 16px; }
  .settings-toggle-list { padding-inline: 16px; }
}

/* ============================================================
   OPS surfaces: onboarding + notifications
   ============================================================ */
.ops-page {
  display: grid;
  gap: 18px;
  color: var(--ink);
}

.ops-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 24px;
  padding: 8px 0 18px;
  border-bottom: 1px solid var(--line);
}

.ops-kicker {
  display: block;
  margin-bottom: 8px;
  color: var(--accent-strong);
  font-size: .74rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.ops-header h1 {
  max-width: 780px;
  margin: 0;
  color: var(--ink);
  font-size: clamp(1.8rem, 3vw, 3rem);
  line-height: 1.02;
  letter-spacing: -.03em;
}

.ops-header p {
  max-width: 660px;
  margin: 10px 0 0;
  color: var(--ink-muted);
  font-size: .94rem;
  line-height: 1.55;
}

.ops-header-score {
  min-width: 150px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  box-shadow: var(--shadow-sm);
  text-align: right;
}

.ops-header-score strong {
  display: block;
  color: var(--ink);
  font-size: 2.35rem;
  line-height: 1;
  letter-spacing: -.03em;
}

.ops-header-score span {
  display: block;
  margin-top: 6px;
  color: var(--ink-subtle);
  font-size: .76rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .06em;
}

.ops-header-score.is-hot {
  border-color: rgba(239, 68, 68, .24);
  background: #fff7f7;
}

.ops-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 22px;
  align-items: start;
}

.ops-main,
.ops-side {
  display: grid;
  gap: 18px;
  min-width: 0;
}

.ops-side {
  position: sticky;
  top: 88px;
}

.ops-section-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 14px;
}

.ops-section-head.spaced { margin-top: 10px; }
.ops-section-head.compact { display: block; padding: 18px 18px 0; }

.ops-section-head h2 {
  margin: 0;
  color: var(--ink);
  font-size: 1rem;
  letter-spacing: -.02em;
}

.ops-section-head p {
  margin: 5px 0 0;
  color: var(--ink-muted);
  font-size: .82rem;
  line-height: 1.45;
}

.ops-badge {
  padding: 7px 10px;
  border: 1px solid var(--accent-glow);
  border-radius: 999px;
  background: var(--accent-light);
  color: var(--accent-strong);
  font-size: .74rem;
  font-weight: 800;
}

.ops-panel {
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  box-shadow: var(--shadow-sm);
}

.ops-metrics {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  box-shadow: var(--shadow-sm);
}

.ops-metrics > div {
  padding: 16px 18px;
  border-right: 1px solid var(--line);
}

.ops-metrics > div:last-child { border-right: 0; }
.ops-metrics span { display: block; color: var(--ink-subtle); font-size: .74rem; font-weight: 800; text-transform: uppercase; letter-spacing: .06em; }
.ops-metrics strong { display: block; margin-top: 7px; color: var(--ink); font-size: 1.6rem; letter-spacing: -.03em; }

.onboarding-progress-line {
  height: 8px;
  overflow: hidden;
  border-radius: 999px;
  background: var(--line);
}

.onboarding-progress-line span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: var(--accent);
  transition: width .3s var(--ease);
}

.setup-sequence {
  display: grid;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  box-shadow: var(--shadow-sm);
}

.setup-step {
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  padding: 16px 18px;
  border-bottom: 1px solid var(--line);
  color: inherit;
  text-decoration: none;
  transition: background .16s var(--ease), transform .16s var(--ease);
}

.setup-step:last-child { border-bottom: 0; }
.setup-step:hover { background: var(--surface-muted); }
.setup-step.is-current { background: var(--accent-light); }

.setup-step-index {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: var(--surface-muted);
  color: var(--ink-muted);
  font-size: .8rem;
  font-weight: 900;
}

.setup-step.is-ready .setup-step-index {
  background: var(--accent);
  color: #fff;
}

.setup-step-copy {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.setup-step-copy strong {
  overflow: hidden;
  color: var(--ink);
  font-size: .92rem;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.setup-step-copy small {
  color: var(--ink-muted);
  font-size: .8rem;
  line-height: 1.35;
}

.setup-step-action {
  color: var(--accent-strong);
  font-size: .78rem;
  font-weight: 800;
}

.ops-table {
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
}

.ops-table-row {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, .9fr) minmax(90px, .35fr);
  gap: 16px;
  align-items: center;
  padding: 15px 18px;
  border-bottom: 1px solid var(--line);
}

.ops-table-row:last-child { border-bottom: 0; }
.ops-table-row span, .ops-facts span { display: block; color: var(--ink-subtle); font-size: .74rem; font-weight: 800; text-transform: uppercase; letter-spacing: .05em; }
.ops-table-row strong, .ops-facts strong { display: block; margin-top: 4px; color: var(--ink); font-size: .88rem; }

.ops-facts,
.ops-type-list,
.ops-rule-list,
.ops-mini-list {
  display: grid;
  padding: 12px 18px 18px;
}

.ops-facts > div,
.ops-type-list > div {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 11px 0;
  border-bottom: 1px solid var(--line);
}

.ops-facts > div:last-child,
.ops-type-list > div:last-child { border-bottom: 0; }
.ops-type-list span { color: var(--ink-muted); font-size: .82rem; }
.ops-type-list strong { color: var(--ink); font-size: .9rem; }

.ops-mini-list a {
  display: grid;
  gap: 4px;
  padding: 12px 0;
  border-bottom: 1px solid var(--line);
  color: inherit;
  text-decoration: none;
}

.ops-mini-list a:last-child { border-bottom: 0; }
.ops-mini-list strong { color: var(--ink); font-size: .86rem; }
.ops-mini-list span { color: var(--ink-muted); font-size: .78rem; line-height: 1.4; }

.ops-empty {
  padding: 24px;
  border: 1px dashed var(--line-strong);
  border-radius: var(--radius);
  background: var(--surface);
}

.ops-empty.compact {
  margin: 14px 18px 18px;
  padding: 16px;
}

.ops-empty strong { display: block; color: var(--ink); font-size: .95rem; }
.ops-empty p { max-width: 480px; margin: 6px 0 14px; color: var(--ink-muted); font-size: .84rem; line-height: 1.5; }

.ops-feed {
  display: grid;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  box-shadow: var(--shadow-sm);
}

.ops-event {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) auto;
  gap: 14px;
  align-items: start;
  padding: 18px;
  border-bottom: 1px solid var(--line);
}

.ops-event:last-child { border-bottom: 0; }
.ops-event.is-unread { background: #fbfefe; }
.ops-event.is-human { border-left: 3px solid var(--warning); }

.ops-event-rail span {
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--surface-muted);
  color: var(--ink-muted);
  font-size: .8rem;
  font-weight: 900;
}

.ops-event.is-human .ops-event-rail span {
  background: #fef3c7;
  color: #92400e;
}

.ops-event-meta {
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--ink-subtle);
  font-size: .73rem;
  font-weight: 800;
  letter-spacing: .05em;
  text-transform: uppercase;
}

.ops-event-content h3 {
  margin: 6px 0 4px;
  color: var(--ink);
  font-size: .98rem;
  letter-spacing: -.01em;
}

.ops-event-content p {
  max-width: 760px;
  margin: 0;
  color: var(--ink-muted);
  font-size: .84rem;
  line-height: 1.5;
}

.ops-event-context {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 11px;
}

.ops-event-context span,
.ops-event-context strong {
  padding: 5px 8px;
  border-radius: 999px;
  background: var(--surface-muted);
  color: var(--ink-muted);
  font-size: .72rem;
  font-weight: 800;
}

.ops-event-context strong {
  background: var(--accent-light);
  color: var(--accent-strong);
}

.ops-event-actions {
  display: flex;
  align-items: center;
  gap: 8px;
}

.ops-event-actions form { margin: 0; }

.ops-rule-list { gap: 0; }
.ops-rule-list > div {
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr);
  column-gap: 10px;
  padding: 12px 0;
  border-bottom: 1px solid var(--line);
}

.ops-rule-list > div:last-child { border-bottom: 0; }
.ops-rule-list span {
  display: grid;
  place-items: center;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--ink);
  color: #fff;
  font-size: .72rem;
  font-weight: 900;
}

.ops-rule-list strong { color: var(--ink); font-size: .86rem; }
.ops-rule-list small { grid-column: 2; color: var(--ink-muted); font-size: .76rem; line-height: 1.35; }

@media (max-width: 1080px) {
  .ops-layout { grid-template-columns: 1fr; }
  .ops-side { position: static; grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 760px) {
  .ops-header { align-items: stretch; flex-direction: column; }
  .ops-header-score { text-align: left; }
  .ops-metrics { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .ops-metrics > div:nth-child(2n) { border-right: 0; }
  .setup-step { grid-template-columns: 34px minmax(0, 1fr); }
  .setup-step-action { grid-column: 2; }
  .ops-table-row { grid-template-columns: 1fr; gap: 10px; }
  .ops-side { grid-template-columns: 1fr; }
  .ops-event { grid-template-columns: 28px minmax(0, 1fr); }
  .ops-event-actions { grid-column: 2; flex-wrap: wrap; }
}

/* AI setup assistant */
.setup-ai-shell {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(340px, .75fr);
  gap: 22px;
  align-items: start;
  padding: 2px;
}

.setup-ai-chat,
.setup-ai-card {
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: var(--surface);
  box-shadow: var(--shadow-sm);
}


.setup-ai-shell.has-no-proposal,
.setup-ai-shell:has(.setup-ai-panel.is-hidden) {
  grid-template-columns: minmax(0, 1fr);
}

.setup-ai-panel.is-hidden,
.setup-generate-row.is-hidden,
.setup-ai-status.is-hidden {
  display: none;
}

.setup-generate-row {
  display: flex;
  justify-content: flex-end;
}

.setup-ai-card-head p {
  margin: 6px 0 0;
  color: var(--ink-muted);
  font-size: .84rem;
  line-height: 1.4;
}

.setup-admin-actions {
  margin-top: 8px;
  border-top: 1px dashed var(--line);
  padding-top: 10px;
}

.setup-ai-chat {
  border-color: rgba(15, 118, 110, .18);
  box-shadow: 0 22px 60px rgba(15, 23, 42, .08);
}

.setup-ai-head,
.setup-ai-card-head {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: start;
  padding: 22px 24px;
  border-bottom: 1px solid var(--line);
  background: linear-gradient(180deg, #fff, #fbfdfc);
}

.setup-ai-head h1,
.setup-ai-card h2 {
  margin: 3px 0 0;
  color: var(--ink);
  font-size: 1.18rem;
  letter-spacing: 0;
}

.setup-ai-account {
  display: grid;
  gap: 6px;
  min-width: 220px;
}

.setup-ai-account label {
  color: var(--ink-subtle);
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .05em;
  text-transform: uppercase;
}

.setup-ai-status {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 12px 22px;
  border-bottom: 1px solid var(--line);
  background: var(--surface-muted);
}

.setup-ai-status span {
  padding: 6px 9px;
  border-radius: 999px;
  background: #fff;
  color: var(--ink-muted);
  font-size: .74rem;
  font-weight: 800;
}

.setup-ai-status span.is-ready {
  background: var(--accent-light);
  color: var(--accent-strong);
}

.setup-ai-brief {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1px;
  border-bottom: 1px solid var(--line);
  background: var(--line);
}

.setup-ai-brief > div {
  display: grid;
  gap: 4px;
  padding: 13px 18px;
  background: #fff;
}

.setup-ai-brief span {
  color: var(--ink-subtle);
  font-size: .68rem;
  font-weight: 900;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.setup-ai-brief strong {
  color: var(--ink);
  font-size: .84rem;
}

.setup-research-box {
  display: grid;
  grid-template-columns: minmax(160px, 1fr) minmax(260px, 1.4fr);
  gap: 14px;
  align-items: end;
  padding: 14px 18px;
  border-bottom: 1px solid var(--line);
  background: #fff;
}

.setup-research-box span {
  display: block;
  color: var(--ink-subtle);
  font-size: .68rem;
  font-weight: 900;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.setup-research-box strong {
  display: block;
  margin-top: 4px;
  color: var(--ink);
  font-size: .84rem;
}

.setup-research-actions {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
}

.setup-research-actions input {
  width: 100%;
  min-height: 38px;
  padding: 9px 11px;
  border: 1.5px solid var(--line);
  border-radius: var(--radius-sm);
  background: #fff;
  color: var(--ink);
  font: inherit;
  font-size: .86rem;
  outline: none;
  transition: border-color var(--dur) ease, box-shadow var(--dur) ease;
}

.setup-research-actions input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-glow);
}

.legacy-config-panel {
  margin: 12px 0 18px;
  padding: 12px 14px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: var(--surface-muted);
  color: var(--ink-muted);
  font-size: .84rem;
}

.legacy-config-panel summary {
  cursor: pointer;
  color: var(--ink);
  font-weight: 800;
}

.legacy-config-panel p {
  margin: 8px 0 10px;
}

.legacy-config-panel pre {
  white-space: pre-wrap;
  margin: 8px 0 0;
  padding: 10px;
  border-radius: var(--radius-sm);
  background: #fff;
  border: 1px solid var(--line);
  color: var(--ink-muted);
  font: inherit;
  font-size: .8rem;
}

.setup-ai-messages {
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-height: 430px;
  max-height: 58vh;
  overflow: auto;
  padding: 24px;
  background:
    radial-gradient(circle at 12% 0%, rgba(15,118,110,.08), transparent 32%),
    linear-gradient(180deg, rgba(255,255,255,.72), rgba(255,255,255,.95)),
    var(--surface-muted);
}

.setup-msg {
  display: flex;
}

.setup-msg > div {
  max-width: min(680px, 82%);
  padding: 12px 14px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: #fff;
  color: var(--ink);
  font-size: .9rem;
  line-height: 1.5;
}

.setup-msg.is-ai > div {
  box-shadow: 0 10px 30px rgba(15,23,42,.05);
}

.setup-msg.is-user {
  justify-content: flex-end;
}

.setup-msg.is-user > div {
  border-color: rgba(15,118,110,.25);
  background: var(--accent);
  color: #fff;
}

.setup-ai-composer {
  display: grid;
  gap: 12px;
  padding: 16px 18px 18px;
  border-top: 1px solid var(--line);
  background: #fff;
}

.setup-quick-start {
  display: grid;
  gap: 8px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: var(--surface-muted);
}

.setup-quick-start > span {
  color: var(--ink-subtle);
  font-size: .68rem;
  font-weight: 900;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.setup-ai-composer textarea {
  display: block;
  width: 100%;
  min-height: 74px;
  padding: 12px 14px;
  border: 1.5px solid var(--line);
  border-radius: var(--radius-sm);
  background: #fff;
  color: var(--ink);
  font: inherit;
  font-size: .9rem;
  line-height: 1.45;
  outline: none;
  resize: vertical;
  transition: border-color var(--dur) ease, box-shadow var(--dur) ease;
}

.setup-ai-composer textarea:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-glow);
}

.setup-prompt-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.setup-prompt-chips button {
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--surface-muted);
  color: var(--ink-muted);
  cursor: pointer;
  font-size: .76rem;
  font-weight: 800;
  padding: 7px 10px;
  transition: background .16s var(--ease), border-color .16s var(--ease), color .16s var(--ease);
}

.setup-prompt-chips button:hover {
  border-color: var(--accent);
  background: var(--accent-light);
  color: var(--accent-strong);
}

.setup-ai-actions,
.setup-ai-card-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
}

.setup-ai-panel {
  display: grid;
  gap: 18px;
  position: sticky;
  top: 86px;
}

.setup-ai-card.compact {
  padding-bottom: 6px;
}

.setup-ai-card.compact h2 {
  padding: 18px 20px 0;
  font-size: 1rem;
}

.setup-score {
  display: grid;
  place-items: center;
  width: 58px;
  height: 58px;
  border-radius: 50%;
  background: var(--ink);
  color: #fff;
  font-size: .92rem;
  font-weight: 900;
}

.setup-ai-summary {
  padding: 18px 20px 6px;
}

.setup-ai-summary strong {
  display: block;
  color: var(--ink);
  font-size: .96rem;
}

.setup-ai-summary p {
  margin: 7px 0 0;
  color: var(--ink-muted);
  font-size: .84rem;
  line-height: 1.45;
}

.setup-ai-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  padding: 12px 20px 18px;
}

.setup-ai-grid > div {
  min-height: 72px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface-muted);
}

.setup-ai-grid span {
  display: block;
  color: var(--ink-subtle);
  font-size: .7rem;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.setup-ai-grid strong {
  display: block;
  margin-top: 7px;
  color: var(--ink);
  font-size: .82rem;
  line-height: 1.35;
}

.setup-ai-card-actions {
  padding: 0 20px 20px;
}

.setup-ai-sims {
  display: grid;
  gap: 12px;
  padding: 14px 20px 20px;
}

.setup-ai-sims > p {
  margin: 0;
  color: var(--ink-muted);
  font-size: .84rem;
  line-height: 1.45;
}

.setup-sim {
  display: grid;
  gap: 7px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface-muted);
}

.setup-sim strong {
  color: var(--ink);
  font-size: .85rem;
}

.setup-sim p {
  margin: 0;
  color: var(--ink-muted);
  font-size: .78rem;
  line-height: 1.45;
}

.setup-roleplay-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 10px 0;
}

.setup-roleplay-chips .btn.is-active {
  background: var(--accent, #2563eb);
  color: #fff;
  border-color: transparent;
}

.setup-sim p.rp-lead {
  color: var(--ink);
  font-weight: 600;
}

.setup-sim p.rp-setter {
  color: var(--ink-muted);
}

.setup-note {
  padding: 12px;
  border: 1px dashed var(--line-strong);
  border-radius: var(--radius);
  color: var(--ink-muted);
  font-size: .82rem;
  line-height: 1.45;
  background: var(--surface-muted);
}

.config-preview {
  border-color: rgba(15,118,110,.18);
  box-shadow: 0 18px 54px rgba(15,23,42,.08);
}

.config-preview .preview-head {
  background: linear-gradient(180deg, #fff, #f8fbfa);
}

.preview-body {
  background:
    radial-gradient(circle at 15% 0%, rgba(15,118,110,.09), transparent 36%),
    linear-gradient(180deg, #fbfdfc, #f4f7f6);
}

.preview-bubble {
  box-shadow: 0 10px 24px rgba(15,23,42,.06);
}

.setter-sandbox .sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.sandbox-composer .sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.setter-sandbox .preview-head {
  gap: 12px;
  align-items: flex-start;
}

.setter-sandbox .preview-head > div {
  display: grid;
  gap: 3px;
}

.setter-sandbox .preview-head span:not(.preview-status) {
  color: var(--ink-muted);
  font-size: .76rem;
  line-height: 1.35;
}

.setter-sandbox .preview-status[data-state="probando"] {
  color: #92400e;
}

.setter-sandbox .preview-status[data-state="probando"]::before {
  background: #f59e0b;
  box-shadow: 0 0 0 3px rgba(245,158,11,.22);
}

.setter-sandbox .preview-status[data-state="error"] {
  color: #b42318;
}

.setter-sandbox .preview-status[data-state="error"]::before {
  background: #ef4444;
  box-shadow: 0 0 0 3px rgba(239,68,68,.18);
}

.sandbox-context {
  display: grid;
  gap: 12px;
  padding: 14px;
  border-bottom: 1px solid var(--line);
  background: #fff;
}

.sandbox-context-primary {
  background: linear-gradient(180deg, #fff, #fbfdfc);
}

.sandbox-context-head {
  display: grid;
  gap: 4px;
}

.sandbox-context-head strong,
.sandbox-options summary strong,
.sandbox-result summary strong,
.sandbox-improve summary strong {
  color: var(--ink);
  font-size: .84rem;
}

.sandbox-context-head p,
.sandbox-options-body p,
.sandbox-improve summary p {
  margin: 0;
  color: var(--ink-muted);
  font-size: .75rem;
  line-height: 1.42;
}

.sandbox-source-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.sandbox-source-list > div {
  min-width: 0;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: #fbfdfc;
}

.sandbox-source-list span {
  display: block;
  color: var(--ink-subtle);
  font-size: .68rem;
  font-weight: 800;
  text-transform: uppercase;
}

.sandbox-source-list strong {
  display: block;
  margin-top: 3px;
  color: var(--ink);
  font-size: .78rem;
}

.sandbox-options,
.sandbox-result,
.sandbox-improve {
  border-top: 1px solid var(--line);
  background: #fff;
}

.sandbox-options summary,
.sandbox-result summary,
.sandbox-improve summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 14px;
  cursor: pointer;
  list-style: none;
}

.sandbox-options summary::-webkit-details-marker,
.sandbox-result summary::-webkit-details-marker,
.sandbox-improve summary::-webkit-details-marker {
  display: none;
}

.sandbox-options summary::after,
.sandbox-result summary::after,
.sandbox-improve summary::after {
  content: '+';
  display: inline-grid;
  place-items: center;
  flex: 0 0 22px;
  width: 22px;
  height: 22px;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--accent-strong);
  font-size: .9rem;
  font-weight: 800;
  line-height: 1;
}

.sandbox-options[open] summary::after,
.sandbox-result[open] summary::after,
.sandbox-improve[open] summary::after {
  content: '-';
}

.sandbox-options summary span,
.sandbox-result summary span {
  display: block;
  margin-top: 3px;
  color: var(--ink-muted);
  font-size: .72rem;
  font-weight: 600;
}

.sandbox-options-body,
.sandbox-result-body,
.sandbox-improve-body {
  display: grid;
  gap: 10px;
  padding: 0 14px 14px;
}

.sandbox-options-body label,
.sandbox-improve-body label {
  color: var(--ink);
  font-size: .76rem;
  font-weight: 800;
}

.sandbox-options-body select {
  display: block;
  width: 100%;
  min-width: 0;
  height: 34px;
  padding: 8px 34px 8px 12px;
  border: 1.5px solid var(--line);
  border-radius: var(--radius-sm);
  background-color: #fff;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2361706a' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  color: var(--ink);
  font: inherit;
  font-size: .8rem;
  outline: none;
  appearance: none;
  -webkit-appearance: none;
  transition: border-color var(--dur) ease, box-shadow var(--dur) ease;
}

.sandbox-options-body select:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-glow);
}

.sandbox-empty-state {
  align-self: stretch;
  display: grid;
  gap: 5px;
  padding: 14px;
  border: 1px dashed rgba(15,118,110,.28);
  border-radius: var(--radius-sm);
  background: rgba(255,255,255,.72);
  color: var(--ink);
}

.sandbox-empty-state strong {
  font-size: .84rem;
}

.sandbox-empty-state span {
  color: var(--ink-muted);
  font-size: .76rem;
  line-height: 1.4;
}

.sandbox-toolbar {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  padding: 10px 14px 12px;
  border-top: 1px solid var(--line);
  background: var(--panel);
}

.sandbox-page-shell {
  display: grid;
  grid-template-columns: minmax(0, 760px);
  justify-content: center;
  margin-top: 22px;
}

.sandbox-page-panel {
  position: static;
  min-height: min(760px, calc(100svh - var(--topbar-h) - 150px));
  max-height: none;
}

.sandbox-message-row {
  display: grid;
  gap: 5px;
}

.sandbox-message-row.is-user {
  justify-items: start;
}

.sandbox-message-row.is-assistant {
  justify-items: end;
}

.sandbox-message-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  max-width: 88%;
}

.sandbox-message-action {
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255,255,255,.78);
  color: var(--ink-muted);
  cursor: pointer;
  font: inherit;
  font-size: .68rem;
  font-weight: 800;
  padding: 4px 8px;
  transition: border-color var(--dur) ease, color var(--dur) ease, background var(--dur) ease;
}

.sandbox-message-action:hover {
  border-color: var(--accent);
  background: #fff;
  color: var(--accent-strong);
}

.sandbox-result[hidden] {
  display: none;
}

.sandbox-result-body > div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding-top: 8px;
  border-top: 1px solid var(--line);
}

.sandbox-result-body span {
  color: var(--ink-subtle);
  font-size: .72rem;
  font-weight: 700;
}

.sandbox-result-body strong {
  color: var(--ink);
  font-size: .78rem;
  text-align: right;
}

.sandbox-improve {
  background: #f8faf9;
}

.sandbox-feedback {
  display: block;
  width: 100%;
  min-height: 54px;
  margin: 0;
  padding: 10px 12px;
  border: 1.5px solid var(--line);
  border-radius: var(--radius-sm);
  background: #fff;
  color: var(--ink);
  font: inherit;
  font-size: .8rem;
  line-height: 1.4;
  outline: none;
  resize: vertical;
  transition: border-color var(--dur) ease, box-shadow var(--dur) ease;
}

.sandbox-feedback:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-glow);
}

.sandbox-feedback::placeholder,
.setup-ai-composer textarea::placeholder {
  color: var(--ink-subtle);
}

@media (max-width: 1080px) {
  .setup-ai-shell { grid-template-columns: 1fr; }
  .setup-ai-panel { position: static; }
}

@media (max-width: 720px) {
  .setup-ai-head,
  .setup-ai-card-head {
    flex-direction: column;
  }
  .setup-ai-account { width: 100%; min-width: 0; }
  .setup-ai-brief { grid-template-columns: 1fr; }
  .setup-research-box,
  .setup-research-actions { grid-template-columns: 1fr; }
  .setup-ai-messages { min-height: 360px; max-height: none; }
  .setup-msg > div { max-width: 94%; }
  .setup-ai-grid { grid-template-columns: 1fr; }
  .setup-ai-actions,
  .setup-ai-card-actions {
    align-items: stretch;
    flex-direction: column;
  }
  .sandbox-toolbar { justify-content: stretch; }
  .sandbox-toolbar .btn,
  .sandbox-improve .btn { width: 100%; }
}

/* Fullscreen setter sandbox */
.is-sandbox-fullscreen .page-body {
  gap: 0;
}

.sandbox-fullscreen {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 340px;
  width: 100%;
  min-height: min(620px, calc(100svh - var(--topbar-h) - 52px));
  height: calc(100svh - var(--topbar-h) - 52px);
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #f4f2ec;
  box-shadow: var(--shadow-sm);
}

.sandbox-chat {
  min-width: 0;
  min-height: 0;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  border-right: 1px solid var(--line);
  background: #f8f7f2;
}

.sandbox-chat-head {
  min-height: 66px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 14px 22px;
  border-bottom: 1px solid var(--line);
  background: rgba(255,255,255,.82);
  backdrop-filter: blur(18px);
}

.sandbox-kicker {
  display: block;
  color: var(--ink-subtle);
  font-size: .68rem;
  font-weight: 900;
  letter-spacing: .08em;
  line-height: 1;
  text-transform: uppercase;
}

.sandbox-chat-head h1 {
  margin-top: 5px;
  font-size: 1rem;
  letter-spacing: 0;
}

.sandbox-head-actions,
.sandbox-side-actions {
  display: flex;
  align-items: center;
  gap: 8px;
}

.sandbox-icon-btn {
  display: inline-grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: #fff;
  color: var(--ink-muted);
  cursor: pointer;
  font: inherit;
  font-size: 1rem;
  font-weight: 900;
  line-height: 1;
  transition: background var(--dur) ease, border-color var(--dur) ease, color var(--dur) ease, transform var(--dur) ease;
}

.sandbox-icon-btn:hover {
  border-color: var(--accent);
  color: var(--accent-strong);
  transform: translateY(-1px);
}

.setter-sandbox .preview-status,
.sandbox-chat-head .preview-status {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 28px;
  padding: 0 10px;
  border: 1px solid rgba(31,143,102,.16);
  border-radius: 999px;
  background: var(--accent-light);
  color: var(--accent-strong);
  font-size: .72rem;
  font-weight: 800;
}

.sandbox-chat-head .preview-status::before {
  content: '';
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-glow);
  animation: pulse 1.6s ease-in-out infinite;
}

.sandbox-chat-head .preview-status[data-state="probando"],
.sandbox-chat-head .preview-status[data-state="enviando"] {
  border-color: rgba(245,158,11,.22);
  background: #fffbeb;
  color: #92400e;
}

.sandbox-chat-head .preview-status[data-state="probando"]::before,
.sandbox-chat-head .preview-status[data-state="enviando"]::before {
  background: #f59e0b;
  box-shadow: 0 0 0 3px rgba(245,158,11,.2);
}

.sandbox-chat-head .preview-status[data-state="error"] {
  border-color: rgba(239,68,68,.2);
  background: #fef2f2;
  color: #b42318;
}

.sandbox-chat-head .preview-status[data-state="error"]::before {
  background: #ef4444;
  box-shadow: 0 0 0 3px rgba(239,68,68,.16);
}

.sandbox-chat-body.preview-body {
  min-height: 0;
  padding: 24px clamp(18px, 4vw, 54px);
  gap: 14px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.55), rgba(255,255,255,.18)),
    #f8f7f2;
}

.sandbox-composer.preview-foot {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 104px auto;
  align-items: center;
  gap: 10px;
  padding: 16px clamp(18px, 4vw, 54px);
  border-top: 1px solid var(--line);
  background: rgba(255,255,255,.9);
}

.sandbox-composer.preview-foot input {
  min-height: 44px;
  padding: 10px 14px;
  border-radius: var(--radius-sm);
  background: #fff;
  font-size: .92rem;
}

.sandbox-composer.preview-foot select {
  min-height: 44px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: #fff;
  font-size: .86rem;
}

.sandbox-composer-actions {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  justify-content: flex-end;
}

.sandbox-composer .btn {
  min-height: 44px;
}

.sandbox-composer-actions #preview-send {
  min-width: 96px;
}

.sandbox-composer .sandbox-reset-btn {
  width: 38px;
  min-height: 38px;
  height: 38px;
  padding: 0;
  border-radius: 999px;
  color: var(--accent-strong);
  border-color: rgba(31,143,102,.18);
  background: var(--accent-light);
  box-shadow: none;
}

.sandbox-composer .sandbox-reset-btn:hover:not(:disabled) {
  border-color: var(--accent);
  background: #fff;
  color: var(--accent-strong);
  box-shadow: 0 6px 18px rgba(31,143,102,.16);
  transform: translateY(-1px);
}

.sandbox-composer .sandbox-reset-btn svg {
  width: 17px;
  height: 17px;
}

.sandbox-chat-body .preview-bubble {
  max-width: min(680px, 78%);
  padding: 12px 14px;
  border-radius: 16px;
  font-size: .94rem;
  line-height: 1.48;
  box-shadow: none;
  white-space: pre-wrap;
}

.sandbox-chat-body .preview-bubble.in {
  border-color: var(--line);
  background: #fff;
}

.sandbox-chat-body .preview-bubble.out {
  background: var(--accent);
  color: #fff;
  box-shadow: 0 10px 24px rgba(31,143,102,.18);
}

.sandbox-message-row {
  position: relative;
  display: grid;
  gap: 6px;
}

.sandbox-message-row.is-user {
  justify-items: start;
}

.sandbox-message-row.is-assistant {
  justify-items: end;
}

.sandbox-message-actions {
  display: flex;
  gap: 6px;
  opacity: .72;
  transition: opacity var(--dur) ease;
}

.sandbox-message-row:hover .sandbox-message-actions,
.sandbox-message-actions:focus-within {
  opacity: 1;
}

.sandbox-message-action {
  display: inline-grid;
  place-items: center;
  width: 28px;
  height: 28px;
  padding: 0;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255,255,255,.86);
  color: var(--ink-muted);
  cursor: pointer;
  font: inherit;
  font-size: .92rem;
  font-weight: 900;
  line-height: 1;
  transition: border-color var(--dur) ease, color var(--dur) ease, background var(--dur) ease, transform var(--dur) ease;
}

.sandbox-message-action:hover {
  border-color: var(--accent);
  background: #fff;
  color: var(--accent-strong);
  transform: translateY(-1px);
}

.sandbox-side {
  min-width: 0;
  min-height: 0;
  overflow: auto;
  display: flex;
  flex-direction: column;
  gap: 0;
  background: #fff;
}

.sandbox-side-section {
  display: grid;
  gap: 9px;
  padding: 16px;
  border-bottom: 1px solid var(--line);
}

.sandbox-context-check {
  background: #fbfdfc;
}

.sandbox-context-check.is-warning {
  background: rgba(245,158,11,.08);
}

.sandbox-context-check span {
  color: var(--ink-subtle);
  font-size: .68rem;
  font-weight: 900;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.sandbox-context-check strong {
  display: block;
  margin-top: 2px;
  color: var(--ink);
  font-size: .98rem;
}

.sandbox-context-check p {
  margin: 0;
  color: var(--ink-muted);
  font-size: .78rem;
  line-height: 1.45;
}

.sandbox-context-missing {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.sandbox-context-missing span {
  padding: 5px 8px;
  border: 1px solid rgba(245,158,11,.24);
  border-radius: 999px;
  background: #fff;
  color: #92400e;
  font-size: .68rem;
}

.sandbox-roleplay p {
  margin: 4px 0 0;
  color: var(--ink-muted);
  font-size: .78rem;
  line-height: 1.45;
}

.sandbox-roleplay-chips,
.sandbox-roleplay-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.sandbox-roleplay-chips button {
  min-height: 32px;
  padding: 0 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: #fff;
  color: var(--ink-muted);
  font: inherit;
  font-size: .76rem;
  font-weight: 800;
  cursor: pointer;
}

.sandbox-roleplay-chips button.is-active {
  border-color: var(--accent);
  background: var(--accent);
  color: #fff;
}

.sandbox-roleplay-actions .btn {
  flex: 1 1 auto;
}

.sandbox-roleplay-actions .btn.is-suggested {
  border-color: var(--accent);
  background: var(--accent);
  color: #fff;
  box-shadow: 0 8px 18px rgba(15,118,85,.16);
}

.sandbox-roleplay-live {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 9px 10px;
  border: 1px solid var(--accent-glow);
  border-radius: var(--radius-sm);
  background: var(--accent-light);
  color: var(--accent-strong);
  font-size: .76rem;
  font-weight: 800;
}

.sandbox-roleplay-live[hidden] {
  display: none;
}

.sandbox-roleplay-live span {
  flex: 0 0 8px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: currentColor;
  box-shadow: 0 0 0 4px rgba(15,118,85,.12);
}

.sandbox-roleplay-note {
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: #fbfdfc;
  color: var(--ink-muted);
  font-size: .76rem;
  line-height: 1.45;
}

.sandbox-side-section label {
  color: var(--ink);
  font-size: .76rem;
  font-weight: 900;
}

.sandbox-review-panel {
  gap: 10px;
  background: linear-gradient(180deg, #fbfdfc 0%, #fff 100%);
}

.sandbox-review-panel p {
  margin: 4px 0 0;
  color: var(--ink-muted);
  font-size: .76rem;
  line-height: 1.45;
}

.sandbox-review-panel .btn {
  width: 100%;
  min-height: 42px;
}

.sandbox-side-actions {
  grid-template-columns: 1fr auto;
}

.sandbox-side .sandbox-options,
.sandbox-side .sandbox-result {
  border-top: 0;
  border-bottom: 1px solid var(--line);
}

.sandbox-side .sandbox-options summary,
.sandbox-side .sandbox-result summary {
  padding: 15px 16px;
}

.sandbox-side .sandbox-options-body,
.sandbox-side .sandbox-result-body {
  padding: 0 16px 16px;
}

.sandbox-side .sandbox-result-body > div {
  padding: 9px 0 0;
}

.sandbox-side .sandbox-feedback {
  min-height: 104px;
  font-size: .86rem;
}

.sandbox-empty-state {
  align-self: center;
  justify-self: center;
  width: min(460px, 100%);
  padding: 18px;
  border-radius: var(--radius-sm);
  background: #fff;
}

.sandbox-loading-overlay {
  position: absolute;
  inset: 0;
  z-index: 12;
  display: grid;
  place-items: center;
  padding: 24px;
  background: rgba(248,247,242,.82);
  backdrop-filter: blur(8px);
}

.sandbox-loading-overlay[hidden] {
  display: none;
}

.sandbox-loading-card {
  width: min(360px, 100%);
  display: grid;
  justify-items: center;
  gap: 10px;
  padding: 24px;
  border: 1px solid rgba(31,143,102,.18);
  border-radius: var(--radius);
  background: #fff;
  color: var(--ink);
  text-align: center;
  box-shadow: 0 22px 60px rgba(15,23,42,.14);
}

.sandbox-loading-card strong {
  font-size: .98rem;
}

.sandbox-loading-card p {
  margin: 0;
  color: var(--ink-muted);
  font-size: .82rem;
  line-height: 1.45;
}

.sandbox-loading-spinner {
  width: 38px;
  height: 38px;
  border: 4px solid var(--accent-glow);
  border-top-color: var(--accent);
  border-radius: 50%;
  animation: sandboxSpin .8s linear infinite;
}

@keyframes sandboxSpin {
  to { transform: rotate(360deg); }
}

@media (max-width: 1040px) {
  .sandbox-fullscreen {
    grid-template-columns: 1fr;
    grid-template-rows: minmax(0, 1fr) auto;
  }

  .sandbox-chat {
    border-right: 0;
    min-height: 0;
  }

  .sandbox-side {
    max-height: 40svh;
    border-top: 1px solid var(--line);
  }
}

@media (max-width: 720px) {
  .sandbox-fullscreen {
    min-height: calc(100svh - var(--topbar-h) - 36px);
    height: auto;
  }

  .sandbox-chat {
    min-height: 72svh;
  }

  .sandbox-chat-head {
    padding: 12px 14px;
  }

  .sandbox-chat-head h1 {
    font-size: .95rem;
  }

  .sandbox-head-actions {
    gap: 6px;
  }

  .sandbox-chat-head .preview-status {
    display: none;
  }

  .sandbox-chat-body.preview-body {
    padding: 18px 14px;
  }

  .sandbox-chat-body .preview-bubble {
    max-width: 90%;
    font-size: .9rem;
  }

  .sandbox-composer.preview-foot {
    grid-template-columns: minmax(0, 1fr) auto;
    padding: 12px 14px 14px;
  }

  .sandbox-composer.preview-foot input {
    grid-column: 1 / -1;
  }

  .sandbox-composer-actions {
    gap: 6px;
  }

  .sandbox-composer-actions #preview-send {
    min-width: 86px;
  }

  .sandbox-composer .sandbox-reset-btn {
    width: 36px;
    min-height: 36px;
    height: 36px;
  }

  .sandbox-side {
    max-height: none;
  }

  .sandbox-side-actions {
    grid-template-columns: 1fr;
  }
}

/* Billing */
.billing-shell {
  display: grid;
  gap: 18px;
}

.billing-hero {
  display: grid;
  grid-template-columns: 1.45fr minmax(260px, .9fr);
  gap: 18px;
  background: linear-gradient(120deg, #1b2b26 0%, #244337 52%, #1f8f66 100%);
  color: #f5fffb;
  border-radius: var(--radius-xl);
  padding: 28px;
  box-shadow: var(--shadow-lg);
}
.billing-hero h1 { font-size: clamp(1.45rem, 2.1vw, 2.05rem); margin: 10px 0; }
.billing-hero p { color: rgba(245,255,251,.82); max-width: 62ch; }
.billing-hero-actions { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 18px; }

.billing-plan-card {
  background: rgba(255,255,255,.11);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: var(--radius-lg);
  padding: 18px;
  backdrop-filter: blur(2px);
}
.billing-plan-card > span { font-size: .74rem; text-transform: uppercase; letter-spacing: .08em; color: rgba(255,255,255,.75); }
.billing-plan-card h2 { margin-top: 6px; font-size: 1.4rem; }
.billing-plan-card p { color: rgba(255,255,255,.83); font-size: .86rem; margin-top: 6px; }
.billing-price { margin-top: 14px; }
.billing-price strong { font-size: 1.55rem; }
.billing-renewal { margin-top: 12px; display: grid; }
.billing-renewal span { color: rgba(255,255,255,.75); font-size: .78rem; }

.billing-summary {
  display: grid;
  grid-template-columns: repeat(4, minmax(160px, 1fr));
  gap: 12px;
}
.billing-summary > div {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  padding: 14px;
  display: grid;
  gap: 4px;
}
.billing-summary span { font-size: .72rem; text-transform: uppercase; letter-spacing: .06em; color: var(--ink-muted); font-weight: 700; }
.billing-summary strong { font-size: 1rem; }
.billing-summary small { color: var(--ink-subtle); }

.billing-section { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); padding: 18px; }
.billing-section-head { display: flex; justify-content: space-between; gap: 12px; align-items: flex-start; margin-bottom: 14px; }
.billing-section-head h2 { font-size: 1.05rem; }
.billing-section-head p { color: var(--ink-muted); font-size: .84rem; margin-top: 4px; }

.billing-usage-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 12px; }
.usage-card { border: 1px solid var(--line); border-radius: var(--radius); padding: 12px; background: #fdfcf9; }
.usage-card header { display: flex; justify-content: space-between; gap: 8px; align-items: baseline; }
.usage-card header span { font-weight: 600; color: var(--ink-muted); font-size: .84rem; }
.usage-bar { margin: 9px 0; height: 9px; border-radius: 999px; background: #e8eeea; overflow: hidden; }
.usage-bar-fill { display: block; height: 100%; border-radius: inherit; }
.usage-bar-fill.is-good { background: linear-gradient(90deg, #52b788, #1f8f66); }
.usage-bar-fill.is-warn { background: linear-gradient(90deg, #e7b66c, #c28f36); }
.usage-bar-fill.is-risk { background: linear-gradient(90deg, #de7f73, #c0392b); }
.usage-card footer { display: flex; justify-content: space-between; gap: 8px; }
.usage-flag { font-size: .72rem; border-radius: 999px; padding: 2px 8px; font-weight: 700; }
.usage-flag.is-good { background: #e6f4ed; color: #126647; }
.usage-flag.is-warn { background: #fff4dd; color: #8b5a16; }
.usage-flag.is-risk { background: #ffe6e2; color: #a22e21; }

.billing-cycle-toggle { display: inline-flex; background: #f2f6f4; padding: 3px; border-radius: 999px; border: 1px solid var(--line); }
.billing-cycle-toggle button { border: 0; background: transparent; padding: 7px 13px; border-radius: 999px; font-weight: 700; color: var(--ink-muted); cursor: pointer; }
.billing-cycle-toggle button.is-active { background: var(--panel); color: var(--ink); box-shadow: var(--shadow-sm); }

.billing-plans-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 12px; }
.plan-card { border: 1px solid var(--line); border-radius: var(--radius); padding: 14px; position: relative; background: #fff; }
.plan-card.is-current { border-color: #84c7aa; box-shadow: inset 0 0 0 1px #b8dfcc; }
.plan-card.is-highlight { border-color: #5ab488; box-shadow: 0 10px 24px rgba(31,143,102,.16); }
.plan-card-flag, .plan-card-pill { position: absolute; top: 10px; right: 10px; font-size: .68rem; border-radius: 999px; padding: 3px 8px; font-weight: 700; }
.plan-card-flag { background: #e7f5ee; color: #126647; }
.plan-card-pill { background: #eef3ff; color: #2449a4; }
.plan-card header p { color: var(--ink-muted); font-size: .82rem; margin-top: 6px; }
.plan-card-pricing { margin: 12px 0; display: grid; }
.plan-card-pricing strong { font-size: 1.4rem; }
.plan-feature-list { list-style: none; display: grid; gap: 6px; margin-bottom: 13px; }
.plan-feature-list li { display: flex; gap: 7px; font-size: .84rem; }
.plan-feature-list li span { color: var(--accent); font-weight: 700; }
.plan-feature-list li.is-muted { color: var(--ink-subtle); }
.plan-feature-list li.is-muted span { color: var(--ink-subtle); }

.billing-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.payment-card { border: 1px solid var(--line); border-radius: var(--radius); padding: 14px; display: flex; align-items: center; justify-content: space-between; gap: 10px; background: #f8fbf9; }
.payment-chip { width: 40px; height: 30px; border-radius: 8px; border: 1px solid #d7dfda; padding: 4px; display: grid; gap: 3px; }
.payment-chip span { border-radius: 2px; background: #d0d8d3; }
.billing-checklist { margin-top: 12px; display: grid; gap: 8px; }
.billing-checklist > div { display: grid; grid-template-columns: 14px 1fr; gap: 8px; align-items: center; }
.billing-checklist > div > span { width: 12px; height: 12px; border-radius: 999px; border: 2px solid #b7c7c0; }
.billing-checklist > div.is-done > span { border-color: #3ca371; background: #3ca371; }

.invoice-list { display: grid; gap: 8px; }
.invoice-row { border: 1px solid var(--line); border-radius: var(--radius-sm); padding: 11px 12px; display: grid; grid-template-columns: 1fr auto auto; gap: 12px; align-items: center; }
.invoice-row span { color: var(--ink-muted); font-size: .82rem; }
.billing-empty { border: 1px dashed var(--line-strong); border-radius: var(--radius); padding: 14px; background: #fafcfb; }

@media (max-width: 1060px) {
  .billing-hero { grid-template-columns: 1fr; }
  .billing-summary { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .billing-layout { grid-template-columns: 1fr; }
}
@media (max-width: 720px) {
  .billing-section-head { flex-direction: column; }
  .billing-summary { grid-template-columns: 1fr; }
  .invoice-row { grid-template-columns: 1fr; gap: 5px; }
}
