/* =========================================================
   Ride Junto — SEO landing page stylesheet
   Brand-consistent subset of homepage styles
   ========================================================= */

:root{
  --navy:#0d2b45;
  --navy-2:#173b5e;
  --yellow:#ffd000;
  --yellow-2:#ffdb33;
  --paper:#fffbf3;
  --paper-2:#f6f2e6;
  --ink:#0d2b45;
  --ink-soft:#3a4a5d;
  --ink-mute:#6b7a8a;
  --line:#e6dfcc;
  --line-soft:#efe8d5;
  --green:#22c55e;
  --blue:#3b82f6;
  --radius:14px;
  --radius-lg:22px;
  --shadow-sm:0 2px 6px rgba(13,43,69,.08);
  --shadow-md:0 12px 30px -12px rgba(13,43,69,.18);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:'Nunito',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  font-size:16px;line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
h1,h2,h3,h4{font-family:'Varela Round',sans-serif;color:var(--navy);line-height:1.18;margin:0 0 .5em}
h1{font-size:clamp(2rem,4.4vw,3.4rem);letter-spacing:-.5px}
h2{font-size:clamp(1.5rem,2.6vw,2.1rem);letter-spacing:-.3px}
h3{font-size:1.18rem}
p{margin:0 0 1em;color:var(--ink-soft)}
a{color:var(--navy);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;height:auto;display:block}

.container{max-width:1140px;margin:0 auto;padding:0 24px}

/* ====== Header / Nav (matches homepage) ====== */
.nav{
  position:sticky;top:0;z-index:50;
  backdrop-filter:saturate(180%) blur(10px);
  background:rgba(251,250,246,.85);
  border-bottom:1px solid rgba(13,43,69,.06);
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding-block:14px;
}
.logo-nav{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'Varela Round',sans-serif;font-size:1.25rem;color:var(--navy);
  text-decoration:none;
}
.logo-nav:hover{text-decoration:none}
.logo-nav .mark{width:42px;height:24px;flex:none}
.logo-nav .word{display:inline-flex;align-items:baseline;gap:1px}
.logo-nav .word span:last-child{color:#c79f00}
.nav-links{display:flex;align-items:center;gap:32px}
.nav-links a{font-weight:600;color:var(--navy);font-size:.95rem;text-decoration:none}
.nav-links a:hover{color:var(--navy);text-decoration:underline}
.nav-cta{display:flex;align-items:center;gap:10px}
.nav-join{
  font-size:.88rem;padding:.6em 1.1em;
  background:var(--yellow);color:var(--navy);border:2px solid var(--navy);
  border-radius:999px;font-family:'Nunito',sans-serif;font-weight:800;
  text-decoration:none;
  transition:transform .15s ease;
}
.nav-join:hover{text-decoration:none;transform:translateY(-1px)}
.menu-toggle{display:none;background:transparent;border:0;padding:8px;cursor:pointer}
.menu-toggle svg{width:26px;height:26px;color:var(--navy)}

/* ====== Hero ====== */
.hero{
  padding:48px 0 56px;
  background:linear-gradient(180deg,var(--paper) 0%,var(--paper-2) 100%);
  border-bottom:1px solid var(--line-soft);
}
.crumb{
  font-size:.82rem;color:var(--ink-mute);
  margin:0 0 16px;
}
.crumb a{color:var(--ink-mute)}
.crumb a:hover{color:var(--navy)}
.crumb .sep{margin:0 6px;opacity:.5}
.state-tag{
  display:inline-block;
  background:rgba(13,43,69,.08);color:var(--navy);
  font-family:'Varela Round',sans-serif;font-size:.78rem;
  letter-spacing:.18em;text-transform:uppercase;
  padding:6px 14px;border-radius:999px;
  margin-bottom:18px;
}
.hero h1{margin-bottom:16px;max-width:18ch}
.hero .lead{
  font-size:1.13rem;color:var(--ink-soft);
  max-width:62ch;margin-bottom:28px;
}
.hero-cta-row{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:.85em 1.5em;border-radius:999px;
  font-family:'Nunito',sans-serif;font-weight:800;font-size:.98rem;
  text-decoration:none;border:2px solid transparent;cursor:pointer;
  transition:transform .15s ease,box-shadow .15s ease;
}
.btn-primary{background:var(--yellow);color:var(--navy);border-color:var(--navy)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:var(--shadow-md);text-decoration:none}
.btn-ghost{background:transparent;color:var(--navy);border-color:var(--navy)}
.btn-ghost:hover{background:var(--navy);color:var(--paper);text-decoration:none}
.micro{
  margin:14px 0 0;font-size:.82rem;color:var(--ink-mute);
}

/* ====== Sections ====== */
section{padding:48px 0}
.section-eyebrow{
  font-family:'Varela Round',sans-serif;font-size:.78rem;font-weight:700;
  letter-spacing:.2em;color:var(--ink-mute);text-transform:uppercase;
  margin:0 0 12px;
}
.section-h{margin-bottom:14px}
.section-lead{
  color:var(--ink-soft);font-size:1.05rem;max-width:62ch;margin:0 0 28px;
}

/* ====== Why-this-city 3-card grid ====== */
.why-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;
  margin-top:8px;
}
.why-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:26px 24px;
}
.why-card h3{margin:8px 0 10px;font-size:1.1rem}
.why-card p{margin:0;color:var(--ink-soft)}
.why-stat{
  font-family:'Varela Round',sans-serif;font-size:1.45rem;color:var(--navy);
}

