/* ============================================================
   sendvia — redesign stylesheet
   ============================================================ */

:root {
  /* Palette — blues */
  --blue-50:  #EEF3FF;
  --blue-100: #DCE6FF;
  --blue-200: #B8CEFF;
  --blue-300: #8DB0FF;
  --blue-400: #5C8BFF;
  --blue-500: #2563EB;
  --blue-600: #1D4ED8;
  --blue-700: #1E40AF;
  --blue-800: #1E3A8A;
  --blue-900: #172554;

  /* Neutrals — warm off-white/near-black */
  --ink-0:   #FAFAF7;
  --ink-50:  #F4F4EF;
  --ink-100: #ECECE6;
  --ink-200: #DFDFD7;
  --ink-300: #C8C8BF;
  --ink-400: #9A9A92;
  --ink-500: #6B6B65;
  --ink-600: #42423E;
  --ink-700: #24241F;
  --ink-800: #141412;
  --ink-900: #0A0B10;

  /* Semantic */
  --ok:     oklch(0.66 0.14 152);
  --ok-bg:  oklch(0.96 0.04 152);
  --warn:   oklch(0.68 0.13 72);
  --warn-bg:oklch(0.96 0.05 72);
  --bad:    oklch(0.60 0.17 22);
  --bad-bg: oklch(0.96 0.04 22);
  --violet: oklch(0.56 0.17 290);
  --violet-bg:oklch(0.96 0.04 290);

  /* App tokens */
  --bg:           var(--ink-0);
  --surface:      #FFFFFF;
  --surface-alt:  var(--ink-50);
  --border:       rgba(20, 20, 18, 0.08);
  --border-strong:rgba(20, 20, 18, 0.16);
  --text:         var(--ink-900);
  --text-dim:     var(--ink-500);
  --text-mute:    var(--ink-400);
  --accent:       var(--blue-500);
  --accent-deep:  var(--blue-800);
  --accent-soft:  var(--blue-50);

  --radius-sm: 6px;
  --radius:    10px;
  --radius-lg: 14px;
  --radius-xl: 20px;

  --shadow-xs: 0 1px 0 rgba(20,20,18,0.04);
  --shadow-sm: 0 1px 2px rgba(20,20,18,0.06), 0 1px 0 rgba(20,20,18,0.04);
  --shadow-md: 0 4px 14px rgba(20,20,18,0.06), 0 1px 2px rgba(20,20,18,0.04);
  --shadow-lg: 0 18px 40px -12px rgba(20,20,18,0.18);

  --sans: 'Geist', ui-sans-serif, system-ui, -apple-system, 'Helvetica Neue', Helvetica, Arial, sans-serif;
  --mono: 'Geist Mono', ui-monospace, 'SF Mono', 'Menlo', monospace;

  /* density */
  --row-h: 44px;
  --pad:   16px;
}

/* Dark mode */
[data-theme="dark"] {
  --bg:           #0A0B10;
  --surface:      #101118;
  --surface-alt:  #15161E;
  --border:       rgba(255,255,255,0.08);
  --border-strong:rgba(255,255,255,0.16);
  --text:         #F1F1EC;
  --text-dim:     #9A9A92;
  --text-mute:    #6B6B65;
  --accent-soft:  rgba(37, 99, 235, 0.12);
  --shadow-sm: 0 1px 2px rgba(0,0,0,0.5);
  --shadow-md: 0 4px 14px rgba(0,0,0,0.5);
  --shadow-lg: 0 18px 40px -12px rgba(0,0,0,0.6);
}

/* Density */
[data-density="compact"] {
  --row-h: 36px;
  --pad:   12px;
}
[data-density="comfortable"] {
  --row-h: 52px;
  --pad:   20px;
}

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

button { font-family: inherit; }
a, a:visited { color: inherit; }

.mono { font-family: var(--mono); font-feature-settings: "ss01", "cv11"; }
.caps {
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 10.5px;
  font-family: var(--mono);
  color: var(--text-mute);
  font-weight: 500;
}
.num { font-family: var(--mono); font-variant-numeric: tabular-nums; letter-spacing: -0.01em; }

/* ================== Layout ================== */
.app {
  display: grid;
  grid-template-columns: 232px 1fr;
  min-height: 100vh;
}

