/* website-alt — variant kit: SaaS-tech density, calculator-first.
   Sits on top of /colors_and_type.css. */
@import url("./colors_and_type.css");

* { box-sizing: border-box; margin: 0; padding: 0; }
html, body {
  background: var(--bg);
  color: var(--fg);
  font-family: var(--font-body);
  font-weight: 300;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; }
img { display: block; max-width: 100%; }

.page { min-height: 100vh; }
.container { max-width: 1240px; margin: 0 auto; padding: 0 48px; }
@media (max-width: 900px) { .container { padding: 0 24px; } }
@media (max-width: 540px) { .container { padding: 0 18px; } }

.section { padding: 96px 0; }
.section--tight { padding: 64px 0; }
.section--dark { background: var(--gol-navy-950); color: #fff; }
@media (max-width: 720px) { .section { padding: 56px 0; } .section--tight { padding: 40px 0; } }

/* Buttons */
.btn {
  height: 44px; padding: 0 20px; border-radius: 12px;
  border: 1px solid transparent;
  font-family: var(--font-display); font-weight: 400; font-size: 14px;
  display: inline-flex; align-items: center; gap: 8px;
  transition: background 140ms, border-color 140ms, color 140ms, box-shadow 140ms, transform 140ms;
  white-space: nowrap;
}
.btn:hover { transform: translateY(-1px); }
.btn--sm { height: 36px; padding: 0 14px; font-size: 13px; border-radius: 10px; }
.btn--lg { height: 52px; padding: 0 24px; font-size: 15px; border-radius: 14px; }
.btn--primary { background: var(--gol-navy-800); color: #fff; border-color: var(--gol-navy-800); }
.btn--primary:hover { background: var(--gol-navy-700); border-color: var(--gol-navy-700); }
.btn--gold { background: var(--gol-gold-500); color: var(--gol-navy-900); border-color: var(--gol-gold-500); font-weight: 500; }
.btn--gold:hover { background: var(--gol-gold-600); border-color: var(--gol-gold-600); }
.btn--outline { background: transparent; color: var(--fg); border: 1px solid var(--slate-300); }
.btn--outline:hover { background: var(--slate-50); border-color: var(--slate-400); }
.btn--outline-dark { background: transparent; color: #fff; border: 1px solid rgba(255,255,255,0.18); }
.btn--outline-dark:hover { background: rgba(255,255,255,0.06); border-color: rgba(255,255,255,0.4); }
.btn--ghost { background: transparent; color: var(--fg); border-color: transparent; }
.btn--ghost:hover { background: var(--slate-100); }

/* Pill / chip */
.pill {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-display); font-weight: 500; font-size: 11px;
  letter-spacing: 0.12em; padding: 5px 10px; border-radius: 999px;
  background: var(--slate-100); color: var(--slate-700); text-transform: uppercase;
}
.pill--navy { background: var(--gol-navy-50); color: var(--gol-navy-700); }
.pill--gold { background: var(--gol-gold-100); color: var(--gol-gold-900); }
.pill--success { background: rgba(31,138,91,0.12); color: var(--success); }
.pill--dark { background: rgba(255,255,255,0.08); color: rgba(255,255,255,0.88); }
.pill--gold-dark { background: rgba(201,166,65,0.16); color: var(--gol-gold-300); }

.eyebrow {
  font-family: var(--font-display); font-weight: 500; font-size: 11px;
  letter-spacing: 0.2em; text-transform: uppercase; color: var(--gol-gold-700);
}
.section--dark .eyebrow { color: var(--gol-gold-400); }

/* Inputs */
.input {
  height: 44px; padding: 0 16px; border-radius: 10px;
  border: 1px solid var(--slate-200); background: #fff;
  color: var(--fg); font-family: var(--font-body); font-weight: 300;
  font-size: 14px; outline: none; transition: border-color 140ms, box-shadow 140ms;
  width: 100%;
}
.input:focus { border-color: var(--gol-navy-700); box-shadow: var(--focus-ring); }
.input--dark {
  background: rgba(255,255,255,0.04); border-color: rgba(255,255,255,0.12); color: #fff;
}
.input--dark:focus { border-color: var(--gol-gold-500); box-shadow: var(--focus-ring-gold); }
.input--dark::placeholder { color: rgba(255,255,255,0.42); }

[data-lucide] { width: 18px; height: 18px; stroke-width: 1.5; }
.numeric { font-variant-numeric: tabular-nums; font-feature-settings: "tnum"; }
.mono { font-family: var(--font-mono); }

/* Card */
.card {
  background: #fff; border: 1px solid var(--border); border-radius: 16px;
  padding: 24px;
}
.card--hover { transition: transform 220ms var(--ease-out), box-shadow 220ms var(--ease-out), border-color 140ms; cursor: pointer; }
.card--hover:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); border-color: var(--gol-navy-200); }
.card--dark { background: rgba(255,255,255,0.04); border-color: rgba(255,255,255,0.08); color: #fff; }

/* Text utilities */
.h-display {
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(40px, 5.5vw, 76px); line-height: 1; letter-spacing: -0.02em;
  color: var(--fg);
}
.h-section {
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(30px, 3.6vw, 44px); line-height: 1.1; letter-spacing: -0.01em;
  color: var(--fg);
}
.h-section-sm { font-size: clamp(24px, 3vw, 36px) !important; }

/* Mobile grid helpers — apply via className */
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; }
@media (max-width: 900px) {
  .grid-3 { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
  .grid-3, .grid-2 { grid-template-columns: 1fr; gap: 14px; }
}
.body-15 { font-family: var(--font-body); font-weight: 300; font-size: 15px; line-height: 1.65; color: var(--fg); }
.body-15-muted { font-family: var(--font-body); font-weight: 300; font-size: 15px; line-height: 1.65; color: var(--fg-muted); }

/* Hairline divider */
.hr { border: 0; height: 1px; background: var(--border); margin: 0; }

/* ------------------------------------------------------------------
   Liquid glass — used for hero nav and the right-side hero tag
   ------------------------------------------------------------------ */
.liquid-glass {
  background: rgba(0, 0, 0, 0.4);
  background-blend-mode: luminosity;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: none;
  box-shadow: inset 0 1px 1px rgba(255, 255, 255, 0.1);
  position: relative;
  overflow: hidden;
}
.liquid-glass::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1.4px;
  background: linear-gradient(180deg,
    rgba(255,255,255,0.32) 0%, rgba(255,255,255,0.12) 20%,
    rgba(255,255,255,0) 40%, rgba(255,255,255,0) 60%,
    rgba(255,255,255,0.12) 80%, rgba(255,255,255,0.32) 100%);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  pointer-events: none;
}
