/* fanjuju-site-2.css — section-specific styles */

/* ===== HERO ===== */
.hero {
  padding: 76px 0 88px;
  background:
    radial-gradient(120% 90% at 88% 0%, #F6F1E4 0%, rgba(246,241,228,0) 52%),
    radial-gradient(100% 80% at 0% 100%, #EEF6EF 0%, rgba(238,246,239,0) 50%),
    var(--bg);
}
.hero-grid { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 56px; align-items: center; }
.hero-tag {
  display: inline-flex; align-items: center; gap: 8px;
  font-weight: 700; font-size: 15px; color: var(--gold-ink);
  background: var(--gold-soft); border: 1px solid var(--gold-bd);
  padding: 7px 16px; border-radius: 999px; margin-bottom: 24px; white-space: nowrap;
}
.hero h1 {
  font-weight: 900; font-size: 54px; line-height: 1.18; letter-spacing: 0.5px;
  color: var(--text); text-wrap: balance;
}
.hero h1 .hl { color: var(--cta); }
.hero-sub { font-size: 20px; color: var(--t2); margin-top: 22px; line-height: 1.7; max-width: 520px; text-wrap: pretty; }
.hero-cta { display: flex; gap: 14px; margin-top: 34px; flex-wrap: wrap; }
.hero-note { margin-top: 20px; font-size: 14.5px; color: var(--t3); display: flex; align-items: center; gap: 8px; }

/* hero visual — stylised co-meal scene */
.hero-card {
  background: var(--card); border-radius: var(--r-xl); box-shadow: var(--shadow-lg);
  border: 1px solid var(--border-2); padding: 26px; position: relative; overflow: hidden;
}
.hero-card .hc-seal { position: absolute; right: -14px; top: -10px; font-family: var(--serif); font-weight: 900; font-size: 150px; color: var(--gold); opacity: 0.07; line-height: 1; }
.hc-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 18px; position: relative; }
.hc-title { font-weight: 800; font-size: 17px; }
.hc-when { font-size: 14px; color: var(--t3); font-weight: 600; }
.hc-table {
  background: var(--green-tint); border-radius: var(--r); padding: 22px; display: flex; flex-direction: column;
  align-items: center; gap: 14px; position: relative;
}
.hc-avatars { display: flex; }
.hc-avatars .av {
  width: 56px; height: 56px; border-radius: 999px; margin-left: -12px; border: 3px solid var(--card);
  display: flex; align-items: center; justify-content: center; font-weight: 800; font-size: 19px; color: #fff;
  box-shadow: var(--shadow-sm);
}
.hc-avatars .av:first-child { margin-left: 0; }
.hc-meal { font-size: 38px; }
.hc-cap { font-weight: 800; font-size: 18px; color: var(--cta-deep); }
.hc-sub { font-size: 14px; color: var(--tile-sub, #4C8C50); font-weight: 600; }
.hc-rows { display: flex; flex-direction: column; gap: 12px; margin-top: 18px; }
.hc-row { display: flex; align-items: center; gap: 12px; padding: 13px 15px; background: var(--surface); border-radius: var(--r); }
.hc-row .ic { width: 38px; height: 38px; border-radius: 11px; background: var(--card); display: flex; align-items: center; justify-content: center; font-size: 19px; flex-shrink: 0; box-shadow: var(--shadow-sm); }
.hc-row .lab { flex: 1; font-weight: 700; font-size: 15.5px; }
.hc-row .val { font-weight: 800; font-size: 15.5px; }

/* trust strip under hero */
.trust-strip { border-top: 1px solid var(--border); background: var(--card); }
.trust-strip .wrap { display: flex; align-items: center; justify-content: space-between; gap: 24px; padding-top: 22px; padding-bottom: 22px; flex-wrap: wrap; }
.ts-item { display: flex; align-items: center; gap: 11px; font-weight: 700; font-size: 15.5px; color: var(--t2); white-space: nowrap; }
.ts-item .ts-ic { font-size: 20px; }

/* ===== PAIN / VALUE ===== */
.pain-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; margin-top: 14px; align-items: stretch; }
.pain-col { padding: 34px; border-radius: var(--r-lg); }
.pain-before { background: var(--surface); border: 1px solid var(--border); }
.pain-after { background: var(--green-tint); border: 1px solid #D6E8D8; }
.pain-col .pc-label { display: inline-flex; align-items: center; gap: 8px; font-weight: 800; font-size: 14px; letter-spacing: 0.5px; padding: 5px 13px; border-radius: 999px; margin-bottom: 18px; white-space: nowrap; }
.pain-before .pc-label { color: var(--t2); background: #E9E6DE; }
.pain-after .pc-label { color: var(--cta-deep); background: #D6EBD8; }
.pain-col h3 { font-weight: 900; font-size: 24px; line-height: 1.4; margin-bottom: 16px; text-wrap: balance; }
.pain-list { display: flex; flex-direction: column; gap: 14px; }
.pain-item { display: flex; gap: 12px; align-items: flex-start; font-size: 16.5px; color: var(--t2); line-height: 1.6; }
.pain-item .pi { font-size: 20px; flex-shrink: 0; line-height: 1.5; }
.pain-after .pain-item { color: #2f4a34; }

/* ===== HOW IT WORKS ===== */
.steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 14px; }
.step { background: var(--card); border: 1px solid var(--border-2); border-radius: var(--r-lg); padding: 30px 28px; box-shadow: var(--shadow-sm); position: relative; transition: transform .16s cubic-bezier(.22,1,.36,1), box-shadow .16s; }
.step:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.step-n {
  width: 46px; height: 46px; border-radius: 13px; display: flex; align-items: center; justify-content: center;
  font-family: "Inter"; font-weight: 800; font-size: 20px; color: #fff; background: var(--cta);
  margin-bottom: 20px; box-shadow: 0 4px 12px rgba(46,125,50,0.25);
}
.step.gold .step-n { background: var(--gold); color: #3a2c0c; box-shadow: 0 4px 12px rgba(201,169,97,0.3); }
.step.blue .step-n { background: var(--dia); box-shadow: 0 4px 12px rgba(62,124,168,0.28); }
.step-ico { font-size: 30px; margin-bottom: 12px; }
.step h3 { font-weight: 900; font-size: 21px; margin-bottom: 10px; }
.step p { font-size: 16px; color: var(--t2); line-height: 1.65; }
.step .step-tag { display: inline-flex; align-items: center; gap: 6px; margin-top: 16px; font-weight: 700; font-size: 14px; color: var(--t2); background: var(--surface); padding: 6px 13px; border-radius: 999px; white-space: nowrap; }

/* ===== ECONOMY ===== */
.eco-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-top: 14px; }
.eco-card { padding: 34px; border-radius: var(--r-lg); border: 1px solid var(--border-2); box-shadow: var(--shadow-sm); position: relative; overflow: hidden; }
.eco-card.coin { background: linear-gradient(165deg, #FDF8EC 0%, var(--card) 60%); border-color: var(--gold-bd); }
.eco-card.dia { background: linear-gradient(165deg, #EEF5FA 0%, var(--card) 60%); border-color: #CFE2EE; }
.eco-emoji { font-size: 40px; margin-bottom: 16px; }
.eco-card h3 { font-weight: 900; font-size: 24px; margin-bottom: 8px; }
.eco-who { font-weight: 700; font-size: 15px; color: var(--t3); margin-bottom: 18px; }
.eco-flow { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-bottom: 18px; }
.eco-flow .ef { font-weight: 800; font-size: 15.5px; padding: 9px 15px; border-radius: var(--r-sm); background: var(--card); border: 1px solid var(--border); box-shadow: var(--shadow-sm); }
.eco-flow .arr { color: var(--t3); font-weight: 800; }
.eco-card p { font-size: 16px; color: var(--t2); line-height: 1.65; }
.eco-card .nt-note { font-size: 13.5px; color: var(--t3); margin-top: 12px; }
.eco-banner {
  margin-top: 24px; background: var(--ink-dark); border-radius: var(--r-lg); padding: 32px 36px;
  display: flex; align-items: center; gap: 28px; flex-wrap: wrap; color: #EAF3EB;
}
.eco-banner .eb-ico { width: 60px; height: 60px; border-radius: 16px; background: rgba(255,255,255,0.1); display: flex; align-items: center; justify-content: center; font-size: 30px; flex-shrink: 0; }
.eco-banner .eb-tx { flex: 1; min-width: 280px; }
.eco-banner h4 { font-weight: 900; font-size: 22px; margin-bottom: 6px; color: #fff; }
.eco-banner p { font-size: 16px; color: #B9CBBC; line-height: 1.6; }
.eco-banner .eb-zero { font-family: "Inter"; font-weight: 900; font-size: 44px; color: #8FD0A0; letter-spacing: -1px; flex-shrink: 0; line-height: 1; }
.eco-banner .eb-zero small { font-size: 17px; font-weight: 700; }
.no-sub-note { text-align: center; margin-top: 22px; font-weight: 700; font-size: 15px; color: var(--t3); }

/* ===== COMPANION RECRUIT ===== */
.recruit { background: linear-gradient(160deg, #1B3322 0%, #16241A 100%); color: #EAF3EB; }
.recruit .eyebrow { color: #9FE0AC; background: rgba(143,208,160,0.14); }
.recruit h2.sec-title { color: #fff; }
.recruit .sec-lede { color: #B9CBBC; }
.recruit-grid { display: grid; grid-template-columns: 1fr 0.9fr; gap: 48px; align-items: center; margin-top: 8px; }
.recruit-feats { display: flex; flex-direction: column; gap: 18px; margin-top: 26px; }
.rf { display: flex; gap: 14px; align-items: flex-start; }
.rf .rf-ic { width: 44px; height: 44px; border-radius: 12px; background: rgba(143,208,160,0.16); display: flex; align-items: center; justify-content: center; font-size: 21px; flex-shrink: 0; }
.rf .rf-tx strong { display: block; font-weight: 800; font-size: 17.5px; color: #fff; margin-bottom: 3px; }
.rf .rf-tx span { font-size: 15.5px; color: #AABFAD; line-height: 1.55; }
.recruit-cta { display: flex; gap: 14px; margin-top: 32px; flex-wrap: wrap; }
/* fee ladder card */
.fee-card { background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.1); border-radius: var(--r-xl); padding: 32px; }
.fee-card h4 { font-weight: 800; font-size: 18px; color: #fff; margin-bottom: 6px; }
.fee-card .fc-sub { font-size: 14.5px; color: #9FB3A3; margin-bottom: 24px; }
.fee-rung { display: flex; align-items: center; gap: 16px; padding: 16px 0; border-top: 1px solid rgba(255,255,255,0.08); }
.fee-rung:first-of-type { border-top: none; }
.fee-rung .fr-tier { font-weight: 800; font-size: 16px; color: #EAF3EB; width: 96px; flex-shrink: 0; }
.fee-rung .fr-bar { flex: 1; height: 10px; border-radius: 999px; background: rgba(255,255,255,0.1); overflow: hidden; }
.fee-rung .fr-fill { height: 100%; border-radius: 999px; background: linear-gradient(90deg, #6FA97C, #9FE0AC); }
.fee-rung .fr-pct { font-family: "Inter"; font-weight: 900; font-size: 20px; color: #fff; width: 60px; text-align: right; flex-shrink: 0; font-variant-numeric: tabular-nums; }

/* ===== TRUST ===== */
.trust-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; margin-top: 14px; }
.trust-card { background: var(--card); border: 1px solid var(--border-2); border-radius: var(--r-lg); padding: 28px; box-shadow: var(--shadow-sm); transition: transform .16s cubic-bezier(.22,1,.36,1), box-shadow .16s; }
.trust-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.trust-card .tc-ic { width: 52px; height: 52px; border-radius: 14px; background: var(--green-tint); display: flex; align-items: center; justify-content: center; font-size: 25px; margin-bottom: 18px; }
.trust-card h3 { font-weight: 900; font-size: 19px; margin-bottom: 9px; }
.trust-card p { font-size: 15.5px; color: var(--t2); line-height: 1.6; }

/* ===== ENTRY ===== */
.entry { background: var(--bg-warm); }
.entry-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-top: 14px; }
.entry-card { border-radius: var(--r-xl); padding: 40px; border: 1px solid var(--border-2); box-shadow: var(--shadow-sm); display: flex; flex-direction: column; }
.entry-card.host { background: linear-gradient(165deg, #EEF6EF 0%, var(--card) 70%); border-color: #D6E8D8; }
.entry-card.comp { background: linear-gradient(165deg, #EAF2F8 0%, var(--card) 70%); border-color: #CFE2EE; }
.entry-card .ec-badge { align-self: flex-start; font-weight: 800; font-size: 14px; padding: 6px 14px; border-radius: 999px; margin-bottom: 18px; white-space: nowrap; }
.entry-card.host .ec-badge { color: var(--cta-deep); background: #D6EBD8; }
.entry-card.comp .ec-badge { color: var(--dia); background: var(--dia-soft); }
.entry-card h3 { font-weight: 900; font-size: 26px; margin-bottom: 10px; }
.entry-card p { font-size: 16.5px; color: var(--t2); line-height: 1.65; margin-bottom: 26px; flex: 1; }
.entry-card .btn { align-self: flex-start; }

/* ===== FAQ ===== */
.faq-list { max-width: 820px; margin: 14px auto 0; display: flex; flex-direction: column; gap: 14px; }
.faq { background: var(--card); border: 1px solid var(--border-2); border-radius: var(--r); box-shadow: var(--shadow-sm); overflow: hidden; }
.faq summary { list-style: none; cursor: pointer; padding: 22px 26px; display: flex; align-items: center; gap: 16px; font-weight: 800; font-size: 18px; }
.faq summary::-webkit-details-marker { display: none; }
.faq summary .q-mark { width: 30px; height: 30px; border-radius: 9px; background: var(--green-tint); color: var(--cta-deep); display: flex; align-items: center; justify-content: center; font-weight: 900; font-size: 16px; flex-shrink: 0; }
.faq summary .q-tx { flex: 1; }
.faq summary .q-chev { color: var(--t3); font-size: 22px; transition: transform .2s; }
.faq[open] summary .q-chev { transform: rotate(180deg); }
.faq .faq-body { padding: 0 26px 24px 72px; font-size: 16.5px; color: var(--t2); line-height: 1.7; }
.faq .faq-body .nt { color: var(--t3); font-size: 14.5px; }

/* ===== FOOTER ===== */
.footer { background: var(--ink-dark); color: #B9CBBC; padding: 56px 0 40px; }
.footer-top { display: flex; justify-content: space-between; gap: 40px; flex-wrap: wrap; margin-bottom: 38px; }
.footer-brand { max-width: 320px; }
.footer-brand .fb-row { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.footer-brand .fb-row .zh { font-weight: 900; font-size: 20px; color: #fff; letter-spacing: 1px; }
.footer-brand p { font-size: 15px; line-height: 1.6; color: #9FB3A3; }
.footer-cols { display: flex; gap: 64px; flex-wrap: wrap; }
.footer-col h5 { font-weight: 800; font-size: 14px; color: #EAF3EB; margin-bottom: 14px; letter-spacing: 0.5px; }
.footer-col a { display: block; font-size: 15px; color: #9FB3A3; margin-bottom: 10px; transition: color .14s; }
.footer-col a:hover { color: #fff; }
.footer-bot { border-top: 1px solid rgba(255,255,255,0.1); padding-top: 26px; display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap; font-size: 13.5px; color: #7E9384; line-height: 1.6; }

/* ===== responsive ===== */
@media (max-width: 920px) {
  .hero-grid, .pain-grid, .eco-grid, .recruit-grid, .entry-grid { grid-template-columns: 1fr; gap: 32px; }
  .steps, .trust-grid { grid-template-columns: 1fr 1fr; }
  .nav-links { display: none; }
  .hero h1 { font-size: 42px; }
  h2.sec-title { font-size: 32px; }
}
@media (max-width: 560px) {
  .wrap { padding: 0 18px; }
  section { padding: 60px 0; }
  .steps, .trust-grid { grid-template-columns: 1fr; }
  .hero h1 { font-size: 34px; }
  .nav-cta .btn-ghost { display: none; }
}
