/* ============================================================
   FPLMan redesign — marketing landing page
   Ported from the original landing styles into the redesign.css
   token system (Hanken Grotesk + Geist Mono, green accent).
   ============================================================ */

.landing{flex:1;}
/* buttons use canonical .btn (.btn--fill / .btn--outline) + .btn--lg; position pills use .pos/.pos-* (redesign.css) */

/* ───────── Hero ───────── */
.hero{
  position:relative;overflow:hidden;padding:48px 24px 52px;
  background:
    radial-gradient(120% 80% at 85% -10%, rgba(21,160,106,.16), transparent 60%),
    linear-gradient(to bottom, var(--green-tint), var(--bg));
}
.hero-inner{max-width:1080px;margin:0 auto;display:grid;grid-template-columns:1fr;gap:28px;align-items:center;}
.hero-eyebrow{
  font-family:var(--mono);font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.12em;
  color:var(--green-deep);margin-bottom:14px;
}
.hero-title{font-size:38px;font-weight:800;letter-spacing:-.03em;line-height:1.05;margin-bottom:16px;color:var(--text);}
.hero-title .accent{color:var(--green-deep);}
.hero-subtitle{font-size:16px;color:var(--text-2);max-width:480px;margin-bottom:26px;line-height:1.6;}
.hero-ctas{display:flex;flex-direction:column;gap:12px;margin-bottom:18px;}
.hero-trust{font-size:12.5px;color:var(--text-3);display:flex;flex-wrap:wrap;gap:8px 14px;align-items:center;}
.hero-trust span{display:inline-flex;align-items:center;gap:6px;}
.hero-trust svg{color:var(--green-deep);flex-shrink:0;}
.hero-visual{position:relative;display:flex;justify-content:center;align-items:center;order:-1;}
.hero-visual::before{
  content:"";position:absolute;width:300px;height:300px;border-radius:50%;
  background:radial-gradient(circle, rgba(21,160,106,.24), transparent 70%);filter:blur(8px);z-index:0;
}
.hero-logo{position:relative;z-index:1;width:100%;max-width:300px;height:auto;filter:drop-shadow(0 14px 34px rgba(20,23,28,.14));}

@media(min-width:640px){
  .hero{padding:60px 24px 64px;}
  .hero-title{font-size:52px;}
  .hero-subtitle{font-size:17px;}
  .hero-ctas{flex-direction:row;}
}
@media(min-width:1024px){
  .hero-inner{grid-template-columns:1.05fr 0.95fr;gap:48px;}
  .hero-visual{order:0;}
  .hero-visual::before{width:440px;height:440px;}
  .hero-logo{max-width:440px;}
  .hero-title{font-size:58px;}
}

/* ───────── Section scaffolding ───────── */
.section{padding:64px 24px;}
.section--surface{background:var(--surface);}
.section-inner{max-width:1080px;margin:0 auto;}
.section-label{
  font-family:var(--mono);font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.1em;
  color:var(--green-deep);text-align:center;margin-bottom:12px;
}
.section-title{font-size:26px;font-weight:800;letter-spacing:-.02em;text-align:center;margin-bottom:40px;color:var(--text);}
@media(min-width:640px){.section-title{font-size:32px;}}

/* ───────── Bento benefits ───────── */
.bento{display:grid;grid-template-columns:1fr;gap:16px;}
.bento-card{
  position:relative;overflow:hidden;background:var(--bg);border:1px solid var(--border);
  border-radius:16px;padding:28px;transition:border-color .15s,transform .15s;
}
.section--surface .bento-card{background:var(--surface-2);}
.bento-card:hover{border-color:var(--border-strong);transform:translateY(-2px);}
.bento-icon{
  display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;
  background:var(--green-tint);color:var(--green-deep);margin-bottom:16px;
}
.bento-title{font-size:17px;font-weight:800;margin-bottom:8px;letter-spacing:-.01em;color:var(--text);}
.bento-desc{font-size:14px;color:var(--text-2);line-height:1.6;}

