/* ═══════════════════════════════════════════════════════════════
   PROSPECT FINANCE — Design System Tokens
   Extracted from: prospect-finance-saas-webflow-template.webflow.io
   ═══════════════════════════════════════════════════════════════ */

/* ── Font Faces ─────────────────────────────────────────────── */
/* Coloca los archivos de fuente en la carpeta fonts/           */

@font-face {
  font-family: "BDO Grotesk";
  src: url("fonts/BDOGrotesk-VF.ttf") format("truetype"),
    url("https://cdn.prod.website-files.com/686b609a7b41400be768eba3/686b609a7b41400be768ebf2_BDOGrotesk-VF.ttf") format("truetype");
  font-weight: 300 900;
  font-display: swap;
}

@font-face {
  font-family: "Roboto Mono";
  src: url("fonts/RobotoMono-Medium.ttf") format("truetype"),
    url("https://cdn.prod.website-files.com/686b609a7b41400be768eba3/686b609a41f6d623e5ae56d1_RobotoMono-Medium.ttf") format("truetype");
  font-weight: 500;
  font-display: swap;
}

@font-face {
  font-family: "Libre Caslon Condensed";
  src: url("fonts/LibreCaslonCondensed-Regular.otf") format("opentype"),
    url("https://cdn.prod.website-files.com/686b609a7b41400be768eba3/686b609a95e69a4723573cc2_LibreCaslonCondensed-Regular.otf") format("opentype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Libre Caslon Condensed";
  src: url("fonts/LibreCaslonCondensed-Italic.otf") format("opentype"),
    url("https://cdn.prod.website-files.com/686b609a7b41400be768eba3/686b609a6adba13360e01280_LibreCaslonCondensed-Italic.otf") format("opentype");
  font-weight: 400;
  font-style: italic;
  font-display: swap;
}

/* ── Root Design Tokens ─────────────────────────────────────── */

:root {
  /* ── Colors ────────────────────────────────── */
  --color-light-1: #FEFAF3;
  --color-light-2: #F1EADD;
  --color-dark: #2F2C25;
  --color-white: #FFFFFF;

  /* Opacity variants */
  --color-dark-7: rgba(47, 44, 37, 0.06);
  --color-dark-12: rgba(47, 44, 37, 0.12);
  --color-light-1-10: rgba(254, 250, 243, 0.10);
  --color-light-1-30: rgba(254, 250, 243, 0.30);
  --color-light-1-60: rgba(254, 250, 243, 0.60);

  /* Glass */
  --color-glass-border: rgba(255, 255, 255, 0.40);
  --color-glass-surface: rgba(254, 250, 243, 0.60);

  /* Semantic */
  --color-text-dark: var(--color-dark);
  --color-text-light: var(--color-light-1);
  --color-success: #A9EE81;
  --color-error: #F5AAAA;
  --color-accent: #369BE4;

  /* Overlays */
  --overlay-medium: rgba(0, 0, 0, 0.50);
  --overlay-heavy: rgba(0, 0, 0, 0.70);

  /* ── Typography ────────────────────────────── */
  --type-font-headings: "Libre Caslon Condensed", "Times New Roman", serif;
  --type-font-body: "BDO Grotesk", Arial, sans-serif;
  --type-font-badges: "Roboto Mono", "Trebuchet MS", monospace;
  --type-base-unit: 14px;
  --type-scale-factor: 1.26;

  /* Type Scale */
  --type-small-size: calc(var(--type-base-unit) / var(--type-scale-factor));
  --type-body-size: var(--type-base-unit);
  --type-lead-size: calc(var(--type-base-unit) * var(--type-scale-factor));
  --type-h5-size: calc(var(--type-lead-size) * var(--type-scale-factor) * var(--type-scale-factor));
  --type-h4-size: calc(var(--type-h5-size) * var(--type-scale-factor));
  --type-h3-size: calc(var(--type-h4-size) * var(--type-scale-factor));
  --type-h2-size: calc(var(--type-h3-size) * var(--type-scale-factor));
  --type-h1-size: calc(var(--type-h2-size) * var(--type-scale-factor));

  /* Line Heights */
  --type-small-lh: 1.4em;
  --type-body-lh: 1.4em;
  --type-lead-lh: 1.4em;
  --type-h5-lh: 1.3em;
  --type-h4-lh: 1.25em;
  --type-h3-lh: 1.2em;
  --type-h2-lh: 1.1em;
  --type-h1-lh: 1.0em;

  /* Letter Spacing */
  --type-h1-ls: -0.02em;
  --type-h2-ls: -0.02em;
  --type-h3-ls: -0.02em;
  --type-h4-ls: -0.02em;
  --type-h5-ls: -0.01em;

  /* ── Spacing (24px base) ───────────────────── */
  --gap-base: 24px;
  --gap-0-125x: calc(var(--gap-base) * 0.125);
  /*  3px */
  --gap-0-25x: calc(var(--gap-base) * 0.25);
  /*  6px */
  --gap-0-5x: calc(var(--gap-base) * 0.5);
  /* 12px */
  --gap-0-75x: calc(var(--gap-base) * 0.75);
  /* 18px */
  --gap-1x: var(--gap-base);
  /* 24px */
  --gap-1-5x: calc(var(--gap-base) * 1.5);
  /* 36px */
  --gap-2x: calc(var(--gap-base) * 2);
  /* 48px */
  --gap-3x: calc(var(--gap-base) * 3);
  /* 72px */
  --gap-4x: calc(var(--gap-base) * 4);
  /* 96px */
  --gap-5x: calc(var(--gap-base) * 5);
  /* 120px */
  --gap-6x: calc(var(--gap-base) * 6);
  /* 144px */
  --gap-7x: calc(var(--gap-base) * 7);
  /* 168px */

  /* ── Section Padding ───────────────────────── */
  --section-padding-base: 96px;
  --section-padding-0-5x: calc(var(--section-padding-base) * 0.5);
  --section-padding-1-5x: calc(var(--section-padding-base) * 1.5);

  /* ── Grid / Container ──────────────────────── */
  --container-max-width: 1440px;
  --container-gutter: 24px;
  --grid-gap-xs: 6px;
  --grid-gap-s: 12px;
  --grid-gap-m: 24px;

  /* ── Border Radius ─────────────────────────── */
  --radius-base: 6px;
  --radius-md: 9px;
  --radius-lg: 12px;
  --radius-pill: 200px;
  --radius-circle: 50%;

  /* ── Shadows ───────────────────────────────── */
  --shadow-sm: 0px 2px 18px rgba(0, 0, 0, 0.12);
  --shadow-md: 0px 4px 18px rgba(0, 0, 0, 0.12);
  --shadow-lg: 0px 2px 18px rgba(0, 0, 0, 0.20);

  /* ── Glass Effects ─────────────────────────── */
  --glass-blur: 12px;
  --glass-shadow-blur: 18px;
  --glass-shadow-color: rgba(0, 0, 0, 0.12);

  /* ── Buttons ───────────────────────────────── */
  --btn-height: 48px;
  --btn-padding-x: 24px;
  --btn-radius: 9px;
  --btn-height-sm: 42px;
  --btn-padding-x-sm: 18px;

  /* ── Forms ─────────────────────────────────── */
  --input-height: 48px;
  --input-padding-x: 18px;
  --input-radius: var(--btn-radius);
  --input-bg: var(--color-dark-7);
  --input-border: transparent;
  --textarea-min-h: 200px;
  --input-group-gap: 12px;
  --checkbox-size: 18px;

  /* ── Navbar ────────────────────────────────── */
  --navbar-bg: var(--color-light-1);
  --navbar-height: 72px;
  --navbar-gap: 24px;
}

/* ── Base Reset & Defaults ──────────────────────────────────── */

*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body {
  font-family: var(--type-font-body);
  font-size: var(--type-body-size);
  line-height: var(--type-body-lh);
  color: var(--color-text-dark);
  background-color: var(--color-light-1);
}

/* ── Typography ─────────────────────────────────────────────── */

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: var(--type-font-headings);
  font-weight: 400;
}

