/* Pinride website — design tokens mirror the app (app/lib/design.ts):
   cool neutral greys + one hi-vis orange accent, Inter throughout. */
:root {
  --bg: #ffffff;
  --surface-alt: #f4f5f7;
  --ink: #16181d;
  --ink2: #5b616e;
  --ink3: #9aa0ac;
  --line: #e6e8ec;
  --accent: #ff6a00;
  --accent-pressed: #e25800;
  --accent-soft: #ffeee0;
  /* place-type colors (match the app) */
  --food: #e8453c;
  --shop: #7c5cdb;
  --sight: #2f9e44;
  --fuel: #1c7ed6;
  --maxw: 960px;
  --radius: 16px;
}

* { box-sizing: border-box; }

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

body {
  margin: 0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  color: var(--ink);
  background: var(--bg);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}

a { color: var(--accent); text-decoration: none; }
a:hover { color: var(--accent-pressed); text-decoration: underline; }

.wrap { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 24px; }

/* ---- header ---- */
.site-header {
  position: sticky; top: 0; z-index: 10;
  background: rgba(255, 255, 255, 0.85);
  backdrop-filter: saturate(1.4) blur(8px);
  border-bottom: 1px solid var(--line);
}
.site-header .wrap {
  display: flex; align-items: center; justify-content: space-between;
  height: 64px;
}
.brand { display: flex; align-items: center; gap: 10px; font-weight: 700; color: var(--ink); }
.brand:hover { text-decoration: none; }
.brand img { width: 26px; height: 26px; display: block; }
.brand span { font-size: 19px; letter-spacing: -0.01em; }
.nav a { color: var(--ink2); font-weight: 500; font-size: 15px; margin-left: 22px; }
.nav a:hover { color: var(--ink); text-decoration: none; }

/* ---- hero ---- */
.hero { text-align: center; padding: 84px 0 64px; }
.hero .mark { width: 88px; height: 88px; margin: 0 auto 24px; display: block; }
.hero h1 {
  font-size: clamp(40px, 7vw, 64px);
  line-height: 1.02; letter-spacing: -0.03em; margin: 0 0 16px; font-weight: 800;
}
.hero .tagline { font-size: clamp(18px, 2.6vw, 22px); color: var(--ink2); margin: 0 auto; max-width: 34ch; }
.badge {
  display: inline-block; margin-top: 28px; padding: 7px 14px;
  background: var(--accent-soft); color: var(--accent-pressed);
  border-radius: 999px; font-size: 13px; font-weight: 600;
  letter-spacing: 0.02em;
}

/* ---- sections ---- */
section { padding: 56px 0; }
.section-title { font-size: clamp(24px, 3.4vw, 32px); letter-spacing: -0.02em; margin: 0 0 8px; font-weight: 800; }
.section-sub { color: var(--ink2); margin: 0 0 36px; max-width: 60ch; }

.cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.card {
  background: var(--surface-alt); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 26px 24px;
}
.card h3 { margin: 0 0 8px; font-size: 18px; letter-spacing: -0.01em; }
.card p { margin: 0; color: var(--ink2); font-size: 15px; }
.card .dot { width: 30px; height: 30px; border-radius: 9px; margin-bottom: 16px; background: var(--accent); }

/* place-type chips */
.types { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 8px; }
.type {
  display: inline-flex; align-items: center; gap: 9px;
  padding: 10px 16px; border: 1px solid var(--line); border-radius: 999px;
  font-weight: 600; font-size: 15px; background: #fff;
}
.type i { width: 11px; height: 11px; border-radius: 50%; display: inline-block; }

/* ---- footer ---- */
.site-footer { border-top: 1px solid var(--line); padding: 40px 0; color: var(--ink3); font-size: 14px; }
.site-footer .wrap { display: flex; flex-wrap: wrap; gap: 16px; align-items: center; justify-content: space-between; }
.site-footer .links a { color: var(--ink2); margin-left: 18px; }
.site-footer .links a:first-child { margin-left: 0; }

/* ---- legal pages ---- */
.legal { padding: 56px 0 72px; }
.legal h1 { font-size: clamp(30px, 5vw, 44px); letter-spacing: -0.02em; margin: 0 0 6px; }
.legal .updated { color: var(--ink3); font-size: 14px; margin: 0 0 36px; }
.legal h2 { font-size: 21px; letter-spacing: -0.01em; margin: 36px 0 10px; }
.legal h3 { font-size: 16px; margin: 22px 0 6px; }
.legal p, .legal li { color: var(--ink); font-size: 16px; }
.legal ul { padding-left: 22px; }
.legal li { margin: 6px 0; }
.legal .draft {
  background: #fff8e6; border: 1px solid #f1d9a0; color: #7a5a00;
  border-radius: 12px; padding: 14px 18px; font-size: 14px; margin: 0 0 32px;
}
.legal a.back { font-size: 14px; font-weight: 600; }

@media (max-width: 720px) {
  .cards { grid-template-columns: 1fr; }
  .hero { padding: 60px 0 44px; }
  section { padding: 44px 0; }
}