.bento-card--dark{background:var(--text);border-color:var(--text);}
.section--surface .bento-card--dark{background:var(--text);}
.bento-card--dark .bento-title{color:#fff;}
.bento-card--dark .bento-desc{color:rgba(255,255,255,.66);}
.bento-card--dark .bento-icon{background:rgba(21,160,106,.22);color:#3fd494;}
.bento-card--dark:hover{border-color:var(--text);}
.bento-mark{position:absolute;right:-36px;bottom:-48px;width:200px;opacity:.10;pointer-events:none;}

.predict-preview{margin-top:22px;display:flex;flex-direction:column;gap:8px;}
.proj-row{
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;
  background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:9px 12px;
}
.section--surface .proj-row{background:var(--bg);}
.proj-main{min-width:0;}
.proj-name-line{display:flex;align-items:center;gap:6px;margin-bottom:6px;}
.proj-name{font-size:13px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text);}
.proj-track{height:7px;border-radius:100px;background:var(--border);overflow:hidden;}
.proj-fill{height:100%;border-radius:100px;background:linear-gradient(90deg, var(--green), var(--green-deep));}
.proj-side{display:flex;flex-direction:column;align-items:flex-end;gap:4px;}
.proj-pts{font-family:var(--mono);font-size:14px;font-weight:700;color:var(--green-deep);white-space:nowrap;}

/* Smart tags + signal pills */
.tag-mk{font-size:9px;font-weight:700;letter-spacing:.08em;padding:2px 5px;border-radius:4px;line-height:1;flex-shrink:0;color:#fff;}
.tag-diff{background:var(--orange);}
.tag-double{background:var(--blue);}
.rec{font-size:10px;font-weight:700;letter-spacing:.04em;padding:2px 7px;border-radius:100px;line-height:1.3;white-space:nowrap;}
.rec-buy{background:var(--green-tint);color:var(--green-deep);}
.rec-sell{background:var(--red-tint);color:#b73a4d;}
.rec-captain{background:var(--purple-tint);color:var(--purple);}
.senti{display:inline-flex;align-items:center;gap:3px;font-family:var(--mono);font-size:11px;font-weight:500;white-space:nowrap;}
.senti-up{color:var(--green-deep);}
.senti-flat{color:var(--text-3);}

@media(min-width:640px){
  .bento{grid-template-columns:repeat(2,1fr);}
  .bento-card--wide{grid-column:span 2;}
}
@media(min-width:1024px){
  .bento{grid-template-columns:repeat(6,1fr);}
  .bento-card--predict{grid-column:span 4;grid-row:span 2;}
  .bento-card--signals{grid-column:span 2;}
  .bento-card--email{grid-column:span 2;}
  .bento-card--sync{grid-column:span 6;}
  .bento-card--wide{grid-column:span 6;}
}
.bento-card--sync{display:flex;flex-direction:column;gap:16px;}
@media(min-width:1024px){
  .bento-card--sync{flex-direction:row;align-items:center;justify-content:space-between;}
  .bento-card--sync .sync-copy{max-width:560px;}
}

/* ───────── How it works ───────── */
.steps{display:flex;flex-direction:column;margin-top:8px;}
.step{padding:24px 0;text-align:left;}
.step-divider{width:100%;height:1px;background:var(--border);}
.step-number{font-family:var(--mono);font-size:11px;color:var(--green-deep);letter-spacing:.06em;margin-bottom:8px;display:block;}
.step-title{font-size:15px;font-weight:800;margin-bottom:6px;color:var(--text);}
.step-desc{font-size:13px;color:var(--text-2);line-height:1.55;}
@media(min-width:640px){
  .steps{flex-direction:row;align-items:stretch;}
  .step{flex:1;padding:0 32px;}
  .step-divider{width:1px;height:auto;align-self:stretch;flex-shrink:0;}
  .step:first-child{padding-left:0;}
  .step:last-child{padding-right:0;}
}

/* ───────── CTA banner ───────── */
.cta-banner{position:relative;overflow:hidden;background:var(--text);padding:72px 24px;text-align:center;}
.cta-banner::before{content:"";position:absolute;inset:0;background:radial-gradient(80% 120% at 50% 120%, rgba(21,160,106,.32), transparent 60%);}
.cta-content{position:relative;z-index:1;}
.cta-headline{font-size:28px;font-weight:800;letter-spacing:-.02em;color:#fff;margin-bottom:12px;}
.cta-sub{font-size:15px;color:rgba(255,255,255,.66);margin:0 auto 32px;max-width:420px;}
.cta-mark{position:absolute;right:-30px;bottom:-60px;width:240px;opacity:.08;z-index:0;}
@media(min-width:640px){.cta-headline{font-size:34px;}}

/* ───────── Dashboard snapshot ───────── */
.showcase{padding:40px 24px 56px;}
.showcase-intro{text-align:center;}
.showcase-title{margin-bottom:12px;}
.showcase-lead{max-width:560px;margin:0 auto 36px;color:var(--text-2);font-size:15px;line-height:1.6;}
.showcase-frame{
  max-width:1000px;margin:0 auto;border:1px solid var(--border);border-radius:16px;overflow:hidden;
  background:var(--surface);box-shadow:var(--shadow-pop);
}
.frame-bar{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--surface-3);border-bottom:1px solid var(--border);}
.frame-dot{width:11px;height:11px;border-radius:50%;background:var(--border-strong);}
.frame-url{
  margin-left:8px;font-family:var(--mono);font-size:12px;color:var(--text-3);
  background:var(--surface);border:1px solid var(--border);border-radius:100px;padding:4px 12px;
}
.frame-body{padding:20px;}
.snap-topline{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;}
.snap-h{font-size:15px;font-weight:800;letter-spacing:-.01em;color:var(--text);}
.snap-gw{font-family:var(--mono);font-size:11px;font-weight:500;color:var(--green-deep);background:var(--green-tint);border-radius:100px;padding:4px 10px;}
.snap-grid{display:grid;grid-template-columns:1fr;gap:16px;}
.snap-panel{background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:16px;}
.snap-panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
.snap-panel-title{font-size:12px;font-weight:800;letter-spacing:.02em;color:var(--text);}
.snap-panel-meta{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-3);}
.snap-list{display:flex;flex-direction:column;gap:8px;}
.ment-row{display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:9px 12px;}
.ment-name{font-size:13px;font-weight:700;display:flex;align-items:center;gap:6px;color:var(--text);}
.ment-src{display:flex;flex-wrap:wrap;gap:4px;margin-top:5px;}
.src{display:inline-flex;align-items:center;gap:3px;font-size:10px;font-weight:500;color:var(--text-3);background:var(--bg);border:1px solid var(--border);border-radius:100px;padding:2px 7px;}
.ment-side{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex-shrink:0;}
.senti-bar{width:64px;height:6px;border-radius:100px;background:var(--border);overflow:hidden;}
.senti-fill{display:block;height:100%;border-radius:100px;background:linear-gradient(90deg, var(--green), var(--green-deep));}
.snap-legend{display:flex;flex-wrap:wrap;gap:8px 18px;margin:20px auto 0;max-width:1000px;justify-content:center;font-size:12px;color:var(--text-3);}
.snap-legend span{display:inline-flex;align-items:center;gap:6px;}
@media(min-width:768px){.snap-grid{grid-template-columns:1fr 1fr;}}