/* ====== How it works compact ====== */
.how-compact{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:32px 28px;
}
.how-compact ol{
  list-style:none;padding:0;margin:0;
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;
  counter-reset:step;
}
.how-compact li{
  position:relative;padding-left:36px;
  counter-increment:step;
}
.how-compact li::before{
  content:counter(step);
  position:absolute;left:0;top:-2px;
  width:26px;height:26px;border-radius:50%;
  background:var(--navy);color:var(--yellow);
  font-family:'Varela Round',sans-serif;font-weight:700;font-size:.95rem;
  display:grid;place-items:center;
}
.how-compact h4{margin:0 0 4px;font-size:1rem;font-family:'Varela Round',sans-serif;color:var(--navy)}
.how-compact p{margin:0;font-size:.92rem;color:var(--ink-soft)}

/* ====== Coverage suburb pills ====== */
.coverage-pills{
  display:flex;flex-wrap:wrap;gap:10px;margin-top:8px;
}
.pill{
  display:inline-block;
  background:#fff;border:1.5px solid var(--line);
  padding:8px 16px;border-radius:999px;
  font-size:.92rem;font-weight:700;color:var(--navy);
}

/* ====== Popular routes cards ====== */
.routes-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:14px;
  margin-top:8px;
}
.route-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:22px 22px;
}
.route-from{font-size:.85rem;color:var(--ink-mute);margin:0 0 2px}
.route-to{
  font-family:'Varela Round',sans-serif;font-size:1.18rem;color:var(--navy);
  margin:0 0 12px;
}
.route-meta{
  display:flex;justify-content:space-between;align-items:center;
  font-size:.88rem;color:var(--ink-mute);
  padding-top:12px;border-top:1px solid var(--line-soft);
  margin-top:8px;
}
.route-cost{
  font-family:'Varela Round',sans-serif;color:var(--green);font-weight:700;
}

/* ====== Trust strip ====== */
.trust-strip{
  background:var(--navy);color:#fff;
  padding:40px 0;border-radius:var(--radius-lg);
  margin-top:8px;
}
.trust-strip .container{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.trust-strip h2{color:#fff;font-size:1.4rem;margin-bottom:18px}
.trust-item h4{color:var(--yellow);font-size:1rem;margin:0 0 4px;font-family:'Varela Round',sans-serif}
.trust-item p{color:rgba(255,255,255,.8);font-size:.92rem;margin:0}

/* ====== FAQ ====== */
.faq-list{display:flex;flex-direction:column;gap:10px;margin-top:8px}
.qa{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:18px 22px;
}
.qa summary{
  cursor:pointer;font-weight:800;color:var(--navy);
  font-family:'Varela Round',sans-serif;font-size:1.02rem;
  list-style:none;
}
.qa summary::-webkit-details-marker{display:none}
.qa summary::after{
  content:'+';float:right;color:var(--ink-mute);
  font-weight:400;font-size:1.4rem;line-height:1;
  transition:transform .2s ease;
}
.qa[open] summary::after{transform:rotate(45deg)}
.qa p{margin:14px 0 0;color:var(--ink-soft)}

/* ====== Further reading ====== */
.further-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:14px;
  margin-top:8px;
}
.further-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:22px;text-decoration:none;color:inherit;
  transition:transform .15s ease,box-shadow .15s ease;
  display:block;
}
.further-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);text-decoration:none}
.further-card .further-eyebrow{
  font-family:'Varela Round',sans-serif;font-size:.74rem;font-weight:700;
  letter-spacing:.2em;color:var(--ink-mute);text-transform:uppercase;
  margin:0 0 8px;
}
.further-card h3{margin:0 0 8px;font-size:1.05rem;color:var(--navy)}
.further-card p{margin:0;font-size:.9rem;color:var(--ink-soft)}
.further-card .further-arrow{
  display:inline-block;margin-top:10px;color:var(--navy);
  font-weight:800;font-size:.88rem;
}