/* Sidebar */
.sidebar {
  background: var(--surface);
  border-right: 1px solid var(--border);
  display: flex; flex-direction: column;
  position: sticky; top: 0;
  height: 100vh;
  overflow: hidden;
}
.sb-head {
  padding: 18px 16px 14px;
  display: flex; align-items: center; justify-content: space-between;
  gap: 10px;
}
.logo {
  display: flex; align-items: center; gap: 9px;
  font-weight: 600; font-size: 15.5px;
  letter-spacing: -0.02em;
}
.logo-mark {
  width: 26px; height: 26px;
  border-radius: 7px;
  background: linear-gradient(135deg, var(--blue-500), var(--blue-800));
  display: grid; place-items: center;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.18), 0 1px 0 rgba(0,0,0,0.12);
  position: relative;
  flex: none;
}
.logo-mark::after {
  /* the paper-plane diagonal */
  content: "";
  position: absolute; inset: 0;
  background:
    linear-gradient(135deg, transparent 42%, rgba(255,255,255,0.9) 42%, rgba(255,255,255,0.9) 58%, transparent 58%);
  mix-blend-mode: screen;
  opacity: 0.85;
}
.logo-mark svg { position: relative; z-index: 1; }

.sb-env {
  font-family: var(--mono);
  font-size: 10px;
  padding: 2px 6px;
  border-radius: 4px;
  background: var(--ink-50);
  color: var(--text-dim);
  border: 1px solid var(--border);
  letter-spacing: 0.04em;
}
[data-theme="dark"] .sb-env { background: #1d1e28; }

.sb-search {
  margin: 2px 12px 10px;
  position: relative;
}
.sb-search input {
  width: 100%;
  background: var(--surface-alt);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 7px 10px 7px 30px;
  font: inherit; font-size: 12.5px;
  color: var(--text);
  outline: none;
}
.sb-search input::placeholder { color: var(--text-mute); }
.sb-search svg { position: absolute; left: 9px; top: 50%; transform: translateY(-50%); color: var(--text-mute); }
.sb-search kbd {
  position: absolute; right: 7px; top: 50%; transform: translateY(-50%);
  font-family: var(--mono); font-size: 10px;
  border: 1px solid var(--border);
  background: var(--surface);
  padding: 1px 5px; border-radius: 4px;
  color: var(--text-mute);
}

.sb-section {
  padding: 10px 18px 4px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-mute);
  display: flex; align-items: center; justify-content: space-between;
}
.sb-section .count {
  font-weight: 400;
  opacity: 0.7;
}

.sb-nav { padding: 2px 10px; display: flex; flex-direction: column; gap: 1px; }
.sb-item {
  display: flex; align-items: center; gap: 10px;
  padding: 7px 10px;
  border-radius: 7px;
  color: var(--text-dim);
  cursor: pointer;
  font-size: 13px;
  border: 1px solid transparent;
  position: relative;
  user-select: none;
}
.sb-item:hover { background: var(--surface-alt); color: var(--text); }
.sb-item .ico {
  width: 16px; height: 16px; flex: none;
  display: grid; place-items: center;
  color: var(--text-mute);
}
.sb-item.active {
  background: var(--accent-soft);
  color: var(--accent);
  font-weight: 500;
}
.sb-item.active .ico { color: var(--accent); }
[data-theme="dark"] .sb-item.active { color: var(--blue-300); }
[data-theme="dark"] .sb-item.active .ico { color: var(--blue-300); }

