/* ===========================================================
   Lift Cloud — Design System
   Editorial-operational. Warm paper, deep ink, signature ember.
   =========================================================== */

@import url('https://fonts.googleapis.com/css2?family=Geist:wght@300;400;500;600;700&family=Geist+Mono:wght@400;500;600&family=Instrument+Serif:ital@0;1&display=swap');

:root {
  /* Surface */
  --paper:        oklch(98.5% 0.005 75);
  --paper-2:      oklch(96.5% 0.007 75);
  --paper-3:      oklch(94% 0.008 75);
  --paper-inv:    oklch(18% 0.008 75);

  /* Ink */
  --ink:          oklch(20% 0.01 75);
  --ink-2:        oklch(40% 0.008 75);
  --ink-3:        oklch(58% 0.006 75);
  --ink-4:        oklch(72% 0.005 75);
  --ink-on-dark:  oklch(96% 0.005 75);

  /* Lines */
  --line:         oklch(92% 0.006 75);
  --line-2:       oklch(86% 0.008 75);
  --line-strong:  oklch(78% 0.01 75);

  /* Signature accent — ember orange */
  --ember:        oklch(64% 0.18 38);
  --ember-deep:   oklch(54% 0.17 38);
  --ember-soft:   oklch(95% 0.035 38);
  --ember-line:   oklch(88% 0.06 38);

  /* Status hues (low chroma, same lightness family) */
  --sage:         oklch(58% 0.10 155);
  --sage-soft:    oklch(95% 0.025 155);
  --sage-line:    oklch(88% 0.05 155);

  --amber:        oklch(64% 0.14 70);
  --amber-soft:   oklch(95% 0.035 70);
  --amber-line:   oklch(88% 0.06 70);

  --rouge:        oklch(58% 0.17 22);
  --rouge-soft:   oklch(95% 0.03 22);
  --rouge-line:   oklch(88% 0.06 22);

  --sky:          oklch(54% 0.12 240);
  --sky-soft:     oklch(95% 0.025 240);
  --sky-line:     oklch(88% 0.05 240);

  /* Spacing scale */
  --s-0: 0;
  --s-1: 4px;
  --s-2: 8px;
  --s-3: 12px;
  --s-4: 16px;
  --s-5: 20px;
  --s-6: 24px;
  --s-7: 32px;
  --s-8: 40px;
  --s-9: 56px;
  --s-10: 72px;

  /* Radii */
  --r-1: 4px;
  --r-2: 6px;
  --r-3: 10px;
  --r-4: 14px;
  --r-5: 20px;
  --r-pill: 999px;

  /* Type */
  --font-sans: 'Geist', ui-sans-serif, system-ui, sans-serif;
  --font-serif: 'Instrument Serif', 'Times New Roman', serif;
  --font-mono: 'Geist Mono', ui-monospace, monospace;

  /* Shadows — sparingly used */
  --shadow-1: 0 1px 0 rgba(20,16,10,0.04), 0 0 0 1px oklch(92% 0.006 75);
  --shadow-2: 0 1px 2px rgba(20,16,10,0.04), 0 8px 24px -8px rgba(20,16,10,0.06);
  --shadow-pop: 0 12px 36px -12px rgba(20,16,10,0.18);
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }

