@font-face {
  font-family: 'Roobert Fallback';
  src: local('Arial'), local('Helvetica Neue'), local('Helvetica'), local('sans-serif');
  size-adjust: 103%;
  ascent-override: 95%;
  descent-override: 25%;
  line-gap-override: 0%;
}

:host {
  /* Brand Colors - from Figma */
  --color-bg-primary: #0a0a0a;
  --color-bg-secondary: #111111;
  --color-bg-card: #171717;
  --color-bg-card-hover: #1c1c1c;
  --color-bg-input: #171717;

  /* Text Colors - Figma neutral-50 / neutral-200 */
  --color-text-primary: #fafafa;
  --color-text-secondary: #e5e5e5;
  --color-text-muted: #a3a3a3;
  --color-text-dim: #656565;

  /* Gradient - Figma: sky-600 -> emerald-400 */
  --gradient-primary: linear-gradient(100deg, rgb(2, 132, 199) 15%, rgb(49, 196, 141) 95%);
  --gradient-hero-bg: radial-gradient(ellipse at 50% 80%, rgba(2, 132, 199, 0.12) 0%, rgba(49, 196, 141, 0.06) 40%, transparent 70%);
  --gradient-cta-bg: radial-gradient(ellipse at center, rgba(49, 196, 141, 0.15) 0%, rgba(2, 132, 199, 0.08) 50%, transparent 100%);
  --gradient-section-divider: radial-gradient(ellipse at center, rgba(49, 196, 141, 0.06) 0%, transparent 70%);

  /* Accent Colors */
  --color-accent-green: #31c48d;
  --color-accent-blue: #0284c7;
  --color-accent-muted: rgba(49, 196, 141, 0.15);

  /* Borders */
  --color-border: #262626;
  --color-border-card: #262626;
  --color-border-input: #656565;

  /* Badge */
  --color-badge-bg: rgba(49, 196, 141, 0.1);
  --color-badge-border: rgba(49, 196, 141, 0.3);
  --color-badge-text: #31c48d;

  /* Spacing */
  --space-xs: 4px;
  --space-sm: 8px;
  --space-md: 16px;
  --space-lg: 24px;
  --space-xl: 32px;
  --space-2xl: 40px;
  --space-3xl: 64px;
  --space-4xl: 96px;
  --space-5xl: 128px;

  /* Border Radius */
  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 16px;
  --radius-xl: 24px;
  --radius-full: 9999px;

  /* Typography */
  --font-display: 'Roobert', 'Roobert Fallback', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-body: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-size-xs: 12px;
  --font-size-sm: 14px;
  --font-size-base: 16px;
  --font-size-lg: 18px;
  --font-size-xl: 20px;
  --font-size-2xl: 24px;
  --font-size-3xl: 32px;
  --font-size-4xl: 48px;
  --font-size-5xl: 64px;
  --font-size-6xl: 80px;

  /* Shadows */
  --shadow-card: 0 1px 3px rgba(0, 0, 0, 0.3);
  --shadow-card-hover: 0 8px 24px rgba(0, 0, 0, 0.4);

  /* Layout */
  --max-width: 1172px;
  --max-width-narrow: 968px;
  --content-padding: 24px;
}

*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

