:root{
  --green:#31533A;
  --green2:#2F6844;
  --green3:#86BE73;
  --gold:#C29B5E;
  --gold2:#D6AE61;
  --text:#58645E;
  --muted:#93A096;
  --soft:#FBFCF7;
  --soft2:#F3F8EF;
  --line:#DDEAD5;
  --white:#fff;
  --teal:#6DB8BF;
}
html,body{
  margin:0;
  padding:0;
  background:#f4f5f2;
  font-family:-apple-system,BlinkMacSystemFont,"PingFang SC","Microsoft YaHei",Arial,sans-serif;
  color:var(--text);
}
.phone{
  width:677px;
  max-width:100%;
  margin:0 auto;
  background:#fff;
  overflow:hidden;
}
.section{
  position:relative;
  padding:42px 42px 40px;
  box-sizing:border-box;
  background:#fff;
}
.soft{
  background:linear-gradient(180deg,#FBFCF7 0%,#FFFFFF 100%);
}
.circle-a,.circle-b,.circle-c{
  position:absolute;
  border-radius:999px;
  pointer-events:none;
}
.circle-a{width:180px;height:180px;left:-92px;top:90px;background:#EEF6EA;opacity:.75;}
.circle-b{width:160px;height:160px;right:-85px;top:410px;background:#F6F0DA;opacity:.48;}
.circle-c{width:120px;height:120px;right:58px;top:-60px;background:#F1F7ED;opacity:.75;}
.hero-title{
  position:relative;
  margin:0;
  color:var(--green);
  font-size:38px;
  line-height:1.18;
  font-weight:800;
  letter-spacing:1px;
}
.hero-title small{
  color:#33383A;
  font-size:30px;
  font-weight:700;
  margin-left:12px;
}
.hero-sub{
  position:relative;
  margin:10px 0 24px;
  color:var(--gold);
  font-size:21px;
  line-height:1.5;
  font-weight:700;
  letter-spacing:.5px;
}
.tags{
  position:relative;
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin:0 0 26px;
}
.tag{
  padding:8px 18px;
  border:1.4px solid #D9E7D0;
  border-radius:20px;
  background:#F7F9F4;
  color:var(--green);
  font-size:13px;
  line-height:1.45;
  font-weight:700;
  letter-spacing:.5px;
  box-sizing:border-box;
}
.tag.gold{background:#FFF8EB;border-color:#E5C985;color:var(--gold);}
.hero-img,.full-img{
  position:relative;
  width:100%;
  display:block;
  margin:0 auto;
  border-radius:0;
}
.orn-title{
  position:relative;
  width:max-content;
  max-width:100%;
  margin:0 auto 26px;
  padding:9px 28px;
  color:var(--green2);
  background:#fff;
  border:1.6px solid #78BD83;
  border-radius:999px;
  text-align:center;
  font-size:18px;
  line-height:1.65;
  font-weight:750;
  letter-spacing:.6px;
  box-sizing:border-box;
}
.orn-title.gold{border-color:#E6BD6B;color:#B68238;}
.orn-title:before,.orn-title:after{
  content:"";
  position:absolute;
  top:50%;
  width:42px;
  height:1px;
  background:linear-gradient(90deg,transparent,var(--gold2));
}
.orn-title:before{left:-54px;}
.orn-title:after{right:-54px;transform:scaleX(-1);}
.section-after-img{margin-top:34px;}
.subnote{
  margin:-16px 0 26px;
  color:#B78B46;
  font-size:13px;
  line-height:1.8;
  text-align:center;
  letter-spacing:.6px;
}
.leaf-panel{
  position:relative;
  padding:18px 20px 8px;
  background:#FBFDF9;
  border:1px solid #E4EFD9;
  border-radius:18px;
}
.leaf{
  position:relative;
  margin:0 0 18px;
  padding-left:34px;
  color:var(--text);
  font-size:16px;
  line-height:2.05;
  letter-spacing:.25px;
  word-break:normal;
  overflow-wrap:break-word;
  text-align:justify;
}
.leaf:before{
  content:"";
  position:absolute;
  left:0;
  top:14px;
  width:20px;
  height:8px;
  border-radius:20px 0 20px 0;
  background:#8CC177;
  transform:rotate(-14deg);
}
.dash{
  height:10px;
  margin:24px 0 28px;
  background:repeating-linear-gradient(110deg,#B8DC9E 0,#B8DC9E 7px,transparent 7px,transparent 18px);
}
.mini-head{
  margin:0 0 22px;
  color:var(--green);
  font-size:25px;
  line-height:1.55;
  font-weight:800;
  letter-spacing:.4px;
}
.mini-head b{color:var(--gold);}
.grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
}
.metric{
  position:relative;
  min-height:116px;
  padding:16px 14px 14px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:16px;
  overflow:hidden;
  box-sizing:border-box;
}
.metric:after{
  content:"";
  position:absolute;
  right:14px;
  top:14px;
  width:30px;
  height:30px;
  border-radius:50%;
  background:#EDF7EA;
}
.metric .label{
  margin:0 0 4px;
  color:#75826E;
  font-size:13px;
  line-height:1.4;
  font-weight:700;
}
.metric .num{
  margin:0;
  color:var(--green);
  font-size:27px;
  line-height:1.15;
  font-weight:850;
  letter-spacing:.2px;
}
.metric.gold .num{color:var(--gold);}
.metric .top{
  margin:7px 0 0;
  color:#B88B42;
  font-size:13px;
  line-height:1.4;
  font-weight:750;
}
.para{
  margin:0 0 16px;
  color:var(--text);
  font-size:16px;
  line-height:2.05;
  letter-spacing:.25px;
  word-break:normal;
  overflow-wrap:break-word;
  text-align:justify;
}
.para:last-child{margin-bottom:0;}
.quote{
  margin:20px 0 0;
  padding:18px 20px;
  background:#F8FBF4;
  border-left:4px solid var(--gold);
  border-radius:0 14px 14px 0;
  color:#58645E;
  font-size:16px;
  line-height:2;
}
.data-row{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:14px;
}
.data-box{
  padding:16px 15px 15px;
  background:#fff;
  border:1px solid #E3ECD8;
  border-radius:15px;
  box-sizing:border-box;
}
.data-box small{
  display:block;
  margin-bottom:4px;
  color:#75826E;
  font-size:12px;
  line-height:1.5;
}
.data-box strong{
  display:block;
  color:var(--green);
  font-size:21px;
  line-height:1.35;
  font-weight:850;
  word-break:normal;
  overflow-wrap:break-word;
}
.data-box em{
  display:block;
  margin-top:4px;
  color:var(--gold);
  font-size:13px;
  line-height:1.5;
  font-style:normal;
  font-weight:750;
}
.split-card{
  padding:22px 22px;
  background:#FBFDF7;
  border:1px solid #E4EFD9;
  border-radius:18px;
}
.gene-list{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
  margin:20px 0 0;
}
.gene{
  padding:12px 10px;
  border:1px solid #E4ECD9;
  border-radius:14px;
  background:#fff;
  text-align:center;
  color:var(--green);
  font-weight:800;
  font-size:15px;
  line-height:1.5;
}
.gene span{
  display:block;
  color:var(--gold);
  font-size:12px;
  margin-top:2px;
}
.footer{
  margin-top:26px;
  padding:26px 22px;
  background:#EEF8EF;
  border-radius:18px;
  text-align:center;
}
.footer h3{
  margin:0 0 8px;
  color:var(--green);
  font-size:20px;
  line-height:1.5;
}
.footer p{
  margin:0;
  color:#5F6D63;
  font-size:14px;
  line-height:1.8;
}
.qr{
  width:110px;
  height:110px;
  margin:16px auto 0;
  display:block;
}
.rank-card{
  margin-top:26px;
  padding:24px 26px 26px;
  background:#FBFCF7;
  border:1px solid #E7E6D5;
  border-radius:22px;
}
.rank-title{
  margin:0;
  color:var(--gold);
  font-size:24px;
  line-height:1.5;
  font-weight:800;
  text-align:center;
  letter-spacing:.3px;
}
.rank-sub{
  margin:6px 0 18px;
  color:#7C817D;
  font-size:13px;
  line-height:1.7;
  text-align:center;
}
.chart{position:relative;padding:8px 0 6px;}
.chart-grid{
  position:absolute;
  left:148px;
  right:58px;
  top:0;
  bottom:0;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  pointer-events:none;
}
.chart-grid span{border-left:1px dashed #E3DED0;}
.bar-row{
  position:relative;
  display:grid;
  grid-template-columns:136px 1fr 64px;
  gap:12px;
  align-items:center;
  margin:0 0 14px;
}
.bar-label{font-size:13px;line-height:1.5;color:#505855;}
.bar-track{position:relative;height:20px;background:transparent;border-radius:999px;overflow:visible;}
.bar-fill{height:20px;border-radius:999px;background:var(--teal);}
.bar-fill.muted{background:#A9C6B0;}
.bar-value{font-size:13px;line-height:1.5;color:var(--green);font-weight:700;white-space:nowrap;}
.axis{display:grid;grid-template-columns:136px 1fr 64px;gap:12px;align-items:start;margin-top:4px;}
.axis-scale{display:grid;grid-template-columns:repeat(5,1fr);font-size:12px;color:#7C817D;}
.axis-scale span{text-align:left;}
.axis-scale span:last-child{text-align:right;}

@media (max-width: 560px){
  .section{padding-left:28px;padding-right:28px;}
  .hero-title{font-size:32px;}
  .hero-title small{display:block;margin-left:0;margin-top:6px;font-size:26px;}
  .grid{grid-template-columns:1fr 1fr;}
  .bar-row{grid-template-columns:110px 1fr 58px;gap:8px;}
  .chart-grid{left:122px;right:54px;}
  .rank-card{padding-left:18px;padding-right:18px;}
}
