/* AGM Advisory — Stripe-grade design system.
   Tokens mirror stripe.com: blurple #635BFF, navy #0A2540, slate #425466,
   aurora gradient hero, skewed section dividers, generous whitespace. */
:root{
  --blurple:#635BFF; --blurple-d:#5249e0;
  --navy:#0A2540; --slate:#425466; --ink:#1a2b42;
  --bg:#ffffff; --soft:#f6f9fc; --line:#e6ebf1; --radius:18px;
  --shadow-sm:0 2px 5px -1px rgba(50,50,93,.12),0 1px 3px -1px rgba(0,0,0,.07);
  --shadow:0 50px 100px -20px rgba(50,50,93,.25),0 30px 60px -30px rgba(0,0,0,.30);
  --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--font);line-height:1.6;-webkit-font-smoothing:antialiased;letter-spacing:-.01em}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{margin:0;letter-spacing:-.025em;line-height:1.1;color:var(--navy)}
p{margin:0}
.eyebrow{text-transform:uppercase;letter-spacing:.1em;font-size:13px;font-weight:700;color:var(--blurple);margin:0 0 16px}
.center{text-align:center}
h2{font-size:clamp(28px,3.6vw,40px);margin-bottom:16px}
.section{max-width:1080px;margin:auto;padding:96px 24px}
.section>h2,.section>.eyebrow{max-width:680px}
.section.center>h2,.section.center>.eyebrow{margin-inline:auto}

