/* ============================================================
   Pago na Hora — Brand & Design System
   Enterprise fintech: editorial serif + grotesque, navy-forward
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Hanken+Grotesk:wght@400;500;600;700;800&family=Newsreader:ital,opsz,wght@0,6..72,400;0,6..72,500;0,6..72,600;1,6..72,500;1,6..72,600&family=IBM+Plex+Mono:wght@400;500;600&display=swap');

:root {
  /* Brand blues — accent, used sparingly */
  --blue-50:  #EEF2FE;
  --blue-100: #DCE4FC;
  --blue-200: #BBC9F7;
  --blue-400: #5277F0;
  --blue-500: #2E58E6;
  --blue-600: #1A47D6;   /* primary accent */
  --blue-700: #1539AE;
  --blue-800: #102C86;

  /* Navy / ink — the dominant brand voice */
  --navy-900: #050C1F;
  --navy-850: #0A1430;
  --navy-800: #0E1B3C;
  --navy-700: #1B2C53;
  --ink:      #0B1730;   /* main text */
  --ink-2:    #404B66;   /* secondary text */
  --ink-3:    #69728C;   /* muted */

  /* Surfaces — neutral premium paper, low blue cast */
  --bg:       #FFFFFF;
  --bg-soft:  #F5F6F9;
  --bg-soft2: #ECEEF3;
  --line:     #E3E6EE;
  --line-2:   #D2D7E2;

  /* Pix / success + states (kept semantic, less decorative) */
  --green:      #07965A;
  --green-600:  #058050;
  --green-tint: #E2F1EA;
  --amber:      #B7791F;
  --amber-tint: #F6EEDC;
  --red:        #C8453F;
  --red-tint:   #F7E7E6;
  --violet:     #5B4BB3;

  /* Radii — sharper, more corporate */
  --r-xs: 6px;
  --r-sm: 8px;
  --r-md: 11px;
  --r-lg: 16px;
  --r-xl: 22px;

  /* Shadows — restrained, no neon glow */
  --sh-xs: 0 1px 2px rgba(11,23,48,.05);
  --sh-sm: 0 1px 2px rgba(11,23,48,.05), 0 2px 6px rgba(11,23,48,.05);
  --sh-md: 0 6px 18px rgba(11,23,48,.07), 0 2px 5px rgba(11,23,48,.05);
  --sh-lg: 0 28px 64px rgba(8,18,42,.14), 0 10px 24px rgba(8,18,42,.07);
  --sh-blue: 0 6px 16px rgba(16,44,134,.18);

  --font:         'Hanken Grotesk', system-ui, -apple-system, sans-serif;
  --font-display: 'Newsreader', Georgia, 'Times New Roman', serif;
  --mono:         'IBM Plex Mono', ui-monospace, monospace;

  --maxw: 1200px;
}

* { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  font-family: var(--font);
  color: var(--ink);
  background: var(--bg);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* Display headings in the editorial serif; sub-headings stay grotesque */
h1, h2, h3 {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-optical-sizing: auto;
  letter-spacing: -0.012em;
  line-height: 1.08;
  color: var(--ink);
}
h4 {
  margin: 0;
  font-family: var(--font);
  font-weight: 700;
  letter-spacing: -0.01em;
  line-height: 1.2;
  color: var(--ink);
}
p { margin: 0; }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }

.mono { font-family: var(--mono); }
.tnum { font-variant-numeric: tabular-nums; }

/* ---- Layout ---- */
.wrap { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 24px; }
.eyebrow {
  display: inline-flex; align-items: center; gap: 9px;
  font-family: var(--font);
  font-size: 12px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase;
  color: var(--ink-3);
}
.eyebrow::before {
  content: ""; width: 22px; height: 1px; background: var(--blue-600); display: inline-block;
}

/* ---- Buttons ---- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font-family: var(--font); font-weight: 700; font-size: 15px;
  padding: 13px 22px; border-radius: 9px; border: 1px solid transparent;
  cursor: pointer; transition: transform .12s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease;
  white-space: nowrap; text-decoration: none;
}
.btn:active { transform: translateY(1px); }
.btn-primary { background: var(--blue-600); color: #fff; box-shadow: var(--sh-blue); }
.btn-primary:hover { background: var(--blue-700); }
.btn-dark { background: var(--navy-850); color: #fff; }
.btn-dark:hover { background: var(--navy-900); }
.btn-ghost { background: #fff; color: var(--ink); border-color: var(--line-2); box-shadow: var(--sh-xs); }
.btn-ghost:hover { border-color: var(--ink-3); background: var(--bg-soft); }
.btn-light { background: rgba(255,255,255,.12); color: #fff; border-color: rgba(255,255,255,.24); }
.btn-light:hover { background: rgba(255,255,255,.2); }
.btn-green { background: var(--green); color: #fff; box-shadow: 0 6px 16px rgba(7,150,90,.2); }
.btn-green:hover { background: var(--green-600); }
.btn-sm { padding: 9px 14px; font-size: 14px; border-radius: 8px; }
.btn-lg { padding: 16px 28px; font-size: 16px; }

/* ---- Chips / badges ---- */
.chip {
  display: inline-flex; align-items: center; gap: 9px;
  padding: 7px 14px; border-radius: 999px; font-size: 13px; font-weight: 600;
  background: #fff; color: var(--ink-2); border: 1px solid var(--line);
  box-shadow: var(--sh-xs);
}
.chip::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--blue-600);
}
.badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 10px; border-radius: 6px; font-size: 12px; font-weight: 700;
  letter-spacing: .01em;
}
.badge-green { background: var(--green-tint); color: var(--green-600); }
.badge-amber { background: var(--amber-tint); color: var(--amber); }
.badge-blue  { background: var(--blue-50); color: var(--blue-700); }
.badge-red   { background: var(--red-tint); color: var(--red); }
.badge-gray  { background: var(--bg-soft2); color: var(--ink-2); }
.dot { width: 7px; height: 7px; border-radius: 50%; display: inline-block; }

/* ---- Logo ---- */
.logo { display: inline-flex; align-items: center; gap: 10px; font-weight: 800; letter-spacing: -.02em; font-size: 20px; color: var(--ink); }
.logo .mark {
  width: 32px; height: 32px; border-radius: 8px; display: grid; place-items: center;
  background: var(--navy-850); box-shadow: inset 0 0 0 1px rgba(255,255,255,.06), 0 4px 12px rgba(10,20,48,.28); flex: none;
}
.logo .mark svg { width: 17px; height: 17px; }
.logo b { font-weight: 800; }
.logo span.thin { font-weight: 600; color: var(--ink-2); }

/* avatar */
.av { width: 36px; height: 36px; border-radius: 8px; display: grid; place-items: center; font-weight: 700; font-size: 13px; color: #fff; flex: none; }

/* card */
.card { background: #fff; border: 1px solid var(--line); border-radius: var(--r-md); box-shadow: var(--sh-sm); }

/* utility */
.muted { color: var(--ink-3); }
.sec { color: var(--ink-2); }
.center { text-align: center; }
.stripe-ph {
  background-image: repeating-linear-gradient(135deg, var(--bg-soft2) 0 10px, #fff 10px 20px);
  border: 1px dashed var(--line-2); border-radius: 10px; display: grid; place-items: center;
  color: var(--ink-3); font-family: var(--mono); font-size: 12px;
}
