:root{
  --primary-green:#2E7D5B;
  --primary-green-dark:#1B5E20;
  --primary-green-light:#66BB6A;
  --primary-green-glow:rgba(46,125,91,.35);
  --beige:#FAF8F1;
  --beige-dark:#F0EBE0;
  --light-brown:#8D6E63;
  --light-orange:#FF9800;
  --light-orange-dark:#F57C00;
  --light-orange-glow:rgba(255,152,0,.35);
  --white:#FFFFFF;
  --text-dark:#2D3436;
  --text-gray:#636E72;
  --border-color:#E8E8E8;
  --shadow-sm:0 2px 8px rgba(0,0,0,.06);
  --shadow-md:0 8px 28px rgba(0,0,0,.10);
  --shadow-lg:0 16px 48px rgba(0,0,0,.14);
  --radius:16px;
  --radius-sm:10px;
  --glass:rgba(255,255,255,.72);
  --light-green:#E8F5E9;
  --ripple:rgba(255,255,255,.5);
  --transition-bounce:cubic-bezier(.34,1.56,.64,1);
}
*{margin:0;padding:0;box-sizing:border-box;}
body{font-family:'Microsoft YaHei','PingFang SC',sans-serif;line-height:1.6;color:var(--text-dark);background:var(--beige);scroll-behavior:smooth;}
/* ===== 固定 Header ===== */
#site-header{position:fixed;top:0;left:0;right:0;z-index:1000;}
.header{background:var(--glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:var(--shadow-sm);transition:box-shadow .3s;}
body{padding-top:103px;}
.header-top{background:linear-gradient(90deg,var(--primary-green-dark),var(--primary-green));color:var(--white);padding:8px 0;font-size:13px;letter-spacing:.3px;}
.header-main{padding:10px 0;}
.logo{display:flex;align-items:center;background:transparent;}
.logo img{max-height:96px;height:auto;width:auto;background:transparent;display:block;transition:transform .3s;}
.logo:hover img{transform:scale(1.04);}
/* ===== 导航 ===== */
.nav-menu{display:flex;list-style:none;gap:4px;}
.nav-menu>li{position:relative;}
.nav-menu>li>a{display:block;padding:10px 16px;color:var(--text-dark);text-decoration:none;font-weight:500;font-size:15px;transition:all .25s;border-radius:8px;position:relative;}
.nav-menu>li>a::after{content:'';position:absolute;bottom:4px;left:50%;width:0;height:2.5px;background:linear-gradient(90deg,var(--primary-green),var(--primary-green-light));border-radius:2px;transition:width .3s,left .3s;}
.nav-menu>li>a:hover{color:var(--primary-green-dark);background:rgba(46,125,91,.07);}
.nav-menu>li>a:hover::after{width:60%;left:20%;}
.nav-menu>li>a.active{color:var(--primary-green-dark);font-weight:600;}
.nav-menu>li>a.active::after{width:60%;left:20%;}
.dropdown-menu{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(10px);background:var(--white);min-width:190px;box-shadow:var(--shadow-md);border-radius:var(--radius-sm);opacity:0;visibility:hidden;transition:all .3s;z-index:999;padding:6px 0;}
.nav-menu>li:hover .dropdown-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);}
.dropdown-menu li{list-style:none;}
.dropdown-menu a{display:block;padding:11px 22px;color:var(--text-dark);text-decoration:none;font-size:14px;transition:all .2s;}
.dropdown-menu a:hover{background:var(--primary-green);color:#fff;padding-left:28px;}
/* ===== 按钮 ===== */
.btn-login{background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));color:#fff;padding:8px 22px;border-radius:22px;text-decoration:none;font-size:14px;font-weight:500;transition:all .3s;box-shadow:0 4px 14px var(--primary-green-glow);}
.btn-login:hover{transform:translateY(-2px);box-shadow:0 6px 20px var(--primary-green-glow);}
.btn-join{background:linear-gradient(135deg,var(--light-orange),var(--light-orange-dark));color:#fff;padding:8px 22px;border-radius:22px;text-decoration:none;margin-right:10px;font-weight:600;font-size:14px;transition:all .3s;box-shadow:0 4px 14px var(--light-orange-glow);}
.btn-join:hover{transform:translateY(-2px);box-shadow:0 8px 24px var(--light-orange-glow);}
.header-actions{display:flex;align-items:center;gap:0;}
.header-member-name{font-size:14px;color:var(--text-dark);margin:0 12px;font-weight:500;white-space:nowrap;}
.header-actions .btn-join + .btn-join{margin-left:10px;}
.btn-primary{display:inline-block;background:linear-gradient(135deg,var(--light-orange),var(--light-orange-dark));color:#fff;padding:13px 38px;border-radius:30px;text-decoration:none;font-size:16px;font-weight:600;transition:all .3s;border:none;cursor:pointer;box-shadow:0 6px 20px var(--light-orange-glow);position:relative;overflow:hidden;}
.btn-primary::before{content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.35),transparent);transition:left .5s;}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 10px 30px var(--light-orange-glow);}
.btn-primary:hover::before{left:120%;}
.btn-primary:active{transform:translateY(-1px) scale(.98);}
/* ===== Section ===== */
.section{padding:80px 0;position:relative;}
.section:nth-child(even){background:rgba(250,248,241,.6);}
.section-title{text-align:center;margin-bottom:55px;}
.section-title h2{font-size:34px;color:var(--primary-green-dark);margin-bottom:14px;letter-spacing:1px;position:relative;display:inline-block;}
.section-title h2::after{content:'';display:block;width:50px;height:3px;background:linear-gradient(90deg,var(--primary-green),var(--light-orange));border-radius:2px;margin:12px auto 0;}
.section-title p{color:var(--text-gray);font-size:16px;}
.container{max-width:1200px;margin:0 auto;padding:0 20px;}
.d-flex{display:flex;}
.justify-between{justify-content:space-between;}
.align-center{align-items:center;}
.gap-15{gap:15px;}
/* ===== Feature Cards (追光) ===== */
.features-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;}
.feature-card{background:var(--white);padding:42px 30px;text-align:center;border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:all .35s cubic-bezier(.23,1,.32,1);text-decoration:none;color:inherit;position:relative;overflow:hidden;border:1px solid transparent;}
.feature-card::before{content:'';position:absolute;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,var(--primary-green-glow),transparent 70%);top:var(--my,50%);left:var(--mx,50%);transform:translate(-50%,-50%);opacity:0;transition:opacity .3s;pointer-events:none;}
.feature-card:hover{transform:translateY(-12px);box-shadow:var(--shadow-lg);border-color:rgba(46,125,91,.15);}
.feature-card:hover::before{opacity:.8;}
.feature-card:hover h3{color:var(--primary-green-dark);}
.feature-card h3{transition:color .3s;}
.feature-icon{width:76px;height:76px;background:linear-gradient(135deg,var(--primary-green),var(--primary-green-light));border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 22px;font-size:30px;color:#fff;box-shadow:0 8px 24px var(--primary-green-glow);transition:transform .35s;}
.feature-card:hover .feature-icon{transform:scale(1.12) rotate(5deg);}
.feature-card p{color:var(--text-gray);font-size:14px;line-height:1.7;}
.section-compact{padding:56px 0;}
.section-compact .features-grid{gap:20px;}
.section-compact .feature-card{padding:29px 30px;}
.section-compact .feature-icon{width:53px;height:53px;font-size:22px;margin-bottom:15px;}
.section-pad-compact{padding:56px 0;}
/* ===== News ===== */
.news-list{background:var(--white);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow-sm);transition:box-shadow .3s;}
.news-list:hover{box-shadow:var(--shadow-md);}
.news-item{display:flex;justify-content:space-between;align-items:center;padding:16px 12px;border-bottom:1px solid var(--border-color);transition:all .25s;border-radius:8px;}
.news-item:hover{background:linear-gradient(90deg,rgba(46,125,91,.04),transparent);padding-left:18px;}
.news-item:last-child{border-bottom:none;}
.news-item a{color:var(--text-dark);text-decoration:none;flex:1;transition:color .2s;}
.news-item a:hover{color:var(--primary-green-dark);}
.news-tag{background:linear-gradient(135deg,var(--light-orange),var(--light-orange-dark));color:#fff;padding:3px 12px;border-radius:12px;font-size:12px;margin-right:14px;box-shadow:0 2px 8px var(--light-orange-glow);}
.news-date{color:var(--text-gray);font-size:13px;white-space:nowrap;}
/* ===== Farmers ===== */
.farmers-slider{overflow:hidden;padding-bottom:20px;}
.farmers-marquee{overflow:hidden;width:100%;}
.farmers-marquee-track{display:flex;gap:25px;width:max-content;animation:farmers-marquee var(--marquee-duration,36s) linear infinite;will-change:transform;}
.farmers-marquee-track:hover{animation-play-state:paused;}
.farmers-marquee .farmer-card{flex-shrink:0;}
@keyframes farmers-marquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}
.farmer-card{min-width:280px;background:var(--white);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:all .35s;}
.farmer-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);}
.farmer-avatar{width:100%;height:190px;background:linear-gradient(135deg,var(--primary-green-light),var(--primary-green));display:flex;align-items:center;justify-content:center;font-size:56px;color:#fff;position:relative;overflow:hidden;}
.farmer-avatar:has(.avatar-img){display:flex;align-items:center;justify-content:center;font-size:0;background:var(--beige-dark);}
.farmer-avatar::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.25),transparent 60%);pointer-events:none;z-index:2;}
.farmer-avatar:has(.avatar-img)::after{display:none;}
.farmer-avatar .avatar-img{display:block;position:absolute;inset:0;width:100%;height:100%;max-width:100%;max-height:100%;object-fit:contain;object-position:center center;z-index:1;}
.farmer-avatar.member-avatar-btn{cursor:pointer;}
.farmer-avatar.member-avatar-btn:hover .member-avatar-tip{opacity:1;}
.member-avatar-tip{position:absolute;inset:0;z-index:2;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.45);color:#fff;font-size:14px;opacity:0;transition:opacity .25s;pointer-events:none;}
.member-intro-modal{max-width:560px;}
.member-intro-label{font-size:15px;color:var(--primary-green-dark);margin:16px 0 10px;}
.member-intro-meta{display:flex;flex-wrap:wrap;gap:8px 16px;font-size:13px;color:var(--text-gray);margin:8px 0 0;}
.member-intro-body{line-height:1.9;color:#444;max-height:50vh;overflow-y:auto;}
.member-intro-body p{margin-bottom:10px;}
.member-intro-empty{color:var(--text-gray);text-align:center;padding:24px 0;}
textarea.form-control{min-height:90px;resize:vertical;}
.intro-area{min-height:220px;}
.farmer-info{padding:20px;}
/* ===== Products ===== */
.products-slider{overflow:hidden;padding-bottom:10px;}
.products-marquee{overflow:hidden;width:100%;}
.products-marquee-track{display:flex;gap:25px;width:max-content;animation:products-marquee var(--marquee-duration,30s) linear infinite;will-change:transform;}
.products-marquee-track:hover{animation-play-state:paused;}
.products-marquee .product-card{flex-shrink:0;min-width:260px;}
@keyframes products-marquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}
.products-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:25px;}
.product-card{background:var(--white);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);text-decoration:none;color:inherit;transition:all .35s;}
.product-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);}
.product-image{width:100%;height:170px;background:linear-gradient(135deg,var(--light-orange),#FFCC80);display:flex;align-items:center;justify-content:center;font-size:46px;color:#fff;position:relative;overflow:hidden;}
.product-image::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at 70% 70%,rgba(255,255,255,.2),transparent 50%);}
.product-image img{width:100%;height:100%;object-fit:cover;position:relative;z-index:1;}
.product-info{padding:18px;}
.product-location{color:var(--text-gray);font-size:13px;margin-top:6px;}
/* ===== Events ===== */
.events-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.event-card{background:var(--white);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:all .35s;}
.event-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);}
.event-img{width:100%;height:180px;overflow:hidden;}
.event-img img{width:100%;height:100%;object-fit:cover;display:block;}
.event-date{background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));color:#fff;padding:22px;text-align:center;}
.event-date .day{font-size:38px;font-weight:700;line-height:1;}
.event-date .month{font-size:13px;opacity:.9;margin-top:4px;}
.event-content{padding:24px;}
.event-meta{display:flex;gap:18px;color:var(--text-gray);font-size:14px;margin:8px 0 14px;flex-wrap:wrap;}
/* ===== Partners ===== */
.partners{background:var(--white);padding:11px 0;}
.partners .section-title{margin-bottom:16px;}
.partners .section-title h2{margin-bottom:8px;}
.partners .section-title h2::after{margin:6px auto 0;}
.partners-slider{display:flex;justify-content:center;align-items:center;gap:30px;flex-wrap:wrap;}
.partner-logo{padding:16px 28px;background:var(--beige);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--text-gray);font-weight:600;font-size:15px;transition:all .3s;border:1px solid var(--border-color);}
.partner-logo:hover{background:var(--primary-green);color:#fff;transform:translateY(-4px);box-shadow:0 8px 20px var(--primary-green-glow);border-color:var(--primary-green);}
.partner-logo .partner-img{max-height:36px;max-width:120px;object-fit:contain;display:block;}
/* ===== Footer ===== */
.footer{background:linear-gradient(135deg,var(--primary-green-dark),#0D3D11);color:#fff;padding:60px 0 30px;}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px;}
.footer-brand{color:#fff;margin-bottom:18px;font-size:20px;}
.footer-desc{opacity:.85;margin-bottom:18px;line-height:1.8;font-size:14px;}
.footer-links{list-style:none;}
.footer-links li{margin-bottom:12px;}
.footer-links a{color:#fff;text-decoration:none;opacity:.8;font-size:14px;transition:all .2s;}
.footer-links a:hover{opacity:1;padding-left:6px;color:var(--light-orange);}
.footer-bottom{border-top:1px solid rgba(255,255,255,.15);padding-top:30px;text-align:center;opacity:.7;font-size:13px;}
.footer-tip{font-size:13px;opacity:.85;}
.footer-title{color:#fff;margin-bottom:18px;font-size:16px;}
/* ===== Page Header ===== */
.page-header{background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));color:#fff;padding:80px 0 50px;text-align:center;margin-top:0;position:relative;overflow:hidden;}
.page-header::before{content:'';position:absolute;top:-50%;right:-10%;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.08),transparent 70%);}
.page-header::after{content:'';position:absolute;bottom:-30%;left:-5%;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(255,152,0,.1),transparent 70%);}
.page-header h1{font-size:36px;position:relative;z-index:1;}
.page-header p{opacity:.9;position:relative;z-index:1;margin-top:8px;}
.page-content{padding:50px 0;}
.content-wrapper{background:var(--white);border-radius:var(--radius);padding:40px;box-shadow:var(--shadow-md);}
/* ===== Forms ===== */
.form-group{margin-bottom:22px;}
.form-group label{display:block;margin-bottom:8px;font-weight:500;font-size:14px;color:var(--text-dark);}
.form-control{width:100%;padding:12px 16px;border:1.5px solid var(--border-color);border-radius:var(--radius-sm);font-size:15px;outline:none;transition:all .25s;background:var(--beige);}
.form-control:focus{border-color:var(--primary-green);background:#fff;box-shadow:0 0 0 3px var(--primary-green-glow);}
/* ===== Table ===== */
.table{width:100%;border-collapse:collapse;}
.table th,.table td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--border-color);}
.table th{background:var(--beige-dark);font-weight:600;color:var(--primary-green-dark);font-size:14px;}
.table tr:hover td{background:rgba(46,125,91,.03);}
/* ===== Utilities ===== */
.text-center{text-align:center;}
.text-right{text-align:right;}
.mt-20{margin-top:20px;}
.mt-30{margin-top:30px;}
.mb-20{margin-bottom:20px;}
.green{color:var(--primary-green);}
.muted{color:var(--text-gray);font-size:13px;}
.empty{text-align:center;color:var(--text-gray);padding:40px 0;}
/* ===== Buttons (small) ===== */
.btn{display:inline-block;padding:8px 20px;border-radius:8px;text-decoration:none;font-size:14px;border:none;cursor:pointer;transition:all .25s;font-weight:500;position:relative;overflow:hidden;}
/* 波纹效果 */
.btn-primary,.btn-join,.btn-login,.btn-success,.btn::after{position:relative;overflow:hidden;}
.ripple{position:absolute;border-radius:50%;background:var(--ripple);transform:scale(0);animation:rippleAnim .6s ease-out;pointer-events:none;}
@keyframes rippleAnim{to{transform:scale(4);opacity:0;}}
.btn-success{background:var(--primary-green);color:#fff;box-shadow:0 3px 10px var(--primary-green-glow);}
.btn-success:hover{background:var(--primary-green-dark);transform:translateY(-2px);}
.btn-warning{background:var(--light-orange);color:#fff;}
.btn-danger{background:#E53935;color:#fff;}
.btn-danger:hover{background:#C62828;}
.btn-secondary{background:var(--text-gray);color:#fff;}
a.btn-secondary,.btn-secondary{display:inline-block;padding:8px 24px;border-radius:8px;background:var(--text-gray);color:#fff;text-decoration:none;font-size:14px;font-weight:500;transition:all .25s;border:none;cursor:pointer;position:relative;overflow:hidden;}
a.btn-secondary:hover,.btn-secondary:hover{background:#424942;transform:translateY(-2px);}
.btn-sm{padding:6px 14px;font-size:12px;}
.btn-outline{background:#fff;color:var(--primary-green-dark);border:1.5px solid var(--primary-green);}
.btn-outline:hover{background:var(--primary-green);color:#fff;}
/* ===== Banner ===== */
.banner{position:relative;height:350px;overflow:hidden;}
.banner-slide{position:absolute;width:100%;height:100%;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity 1s;}
.banner-slide.active{opacity:1;}
.banner-content{text-align:center;color:#fff;max-width:800px;padding:0 20px;z-index:2;}
.banner-content h1{font-size:50px;margin-bottom:20px;text-shadow:0 4px 20px rgba(0,0,0,.4);letter-spacing:2px;}
.banner-content p{font-size:20px;text-shadow:0 2px 10px rgba(0,0,0,.3);margin-bottom:30px;opacity:.95;}
.banner-slide::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 70% 30%,rgba(255,255,255,.1),transparent 50%);animation:bannerShine 8s ease-in-out infinite;}
@keyframes bannerShine{0%,100%{opacity:.3;}50%{opacity:.8;}}
/* ===== Tech Cards ===== */
.tech-card{display:flex;gap:20px;background:#fff;padding:24px;border-radius:var(--radius);box-shadow:var(--shadow-sm);text-decoration:none;color:inherit;transition:all .3s;margin-bottom:20px;position:relative;overflow:hidden;}
.tech-card::before{content:'';position:absolute;width:260px;height:260px;border-radius:50%;background:radial-gradient(circle,var(--primary-green-glow),transparent 70%);top:var(--my,50%);left:var(--mx,50%);transform:translate(-50%,-50%);opacity:0;transition:opacity .3s;pointer-events:none;}
.tech-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);}
.tech-card:hover::before{opacity:.6;}
.tech-icon{width:68px;height:68px;min-width:68px;background:linear-gradient(135deg,var(--primary-green),var(--primary-green-light));border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:30px;color:#fff;box-shadow:0 6px 18px var(--primary-green-glow);transition:transform .3s;}
.tech-card:hover .tech-icon{transform:scale(1.1);}
.tech-info h4{margin-bottom:6px;color:var(--primary-green-dark);}
.tech-cat{display:inline-block;background:var(--beige);color:var(--primary-green-dark);padding:2px 10px;border-radius:10px;font-size:12px;margin-bottom:8px;}
.tech-info p{color:var(--text-gray);font-size:14px;}
.tech-summary{font-size:17px;color:var(--primary-green-dark);background:var(--beige);padding:18px 22px;border-radius:var(--radius-sm);margin-bottom:25px;border-left:4px solid var(--primary-green);}
/* ===== Detail Page ===== */
.detail-page{max-width:860px;}
.detail-title{font-size:30px;color:var(--primary-green-dark);line-height:1.4;margin-bottom:16px;text-align:center;}
.detail-meta{text-align:center;color:var(--text-gray);font-size:14px;padding-bottom:20px;border-bottom:1px solid var(--border-color);margin-bottom:28px;}
.detail-body{font-size:16px;}
.detail-body p{line-height:2;margin-bottom:14px;}
.rich-content img{max-width:100%;height:auto;border-radius:8px;margin:12px 0;display:block;}
.rich-content p{line-height:2;margin-bottom:14px;}
.product-card-click{cursor:pointer;}
.product-hit{cursor:pointer;}
.product-info h4.product-hit:hover{color:var(--primary-green-dark);}
.product-image.product-hit:hover{opacity:.95;}
.detail-cover{width:100%;height:min(56vw,360px);min-height:200px;display:flex;align-items:center;justify-content:center;background:var(--beige-dark);border-radius:8px;overflow:hidden;margin-bottom:18px;}
.detail-cover img{display:block;width:100%;height:100%;max-width:100%;max-height:100%;object-fit:contain;object-position:center center;border-radius:8px;}
.product-contact-line{margin:0 0 12px;font-size:15px;color:var(--primary-green-dark);}
.detail-back{margin-top:36px;text-align:center;}
/* ===== Toast ===== */
.toast{position:fixed;top:24px;left:50%;transform:translate(-50%,-80px);background:#333;color:#fff;padding:14px 30px;border-radius:30px;z-index:10000;opacity:0;transition:all .3s;font-size:15px;box-shadow:0 8px 30px rgba(0,0,0,.25);}
.toast.show{opacity:1;transform:translate(-50%,0);}
.toast.success{background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));}
.toast.error{background:linear-gradient(135deg,#E53935,#C62828);}
/* ===== Modal ===== */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999;}
.modal-box{background:#fff;border-radius:var(--radius);padding:32px;width:90%;max-width:420px;box-shadow:0 20px 60px rgba(0,0,0,.3);}
.modal-box h3{margin-bottom:22px;color:var(--primary-green-dark);text-align:center;}
.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:8px;}
.form-actions .btn{padding:10px 24px;}
/* ===== Fixed Contact ===== */
.fixed-contact{position:fixed;right:18px;top:50%;transform:translateY(-50%);z-index:999;display:flex;flex-direction:column;gap:10px;}
.fixed-contact a{width:48px;height:48px;background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;text-decoration:none;font-size:20px;box-shadow:0 4px 16px var(--primary-green-glow);transition:all .3s;}
.fixed-contact a:hover{transform:scale(1.15) rotate(8deg);}
/* ===== QR Code ===== */
.qrcode-box{width:120px;height:120px;background:#fff;border-radius:var(--radius-sm);margin:0 auto 10px;padding:6px;overflow:hidden;display:flex;align-items:center;justify-content:center;}
.qrcode-box img{width:100%;height:100%;object-fit:contain;display:block;}
.qrcode-modal{width:180px;height:180px;padding:8px;margin:10px auto 16px;}
/* ===== Admin ===== */
.admin-header{background:var(--primary-green-dark);color:#fff;padding:15px 30px;display:flex;justify-content:space-between;align-items:center;}
.admin-sidebar{width:250px;background:#fff;height:calc(100vh - 70px);position:fixed;left:0;top:70px;box-shadow:2px 0 10px rgba(0,0,0,.1);padding:20px 0;}
.admin-menu{list-style:none;}
.admin-menu li a{display:block;padding:14px 30px;color:var(--text-dark);text-decoration:none;transition:all .25s;border-left:3px solid transparent;font-size:14px;}
.admin-menu li a:hover,.admin-menu li a.active{background:var(--beige);color:var(--primary-green-dark);border-left-color:var(--primary-green);}
.admin-content{margin-left:250px;padding:30px;background:var(--beige);min-height:calc(100vh - 70px);}
.admin-card{background:#fff;border-radius:var(--radius-sm);padding:25px;box-shadow:var(--shadow-sm);margin-bottom:25px;}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:30px;}
.stat-card{background:linear-gradient(135deg,#fff,var(--beige));padding:25px;border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);transition:transform .25s;}
.stat-card:hover{transform:translateY(-4px);}
.stat-number{font-size:36px;font-weight:700;background:linear-gradient(135deg,var(--primary-green),var(--primary-green-dark));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.pagination{display:flex;justify-content:center;gap:10px;margin-top:30px;}
.pagination a{padding:8px 15px;border:1px solid var(--border-color);border-radius:6px;text-decoration:none;color:var(--text-dark);transition:all .2s;}
.pagination a:hover,.pagination a.active{background:var(--primary-green);color:#fff;border-color:var(--primary-green);}
.admin-table img.thumb{width:50px;height:50px;border-radius:6px;object-fit:cover;}
.admin-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:12px;}
.admin-modal{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px;}
.admin-modal .modal-box{max-width:640px;max-height:88vh;overflow-y:auto;}
/* ===== Grid Layouts ===== */
.row-2{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.row-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;}
.contact-info-box{background:var(--beige);padding:30px;border-radius:var(--radius);line-height:2.4;}
.contact-info-box p{margin-bottom:6px;}
.form-card{background:#fff;padding:30px;border-radius:var(--radius);border:1px solid var(--border-color);}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.form-hint{margin-top:8px;font-size:13px;color:var(--text-gray);line-height:1.5;}
.join-photo-upload{display:flex;gap:16px;align-items:flex-start;}
.join-photo-preview{width:120px;height:120px;border-radius:var(--radius);border:2px dashed var(--border-color);background:var(--beige) center/cover no-repeat;flex-shrink:0;display:flex;align-items:center;justify-content:center;}
.join-photo-placeholder{font-size:13px;color:var(--text-gray);}
.join-photo-preview.has-photo .join-photo-placeholder{display:none;}
.join-photo-side{flex:1;min-width:0;}
.market-type-tabs{display:flex;gap:12px;flex-wrap:wrap;}
.login-type-tabs{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:20px;}
.sms-code-row{display:flex;gap:10px;align-items:center;}
.sms-code-row .form-control{flex:1;min-width:0;}
.sms-code-row .btn{flex-shrink:0;white-space:nowrap;}
.farmers-list{display:grid;grid-template-columns:repeat(3,1fr);gap:25px;}
.member-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:12px 20px;margin-bottom:24px;}
.member-toolbar .form-control{max-width:360px;flex:1;min-width:200px;}
.member-toolbar-tip{font-size:14px;color:var(--text-gray);}
.pagination-ellipsis{padding:8px 4px;color:var(--text-gray);}
.badge{display:inline-block;padding:2px 10px;border-radius:10px;font-size:12px;color:#fff;}
.badge-ok{background:var(--primary-green);}
.badge-no{background:var(--text-gray);}
.badge-wait{background:var(--light-orange);}
/* ===== Animations ===== */
.fade{opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease;}
.fade.in{opacity:1;transform:none;}
@keyframes floatUp{0%{opacity:0;transform:translateY(40px);}100%{opacity:1;transform:none;}}
/* ===== 高级增强 ===== */
/* Banner 动态光泽 */
.banner-slide::after{content:'';position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);animation:bannerSweep 6s ease-in-out infinite;z-index:1;}
@keyframes bannerSweep{0%,100%{left:-100%;}50%{left:200%;}}
/* 卡片追光通用 */
.feature-card,.tech-card,.product-card,.farmer-card,.event-card,.partner-logo{position:relative;overflow:visible;}
.feature-card::before,.tech-card::before{z-index:0;}
.feature-card>*{position:relative;z-index:1;}
.tech-card>*{position:relative;z-index:1;}
/* page-header 粒子装饰 */
.page-header h1{animation:fadeSlideDown .8s ease;}
.page-header p{animation:fadeSlideUp .8s ease .15s both;}
@keyframes fadeSlideDown{from{opacity:0;transform:translateY(-20px);}to{opacity:1;transform:none;}}
@keyframes fadeSlideUp{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:none;}}
/* 导航 active 发光 */
.nav-menu>li>a.active{background:rgba(46,125,91,.08);}
/* 产品卡片追光 */
.product-card::before{content:'';position:absolute;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,var(--light-orange-glow),transparent 70%);top:var(--my,50%);left:var(--mx,50%);transform:translate(-50%,-50%);opacity:0;transition:opacity .3s;pointer-events:none;z-index:0;}
.product-card:hover::before{opacity:.6;}
.product-card>*{position:relative;z-index:1;}
/* 会员卡片追光 */
.farmer-card::before{content:'';position:absolute;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,var(--primary-green-glow),transparent 70%);top:var(--my,50%);left:var(--mx,50%);transform:translate(-50%,-50%);opacity:0;transition:opacity .3s;pointer-events:none;z-index:0;}
.farmer-card:hover::before{opacity:.5;}
.farmer-card>*{position:relative;z-index:1;}
/* 活动卡片追光 */
.event-card::before{content:'';position:absolute;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,var(--primary-green-glow),transparent 70%);top:var(--my,50%);left:var(--mx,50%);transform:translate(-50%,-50%);opacity:0;transition:opacity .3s;pointer-events:none;z-index:0;}
.event-card:hover::before{opacity:.5;}
.event-card>*{position:relative;z-index:1;}
/* 滚动条美化 */
::-webkit-scrollbar{width:8px;height:8px;}
::-webkit-scrollbar-track{background:var(--beige-dark);}
::-webkit-scrollbar-thumb{background:var(--primary-green-light);border-radius:4px;}
::-webkit-scrollbar-thumb:hover{background:var(--primary-green);}
/* 选中文本 */
::selection{background:var(--primary-green);color:#fff;}
/* 输入框聚焦发光 */
.form-control:focus{box-shadow:0 0 0 4px rgba(46,125,91,.12);}
/* 新闻标签动画 */
.news-tag{transition:all .25s;}
.news-item:hover .news-tag{transform:scale(1.08);}
/* 合作伙伴 hover 发光 */
.partner-logo::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at center,rgba(46,125,91,.1),transparent 70%);opacity:0;transition:opacity .3s;}
.partner-logo:hover::before{opacity:1;}
/* 按钮 hover 发光增强 */
.btn-join:hover,.btn-login:hover{filter:brightness(1.08);}
/* section-title 动画 */
.section-title h2{animation:fadeSlideDown .6s ease;}
.section-title p{animation:fadeSlideUp .6s ease .1s both;}
/* ===== Responsive ===== */
@media (prefers-reduced-motion:reduce){
  .farmers-marquee-track,.products-marquee-track{animation:none;flex-wrap:wrap;justify-content:center;width:100%;}
}
@media(max-width:1024px){
  .features-grid,.products-grid{grid-template-columns:repeat(2,1fr);}
  .events-grid,.footer-grid{grid-template-columns:repeat(2,1fr);}
  .nav-menu{display:none;}
  .row-3,.farmers-list{grid-template-columns:repeat(2,1fr);}
  .contact-grid{grid-template-columns:1fr;}
}
@media(max-width:768px){
  body{padding-top:81px;}
  .banner{height:252px;}
  .banner-content h1{font-size:28px;}
  .banner-content p{font-size:16px;}
  .features-grid,.products-grid,.events-grid,.footer-grid,.stats-grid,.row-3,.farmers-list,.form-row{grid-template-columns:1fr;}
  .content-wrapper{padding:20px;}
  .admin-sidebar{display:none;}
  .admin-content{margin-left:0;}
  .section{padding:50px 0;}
  .section-compact,.section-pad-compact{padding:35px 0;}
  .section-title h2{font-size:28px;}
}