.sb-item .badge {
  margin-left: auto;
  font-family: var(--mono);
  font-size: 10px;
  padding: 1px 5px;
  border-radius: 999px;
  background: var(--ink-100);
  color: var(--text-dim);
}
[data-theme="dark"] .sb-item .badge { background: #1e1f29; }

.sb-item.admin .ico { color: var(--bad); }
.sb-item.admin { color: var(--bad); opacity: 0.85; }

.sb-foot {
  margin-top: auto;
  padding: 12px;
  border-top: 1px solid var(--border);
  display: flex; flex-direction: column; gap: 10px;
}
.sb-user {
  display: flex; align-items: center; gap: 10px;
  padding: 6px 8px; border-radius: 8px; cursor: pointer;
}
.sb-user:hover { background: var(--surface-alt); }
.sb-user .avatar {
  width: 28px; height: 28px; border-radius: 8px;
  background: linear-gradient(135deg, #FFC796, #FF6B6B);
  display: grid; place-items: center;
  font-weight: 600; font-size: 12px; color: white;
  flex: none;
}
.sb-user .meta { display: flex; flex-direction: column; min-width: 0; }
.sb-user .meta b { font-size: 12.5px; font-weight: 500; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.sb-user .meta span { font-size: 11px; color: var(--text-mute); }

/* Main */
.main {
  min-width: 0;
  display: flex; flex-direction: column;
}

.topbar {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 28px;
  border-bottom: 1px solid var(--border);
  background: var(--bg);
  position: sticky; top: 0; z-index: 20;
  backdrop-filter: blur(10px);
}
.crumbs { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--text-dim); }
.crumbs b { color: var(--text); font-weight: 500; }
.crumbs .sep { color: var(--text-mute); }

.tb-spacer { flex: 1; }
.tb-actions { display: flex; align-items: center; gap: 8px; }

.pill {
  display: inline-flex; align-items: center; gap: 6px;
  border-radius: 999px;
  padding: 4px 9px;
  font-size: 11.5px;
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text-dim);
  font-family: var(--mono);
  letter-spacing: 0.02em;
}
.pill .dot {
  width: 6px; height: 6px; border-radius: 999px;
  background: var(--ok);
  box-shadow: 0 0 0 3px oklch(0.66 0.14 152 / 0.18);
  animation: pulse 2.2s ease-in-out infinite;
}
.pill.lvl-warn .dot {
  background: var(--warn);
  box-shadow: 0 0 0 3px oklch(0.68 0.13 72 / 0.18);
  animation: pulse-warn 2.2s ease-in-out infinite;
}
.pill.lvl-bad .dot {
  background: var(--bad);
  box-shadow: 0 0 0 3px oklch(0.60 0.17 22 / 0.18);
  animation: pulse-bad 2.2s ease-in-out infinite;
}
.pill.lvl-warn { color: var(--warn); }
.pill.lvl-bad  { color: var(--bad); }
@keyframes pulse {
  0%,100% { box-shadow: 0 0 0 3px oklch(0.66 0.14 152 / 0.18); }
  50%     { box-shadow: 0 0 0 6px oklch(0.66 0.14 152 / 0.04); }
}
@keyframes pulse-warn {
  0%,100% { box-shadow: 0 0 0 3px oklch(0.68 0.13 72 / 0.18); }
  50%     { box-shadow: 0 0 0 6px oklch(0.68 0.13 72 / 0.04); }
}
@keyframes pulse-bad {
  0%,100% { box-shadow: 0 0 0 3px oklch(0.60 0.17 22 / 0.18); }
  50%     { box-shadow: 0 0 0 6px oklch(0.60 0.17 22 / 0.04); }
}

/* Buttons */
.btn {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 7px 12px;
  border-radius: 8px;
  font: inherit;
  font-size: 12.5px;
  font-weight: 500;
  cursor: pointer;
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text);
  transition: background .12s, border-color .12s, transform .06s;
}
.btn:hover { background: var(--surface-alt); }
.btn:active { transform: translateY(0.5px); }
.btn.primary,
.btn.primary:visited,
.btn.primary:hover,
.btn.primary:focus,
.btn.primary:active {
  background: var(--accent);
  color: #fff;
  border-color: transparent;
  box-shadow: 0 1px 0 rgba(255,255,255,0.2) inset, 0 1px 2px rgba(37,99,235,0.35);
}
.btn.primary:hover { background: var(--blue-600); }
.btn.danger,
.btn.danger:visited,
.btn.danger:hover {
  background: var(--bad);
  color: #fff;
  border-color: transparent;
}
/* Ghost-danger: subtle red-tinted button for destructive secondary actions */
.btn.danger.ghost,
.btn.danger.ghost:visited {
  background: transparent;
  color: var(--bad);
  border: 1px solid color-mix(in oklab, var(--bad) 25%, var(--border));
}
.btn.danger.ghost:hover {
  background: var(--bad-bg);
  color: var(--bad);
  border-color: color-mix(in oklab, var(--bad) 45%, var(--border));
}
/* Success-ghost: green-tinted secondary action */
.btn.success,
.btn.success:visited {
  background: transparent;
  color: var(--ok);
  border: 1px solid color-mix(in oklab, var(--ok) 25%, var(--border));
}
.btn.success:hover {
  background: var(--ok-bg);
  color: var(--ok);
  border-color: color-mix(in oklab, var(--ok) 45%, var(--border));
}
.btn.ghost { background: transparent; }
.btn.ghost:hover { background: var(--surface-alt); }
.btn.sm { padding: 4px 8px; font-size: 11.5px; border-radius: 6px; }