body,
:host {
  font-family: var(--font-body);
  background-color: var(--color-bg-primary);
  color: var(--color-text-primary);
  line-height: 1.5;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

a {
  color: inherit;
  text-decoration: none;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

.bRiS5X78Bi5qoXHZRqfP {
  position: relative;
  width: 100%;
  padding: 80px 0;
}

.tQzhRUKzRyndaUYVXMPl {
  max-width: 1060px;
  margin: 0 auto;
  padding: 0 var(--content-padding);
}

.jILH8eqhd8jLs9WbTMH_ {
  font-family: var(--font-display);
  font-size: 48px;
  font-weight: 600;
  line-height: 58px;
  color: #fafafa;
  text-align: center;
  margin-bottom: 16px;
}

.Tplg73WItYXN21iaXSz3 {
  font-family: var(--font-body);
  font-size: 16px;
  color: #a3a3a3;
  text-align: center;
  margin-bottom: 56px;
  line-height: 1.6;
}

.FUOw7WIV6_exKrSj6SzA {
  overflow-x: auto;
  border-radius: 16px;
  border: 1px solid #1f1f1f;
}

.QeslvgRTrblAam7OiHf_ {
  display: table;
  width: 100%;
  min-width: 720px;
  border-collapse: collapse;
  table-layout: fixed;
}

/* ─── Column headers ─── */

.R45w0C5gAJT74JwgYyPW {
  display: table-cell;
  padding: 20px 24px;
  font-family: var(--font-display);
  font-size: 14px;
  font-weight: 600;
  color: #a3a3a3;
  border-bottom: 1px solid #1f1f1f;
  background: #0f0f0f;
  text-align: left;
  width: 25%;
}

.R45w0C5gAJT74JwgYyPW:first-child {
  width: 22%;
}

.abFdcQaO41bTBgubMbgw {
  display: table-cell;
  color: #31c48d;
  background: linear-gradient(180deg, rgba(49, 196, 141, 0.06) 0%, rgba(49, 196, 141, 0.02) 100%);
  border-top: 2px solid #31c48d;
  border-radius: 0 16px 0 0;
  position: relative;
  width: 28%;
}

.abFdcQaO41bTBgubMbgw::before {
  content: "\2605  RECOMMENDED";
  display: block;
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.5px;
  color: #31c48d;
  margin-bottom: 4px;
  opacity: 0.6;
}

/* ─── Feature label (first column) ─── */

.FADITrJhMd6od_o0PC2F {
  display: table-cell;
  padding: 16px 24px;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 500;
  color: #d4d4d4;
  border-bottom: 1px solid #1a1a1a;
  vertical-align: middle;
  background: #0a0a0a;
}

/* ─── Competitor cells ─── */

.uls4cMnca9sEv9h8g8xF {
  display: table-cell;
  padding: 16px 24px;
  font-family: var(--font-body);
  font-size: 13px;
  color: #a3a3a3;
  border-bottom: 1px solid #1a1a1a;
  vertical-align: top;
  line-height: 1.55;
}

/* ─── reap column ─── */

.dN3NB14DCqbATw4f3Zg9 {
  display: table-cell;
  padding: 16px 24px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  color: #e5e5e5;
  border-bottom: 1px solid rgba(49, 196, 141, 0.08);
  background: rgba(49, 196, 141, 0.025);
  vertical-align: top;
  line-height: 1.55;
}

.uls4cMnca9sEv9h8g8xF span,
.dN3NB14DCqbATw4f3Zg9 span {
  vertical-align: middle;
}

/* ─── Icons ─── */

.Cbqpww3NxQdOexmZ7jon {
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  margin-top: 1px;
  margin-right: 10px;
  display: inline-block;
  vertical-align: top;
}

.PRsjazNtKHoKRD9wZpog {
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  margin-top: 1px;
  margin-right: 10px;
  display: inline-block;
  vertical-align: top;
  opacity: 0.5;
}

.NLq4abdtxfqwxI6Gkbx9 {
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  margin-top: 1px;
  margin-right: 10px;
  display: inline-block;
  vertical-align: top;
  opacity: 0.6;
}

/* ─── Responsive ─── */

@media (max-width: 1024px) {
  .jILH8eqhd8jLs9WbTMH_ {
    font-size: 40px;
    line-height: 50px;
  }
}

@media (max-width: 768px) {
  .bRiS5X78Bi5qoXHZRqfP {
    padding: 56px 0;
  }

  .jILH8eqhd8jLs9WbTMH_ {
    font-size: 32px;
    line-height: 40px;
    margin-bottom: 32px;
  }

  .R45w0C5gAJT74JwgYyPW,
  .FADITrJhMd6od_o0PC2F,
  .uls4cMnca9sEv9h8g8xF,
  .dN3NB14DCqbATw4f3Zg9 {
    padding: 14px 16px;
    font-size: 13px;
  }
}

@media (max-width: 480px) {
  .jILH8eqhd8jLs9WbTMH_ {
    font-size: 26px;
    line-height: 34px;
  }
}