/* buttons — Stripe pill, subtle lift */
.btn{display:inline-flex;align-items:center;gap:7px;background:var(--blurple);color:#fff;font-weight:600;font-size:15px;padding:11px 20px;border:0;border-radius:999px;cursor:pointer;transition:transform .12s ease,background .12s ease,box-shadow .12s ease;box-shadow:var(--shadow-sm)}
.btn:hover{background:var(--blurple-d);transform:translateY(-1px) scale(1.015)}
.btn::after{content:"→";font-weight:500;transition:transform .12s ease}
.btn:hover::after{transform:translateX(3px)}
.btn-sm{padding:8px 15px;font-size:14px}
.btn-ghost{background:rgba(255,255,255,.0);color:var(--blurple);box-shadow:none;border:0;padding-left:6px}
.btn-ghost::after{content:"→"}

/* nav */
.nav{position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:30px;max-width:1080px;margin:auto;padding:20px 24px}
.brand{display:flex;align-items:center;gap:9px;font-weight:700;font-size:18px;color:var(--navy)}
.nav nav{display:flex;gap:28px;margin-left:auto;font-size:15px;font-weight:500;color:var(--slate)}
.nav nav a:hover{color:var(--blurple)}
.nav>.btn{margin-left:6px}

/* ===== hero with aurora gradient ===== */
.hero{position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;inset:-40% -10% auto -10%;height:760px;z-index:-1;
  background:
    radial-gradient(60% 60% at 15% 20%,#ffd9a0 0%,rgba(255,217,160,0) 60%),
    radial-gradient(50% 50% at 80% 10%,#ff80b5 0%,rgba(255,128,181,0) 55%),
    radial-gradient(55% 55% at 70% 60%,#00d4ff 0%,rgba(0,212,255,0) 55%),
    radial-gradient(70% 70% at 35% 70%,#9089fc 0%,rgba(144,137,252,0) 60%),
    linear-gradient(120deg,#f6f9fc 0%,#eef1ff 100%);
  transform:skewY(-7deg);transform-origin:top left;filter:saturate(1.05)}
.hero-inner{max-width:1080px;margin:auto;padding:72px 24px 110px;display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.hero h1{font-size:clamp(40px,5.4vw,62px);margin-bottom:22px;background:linear-gradient(92deg,#0a2540 0%,#3a2fb0 55%,#635bff 100%);-webkit-background-clip:text;background-clip:text;color:transparent}
.lead{font-size:19px;color:var(--slate);max-width:520px}
.hero-cta{display:flex;gap:16px;align-items:center;margin:30px 0 26px;flex-wrap:wrap}
.trust{font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:#8898aa;margin-bottom:14px}
.logos{display:flex;flex-wrap:wrap;gap:24px;align-items:center;font-weight:700;font-size:15px;color:#7a8aa0;opacity:.8}

/* floating dashboard stat card */
.hero-card{position:relative;display:flex;justify-content:center}
.hero-photo{display:none}
.stat-card{width:100%;max-width:400px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow)}
.stat-card::before{content:"AGM · Pipeline health";display:block;font-size:12px;font-weight:600;color:#8898aa;text-transform:uppercase;letter-spacing:.08em;margin-bottom:18px}
.sc-row{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--slate);margin-top:16px}
.sc-row strong{margin-left:auto;color:var(--navy);font-size:16px}
.sc-row:first-of-type{margin-top:0}
.sc-dot{width:8px;height:8px;border-radius:50%;background:#cfd7e3}
.sc-dot.up{background:var(--blurple)}
.sc-bar{height:7px;border-radius:6px;background:var(--soft);margin:9px 0 2px;overflow:hidden}
.sc-bar i{display:block;height:100%;border-radius:6px;background:linear-gradient(90deg,#635bff,#00d4ff)}
.sc-foot{font-size:12px;color:#8898aa;margin-top:18px}

/* stat band */
.band-stats{max-width:1080px;margin:auto;padding:8px 24px 40px;display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.band-stats div{display:flex;flex-direction:column;gap:5px}
.band-stats strong{font-size:34px;letter-spacing:-.04em;color:var(--navy)}
.band-stats span{font-size:14px;color:var(--slate)}

/* cards */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:44px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow-sm);transition:transform .18s ease,box-shadow .18s ease}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.ic{width:44px;height:44px;border-radius:11px;display:grid;place-items:center;background:linear-gradient(135deg,#635bff,#00d4ff);color:#fff;margin-bottom:18px}
.ic svg{width:22px;height:22px}
.card h3{font-size:19px;margin-bottom:10px}
.card p{color:var(--slate);font-size:15px}

/* ===== approach: skewed navy block ===== */
.split{position:relative;margin:40px 0;padding:110px 0;background:var(--navy);color:#fff}
.split::before,.split::after{content:"";position:absolute;left:0;right:0;height:90px;background:var(--navy)}
.split::before{top:-44px;transform:skewY(-3deg)}
.split::after{bottom:-44px;transform:skewY(-3deg)}
.split-inner{position:relative;max-width:1080px;margin:auto;padding:0 24px;display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.split-copy .eyebrow{color:#7c93ff}
.split-copy h2{color:#fff}
.checks{list-style:none;padding:0;margin:24px 0 28px;display:grid;gap:18px}
.checks li{position:relative;padding-left:32px;color:#c5d0e0;font-size:15.5px}
.checks li b{color:#fff;font-weight:600}
.checks li::before{content:"";position:absolute;left:0;top:5px;width:18px;height:18px;border-radius:50%;background:linear-gradient(135deg,#635bff,#00d4ff)}
.split-visual{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.1)}
.split-visual img{width:100%;height:100%;display:block;object-fit:cover;aspect-ratio:4/3}
.split .flow{display:none}

/* quote */
.quote{max-width:820px;margin:auto;padding:96px 24px;text-align:center}
.quote blockquote{font-size:clamp(22px,2.8vw,30px);line-height:1.38;font-weight:500;color:var(--navy);margin:0 0 24px;letter-spacing:-.02em}
.quote-by{display:inline-flex;align-items:center;gap:12px}
.quote-by span{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;font-weight:700;color:#fff;background:linear-gradient(135deg,#635bff,#00d4ff)}
.quote-by div{text-align:left}
.quote-by small{display:block;color:var(--slate);font-size:13px}

/* cases */
.cases{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:44px}
.case{background:var(--soft);border-radius:var(--radius);padding:28px;transition:transform .18s ease}
.case:hover{transform:translateY(-3px)}
.case h4{font-size:13px;text-transform:uppercase;letter-spacing:.05em;color:var(--blurple);margin-bottom:12px}
.case p{color:var(--slate);font-size:15px}

/* team */
.team{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:44px}
.member{text-align:center}
.av{width:96px;height:96px;border-radius:50%;object-fit:cover;margin:0 auto 16px;display:block;box-shadow:0 12px 30px -12px rgba(10,37,64,.45)}
.member strong{display:block;color:var(--navy);margin-bottom:4px}
.member small{color:var(--slate);font-size:13px}

/* CTA */
.cta{padding:40px 24px 110px}
.cta-inner{position:relative;max-width:760px;margin:auto;text-align:center;background:linear-gradient(120deg,#635bff 0%,#3a2fb0 60%,#0a2540 100%);color:#fff;border-radius:26px;padding:60px 44px;overflow:hidden;box-shadow:var(--shadow)}
.cta-inner::before{content:"";position:absolute;inset:auto -20% -60% auto;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,#00d4ff66,transparent 70%)}
.cta-inner h2{color:#fff;margin-bottom:12px;position:relative}
.cta-inner>p{color:#d4dcff;margin-bottom:28px;position:relative}
.cta-form{display:grid;gap:12px;max-width:440px;margin:0 auto 16px;text-align:left;position:relative}
.cta-form input,.cta-form textarea{width:100%;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:10px;padding:13px 15px;color:#fff;font:inherit}
.cta-form input::placeholder,.cta-form textarea::placeholder{color:#b8c0e8}
.cta-form textarea{min-height:92px;resize:vertical}
.cta-form .btn{width:100%;justify-content:center;background:#fff;color:var(--blurple)}
.cta-form .btn:hover{background:#f0f0ff}
.contact-alt{font-size:14px;color:#c7cdf2;position:relative}
.contact-alt a{color:#fff;text-decoration:underline}

/* footer */
.foot{max-width:1080px;margin:auto;padding:48px 24px;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;align-items:center;gap:12px;color:var(--slate);font-size:14px}
.foot-brand{display:flex;align-items:center;gap:9px;font-weight:700;color:var(--navy)}
.foot p{margin:0}
.foot p:nth-of-type(1){margin-left:auto}
.foot-legal{color:#8898aa;width:100%;margin-top:4px}

@media(max-width:860px){
  .hero-inner,.split-inner{grid-template-columns:1fr;gap:34px}
  .band-stats{grid-template-columns:repeat(2,1fr);gap:18px}
  .cards,.cases,.team{grid-template-columns:1fr}
  .nav nav{display:none}
  .hero::before{height:880px}
}

/* ===================== MOTION ===================== */
/* fluid animated aurora — drift + slow rotate + hue shift (Stripe mesh feel) */
.hero::before{
  background-size:160% 160%;
  animation:auroraDrift 18s ease-in-out infinite alternate, auroraHue 24s linear infinite;
  will-change:transform,background-position,filter;
}
@keyframes auroraDrift{
  0%{background-position:0% 50%;transform:skewY(-7deg) scale(1.05) translateY(0)}
  50%{background-position:100% 50%;transform:skewY(-7deg) scale(1.12) translateY(-18px)}
  100%{background-position:50% 100%;transform:skewY(-7deg) scale(1.08) translateY(6px)}
}
@keyframes auroraHue{0%{filter:saturate(1.05) hue-rotate(0deg)}100%{filter:saturate(1.05) hue-rotate(26deg)}}

/* floating dashboard card — gentle bob */
.stat-card{animation:floaty 7s ease-in-out infinite}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* shimmering stat bars */
.sc-bar i{position:relative;overflow:hidden}
.sc-bar i::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.55),transparent);transform:translateX(-100%);animation:shimmer 2.6s ease-in-out infinite}
@keyframes shimmer{0%{transform:translateX(-100%)}60%,100%{transform:translateX(100%)}}

/* gradient text subtle flow */
.hero h1{background-size:200% auto;animation:textFlow 8s ease-in-out infinite}
@keyframes textFlow{0%,100%{background-position:0% center}50%{background-position:100% center}}

/* button sheen on hover */
.btn{position:relative;overflow:hidden}
.btn::before{content:"";position:absolute;top:0;left:-75%;width:50%;height:100%;background:linear-gradient(120deg,transparent,rgba(255,255,255,.35),transparent);transform:skewX(-20deg);transition:left .5s ease}
.btn:hover::before{left:130%}

/* scroll reveal (JS adds .motion to body + .in when in view) */
body.motion .animate{opacity:0;transform:translateY(28px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
body.motion .animate.in{opacity:1;transform:none}
body.motion .stagger>*{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
body.motion .stagger.in>*{opacity:1;transform:none}
body.motion .stagger.in>*:nth-child(2){transition-delay:.09s}
body.motion .stagger.in>*:nth-child(3){transition-delay:.18s}
body.motion .stagger.in>*:nth-child(4){transition-delay:.27s}

/* card hover already lifts; add icon pulse */
.card:hover .ic{transform:scale(1.08) rotate(-3deg);transition:transform .25s ease}

@media(prefers-reduced-motion:reduce){
  .hero::before,.stat-card,.sc-bar i::after,.hero h1{animation:none}
  body.motion .animate,body.motion .stagger>*{opacity:1;transform:none;transition:none}
}

/* ===== rich content: sub, mini, metrics, posts, faq, rich footer, sea waves ===== */
.sub{max-width:680px;margin:0 auto 6px;color:var(--slate);font-size:16px}
.footnote{max-width:680px;margin:28px auto 0;color:#8898aa;font-size:12.5px;line-height:1.55}
.mini{list-style:none;padding:0;margin:16px 0 0;display:grid;gap:7px;text-align:left}
.mini li{position:relative;padding-left:20px;color:var(--slate);font-size:13.5px}
.mini li::before{content:"";position:absolute;left:0;top:7px;width:7px;height:7px;border-radius:2px;background:linear-gradient(135deg,#635bff,#00d4ff)}
.card{text-align:left}

.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:40px}
.metric{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px 20px;box-shadow:var(--shadow-sm)}
.metric strong{display:block;font-size:38px;letter-spacing:-.04em;background:linear-gradient(135deg,#635bff,#00d4ff);-webkit-background-clip:text;background-clip:text;color:transparent}
.metric span{display:block;font-weight:600;color:var(--navy);margin:6px 0 2px;font-size:15px}
.metric small{color:#8898aa;font-size:12.5px}

.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:40px}
.post{display:block;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;text-align:left;transition:transform .18s ease,box-shadow .18s ease}
.post:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.ptag{display:inline-block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--blurple);background:rgba(99,91,255,.09);padding:5px 10px;border-radius:999px;margin-bottom:14px}
.post h4{font-size:18px;color:var(--navy);margin-bottom:14px;line-height:1.25}
.post time{font-size:12.5px;color:#8898aa}

.faq{max-width:760px;margin:36px auto 0;text-align:left;display:grid;gap:12px}
.faq details{background:#fff;border:1px solid var(--line);border-radius:14px;padding:6px 22px;transition:box-shadow .2s ease}
.faq details[open]{box-shadow:var(--shadow-sm)}
.faq summary{cursor:pointer;list-style:none;padding:16px 0;font-weight:600;color:var(--navy);display:flex;align-items:center;justify-content:space-between;font-size:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:22px;color:var(--blurple);font-weight:400;transition:transform .2s ease}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{color:var(--slate);font-size:15px;padding:0 0 18px;margin:0}

.member p{color:var(--slate);font-size:13px;margin-top:8px;max-width:240px;margin-inline:auto}

/* rich footer */
.foot{display:block;max-width:1080px;margin:auto;padding:64px 24px 40px;border-top:1px solid var(--line);color:var(--slate);font-size:14px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:40px}
.foot-about p{margin:14px 0 16px;max-width:300px;color:var(--slate);font-size:14px}
.foot-li{display:inline-flex;align-items:center;gap:7px;color:var(--blurple);font-weight:600}
.foot-li svg{color:var(--blurple)}
.foot-col h5{font-size:13px;text-transform:uppercase;letter-spacing:.06em;color:var(--navy);margin:0 0 14px}
.foot-col a,.foot-col span{display:block;color:var(--slate);margin-bottom:9px;line-height:1.5}
.foot-col a:hover{color:var(--blurple)}
.foot-legal{display:flex;flex-wrap:wrap;justify-content:space-between;gap:10px;margin-top:40px;padding-top:24px;border-top:1px solid var(--line);color:#8898aa;font-size:13px}
.foot-links a{color:#8898aa}
.foot-links a:hover{color:var(--blurple)}

/* ===== SEA WAVES (animated dividers on navy split) ===== */
.split{margin:64px 0;padding:130px 0 140px;overflow:hidden}
.split::before,.split::after{display:none}
.wave{position:absolute;left:0;width:200%;height:90px;fill:var(--navy)}
.wave-top{top:-1px;transform:translateY(-78px)}
.wave-bottom{bottom:-1px;transform:translateY(78px) rotate(180deg)}
.wave path{animation:waveSlide 14s ease-in-out infinite alternate}
.wave-bottom path{animation-duration:18s}
@keyframes waveSlide{0%{transform:translateX(0)}100%{transform:translateX(-18%)}}

@media(max-width:860px){
  .metrics{grid-template-columns:repeat(2,1fr)}
  .posts{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .foot-about{grid-column:1/-1}
}
