/* ==========================================================================
   花不弃庄园 · 通用组件
   ========================================================================== */

/* ====================== 按钮 ====================== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  height:46px;padding:0 24px;border-radius:var(--r-pill);
  font-size:15px;font-weight:600;letter-spacing:.02em;
  transition:transform .12s ease,box-shadow .12s ease,background .2s;
  white-space:nowrap;
}
.btn:active{transform:scale(.97)}
.btn-primary{background:var(--green-700);color:#fff;box-shadow:var(--shadow-soft)}
.btn-terracotta{background:var(--terracotta);color:#fff;box-shadow:var(--shadow-fab)}
.btn-ghost{background:transparent;color:var(--green-700);border:1.5px solid var(--green-700)}
.btn-soft{background:var(--green-100);color:var(--green-900)}
.btn-block{display:flex;width:100%}
.btn-sm{height:34px;padding:0 16px;font-size:13px}
.btn-text{color:var(--green-700);font-size:13px;font-weight:600;display:inline-flex;align-items:center;gap:2px}
.btn-text::after{content:"›";font-size:18px;line-height:1;transition:transform .15s}
.btn-text:hover::after{transform:translateX(2px)}

/* ====================== 卡片 ====================== */
.card{
  background:var(--cream);
  border-radius:var(--r-lg);
  box-shadow:var(--shadow-card);
  overflow:hidden;
}
.card-pad{padding:var(--sp-4)}
.card-tinted{background:var(--green-100)}