/* ====== Signup form ====== */
.signup-block{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:36px 32px;text-align:center;
}
.signup-block h2{margin-bottom:8px}
.signup-block .signup-lead{margin:0 0 22px;color:var(--ink-soft)}
.signup-form{
  display:grid;grid-template-columns:1fr 1fr 140px auto;gap:10px;
  max-width:760px;margin:0 auto;
  align-items:stretch;
}
.signup-form input{
  padding:.85em 1em;border:1.5px solid var(--line);border-radius:999px;
  font-family:'Nunito',sans-serif;font-size:.95rem;color:var(--navy);
  background:#fff;outline:none;
  transition:border-color .15s ease,box-shadow .15s ease;
}
.signup-form input:focus{border-color:var(--navy);box-shadow:0 0 0 3px rgba(13,43,69,.1)}
.signup-form button{
  background:var(--yellow);color:var(--navy);border:2px solid var(--navy);
  padding:.85em 1.6em;border-radius:999px;
  font-family:'Nunito',sans-serif;font-weight:800;font-size:.95rem;
  cursor:pointer;
  transition:transform .15s ease;
}
.signup-form button:hover{transform:translateY(-1px)}
.signup-success{
  display:none;background:rgba(34,197,94,.1);border:1.5px solid var(--green);
  color:var(--navy);padding:18px 22px;border-radius:var(--radius);
  font-weight:700;
}
.signup-block.is-success .signup-form{display:none}
.signup-block.is-success .signup-success{display:block}
.signup-fineprint{
  margin-top:14px;font-size:.82rem;color:var(--ink-mute);
}

/* ====== Footer (matches homepage) ====== */
footer{
  background:var(--paper);
  padding:54px 0 40px;margin-top:60px;
  font-size:.92rem;color:var(--ink-soft);
  border-top:1px solid var(--line);
}
.foot-seo{
  margin-bottom:34px;padding-bottom:26px;border-bottom:1px solid var(--line);
}
.foot-seo h5{
  font-family:'Varela Round',sans-serif;font-size:.78rem;color:var(--ink-mute);
  text-transform:uppercase;letter-spacing:.16em;margin:0 0 10px;font-weight:700;
}
.foot-seo h5:not(:first-child){margin-top:16px}
.foot-seo ul{
  list-style:none;padding:0;margin:0;
  display:flex;flex-wrap:wrap;gap:8px 22px;font-size:.94rem;
}
.foot-seo a{color:var(--ink-soft);text-decoration:none}
.foot-seo a:hover{color:var(--navy);text-decoration:underline}
.foot-grid{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px;
}
.foot-grid h4{
  font-family:'Varela Round',sans-serif;font-size:.95rem;color:var(--navy);
  margin-bottom:14px;text-transform:uppercase;letter-spacing:.06em;
}
.foot-grid ul{list-style:none;padding:0;margin:0;display:grid;gap:8px}
.foot-grid a{color:var(--ink-soft);text-decoration:none}
.foot-grid a:hover{color:var(--navy)}
.foot-bottom{
  margin-top:38px;padding-top:22px;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;
  font-size:.85rem;color:var(--ink-mute);
}

/* ====== Responsive ====== */
@media (max-width:920px){
  .why-grid,.routes-grid,.further-grid{grid-template-columns:1fr 1fr}
  .how-compact ol{grid-template-columns:1fr 1fr}
  .trust-strip .container{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr 1fr;gap:28px}
  .signup-form{grid-template-columns:1fr 1fr;}
  .signup-form button{grid-column:1 / -1}
}
@media (max-width:640px){
  section{padding:36px 0}
  .hero{padding:32px 0 40px}
  .why-grid,.routes-grid,.further-grid{grid-template-columns:1fr}
  .how-compact{padding:26px 22px}
  .how-compact ol{grid-template-columns:1fr;gap:20px}
  .trust-strip .container{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .signup-form{grid-template-columns:1fr}
  .signup-form button{grid-column:auto}
  .nav-links{display:none}
  .nav-join{font-size:.86rem;padding:.5em 1em}
  .logo-nav{font-size:1.1rem}
  .logo-nav .mark{width:36px;height:22px}
}
