﻿/* ============================================================================
   PostMarshal — public marketing site
   Brand tokens from GetMarley_Brand_Pack.html (v1, June 2026). Do not invent
   colours or type outside the pack.
   ========================================================================== */

:root{
  --gm-green:      #178A6E;
  --gm-green-deep: #0F6651;
  --gm-amber:      #F3A24B;
  --gm-amber-soft: #FFD9A8;
  --gm-ink:        #1C2B2D;
  --gm-paper:      #FBF8F2;
  --gm-mist:       #E7EFEA;
  --gm-muted:      #5E6E6A;
  --gm-line:       #D8DFD9;

  --font-display: 'Fraunces', Georgia, serif;
  --font-body: 'Inter', system-ui, -apple-system, sans-serif;
  --font-mono: 'JetBrains Mono', ui-monospace, monospace;

  --wrap: 1080px;
  --radius: 14px;
}

*{ box-sizing: border-box; margin: 0; padding: 0; }

html{ scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior: auto; }
  *, *::before, *::after{ animation: none !important; transition: none !important; }
}

body{
  overflow-x: clip;
  font-family: var(--font-body);
  background: var(--gm-paper);
  color: var(--gm-ink);
  line-height: 1.6;
  font-size: 17px;
  -webkit-font-smoothing: antialiased;
}

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

::selection{ background: var(--gm-amber-soft); color: var(--gm-ink); }

a{ color: var(--gm-green-deep); }
a:focus-visible, button:focus-visible{
  outline: 3px solid var(--gm-green);
  outline-offset: 3px;
  border-radius: 4px;
}

h1, h2, .display{
  font-family: var(--font-display);
  font-weight: 500;
  letter-spacing: -0.02em;
  line-height: 1.05;
}

/* --- Header ---------------------------------------------------------------- */
.site-head{
  border-bottom: 1px solid var(--gm-line);
  background: rgba(251,248,242,0.92);
  backdrop-filter: blur(6px);
  position: sticky; top: 0; z-index: 20;
}
.site-head .wrap{
  display: flex; align-items: center; gap: 28px;
  padding-top: 16px; padding-bottom: 16px;
}
.brand{
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--font-display); font-weight: 600; font-size: 23px;
  letter-spacing: -0.02em; color: var(--gm-ink); text-decoration: none;
}
/* Wordmark is SOLID single colour (ink in the lockup; the #gm-mark carries the green+amber). The
   former two-tone .get rule is retired — the colour break made the one-word name read as two. */
.nav-links{ margin-left: auto; display: flex; align-items: center; gap: 22px; flex-wrap: wrap; }
.nav-links a{
  color: var(--gm-muted); text-decoration: none; font-size: 15px; font-weight: 500;
}
.nav-links a:hover{ color: var(--gm-ink); }
.nav-cta{
  background: var(--gm-green); color: #fff !important; font-weight: 600;
  padding: 9px 18px; border-radius: 10px;
}
.nav-cta:hover{ background: var(--gm-green-deep); }
@media (max-width: 720px){
  .nav-links a:not(.nav-cta){ display: none; }
}