/* Page container */
.page {
  padding: 22px 28px 48px;
  display: flex; flex-direction: column; gap: 18px;
  max-width: 1280px;
}
.page-title {
  display: flex; align-items: end; gap: 14px;
  margin-top: 6px;
}
.page-title h1 {
  margin: 0;
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.02em;
}
.page-title .sub {
  color: var(--text-dim); font-size: 13px;
  margin-bottom: 3px;
}

/* Card */
.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xs);
}
.card-h {
  padding: 14px 18px;
  display: flex; align-items: center; gap: 10px;
  border-bottom: 1px solid var(--border);
}
.card-h h3 {
  font-size: 13.5px; font-weight: 500; margin: 0;
  letter-spacing: -0.01em;
}
.card-h .right { margin-left: auto; display: flex; gap: 6px; align-items: center; }
.card-b { padding: 18px; }

/* KPI cards */
.kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}
.kpi {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 16px 18px;
  display: flex; flex-direction: column; gap: 8px;
  position: relative;
  overflow: hidden;
}
.kpi .label { display: flex; align-items: center; gap: 7px; }
.kpi .label .ico { color: var(--text-mute); }
.kpi .val {
  font-family: var(--mono);
  font-size: 28px;
  font-weight: 500;
  letter-spacing: -0.02em;
  line-height: 1;
}
.kpi .delta {
  font-family: var(--mono);
  font-size: 11.5px;
  display: inline-flex; align-items: center; gap: 4px;
}
.kpi .delta.up { color: var(--ok); }
.kpi .delta.down { color: var(--bad); }

/* Table */
.table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.table th {
  text-align: left;
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-mute);
  font-weight: 500;
  padding: 10px 14px;
  border-bottom: 1px solid var(--border);
  background: var(--surface-alt);
}
.table td {
  padding: 0 14px;
  height: var(--row-h);
  border-bottom: 1px solid var(--border);
  color: var(--text);
  vertical-align: middle;
}
.table tr:last-child td { border-bottom: 0; }
.table tr:hover td { background: var(--surface-alt); }

/* status pills */
.st {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 2px 8px;
  border-radius: 999px;
  font-size: 11px;
  font-family: var(--mono);
  letter-spacing: 0.02em;
  border: 1px solid transparent;
}
.st .d { width: 5px; height: 5px; border-radius: 999px; background: currentColor; }
.st.ok    { color: var(--ok); background: var(--ok-bg); }
.st.warn  { color: var(--warn); background: var(--warn-bg); }
.st.bad   { color: var(--bad); background: var(--bad-bg); }
.st.info  { color: var(--blue-600); background: var(--blue-50); }
.st.violet{ color: var(--violet); background: var(--violet-bg); }
[data-theme="dark"] .st.ok    { background: oklch(0.3 0.06 152 / 0.4); }
[data-theme="dark"] .st.warn  { background: oklch(0.3 0.06 72 / 0.4); }
[data-theme="dark"] .st.bad   { background: oklch(0.3 0.08 22 / 0.4); }
[data-theme="dark"] .st.info  { background: oklch(0.3 0.1 260 / 0.4); color: var(--blue-300); }
[data-theme="dark"] .st.violet{ background: oklch(0.3 0.08 290 / 0.4); }

/* subtle grid bg util */
.grid-bg {
  background-image:
    linear-gradient(var(--border) 1px, transparent 1px),
    linear-gradient(90deg, var(--border) 1px, transparent 1px);
  background-size: 32px 32px;
  background-position: -1px -1px;
}