.la {
  font-family: var(--font-sans);
  color: var(--ink);
  background: var(--paper);
  font-size: 14px;
  line-height: 1.4;
  letter-spacing: -0.005em;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* ---------- Type primitives ---------- */
.la-display      { font-family: var(--font-serif); font-weight: 400; letter-spacing: -0.02em; line-height: 1.04; }
.la-display i    { font-style: italic; }
.la-h1           { font-size: 28px; font-weight: 500; letter-spacing: -0.02em; line-height: 1.15; }
.la-h2           { font-size: 20px; font-weight: 500; letter-spacing: -0.015em; }
.la-h3           { font-size: 16px; font-weight: 500; letter-spacing: -0.01em; }
.la-eyebrow      { font-family: var(--font-mono); font-size: 11px; font-weight: 500; text-transform: uppercase; letter-spacing: 0.08em; color: var(--ink-3); }
.la-mono         { font-family: var(--font-mono); font-feature-settings: "tnum","ss01"; }
.la-tnum         { font-variant-numeric: tabular-nums; font-feature-settings: "tnum"; }
.la-muted        { color: var(--ink-3); }
.la-quiet        { color: var(--ink-4); }
.la-tiny         { font-size: 11px; letter-spacing: 0; }
.la-small        { font-size: 12px; }
.la-link         { color: var(--ink); border-bottom: 1px solid var(--line-2); cursor: pointer; padding-bottom: 1px; }
.la-link:hover   { border-bottom-color: var(--ember); }

/* ---------- Surface shell (shared chrome) ---------- */
.la-app {
  display: grid;
  grid-template-columns: 224px 1fr;
  grid-template-rows: 52px 1fr;
  height: 100%;
  background: var(--paper);
}
.la-topbar {
  grid-column: 1 / -1;
  border-bottom: 1px solid var(--line);
  display: flex;
  align-items: center;
  padding: 0 var(--s-5);
  gap: var(--s-5);
  background: var(--paper);
  position: relative;
  z-index: 2;
}
.la-side {
  border-right: 1px solid var(--line);
  background: var(--paper);
  padding: var(--s-5) var(--s-3);
  display: flex;
  flex-direction: column;
  gap: var(--s-1);
  overflow: hidden;
}
.la-main {
  overflow: auto;
  background: var(--paper);
}

/* Logo lockup */
.la-logo {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--ink);
  font-size: 15px;
}
.la-logo-mark {
  width: 22px; height: 22px;
  border-radius: 5px;
  background: var(--ink);
  color: var(--paper);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: 11px;
  letter-spacing: -0.04em;
  position: relative;
}
.la-logo-mark::after{
  content: ""; position:absolute; left:3px; bottom:3px; width: 5px; height: 5px;
  background: var(--ember); border-radius: 1.5px;
}

/* ---------- Side rail items ---------- */
.la-rail-group {
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ink-4);
  padding: var(--s-5) var(--s-3) var(--s-2);
}
.la-rail-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 7px 10px;
  border-radius: var(--r-2);
  color: var(--ink-2);
  cursor: pointer;
  font-size: 13.5px;
  font-weight: 450;
  position: relative;
}
.la-rail-item:hover { background: var(--paper-2); color: var(--ink); }
.la-rail-item.is-active {
  background: var(--paper-2);
  color: var(--ink);
  font-weight: 500;
}
.la-rail-item.is-active::before {
  content: "";
  position: absolute;
  left: -10px;
  top: 6px; bottom: 6px;
  width: 3px;
  border-radius: 2px;
  background: var(--ember);
}
.la-rail-item .ico {
  width: 16px; height: 16px;
  color: var(--ink-3);
  flex: none;
}
.la-rail-item.is-active .ico { color: var(--ink); }
.la-rail-item .badge {
  margin-left: auto;
  font-family: var(--font-mono);
  font-size: 10px;
  background: var(--paper-3);
  color: var(--ink-2);
  padding: 1px 6px;
  border-radius: 999px;
}

/* ---------- Topbar bits ---------- */
.la-segmented {
  display: inline-flex;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 2px;
  background: var(--paper-2);
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.la-segmented button,
.la-segmented a {
  border: 0; background: transparent; color: var(--ink-3);
  padding: 4px 10px; border-radius: 6px; cursor: pointer;
  font: inherit; text-transform: inherit; letter-spacing: inherit;
  display: inline-flex; align-items: center; gap: 6px;
  text-decoration: none;
}
.la-segmented button.on,
.la-segmented a.on {
  background: var(--paper); color: var(--ink); box-shadow: 0 1px 0 rgba(0,0,0,.03);
}

.la-pill {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 5px 10px; border: 1px solid var(--line);
  border-radius: 999px; background: var(--paper); cursor: pointer;
  font-size: 12.5px; color: var(--ink-2);
}
.la-pill:hover { border-color: var(--line-2); color: var(--ink); }
.la-pill .av { width: 18px; height: 18px; border-radius: 999px; background: var(--ember); color: white; font-size: 9px; display: inline-flex; align-items:center; justify-content:center; font-weight: 600; }

.la-iconbtn {
  width: 32px; height: 32px;
  border-radius: 8px;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--ink-2); cursor: pointer; border: 1px solid transparent;
  background: transparent;
}
.la-iconbtn:hover { background: var(--paper-2); }