h1 {
  font-size: var(--type-h1-size);
  line-height: var(--type-h1-lh);
  letter-spacing: var(--type-h1-ls);
}

h2 {
  font-size: var(--type-h2-size);
  line-height: var(--type-h2-lh);
  letter-spacing: var(--type-h2-ls);
}

h3 {
  font-size: var(--type-h3-size);
  line-height: var(--type-h3-lh);
  letter-spacing: var(--type-h3-ls);
}

h4 {
  font-size: var(--type-h4-size);
  line-height: var(--type-h4-lh);
  letter-spacing: var(--type-h4-ls);
}

h5 {
  font-size: var(--type-h5-size);
  line-height: var(--type-h5-lh);
  letter-spacing: var(--type-h5-ls);
}

p {
  font-size: var(--type-body-size);
  line-height: var(--type-body-lh);
}

.text-lead {
  font-size: var(--type-lead-size);
  line-height: var(--type-lead-lh);
}

.text-small {
  font-size: var(--type-small-size);
  line-height: var(--type-small-lh);
}

.text-badge {
  font-family: var(--type-font-badges);
  font-size: var(--type-small-size);
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

/* ── Container ──────────────────────────────────────────────── */

.container {
  width: 100%;
  max-width: var(--container-max-width);
  margin: 0 auto;
  padding-left: var(--container-gutter);
  padding-right: var(--container-gutter);
}

/* ── Buttons ────────────────────────────────────────────────── */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: var(--btn-height);
  padding: 0 var(--btn-padding-x);
  font-family: var(--type-font-body);
  font-size: var(--type-body-size);
  font-weight: 500;
  text-decoration: none;
  border: none;
  border-radius: var(--btn-radius);
  cursor: pointer;
  transition: all 0.25s ease;
}