/* Code */
.code {
  background: #0B0C12;
  color: #D8DCE5;
  border-radius: var(--radius);
  padding: 14px 16px;
  font-family: var(--mono);
  font-size: 12.5px;
  line-height: 1.6;
  overflow-x: auto;
  border: 1px solid #1a1b24;
}
.code .k { color: #A7B3FF; }
.code .s { color: #C4F0AD; }
.code .c { color: #7A8099; font-style: italic; }
.code .n { color: #F5B57A; }
.code .p { color: #D8DCE5; }

/* progress */
.bar { position: relative; height: 6px; border-radius: 999px; background: var(--ink-100); overflow: hidden; }
[data-theme="dark"] .bar { background: #1b1c26; }
.bar > span { display: block; height: 100%; border-radius: 999px; background: var(--accent); }

/* form */
.field { display: flex; flex-direction: column; gap: 6px; }
.field label { font-size: 12px; font-weight: 500; }
.field .hint { font-size: 11.5px; color: var(--text-dim); }
.field input, .field select, .field textarea {
  width: 100%;
  background: var(--surface-alt);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 9px 11px;
  font: inherit; font-size: 13px;
  color: var(--text);
  outline: none;
  transition: border-color .12s, background .12s;
}
.field input:focus, .field select:focus, .field textarea:focus {
  border-color: var(--accent);
  background: var(--surface);
  box-shadow: 0 0 0 3px oklch(from var(--accent) l c h / 0.15);
}
.field input::placeholder { color: var(--text-mute); }

/* tabs */
.tabs { display: flex; gap: 2px; border-bottom: 1px solid var(--border); }
.tab {
  padding: 8px 12px;
  font-size: 13px;
  color: var(--text-dim);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
}
.tab:hover { color: var(--text); }
.tab.active { color: var(--text); border-color: var(--accent); }

/* segmented */
.seg {
  display: inline-flex;
  padding: 3px;
  background: var(--surface-alt);
  border: 1px solid var(--border);
  border-radius: 8px;
  gap: 2px;
}
.seg button {
  background: transparent; border: 0;
  padding: 4px 10px;
  border-radius: 5px;
  font: inherit; font-size: 11.5px;
  color: var(--text-dim);
  cursor: pointer;
  font-family: var(--mono);
}
.seg button.on { background: var(--surface); color: var(--text); box-shadow: var(--shadow-xs); }

/* Live feed */
.feed { display: flex; flex-direction: column; }
.feed-row {
  display: grid;
  grid-template-columns: 16px 80px 1fr auto;
  gap: 12px; align-items: center;
  padding: 9px 4px;
  border-bottom: 1px dashed var(--border);
  font-size: 12.5px;
}
.feed-row:last-child { border-bottom: 0; }
.feed-row .t { color: var(--text-mute); font-family: var(--mono); font-size: 11px; }
.feed-row .who { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.feed-row .who b { font-weight: 500; }
.feed-row .who span { color: var(--text-dim); margin-left: 6px; }
.feed-dot { width: 8px; height: 8px; border-radius: 999px; background: var(--ok); position: relative; }
.feed-dot.bad { background: var(--bad); }
.feed-dot.warn { background: var(--warn); }
.feed-dot.info { background: var(--blue-500); }
.feed-row.enter { animation: slideIn .4s ease; }
@keyframes slideIn {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Gauge */
.gauge {
  --p: 0.958;
  --size: 120px;
  width: var(--size); height: var(--size);
  border-radius: 50%;
  background:
    conic-gradient(var(--accent) calc(var(--p) * 360deg), var(--ink-100) 0);
  display: grid; place-items: center;
  position: relative;
}
[data-theme="dark"] .gauge { background: conic-gradient(var(--accent) calc(var(--p) * 360deg), #1b1c26 0); }
.gauge::before {
  content: ""; position: absolute; inset: 8px;
  background: var(--surface); border-radius: 50%;
}
.gauge-v {
  position: relative;
  font-family: var(--mono);
  font-size: 22px; font-weight: 500;
  letter-spacing: -0.02em;
}

/* Sparkline container */
.spark { width: 100%; height: 36px; display: block; }

/* Chips checkmark list */
.features { display: flex; flex-direction: column; gap: 8px; }
.features .ln { display: flex; align-items: center; gap: 8px; font-size: 13px; }
.features .ln svg { color: var(--ok); flex: none; }
.features .ln.x svg { color: var(--text-mute); }
.features .ln.x { color: var(--text-mute); }

/* Domain verification tiles */
.dns-row {
  display: grid;
  grid-template-columns: 70px 1fr auto auto;
  gap: 12px; align-items: center;
  padding: 10px 14px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--surface-alt);
  font-family: var(--mono);
  font-size: 11.5px;
}
.dns-row + .dns-row { margin-top: 6px; }
.dns-row .val { color: var(--text-dim); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* Banner */
.banner {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 12px 14px;
  border-radius: 10px;
  background: var(--blue-50);
  border: 1px solid var(--blue-100);
  color: var(--blue-800);
  font-size: 13px;
}
[data-theme="dark"] .banner {
  background: oklch(0.28 0.1 260 / 0.35);
  border-color: oklch(0.4 0.1 260 / 0.4);
  color: var(--blue-200);
}
.banner b { font-weight: 500; }
.banner .ico { flex: none; margin-top: 1px; }

/* Tweaks panel */
.tweaks {
  position: fixed; right: 18px; bottom: 18px;
  width: 280px;
  background: var(--surface);
  border: 1px solid var(--border-strong);
  border-radius: 14px;
  box-shadow: var(--shadow-lg);
  z-index: 100;
  overflow: hidden;
  font-size: 13px;
}
.tweaks .hd {
  padding: 11px 14px;
  display: flex; align-items: center; justify-content: space-between;
  border-bottom: 1px solid var(--border);
  font-weight: 500;
}
.tweaks .hd small { color: var(--text-mute); font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.06em; text-transform: uppercase; }
.tweaks .bd { padding: 12px 14px; display: flex; flex-direction: column; gap: 12px; }
.tw-row { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.tw-row label { font-size: 12.5px; color: var(--text-dim); }
.sw-dots { display: flex; gap: 6px; }
.sw-dot {
  width: 18px; height: 18px; border-radius: 999px;
  border: 2px solid transparent; cursor: pointer;
  outline: 1px solid var(--border);
}
.sw-dot.sel { border-color: var(--text); }

/* Chart */
.chart { width: 100%; height: 240px; display: block; }

/* Plan card */
.plan {
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 20px;
  background: var(--surface);
  display: flex; flex-direction: column; gap: 14px;
  position: relative;
}
.plan.cur {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px oklch(from var(--accent) l c h / 0.1);
}
.plan .price { font-family: var(--mono); font-size: 34px; font-weight: 500; letter-spacing: -0.02em; line-height: 1; }
.plan .price small { font-size: 13px; color: var(--text-dim); font-family: var(--sans); margin-left: 4px; }
.plan .tag { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-mute); }
.plan .yours {
  position: absolute; top: 14px; right: 14px;
  font-family: var(--mono); font-size: 10px;
  padding: 3px 8px; border-radius: 999px;
  background: var(--accent-soft); color: var(--accent);
}

/* Domain card */
.dom {
  border: 1px solid var(--border); border-radius: 12px;
  padding: 14px 16px;
  display: flex; flex-direction: column; gap: 10px;
  background: var(--surface);
}
.dom .row { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.dom .name { font-size: 14.5px; font-weight: 500; letter-spacing: -0.01em; }
.dom .meta { font-family: var(--mono); font-size: 11.5px; color: var(--text-dim); }

/* Inline kbd list */
.kbds { display: inline-flex; gap: 4px; }
.kbd {
  font-family: var(--mono); font-size: 10.5px;
  border: 1px solid var(--border);
  background: var(--surface-alt);
  padding: 1px 5px; border-radius: 4px;
  color: var(--text-dim);
}

/* helper */
.row { display: flex; align-items: center; gap: 10px; }
.grow { flex: 1; min-width: 0; }
.mute { color: var(--text-dim); }
.small { font-size: 12px; }
.hide { display: none !important; }
.right { margin-left: auto; }
.sep { width: 1px; height: 18px; background: var(--border); }