/* ---------- Buttons ---------- */
.la-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 14px;
  border-radius: var(--r-2);
  font-family: var(--font-sans); font-weight: 500; font-size: 13px;
  letter-spacing: -0.005em;
  border: 1px solid var(--line-2);
  background: var(--paper); color: var(--ink);
  cursor: pointer;
  transition: background .12s, border-color .12s;
}
.la-btn:hover { background: var(--paper-2); }
.la-btn.primary {
  background: var(--ink); color: var(--paper);
  border-color: var(--ink);
}
.la-btn.primary:hover { background: oklch(12% 0.01 75); }
.la-btn.ember {
  background: var(--ember); color: white; border-color: var(--ember);
}
.la-btn.ember:hover { background: var(--ember-deep); border-color: var(--ember-deep); }
.la-btn.ghost {
  background: transparent; border-color: transparent;
}
.la-btn.ghost:hover { background: var(--paper-2); }
.la-btn.sm { padding: 5px 10px; font-size: 12px; border-radius: 6px; }
.la-btn.lg { padding: 11px 18px; font-size: 14px; }
.la-btn.block { width: 100%; justify-content: center; }
.la-btn.danger { color: var(--rouge); border-color: var(--rouge-line); }

/* ---------- Cards & shells ---------- */
.la-card {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--r-3);
}
.la-card.padded { padding: var(--s-6); }
.la-card.flat { border-radius: 0; }

.la-section-head {
  display: flex; align-items: baseline; justify-content: space-between;
  padding: 0 0 var(--s-3); margin-bottom: var(--s-4);
  border-bottom: 1px solid var(--line);
}

/* ---------- Status pills ---------- */
.la-status {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 2px 8px 2px 6px; border-radius: 999px;
  font-family: var(--font-mono); font-size: 10.5px; font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.06em;
  border: 1px solid;
}
.la-status::before {
  content: ""; width: 6px; height: 6px; border-radius: 999px; background: currentColor;
}
.la-status.planning { color: oklch(45% 0.05 250); border-color: var(--sky-line); background: var(--sky-soft); }
.la-status.progress { color: oklch(45% 0.10 70); border-color: var(--amber-line); background: var(--amber-soft); }
.la-status.need-info{ color: oklch(45% 0.15 22); border-color: var(--rouge-line); background: var(--rouge-soft); }
.la-status.done     { color: oklch(40% 0.08 155); border-color: var(--sage-line); background: var(--sage-soft); }
.la-status.paid     { color: oklch(40% 0.08 155); border-color: var(--sage-line); background: var(--sage-soft); }
.la-status.overdue  { color: oklch(45% 0.15 22); border-color: var(--rouge-line); background: var(--rouge-soft); }
.la-status.open     { color: var(--ink-2); border-color: var(--line-2); background: var(--paper-2); }
.la-status.draft    { color: var(--ink-3); border-color: var(--line-2); background: var(--paper-2); }
.la-status.sent     { color: oklch(45% 0.05 250); border-color: var(--sky-line); background: var(--sky-soft); }
.la-status.accepted { color: oklch(40% 0.08 155); border-color: var(--sage-line); background: var(--sage-soft); }
.la-status.trial    { color: oklch(45% 0.10 70); border-color: var(--amber-line); background: var(--amber-soft); }

/* ---------- KPI tile ---------- */
.la-kpi {
  border: 1px solid var(--line);
  border-radius: var(--r-3);
  padding: var(--s-5) var(--s-5);
  display: flex; flex-direction: column; gap: 6px;
  background: var(--paper);
  min-height: 130px;
  position: relative;
}
.la-kpi .label { display: flex; justify-content: space-between; align-items: center; }
.la-kpi .label .name { font-family: var(--font-mono); font-size: 10.5px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--ink-3); }
.la-kpi .value { font-family: var(--font-serif); font-size: 40px; line-height: 1; letter-spacing: -0.02em; color: var(--ink); font-feature-settings:"tnum"; }
.la-kpi .value .u { font-family: var(--font-sans); font-size: 14px; color: var(--ink-3); margin-left: 4px; }
.la-kpi .foot { font-size: 12px; color: var(--ink-3); margin-top: auto; padding-top: var(--s-2); display:flex; gap: 6px; align-items: center;}