/* --- Buttons ---------------------------------------------------------------- */
.btn{
  display: inline-flex; align-items: center; justify-content: center; gap: 9px;
  font-family: var(--font-body); font-weight: 600; font-size: 16.5px;
  padding: 14px 26px; border-radius: 11px; border: none; cursor: pointer;
  text-decoration: none; transition: transform .15s ease, background .15s ease, box-shadow .15s ease;
}
.btn-warm{ background: var(--gm-amber); color: var(--gm-ink); box-shadow: 0 2px 0 rgba(28,43,45,.18); }
.btn-warm:hover{ transform: translateY(-1px); box-shadow: 0 4px 10px rgba(28,43,45,.14); }
.btn-green{ background: var(--gm-green); color: #fff; }
.btn-green:hover{ background: var(--gm-green-deep); }
.btn-ghost{ background: transparent; color: var(--gm-green-deep); border: 1.5px solid var(--gm-green); }
.btn-ghost:hover{ background: var(--gm-mist); }

/* --- Hero -------------------------------------------------------------------- */
.hero{ padding: 88px 0 84px; overflow: hidden; }
.hero .wrap{
  display: grid; grid-template-columns: minmax(0, 11fr) minmax(0, 9fr);
  gap: 56px; align-items: center;
}
.eyebrow{
  font-family: var(--font-mono); font-size: 12.5px; font-weight: 500;
  letter-spacing: .14em; text-transform: uppercase; color: var(--gm-green);
  margin-bottom: 22px;
}
.hero h1{ font-size: clamp(42px, 6vw, 66px); margin-bottom: 22px; }
.hero h1 em{ font-style: italic; font-weight: 600; color: var(--gm-green-deep); }
.hero .promise{
  font-size: 19px; color: var(--gm-muted); max-width: 34em; margin-bottom: 34px;
}
.hero .ctas{ display: flex; gap: 14px; flex-wrap: wrap; align-items: center; }
.hero .ctas .quiet-note{ font-size: 13.5px; color: var(--gm-muted); flex-basis: 100%; margin-top: 10px; }

/* staggered load — progressive enhancement: content is VISIBLE by default and only
   animates where motion is allowed (so nothing can ever be stuck hidden) */
@keyframes rise{ from{ opacity: 0; transform: translateY(14px); } to{ opacity: 1; transform: none; } }
@media (prefers-reduced-motion: no-preference){
  .rise{ animation: rise .6s cubic-bezier(.2,.7,.3,1) both; }
  .rise-1{ animation-delay: .05s; } .rise-2{ animation-delay: .15s; }
  .rise-3{ animation-delay: .25s; } .rise-4{ animation-delay: .4s; }
}

/* the hero "magic" panel: spoken sentence -> programme */
.magic{
  position: relative;
  display: flex; flex-direction: column; gap: 14px;
}
.speech{
  position: relative;
  background: #fff; border: 1px solid var(--gm-line); border-radius: 16px;
  padding: 18px 20px 16px;
  font-family: var(--font-display); font-size: 19px; font-weight: 500;
  line-height: 1.35; color: var(--gm-ink);
  box-shadow: 0 6px 22px rgba(28,43,45,.06);
}
.speech .who{
  display: block; font-family: var(--font-mono); font-size: 11px;
  letter-spacing: .12em; text-transform: uppercase; color: var(--gm-muted);
  margin-bottom: 7px; font-weight: 500;
}
.speech::after{ /* bubble tail */
  content: ""; position: absolute; left: 36px; bottom: -10px;
  width: 18px; height: 18px; background: #fff;
  border-right: 1px solid var(--gm-line); border-bottom: 1px solid var(--gm-line);
  transform: rotate(45deg) skew(8deg, 8deg);
}
.flow-arrow{
  align-self: center; color: var(--gm-green); display: flex; align-items: center; gap: 8px;
  font-family: var(--font-mono); font-size: 11.5px; letter-spacing: .12em;
  text-transform: uppercase; font-weight: 500; padding: 2px 0;
}
.plan{
  background: #fff; border: 1px solid var(--gm-line); border-radius: 16px;
  overflow: hidden; box-shadow: 0 10px 30px rgba(28,43,45,.07);
}
.plan .plan-head{
  display: flex; align-items: center; gap: 9px;
  background: var(--gm-ink); color: #fff;
  font-family: var(--font-mono); font-size: 11.5px; letter-spacing: .12em;
  text-transform: uppercase; padding: 11px 16px;
}
.plan .plan-head .dotsep{ color: var(--gm-amber); }
.plan ul{ list-style: none; }
.plan li{
  display: flex; gap: 12px; align-items: baseline;
  padding: 13px 16px; border-bottom: 1px solid var(--gm-line); font-size: 14.5px; flex-wrap: wrap;
}
.plan li:last-child{ border-bottom: none; }
.plan .when{
  font-family: var(--font-mono); font-size: 12px; color: var(--gm-green-deep);
  white-space: nowrap; font-weight: 500; min-width: 86px;
}
.plan .chip{
  margin-left: auto; font-family: var(--font-mono); font-size: 10px;
  letter-spacing: .08em; color: var(--gm-green-deep);
  background: var(--gm-mist); border-radius: 999px; padding: 3px 9px; white-space: nowrap;
}
.plan .chip.amber{ background: var(--gm-amber-soft); color: var(--gm-ink); }

/* Marshal sits beside the bubble */
.hero-marshal{
  position: absolute; right: -8px; top: -74px; width: 118px; height: 118px;
  display: flex; align-items: center; justify-content: center;
}
@media (max-width: 980px){
  .hero .wrap{ grid-template-columns: minmax(0, 1fr); gap: 44px; }
  .hero-marshal{ top: -66px; right: 4px; width: 104px; height: 104px; }
  .hero{ padding-top: 56px; }
  .magic{ margin-top: 76px; }
}

/* --- Sections (shared) -------------------------------------------------------- */
section{ padding: 84px 0; }
.sec-eyebrow{
  font-family: var(--font-mono); font-size: 12px; font-weight: 500;
  letter-spacing: .14em; text-transform: uppercase; color: var(--gm-green);
  margin-bottom: 14px;
}
section h2{ font-size: clamp(30px, 4vw, 42px); margin-bottom: 16px; }
.sec-lead{ font-size: 18px; color: var(--gm-muted); max-width: 38em; }

/* --- How it works ---------------------------------------------------------------- */
.how{ border-top: 1px solid var(--gm-line); }
.steps{
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; margin-top: 46px;
}
.step{
  background: #fff; border: 1px solid var(--gm-line); border-radius: var(--radius);
  padding: 26px 24px 28px;
}
.step .n{
  font-family: var(--font-mono); font-size: 12.5px; color: var(--gm-green);
  letter-spacing: .1em; font-weight: 500; display: block; margin-bottom: 14px;
}
.step h3{
  font-family: var(--font-display); font-weight: 500; font-size: 24px;
  letter-spacing: -0.01em; margin-bottom: 10px;
}
.step p{ font-size: 15.5px; color: var(--gm-muted); }
@media (max-width: 860px){ .steps{ grid-template-columns: minmax(0, 1fr); } }

/* --- Why it's different (the honesty moat) — the one dark moment ------------------- */
.why{ background: var(--gm-ink); color: #fff; }
.why .sec-eyebrow{ color: var(--gm-amber); }
.why h2{ color: #fff; }
.why .sec-lead{ color: rgba(255,255,255,.72); }
.moat{
  display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin-top: 44px;
}
.moat-card{
  border: 1px solid rgba(255,255,255,.16); border-radius: var(--radius);
  padding: 24px 24px 26px; background: rgba(255,255,255,.03);
}
.moat-card h3{
  font-family: var(--font-display); font-weight: 500; font-size: 22px;
  margin-bottom: 9px; color: #fff;
}
.moat-card p{ font-size: 15px; color: rgba(255,255,255,.72); }
.moat-card.keystone{
  background: rgba(243,162,75,.1); border-color: var(--gm-amber);
}
.moat-card.keystone h3{ color: var(--gm-amber); }
.moat-card.keystone p{ color: rgba(255,255,255,.85); }
.why .proof{
  margin-top: 34px; border-left: 3px solid var(--gm-amber);
  padding: 8px 0 8px 18px; max-width: 44em;
}
.why .proof .says{
  font-family: var(--font-mono); font-size: 11.5px; letter-spacing: .12em;
  text-transform: uppercase; color: var(--gm-amber); display: block; margin-bottom: 6px;
}
.why .proof q{
  font-family: var(--font-display); font-size: 19px; line-height: 1.45; color: #fff;
}
@media (max-width: 860px){ .moat{ grid-template-columns: minmax(0, 1fr); } }

/* --- Who it's for ----------------------------------------------------------------- */
.who-for .inner{
  display: grid; grid-template-columns: minmax(0, 7fr) minmax(0, 4fr);
  gap: 52px; align-items: center;
}
.trades{ display: flex; flex-wrap: wrap; gap: 9px; margin-top: 26px; }
.trade{
  font-family: var(--font-mono); font-size: 12.5px; color: var(--gm-green-deep);
  background: var(--gm-mist); border-radius: 999px; padding: 6px 13px;
}
.who-marshal{ display: flex; justify-content: center; }
@media (max-width: 860px){
  .who-for .inner{ grid-template-columns: minmax(0, 1fr); gap: 36px; }
  .who-marshal{ order: -1; }
  .who-marshal svg{ width: 150px; height: auto; }
}

/* --- Early access ------------------------------------------------------------------- */
.early{ border-top: 1px solid var(--gm-line); }
.early .panel{
  background: var(--gm-mist); border-radius: 20px; padding: 56px 48px;
  display: grid; grid-template-columns: minmax(0, 8fr) minmax(0, 4fr);
  gap: 40px; align-items: center;
}
.early .small-print{ font-size: 13.5px; color: var(--gm-muted); margin-top: 18px; max-width: 36em; }
.early-marshal{ display: flex; justify-content: center; }
@media (max-width: 860px){
  .early .panel{ grid-template-columns: minmax(0, 1fr); padding: 40px 28px; }
  .early-marshal{ display: none; }
}

/* --- Footer ----------------------------------------------------------------------------- */
.site-foot{ background: var(--gm-ink); color: rgba(255,255,255,.7); padding: 52px 0 44px; }
.site-foot .top{
  display: flex; align-items: flex-start; gap: 28px; flex-wrap: wrap;
  padding-bottom: 30px; border-bottom: 1px solid rgba(255,255,255,.14); margin-bottom: 26px;
}
.site-foot .brand{ color: #fff; }
.site-foot .tagline{ font-size: 14.5px; max-width: 26em; }
.site-foot .links{ margin-left: auto; display: flex; gap: 22px; flex-wrap: wrap; }
.site-foot .links a{ color: rgba(255,255,255,.78); text-decoration: none; font-size: 14.5px; }
.site-foot .links a:hover{ color: #fff; }
.site-foot .legal{ font-size: 13px; color: rgba(255,255,255,.5); }
@media (max-width: 720px){ .site-foot .links{ margin-left: 0; } }

/* --- Legal / document pages -------------------------------------------------------------- */
.doc{ padding: 64px 0 90px; }
.doc .wrap{ max-width: 760px; }
.doc h1{ font-size: clamp(34px, 5vw, 46px); margin-bottom: 8px; }
.doc .updated{
  font-family: var(--font-mono); font-size: 13px; color: var(--gm-muted); margin-bottom: 36px;
}
.doc h2{
  font-size: 24px; margin: 40px 0 12px; font-weight: 500;
}
.doc p{ margin-bottom: 14px; color: var(--gm-ink); }
.doc ul{ margin: 0 0 16px 22px; }
.doc li{ margin-bottom: 9px; }
.doc .callout{
  background: var(--gm-mist); border-left: 4px solid var(--gm-green);
  border-radius: 10px; padding: 18px 20px; margin: 26px 0; font-size: 15.5px;
}