/* ====================== 标签 Tag ====================== */
.tag{
  display:inline-flex;align-items:center;gap:3px;
  height:22px;padding:0 9px;border-radius:var(--r-pill);
  font-size:11px;font-weight:600;line-height:1;
}
.tag-green{background:var(--green-100);color:var(--green-700)}
.tag-reborn{background:var(--green-100);color:var(--green-700)}
.tag-recovering{background:#FBEACB;color:#A4721A}
.tag-welfare{background:var(--terracotta);color:#fff}
.tag-member{background:var(--sunny);color:#6B4A12}
.tag-outline{background:transparent;border:1px solid var(--wood);color:var(--ink-60)}

/* ====================== 顶部导航 NavBar ====================== */
.navbar{
  position:sticky;top:0;z-index:40;
  height:50px;display:flex;align-items:center;gap:8px;
  padding:0 var(--page-pad);
  background:rgba(251,248,241,.92);
  backdrop-filter:saturate(1.4) blur(8px);
  -webkit-backdrop-filter:saturate(1.4) blur(8px);
}
.navbar .back{width:34px;height:34px;display:flex;align-items:center;justify-content:center;color:var(--ink)}
.navbar .title{flex:1;font-weight:600;font-size:16px;text-align:center;margin:0 -34px 0 0}
.navbar .right{display:flex;align-items:center;gap:8px;color:var(--green-700)}
/* 导航品牌标识：花不弃 logo + 页面副名 */
.navbar .brand{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;line-height:1;margin:0 -34px 0 0}
.navbar .brand .b-logo{display:inline-flex;align-items:center;gap:6px}
.navbar .brand .b-logo svg{width:20px;height:20px}
.navbar .brand .b-logo .lw-main{font-family:var(--font-serif);font-weight:800;font-size:17px;color:var(--ink);letter-spacing:.05em}
.navbar .brand .b-page{font-size:10px;color:var(--ink-60);letter-spacing:.15em;margin-top:3px}
/* 深色背景导航（pickup/member/profile）的品牌标识用白字 */
.navbar.on-dark .brand .b-logo .lw-main{color:#FBF8F1}
.navbar.on-dark .brand .b-logo svg{color:#FBF8F1}
.navbar.on-dark .brand .b-page{color:rgba(255,255,255,.8)}
.navbar.on-dark .back{color:#FBF8F1}
/* 沉浸式透明导航（首页 Hero 用） */
.navbar-ghost{
  position:absolute;top:0;left:0;right:0;z-index:40;
  height:50px;display:flex;align-items:center;justify-content:space-between;
  padding:0 var(--page-pad);color:#fff;
}
.navbar-ghost .loc{display:flex;align-items:center;gap:3px;font-size:12px;font-weight:600;
  background:rgba(61,52,42,.32);padding:5px 10px;border-radius:var(--r-pill);backdrop-filter:blur(4px)}
.navbar-ghost .member{font-size:12px;font-weight:600;
  background:rgba(255,255,255,.22);padding:5px 10px;border-radius:var(--r-pill);backdrop-filter:blur(4px)}

/* ====================== 底部 TabBar ====================== */
.tabbar{
  position:fixed;left:50%;transform:translateX(-50%);bottom:0;
  width:100%;max-width:430px;z-index:50;
  height:calc(var(--tabbar-h) + var(--safe-bottom));
  padding-bottom:var(--safe-bottom);
  display:flex;background:rgba(251,248,241,.95);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border-top:1px solid var(--ink-10);
}
.tabbar a{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;
  color:var(--ink-30);font-size:10px;font-weight:600}
.tabbar a.on{color:var(--green-700)}
.tabbar svg{width:24px;height:24px}

/* ====================== 悬浮按钮 FAB（免费收花，全站常驻） ====================== */
.fab{
  position:fixed;right:14px;bottom:calc(var(--tabbar-h) + var(--safe-bottom) + 14px);
  z-index:45;display:flex;align-items:center;gap:6px;
  height:46px;padding:0 18px 0 14px;border-radius:var(--r-pill);
  background:linear-gradient(135deg,var(--terracotta),var(--terracotta-d));
  color:#fff;font-size:14px;font-weight:700;box-shadow:var(--shadow-fab);
  animation:fabPulse 2.6s ease-in-out infinite;
}
.fab:active{transform:scale(.96)}
.fab svg{width:22px;height:22px}
@keyframes fabPulse{0%,100%{box-shadow:0 6px 18px rgba(217,142,90,.35)}50%{box-shadow:0 8px 26px rgba(217,142,90,.55)}}

/* ====================== 栅格工具 ====================== */
.row{display:flex;align-items:center}
.row-between{display:flex;align-items:center;justify-content:space-between}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}
.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mt-5{margin-top:20px}.mt-6{margin-top:24px}
.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}
.center{display:flex;align-items:center;justify-content:center}

/* ====================== 价格 ====================== */
.price{color:var(--terracotta);font-weight:800;font-family:var(--font-serif)}
.price .sym{font-size:13px;font-weight:700}
.price .num{font-size:20px}
.price .old{font-size:12px;color:var(--ink-30);text-decoration:line-through;font-weight:400;margin-left:5px;font-family:var(--font-sans)}

/* ====================== 分隔 ====================== */
.hr{height:1px;background:var(--ink-10);border:none;margin:var(--sp-4) 0}
.divider-dot{display:flex;align-items:center;gap:8px;color:var(--ink-30);font-size:12px}
.divider-dot::before,.divider-dot::after{content:"";flex:1;height:1px;background:var(--ink-10)}

/* ====================== 表单 ====================== */
.field{margin-bottom:14px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--ink);margin-bottom:6px}
.field label .req{color:var(--terracotta)}
.input,.textarea,.select{
  width:100%;background:var(--cream);border:1.5px solid var(--ink-10);
  border-radius:var(--r-md);padding:13px 14px;font-size:14px;
  transition:border-color .2s,background .2s;
}
.input:focus,.textarea:focus,.select:focus{outline:none;border-color:var(--green-500);background:#fff}
.textarea{min-height:90px;resize:vertical;line-height:1.6}
.upload{border:1.5px dashed var(--wood);border-radius:var(--r-md);background:var(--cream);
  height:96px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:var(--ink-60);font-size:12px}
.upload svg{width:28px;height:28px;color:var(--green-500)}

/* ====================== Toast ====================== */
.toast{
  position:fixed;left:50%;top:50%;transform:translate(-50%,-50%) scale(.9);
  z-index:99;background:rgba(61,52,42,.92);color:#fff;
  padding:14px 22px;border-radius:var(--r-md);font-size:14px;
  opacity:0;pointer-events:none;transition:opacity .25s,transform .25s;
  max-width:80%;text-align:center;line-height:1.5;
}
.toast.show{opacity:1;transform:translate(-50%,-50%) scale(1)}

/* ====================== 区块标题（带"查看全部"） ====================== */
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:14px}
.sec-head .h2 .leaf{width:6px;height:18px;background:var(--green-300);border-radius:3px}

/* ====================== 数据墙 ====================== */
.stat-num{font-family:var(--font-serif);font-size:22px;font-weight:800;color:var(--green-700);line-height:1}
.stat-lbl{font-size:11px;color:var(--ink-60);margin-top:4px}

/* ====================== 轮播圆点 ====================== */
.dots{display:flex;justify-content:center;gap:6px;margin-top:10px}
.dots span{width:6px;height:6px;border-radius:50%;background:var(--ink-30);transition:all .3s}
.dots span.on{width:18px;border-radius:3px;background:var(--green-700)}

/* ==========================================================================
   品牌 Logo 组件
   ========================================================================== */
.logo-mark{display:inline-flex;align-items:center;justify-content:center}
.logo-mark svg{display:block}
.logo-full{display:inline-flex;align-items:center;gap:7px}
.lw{display:inline-flex;flex-direction:column;line-height:1}
.lw-main{font-family:var(--font-serif);font-weight:800;letter-spacing:.04em}
.lw-sub{font-family:var(--font-serif);font-size:11px;font-weight:500;letter-spacing:.18em;opacity:.82;margin-top:5px}

/* 导航栏小 logo（横排 图标+花不弃） */
.navbar .logo-full,.navbar-ghost .logo-full{gap:6px}
.navbar .logo-full svg,.navbar-ghost .logo-full svg{width:24px;height:24px}
.navbar .lw-main,.navbar-ghost .lw-main{font-size:18px}

/* 首页 Hero 大 logo（品牌字样突出，客户需求） */
.hero-logo{display:flex;flex-direction:column;align-items:flex-start;margin-bottom:18px}
.hero-logo .mark-big{width:58px;height:58px;margin-bottom:14px;filter:drop-shadow(0 4px 12px rgba(0,0,0,.25))}
.hero-logo .mark-big svg{width:58px;height:58px}
.hero-logo .word-big{font-family:var(--font-serif);font-weight:800;font-size:52px;letter-spacing:.06em;line-height:1;
  color:#FBF8F1;text-shadow:0 4px 18px rgba(0,0,0,.35),0 1px 0 rgba(255,255,255,.15)}
.hero-logo .word-tag{display:inline-flex;align-items:center;gap:8px;margin-top:12px;
  font-size:11px;letter-spacing:.2em;font-weight:600;color:#FBF8F1;
  background:rgba(255,255,255,.16);padding:5px 12px;border-radius:var(--r-pill);backdrop-filter:blur(4px)}
.hero-logo .word-tag::before{content:"";width:5px;height:5px;border-radius:50%;background:#A8C97F}

/* ====================== 植物居民卡片 ====================== */
.plant-card{display:block}
.plant-card__img{
  height:130px;background-size:cover;background-position:center;
  position:relative;
}
.plant-card__img .tag{position:absolute;left:10px;top:10px}
.plant-card__body{padding:12px 14px 14px}
.plant-card__body .h3{font-size:16px}

/* ====================== Hero 区 ====================== */
.hero{
  position:relative;height:340px;
  background-size:cover;background-position:center;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:0 var(--page-pad) 28px;color:#fff;
}
.hero::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(61,52,42,.15) 0%,rgba(61,52,42,0) 40%,rgba(61,52,42,.55) 100%);}
.hero>*{position:relative;z-index:2}
.hero .slogan{font-family:var(--font-serif);font-size:30px;font-weight:700;line-height:1.3;
  text-shadow:0 2px 12px rgba(0,0,0,.3);margin-bottom:8px}
.hero .sub{font-size:13px;opacity:.92;text-shadow:0 1px 6px rgba(0,0,0,.3);font-weight:500}

/* 收花大入口条 */
.pickup-cta{
  margin:-22px var(--page-pad) 0;position:relative;z-index:5;
  background:linear-gradient(135deg,var(--terracotta),var(--terracotta-d));
  border-radius:var(--r-lg);padding:14px 16px;color:#fff;
  display:flex;align-items:center;gap:12px;box-shadow:var(--shadow-fab);
}
.pickup-cta .ic-wrap{width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.22);
  display:flex;align-items:center;justify-content:center;flex:none}
.pickup-cta .ic-wrap svg{width:24px;height:24px}
.pickup-cta .t{flex:1}
.pickup-cta .t b{font-size:15px;display:block;line-height:1.3}
.pickup-cta .t small{font-size:11.5px;opacity:.9}
.pickup-cta .go{width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.25);
  display:flex;align-items:center;justify-content:center}
.pickup-cta .go svg{width:18px;height:18px}

/* 六宫格入口 */
.entry-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.entry{display:flex;flex-direction:column;align-items:center;gap:8px;
  padding:16px 6px;background:var(--cream);border-radius:var(--r-md);
  box-shadow:var(--shadow-card);transition:transform .12s}
.entry:active{transform:scale(.96)}
.entry .icb{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center}
.entry .icb svg{width:26px;height:26px;color:#fff}
.entry .name{font-size:13px;font-weight:600;color:var(--ink)}
.entry .desc{font-size:10.5px;color:var(--ink-60)}

/* 分区 banner */
.season-banner{
  margin:0 var(--page-pad);border-radius:var(--r-lg);overflow:hidden;
  position:relative;height:110px;display:flex;align-items:center;
  box-shadow:var(--shadow-card);
}
.season-banner .pic{position:absolute;inset:0;background-size:cover;background-position:center}
.season-banner .pic::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.45),rgba(0,0,0,0))}
.season-banner .txt{position:relative;z-index:2;color:#fff;padding:0 20px}
.season-banner .txt b{font-family:var(--font-serif);font-size:18px;display:block}
.season-banner .txt small{font-size:12px;opacity:.92}

/* 内容瀑布流(庄园日常) */
.feed-item{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--ink-10)}
.feed-item:last-child{border-bottom:none}
.feed-item .thumb{width:84px;height:84px;border-radius:var(--r-md);flex:none;background-size:cover;background-position:center}
.feed-item .meta{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:space-between}
.feed-item .ftag{display:inline-block;font-size:10px;color:var(--green-700);background:var(--green-100);
  padding:2px 7px;border-radius:var(--r-pill);font-weight:600;align-self:flex-start}
.feed-item .ftitle{font-size:14px;font-weight:600;line-height:1.4;margin-top:6px;color:var(--ink)}
.feed-item .finfo{font-size:11px;color:var(--ink-60);margin-top:4px}

/* 数据墙 */
.stat-wall{display:flex;justify-content:space-around;text-align:center;
  background:var(--green-100);border-radius:var(--r-lg);padding:18px 8px;margin:0 var(--page-pad)}
