/* Snaplot brand tokens — loaded site-wide. ~1 KB.
 * Reference for the marketing pages (home, pricing, how-it-works, header, footer).
 * In-app pages still use the older _tokens.css inside the snaplot-bridge plugin.
 */
:root {
  --snap-navy:      #0E2A47;
  --snap-navy-2:    #1A3D63;
  --snap-amber:     #F59E0B;
  --snap-amber-2:   #D97706;
  --snap-ivory:     #FFFCF5;
  --snap-cream:     #FAF6EC;
  --snap-slate:     #475569;
  --snap-slate-2:   #64748B;
  --snap-line:      #E5E1D5;
  --snap-success:   #16A34A;
  --snap-radius-sm: 8px;
  --snap-radius:    14px;
  --snap-radius-lg: 24px;
  --snap-shadow:    0 12px 32px rgba(14, 42, 71, .08);
  --snap-shadow-lg: 0 28px 64px rgba(14, 42, 71, .14);
  --snap-font:      'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

* { box-sizing: border-box; }

body.snap-marketing {
  margin: 0;
  font-family: var(--snap-font);
  font-size: 17px;
  line-height: 1.65;
  color: var(--snap-navy);
  background: var(--snap-ivory);
  -webkit-font-smoothing: antialiased;
}

body.snap-marketing a       { color: var(--snap-navy); text-decoration: none; }
body.snap-marketing a:hover { color: var(--snap-amber-2); }
body.snap-marketing img,
body.snap-marketing svg     { max-width: 100%; height: auto; }

/* Re-usable button system (works on home + pricing + how-it-works) */
.snap-btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: 8px;
  padding: 14px 22px;
  font: 700 16px/1 var(--snap-font);
  border-radius: var(--snap-radius);
  border: 0;
  cursor: pointer;
  text-decoration: none;
  transition: transform .12s ease, background .12s ease, box-shadow .12s ease;
}
.snap-btn-primary {
  background: var(--snap-amber);
  color: #1A1F2E;
  box-shadow: 0 8px 22px rgba(245, 158, 11, .35);
}
.snap-btn-primary:hover {
  background: var(--snap-amber-2);
  color: #1A1F2E;
  transform: translateY(-1px);
  box-shadow: 0 14px 28px rgba(245, 158, 11, .42);
}
.snap-btn-ghost {
  background: transparent;
  color: var(--snap-navy);
  border: 1.5px solid var(--snap-navy);
}
.snap-btn-ghost:hover {
  background: var(--snap-navy);
  color: var(--snap-ivory);
}

.snap-container { width: 100%; max-width: 1180px; margin: 0 auto; padding: 0 24px; }

/* Eyebrow */
.snap-eyebrow {
  display: inline-block;
  font: 600 12px/1 var(--snap-font);
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--snap-amber-2);
  margin-bottom: 16px;
}

@media (max-width: 640px) {
  body.snap-marketing { font-size: 16px; }
  .snap-btn { padding: 14px 18px; font-size: 15px; }
}

/* ==========  SITE HEADER  ========== */
.snap-site-header {
  position: sticky; top: 0; z-index: 50;
  background: var(--snap-ivory);
  border-bottom: 1px solid var(--snap-line);
  font-family: var(--snap-font);
}
.snap-site-header__inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: 24px;
  padding: 16px 24px;
  min-height: 72px;
}
.snap-site-header__brand img { display: block; height: 36px; width: auto; }
.snap-site-header__nav {
  display: flex; align-items: center; gap: 32px;
  flex: 1; justify-content: center;
}
.snap-site-header__link {
  font: 600 15px/1 var(--snap-font);
  color: var(--snap-navy);
  text-decoration: none;
  padding: 8px 0;
  border-bottom: 2px solid transparent;
  transition: border-color .12s ease, color .12s ease;
}
.snap-site-header__link:hover,
.snap-site-header__link.is-active {
  color: var(--snap-amber-2);
  border-color: var(--snap-amber);
}
.snap-site-header__cta { display: flex; gap: 10px; align-items: center; }
.snap-site-header__cta .snap-btn { padding: 10px 18px; font-size: 14px; }

.snap-site-header__toggle-input { display: none; }
.snap-site-header__toggle { display: none; }

@media (max-width: 900px) {
  .snap-site-header__toggle {
    display: flex; flex-direction: column; gap: 5px;
    width: 36px; height: 36px;
    padding: 8px 6px;
    cursor: pointer;
    margin-left: auto;
    border-radius: 6px;
  }
  .snap-site-header__toggle span {
    display: block; height: 2px; background: var(--snap-navy); border-radius: 2px;
    transition: transform .2s, opacity .2s;
  }
  .snap-site-header__nav,
  .snap-site-header__cta {
    position: absolute; top: 72px; left: 0; right: 0;
    background: var(--snap-ivory);
    border-bottom: 1px solid var(--snap-line);
    flex-direction: column;
    padding: 16px 24px 24px;
    gap: 14px;
    align-items: stretch;
    display: none;
  }
  .snap-site-header__cta { top: auto; padding-top: 0; border-bottom: 1px solid var(--snap-line); }
  .snap-site-header__cta .snap-btn { width: 100%; padding: 14px 18px; font-size: 15px; }
  .snap-site-header__toggle-input:checked ~ .snap-site-header__nav,
  .snap-site-header__toggle-input:checked ~ .snap-site-header__cta {
    display: flex;
  }
  .snap-site-header__toggle-input:checked ~ .snap-site-header__cta { top: auto; }
}

/* ==========  SITE FOOTER  ========== */
.snap-site-footer {
  background: var(--snap-navy);
  color: var(--snap-ivory);
  font-family: var(--snap-font);
  margin-top: 80px;
}
.snap-site-footer a { color: var(--snap-ivory); text-decoration: none; opacity: .85; transition: opacity .12s; }
.snap-site-footer a:hover { color: var(--snap-amber); opacity: 1; }
.snap-site-footer__grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 48px;
  padding: 64px 24px 48px;
}
.snap-site-footer__col h3 {
  font: 600 13px/1 var(--snap-font);
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--snap-amber);
  margin: 0 0 16px;
}
.snap-site-footer__col ul { list-style: none; padding: 0; margin: 0; }
.snap-site-footer__col li { margin: 0 0 10px; font-size: 15px; }
.snap-site-footer__col--brand img { height: 40px; margin-bottom: 16px; }
.snap-site-footer__tagline { margin: 0 0 12px; font-size: 15px; opacity: .85; max-width: 320px; }
.snap-site-footer__contact { margin: 0; font-size: 15px; }
.snap-site-footer__bar {
  border-top: 1px solid rgba(255,252,245,.12);
  padding: 20px 0;
  font-size: 13px;
  opacity: .75;
}
.snap-site-footer__bar-inner { display: flex; justify-content: space-between; gap: 16px; padding: 0 24px; flex-wrap: wrap; }
.snap-site-footer__bar p { margin: 0; }

@media (max-width: 900px) {
  .snap-site-footer__grid { grid-template-columns: 1fr 1fr; gap: 32px; padding: 48px 24px 32px; }
  .snap-site-footer__col--brand { grid-column: 1 / -1; }
}
@media (max-width: 520px) {
  .snap-site-footer__grid { grid-template-columns: 1fr; }
}