/* ---------- Tables ---------- */
.la-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.la-table th, .la-table td {
  text-align: left;
  padding: 12px 14px;
  border-bottom: 1px solid var(--line);
  vertical-align: middle;
}
.la-table th {
  font-family: var(--font-mono);
  font-size: 10.5px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-3);
  background: var(--paper-2);
}
.la-table tbody tr:hover { background: var(--paper-2); }
.la-table .code { font-family: var(--font-mono); font-size: 11.5px; color: var(--ink-3); }
.la-table .num { text-align: right; font-variant-numeric: tabular-nums; font-feature-settings: "tnum"; }

/* ---------- Avatar / company chip ---------- */
.la-avatar {
  width: 24px; height: 24px; border-radius: 999px;
  display: inline-flex; align-items:center; justify-content:center;
  background: var(--paper-3); color: var(--ink-2); font-size: 10px; font-weight: 600;
  font-family: var(--font-mono); text-transform: uppercase;
}
.la-avatar.sq { border-radius: 5px; }
.la-avatar.md { width: 32px; height: 32px; font-size: 12px; }
.la-avatar.lg { width: 48px; height: 48px; font-size: 16px; }
.la-avatar.ember { background: var(--ember); color: white; }
.la-avatar.ink { background: var(--ink); color: var(--paper); }
.la-avatar.sage { background: var(--sage); color: white; }
.la-avatar.sky { background: var(--sky); color: white; }

/* ---------- Bars / progress ---------- */
.la-bar {
  width: 100%; height: 6px; background: var(--paper-3);
  border-radius: 999px; overflow: hidden;
}
.la-bar .fill { height: 100%; background: var(--ink); border-radius: 999px; }
.la-bar .fill.ember { background: var(--ember); }
.la-bar .fill.sage { background: var(--sage); }
.la-bar .fill.amber { background: var(--amber); }
.la-bar .fill.rouge { background: var(--rouge); }

/* ---------- Inputs ---------- */
.la-input {
  width: 100%;
  padding: 9px 12px;
  border: 1px solid var(--line-2);
  border-radius: var(--r-2);
  font: inherit; color: var(--ink);
  background: var(--paper);
  font-size: 13.5px;
}
.la-input:focus {
  outline: none;
  border-color: var(--ink);
  box-shadow: 0 0 0 3px oklch(92% 0.008 75);
}
.la-input.lg { padding: 12px 14px; font-size: 14.5px; }
.la-label { display: block; font-size: 12px; color: var(--ink-2); margin-bottom: 6px; font-weight: 500; }
.la-field { margin-bottom: var(--s-4); }

/* ---------- The defining two-area panel (client-visible vs internal-only) ---------- */
.la-two-area {
  display: grid; grid-template-columns: 1fr 1fr;
  border: 1px solid var(--line);
  border-radius: var(--r-3);
  overflow: hidden;
}
.la-area-head {
  padding: 10px 16px;
  font-family: var(--font-mono); font-size: 10.5px; text-transform: uppercase; letter-spacing: 0.08em;
  display: flex; align-items: center; gap: 8px; font-weight: 500;
  border-bottom: 1px solid;
}
.la-area--client { background: var(--sage-soft); border-right: 1px solid var(--line); }
.la-area--client .la-area-head { background: var(--sage); color: white; border-bottom-color: var(--sage); }
.la-area--internal { background: var(--amber-soft); }
.la-area--internal .la-area-head { background: oklch(42% 0.12 70); color: white; border-bottom-color: oklch(42% 0.12 70); }
.la-area-body { padding: var(--s-5); display: flex; flex-direction: column; gap: var(--s-4); }

.la-update {
  background: var(--paper); border: 1px solid var(--line);
  border-radius: var(--r-3); padding: 12px 14px;
}
.la-update .meta { display: flex; align-items: center; gap: 8px; margin-bottom: 6px; }
.la-update .name { font-weight: 500; font-size: 13px; }
.la-update .time { font-size: 11px; color: var(--ink-3); font-family: var(--font-mono); }
.la-update .body { font-size: 13.5px; color: var(--ink-2); }

