/* SJP Bar Association Management System — marketing site. SJP navy/gold theme. */
:root{
  --navy:#0f172a; --navy-2:#111c33; --navy-3:#1b2942; --line:#1f2d4a;
  --gold:#c9a227; --gold-2:#e0b94a; --ink:#0f172a; --muted:#5b6b86;
  --paper:#f7f9fc; --white:#fff; --soft:#eef2f8;
  --container:1180px; --radius:14px;
  --shadow:0 10px 30px rgba(15,23,42,.08); --shadow-lg:0 24px 60px rgba(15,23,42,.16);
  --t:all .2s cubic-bezier(.4,0,.2,1);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Inter',-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--white);line-height:1.6;overflow-x:hidden;max-width:100vw}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{line-height:1.18;margin:0 0 .4em;font-weight:800;letter-spacing:-.02em}
p{margin:0 0 1em}
.container{max-width:var(--container);margin:0 auto;padding:0 22px}
.text-gold{color:var(--gold)}
.center{text-align:center}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:.5em;border:1px solid transparent;border-radius:10px;padding:13px 26px;font-weight:700;font-size:15px;cursor:pointer;transition:var(--t);white-space:nowrap}
.btn-sm{padding:9px 18px;font-size:14px}
.btn-primary{background:var(--gold);color:var(--navy)}
.btn-primary:hover{background:var(--gold-2);transform:translateY(-1px);box-shadow:0 8px 22px rgba(201,162,39,.35)}
.btn-dark{background:var(--navy);color:#fff}
.btn-dark:hover{background:var(--navy-3);transform:translateY(-1px)}
.btn-ghost{background:transparent;border-color:rgba(255,255,255,.25);color:#fff}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}
.btn-ghost-d{background:transparent;border-color:var(--line);color:var(--navy)}
.btn-ghost-d:hover{border-color:var(--gold);color:var(--gold)}

/* Header */
.site-header{position:sticky;top:0;z-index:1000;background:rgba(15,23,42,.92);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.07)}
.site-header.scrolled{box-shadow:0 6px 24px rgba(0,0,0,.25)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:18px;height:70px}
.brand{display:flex;align-items:center;gap:10px;color:#fff;font-weight:800}
.brand img{height:38px}
.brand small{display:block;font-size:11px;font-weight:600;color:var(--gold);letter-spacing:.04em}
.nav-links{display:flex;gap:26px;list-style:none;margin:0;padding:0}
.nav-links a{color:#cdd8ea;font-size:15px;font-weight:500;transition:var(--t)}
.nav-links a:hover{color:var(--gold)}
.nav-cta{display:flex;align-items:center;gap:10px}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;width:38px;height:38px;flex-direction:column;justify-content:center;gap:5px}
.nav-toggle span{display:block;height:2px;background:#fff;border-radius:2px;transition:var(--t)}

/* Hero */
.hero{position:relative;background:radial-gradient(1200px 500px at 70% -10%,rgba(201,162,39,.18),transparent),linear-gradient(180deg,var(--navy),var(--navy-2));color:#fff;padding:84px 0 90px;overflow:hidden}
.hero:after{content:"";position:absolute;inset:0;background:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="40" height="40"><path d="M0 39.5H40M39.5 0V40" stroke="%23ffffff" stroke-opacity="0.03"/></svg>');pointer-events:none}
.hero .container{position:relative;z-index:1;max-width:880px;text-align:center}
.eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(201,162,39,.12);border:1px solid rgba(201,162,39,.3);color:var(--gold);padding:7px 16px;border-radius:30px;font-size:13px;font-weight:600;margin-bottom:22px}
.hero h1{font-size:clamp(32px,5vw,54px);color:#fff;margin-bottom:18px}
.hero h1 .text-gold{background:linear-gradient(90deg,var(--gold),var(--gold-2));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero .lead{font-size:clamp(16px,2.2vw,20px);color:#b8c4da;max-width:680px;margin:0 auto 30px}
.hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.hero-trust{margin-top:34px;color:#8295b3;font-size:14px}
.hero-trust b{color:#dbe4f3}

/* Sections */
.section{padding:78px 0}
.section.bg-light{background:var(--paper)}
.section.bg-navy{background:linear-gradient(180deg,var(--navy-2),var(--navy));color:#fff}
.section-head{max-width:680px;margin:0 auto 50px;text-align:center}
.section-head .eyebrow{color:var(--gold);background:rgba(201,162,39,.1);border-color:rgba(201,162,39,.25)}
.section-head h2{font-size:clamp(26px,3.5vw,40px)}
.section.bg-navy .section-head h2,.section.bg-navy h3{color:#fff}
.section-head p{color:var(--muted);font-size:17px}
.section.bg-navy .section-head p{color:#b8c4da}

/* Feature grid */
.grid{display:grid;gap:22px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--white);border:1px solid var(--soft);border-radius:var(--radius);padding:30px 26px;transition:var(--t)}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:rgba(201,162,39,.4)}
.card .ico{width:50px;height:50px;border-radius:12px;background:linear-gradient(135deg,var(--navy),var(--navy-3));color:var(--gold);display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:16px}
.card h3{font-size:19px;margin-bottom:8px}
.card p{color:var(--muted);font-size:15px;margin:0}

/* Steps */
.steps{counter-reset:s;display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.step{position:relative;padding:28px 22px;background:var(--white);border:1px solid var(--soft);border-radius:var(--radius)}
.step:before{counter-increment:s;content:counter(s);position:absolute;top:-16px;left:22px;width:36px;height:36px;border-radius:50%;background:var(--gold);color:var(--navy);font-weight:800;display:flex;align-items:center;justify-content:center}
.step h3{font-size:17px;margin:12px 0 6px}
.step p{color:var(--muted);font-size:14px;margin:0}

/* Pricing */
.price-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;align-items:stretch}
.plan{background:var(--white);border:1px solid var(--soft);border-radius:var(--radius);padding:26px 20px;display:flex;flex-direction:column;text-align:center}
.plan.featured{border-color:var(--gold);box-shadow:var(--shadow-lg);position:relative}
.plan.featured:before{content:"Popular";position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--gold);color:var(--navy);font-size:12px;font-weight:700;padding:4px 14px;border-radius:20px}
.plan h3{font-size:18px}
.plan .price{font-size:30px;font-weight:800;color:var(--navy);margin:8px 0 2px}
.plan .price small{font-size:14px;color:var(--muted);font-weight:600}
.plan .meta{color:var(--muted);font-size:13px;min-height:38px}
.plan ul{list-style:none;padding:0;margin:18px 0;text-align:left;font-size:14px;color:#33415c}
.plan li{padding:6px 0 6px 24px;position:relative}
.plan li:before{content:"\2713";position:absolute;left:0;color:var(--gold);font-weight:800}
.plan .btn{margin-top:auto;justify-content:center}

/* CTA band */
.cta-band{background:linear-gradient(120deg,var(--navy),var(--navy-3));color:#fff;border-radius:20px;padding:54px 40px;text-align:center}
.cta-band h2{font-size:clamp(24px,3vw,34px);color:#fff}
.cta-band p{color:#b8c4da;max-width:560px;margin:0 auto 26px}

/* Footer */
.site-footer{background:var(--navy);color:#aebbd2;padding:60px 0 26px;border-top:1px solid var(--line)}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:34px;margin-bottom:36px}
.footer-brand img{height:40px;margin-bottom:12px}
.footer-brand p{font-size:14px;color:#8295b3;max-width:300px}
.footer-col h4{color:#fff;font-size:15px;margin-bottom:14px}
.footer-col ul{list-style:none;padding:0;margin:0}
.footer-col li{margin-bottom:9px}
.footer-col a{color:#aebbd2;font-size:14px;transition:var(--t)}
.footer-col a:hover{color:var(--gold)}
.footer-bottom{border-top:1px solid var(--line);padding-top:22px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:13px;color:#7d8ba6}
.footer-bottom a{color:var(--gold)}

/* Forms (signup) */
.form-wrap{max-width:680px;margin:0 auto;background:var(--white);border:1px solid var(--soft);border-radius:18px;padding:38px 34px;box-shadow:var(--shadow)}
.field{margin-bottom:18px}
.field label{display:block;font-weight:600;font-size:14px;margin-bottom:6px;color:#33415c}
.field input,.field textarea,.field select{width:100%;border:1px solid #d7deea;border-radius:10px;padding:12px 14px;font-size:15px;font-family:inherit;transition:var(--t)}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,162,39,.15)}
.field .hint{font-size:12.5px;color:var(--muted);margin-top:4px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.alert{padding:14px 16px;border-radius:10px;margin-bottom:18px;font-size:14px}
.alert-ok{background:#e9f8ef;border:1px solid #b7e6c9;color:#1a7f43}
.alert-err{background:#fde9e9;border:1px solid #f3bcbc;color:#b3261e}
.hp{position:absolute;left:-9999px}

/* scroll reveal */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:none}

@media(max-width:980px){
  .grid-3,.grid-4,.steps,.price-grid,.footer-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  .nav-links{position:fixed;inset:70px 0 auto 0;background:var(--navy-2);flex-direction:column;gap:0;padding:10px 22px 20px;transform:translateY(-150%);transition:var(--t);border-bottom:1px solid var(--line)}
  .nav-links.open{transform:translateY(0)}
  .nav-links li{border-bottom:1px solid rgba(255,255,255,.06)}
  .nav-links a{display:block;padding:14px 0}
  .nav-toggle{display:flex}
  .nav-cta .hide-sm{display:none}
  .grid-3,.grid-4,.steps,.price-grid,.grid-2,.field-row,.footer-grid{grid-template-columns:1fr}
  .section{padding:56px 0}
  .cta-band{padding:40px 24px}
  .footer-bottom{flex-direction:column}
}