.btn-primary {
  background-color: var(--color-dark);
  color: var(--color-text-light);
}

.btn-primary:hover {
  opacity: 0.85;
}

.btn-secondary {
  background-color: transparent;
  color: var(--color-text-dark);
  border: 1px solid var(--color-dark-12);
}

.btn-secondary:hover {
  background-color: var(--color-dark-7);
}

.btn-sm {
  height: var(--btn-height-sm);
  padding: 0 var(--btn-padding-x-sm);
}

.btn-light {
  background-color: var(--color-light-1);
  color: var(--color-dark);
}

/* ── Form Inputs ────────────────────────────────────────────── */

.input {
  width: 100%;
  height: var(--input-height);
  padding: 0 var(--input-padding-x);
  font-family: var(--type-font-body);
  font-size: var(--type-body-size);
  color: var(--color-text-dark);
  background-color: var(--input-bg);
  border: 1px solid var(--input-border);
  border-radius: var(--input-radius);
  outline: none;
  transition: border-color 0.2s ease;
}

.input:focus {
  border-color: var(--color-dark-12);
}

.input::placeholder {
  color: var(--color-dark);
  opacity: 0.4;
}

textarea.input {
  min-height: var(--textarea-min-h);
  padding-top: var(--gap-0-5x);
  padding-bottom: var(--gap-0-5x);
  resize: vertical;
}

/* ── Cards ──────────────────────────────────────────────────── */

.card {
  background: var(--color-white);
  border: 1px solid var(--color-dark-12);
  border-radius: var(--radius-lg);
  padding: var(--gap-1x);
  box-shadow: var(--shadow-sm);
}

.card-glass {
  background: var(--color-glass-surface);
  border: 1px solid var(--color-glass-border);
  border-radius: var(--radius-lg);
  padding: var(--gap-1x);
  backdrop-filter: blur(var(--glass-blur));
  -webkit-backdrop-filter: blur(var(--glass-blur));
  box-shadow: var(--shadow-sm);
}

/* ── Badges / Tags ──────────────────────────────────────────── */

.badge {
  display: inline-flex;
  align-items: center;
  gap: var(--gap-0-25x);
  font-family: var(--type-font-badges);
  font-size: var(--type-small-size);
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: var(--gap-0-25x) var(--gap-0-5x);
  border-radius: var(--radius-base);
  background: var(--color-dark-7);
  color: var(--color-text-dark);
}

/* ── Section Utility ────────────────────────────────────────── */

.section {
  padding-top: var(--section-padding-base);
  padding-bottom: var(--section-padding-base);
}

.section-dark {
  background-color: var(--color-dark);
  color: var(--color-text-light);
}

.section-light {
  background-color: var(--color-light-1);
  color: var(--color-text-dark);
}

.section-cream {
  background-color: var(--color-light-2);
  color: var(--color-text-dark);
}