/* ---------- Misc utility ---------- */
.la-row { display: flex; align-items: center; gap: var(--s-3); }
.la-col { display: flex; flex-direction: column; gap: var(--s-3); }
.la-spread { display: flex; align-items: center; justify-content: space-between; }
.la-grow { flex: 1; }
.la-pad-6 { padding: var(--s-6); }
.la-pad-8 { padding: var(--s-8); }
.la-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-4); }
.la-grid-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: var(--s-4); }
.la-grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--s-4); }
.la-divider { border-top: 1px solid var(--line); }
.la-stripe {
  background-image: repeating-linear-gradient(
    135deg, var(--paper-3) 0 2px, transparent 2px 8px
  );
  border: 1px dashed var(--line-2);
  border-radius: var(--r-3);
  display: flex; align-items: center; justify-content: center;
  color: var(--ink-4); font-family: var(--font-mono); font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.08em;
}

/* ---------- Public surfaces (dark counterpart) ---------- */
.la-dark {
  background: var(--paper-inv);
  color: var(--ink-on-dark);
  font-family: var(--font-sans);
}

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

/* Kanban */
.la-kanban {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-3);
  min-height: 100%;
}
.la-kcol {
  background: var(--paper-2);
  border-radius: var(--r-3);
  padding: var(--s-3);
  display: flex; flex-direction: column; gap: var(--s-3);
  border: 1px solid var(--line);
}
.la-kcol-head { display: flex; align-items:center; justify-content: space-between; padding: 4px 6px; }
.la-kcard {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--r-2);
  padding: 12px;
  cursor: grab;
  display: flex; flex-direction: column; gap: 8px;
}
.la-kcard .kcard-head { display: flex; align-items: center; gap: 6px; font-family: var(--font-mono); font-size: 10.5px; color: var(--ink-3);}
.la-kcard .kcard-title { font-size: 13.5px; font-weight: 500; line-height: 1.3; letter-spacing: -0.005em;}
.la-kcard .kcard-foot { display: flex; align-items: center; gap: 8px; font-size: 11px; color: var(--ink-3); font-family: var(--font-mono);}

/* Calendar */
.la-cal {
  display: grid; grid-template-columns: 56px repeat(5, 1fr);
  border: 1px solid var(--line); border-radius: var(--r-3); overflow: hidden;
}
.la-cal-cell { border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); min-height: 44px; padding: 4px; position: relative;}
.la-cal-cell:last-child { border-right: 0; }
.la-cal-time { font-family: var(--font-mono); font-size: 10px; color: var(--ink-4); text-align: right; padding-right: 8px; padding-top: 2px;}
.la-cal-event {
  position: absolute; left: 4px; right: 4px;
  background: var(--ember-soft); border-left: 3px solid var(--ember);
  padding: 4px 6px; font-size: 11px;
  border-radius: 4px; color: var(--ink);
}

/* Checkbox indicators */
.la-check {
  width: 14px; height: 14px;
  border: 1px solid var(--line-strong);
  border-radius: 3px; display: inline-flex; align-items:center; justify-content:center;
  background: var(--paper); color: var(--paper);
}
.la-check.on { background: var(--ink); border-color: var(--ink); color: var(--paper); }

/* ---------- Vault-specific ---------- */
.la-sens {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-mono); font-size: 10.5px; font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.06em;
  padding: 3px 8px; border-radius: 999px;
  border: 1px solid;
}
.la-sens .dot { width: 8px; height: 8px; border-radius: 999px; background: currentColor; }
.la-sens.normal   { color: var(--sage); border-color: var(--sage-line); background: var(--sage-soft); }
.la-sens.high     { color: oklch(50% 0.15 50); border-color: var(--amber-line); background: var(--amber-soft); }
.la-sens.critical { color: oklch(38% 0.16 22); border-color: var(--rouge-line); background: var(--rouge-soft); font-weight: 600; }
.la-sens.critical .dot { background: oklch(38% 0.16 22); }

/* TOTP digits */
.la-totp {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.12em;
  font-weight: 500;
}
.la-totp-big {
  font-size: 28px;
  font-weight: 600;
}
.la-totp-jumbo {
  font-size: 44px;
  font-weight: 600;
  letter-spacing: 0.18em;
}

/* Secret field with reveal button */
.la-secret {
  display: flex; align-items: center;
  border: 1px solid var(--line-2);
  border-radius: var(--r-2);
  background: var(--paper-2);
  overflow: hidden;
  font-family: var(--font-mono);
}
.la-secret .val {
  flex: 1; padding: 9px 12px; font-size: 13px;
  color: var(--ink); letter-spacing: 0.08em;
  user-select: all;
}
.la-secret.masked .val { color: var(--ink-3); letter-spacing: 0.2em; }
.la-secret .actions { display: flex; border-left: 1px solid var(--line); }
.la-secret .actions button {
  background: var(--paper); border: 0; padding: 0 12px;
  cursor: pointer; color: var(--ink-2); font-size: 12px;
  display: inline-flex; align-items: center; gap: 5px;
  border-left: 1px solid var(--line);
  font-family: var(--font-sans);
}
.la-secret .actions button:first-child { border-left: 0; }
.la-secret .actions button:hover { background: var(--paper-2); color: var(--ink); }

/* Reveal panel watermark */
.la-watermark {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  overflow: hidden;
  user-select: none;
  font-family: var(--font-mono);
  font-size: 22px;
  letter-spacing: 0.15em;
  color: var(--ink);
  opacity: 0.07;
  z-index: 0;
}
.la-watermark-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 36px;
  transform: rotate(-22deg) scale(1.6);
  white-space: nowrap;
}

/* Progress ring for TOTP */
.la-ring {
  --p: 0;
  width: 24px; height: 24px;
  border-radius: 50%;
  background:
    conic-gradient(var(--ember) calc(var(--p) * 1%), var(--paper-3) 0);
  position: relative;
  flex: none;
}
.la-ring::after {
  content: "";
  position: absolute; inset: 4px; border-radius: 50%;
  background: var(--paper);
}
.la-ring.lg { width: 48px; height: 48px; }
.la-ring.lg::after { inset: 6px; }

/* Service tile */
.la-service-tile {
  width: 40px; height: 40px;
  border-radius: 8px;
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--font-mono); font-weight: 600; font-size: 14px;
  background: var(--paper-2);
  border: 1px solid var(--line);
  color: var(--ink);
  flex: none;
}
.la-service-tile.lg { width: 56px; height: 56px; font-size: 18px; }
.la-service-tile.google { background: oklch(96% 0.04 250); color: oklch(40% 0.18 250); border-color: oklch(85% 0.08 250); }
.la-service-tile.meta   { background: oklch(94% 0.04 240); color: oklch(40% 0.18 240); border-color: oklch(85% 0.08 240); }
.la-service-tile.wp     { background: oklch(95% 0.02 220); color: oklch(40% 0.05 220); border-color: oklch(86% 0.04 220); }
.la-service-tile.stripe { background: oklch(95% 0.04 290); color: oklch(40% 0.18 290); border-color: oklch(86% 0.08 290); }
.la-service-tile.bank   { background: var(--rouge-soft); color: oklch(38% 0.16 22); border-color: var(--rouge-line); }
.la-service-tile.email  { background: oklch(95% 0.03 200); color: oklch(40% 0.10 200); border-color: oklch(86% 0.06 200); }
.la-service-tile.host   { background: var(--paper-3); color: var(--ink); }
.la-service-tile.shop   { background: oklch(95% 0.04 145); color: oklch(40% 0.14 145); border-color: oklch(86% 0.07 145); }

/* Tab strip used in Connection detail */
.la-tabs {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--line);
}
.la-tabs a, .la-tabs button {
  padding: 12px 16px;
  text-decoration: none;
  color: var(--ink-3);
  font-size: 13px;
  font-weight: 400;
  background: none;
  border: 0;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  cursor: pointer;
  font-family: var(--font-sans);
  display: inline-flex; align-items: center; gap: 6px;
}
.la-tabs a.on, .la-tabs button.on {
  color: var(--ink);
  font-weight: 500;
  border-bottom-color: var(--ember);
}
.la-tabs .count {
  font-family: var(--font-mono);
  font-size: 10px;
  background: var(--paper-3);
  color: var(--ink-3);
  padding: 1px 6px;
  border-radius: 999px;
}

