:root {
  --wood:#6b4423; --wood-dark:#4a2e17; --wood-light:#8a5a30;
  --paper:#f3e9d2; --paper-dark:#e6d6b3; --ink:#2b2118;
  --red:#b5322e; --red-dark:#8c2420; --gold:#c8932f;
  --green:#5a7d4f; --muted:#8a7a5f;
  --shadow:0 6px 18px rgba(40,25,10,.28);
}
* { box-sizing:border-box; }
body {
  margin:0; color:var(--ink);
  font-family:"Hiragino Sans","PingFang SC","Microsoft YaHei",sans-serif;
  background:
    radial-gradient(circle at 20% 10%, rgba(255,255,255,.05), transparent 40%),
    repeating-linear-gradient(0deg, #5c3a1d, #5c3a1d 38px, #573619 38px, #573619 40px);
  min-height:100vh;
}
a { color:var(--red); }
button { font-family:inherit; cursor:pointer; }

/* ---------- 顶部招牌 ---------- */
header.signboard {
  background:linear-gradient(180deg,var(--wood-light),var(--wood) 60%,var(--wood-dark));
  border-bottom:6px solid var(--wood-dark);
  box-shadow:var(--shadow);
  position:sticky; top:0; z-index:50;
}
.nav { max-width:1080px; margin:0 auto; display:flex; align-items:center; gap:18px; padding:12px 20px; position:relative; }
.navlinks { display:flex; align-items:center; gap:18px; }
.hamburger { display:none; background:none; border:none; color:var(--paper); font-size:26px; line-height:1; padding:4px 8px; cursor:pointer; }
.brand { display:flex; align-items:center; gap:12px; cursor:pointer; }
.brand .plaque {
  background:var(--paper); color:var(--wood-dark); font-weight:800;
  padding:6px 14px; border-radius:6px; border:3px solid var(--wood-dark);
  letter-spacing:.15em; box-shadow:inset 0 0 0 2px var(--paper-dark);
  font-size:22px; transform:rotate(-2deg);
}
.brand .sub { color:var(--paper); font-size:13px; opacity:.9; }
.nav .spacer { flex:1; }
.nav a.navlink { color:var(--paper); text-decoration:none; font-weight:600; padding:6px 10px; border-radius:6px; }
.nav a.navlink:hover { background:rgba(0,0,0,.18); }
.bell { position:relative; background:none; border:none; font-size:20px; color:var(--paper); }
.bell .dot {
  position:absolute; top:-2px; right:-4px; background:var(--red); color:#fff;
  border-radius:10px; font-size:11px; padding:0 5px; line-height:16px; min-width:16px; text-align:center;
}

/* 手机端：顶部导航折叠为汉堡菜单 */
@media (max-width:768px) {
  .brand .sub { display:none; }
  .brand .plaque { font-size:19px; padding:5px 12px; }
  .hamburger { display:block; }
  .navlinks {
    display:none; position:absolute; top:100%; right:8px; left:8px; z-index:60;
    flex-direction:column; align-items:stretch; gap:4px;
    background:var(--wood-dark); border:1px solid rgba(0,0,0,.25);
    border-radius:0 0 12px 12px; padding:8px; box-shadow:var(--shadow);
  }
  .navlinks.open { display:flex; }
  .nav a.navlink { padding:12px 14px; border-radius:8px; font-size:16px; }
  .navlinks .bell { padding:12px 14px; text-align:left; font-size:18px; }
}

/* ---------- 容器 / 纸张卡片 ---------- */
.wrap { max-width:1080px; margin:24px auto; padding:0 20px; }
.paper {
  background:var(--paper); border-radius:10px; padding:22px;
  box-shadow:var(--shadow); border:1px solid var(--paper-dark);
  position:relative;
}
.paper + .paper { margin-top:18px; }
h1,h2,h3 { margin:0 0 12px; }
.section-title { display:flex; align-items:center; gap:10px; }
.section-title::before { content:"●"; color:var(--red); font-size:12px; }

/* ---------- 英雄区 ---------- */
.hero { text-align:center; padding:34px 22px; }
.hero .big { font-size:34px; font-weight:900; letter-spacing:.05em; }
.hero .tagline { color:var(--muted); margin:8px 0 18px; font-size:16px; }

/* ---------- 按钮 ---------- */
.btn { border:none; border-radius:8px; padding:10px 18px; font-weight:700; font-size:14px; }
.btn-red { background:var(--red); color:#fff; }
.btn-red:hover { background:var(--red-dark); }
.btn-wood { background:var(--wood); color:var(--paper); }
.btn-wood:hover { background:var(--wood-dark); }
.btn-ghost { background:transparent; border:2px solid var(--wood); color:var(--wood-dark); }
.btn-green { background:var(--green); color:#fff; }
.btn-sm { padding:6px 12px; font-size:13px; }

/* ---------- 欢迎 NPC（定春，标题右侧） ---------- */
.yz-hero-row { position:relative; min-height:160px; display:flex; align-items:center; justify-content:center; }
.yz-hero-text { width:100%; text-align:center; }
.yz-hero-dog { position:absolute; right:0; top:50%; transform:translateY(-50%); width:165px; }
@media (max-width:768px) {
  .yz-hero-row { flex-direction:column; min-height:0; }
  .yz-hero-dog { position:static; transform:none; width:160px; margin:14px auto 0; }
}
.yz-scene { width:100%; height:auto; display:block; }
.yz-bubble {
  position:relative; display:inline-block; margin:0 auto 4px;
  background:#fffdf6; color:var(--ink); border:2px solid var(--wood);
  border-radius:14px; padding:8px 14px; font-weight:600; font-size:13px; line-height:1.4;
  box-shadow:0 3px 10px rgba(40,25,10,.18); max-width:100%;
}
.yz-bubble::after {
  content:""; position:absolute; left:50%; margin-left:-8px; bottom:-12px; width:0; height:0;
  border:8px solid transparent; border-top-color:var(--wood);
}
.yz-bubble::before {
  content:""; position:absolute; left:50%; margin-left:-7px; bottom:-8px; width:0; height:0; z-index:1;
  border:7px solid transparent; border-top-color:#fffdf6;
}
@keyframes yzbob { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-6px)} }
@keyframes yzwag { from{transform:rotate(-9deg)} to{transform:rotate(11deg)} }
.yz-bob2 { animation:yzbob 3.9s ease-in-out infinite; transform-origin:center bottom; }
.yz-tail { transform-origin:486px 256px; animation:yzwag .7s ease-in-out infinite alternate; }
@media (prefers-reduced-motion: reduce) {
  .yz-bob2,.yz-tail { animation:none; }
}

/* ---------- 表单 ---------- */
label { display:block; font-weight:600; margin:12px 0 4px; font-size:14px; }
input, textarea, select {
  width:100%; padding:10px 12px; border:1px solid var(--paper-dark); border-radius:8px;
  background:#fffdf6; font-family:inherit; font-size:14px; box-sizing:border-box;
}
/* 统一单行控件高度，避免 select 与 number 输入框高度不一致 */
input:not([type=checkbox]):not([type=radio]), select { height:44px; line-height:1.4; }
textarea { height:auto; min-height:96px; resize:vertical; }
.row { display:flex; gap:14px; flex-wrap:wrap; }
.row > * { flex:1; min-width:180px; }
.hint { font-size:12px; color:var(--muted); margin-top:4px; }

/* ---------- 卡片网格 ---------- */
.grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:16px; }
.card {
  background:#fffdf6; border:1px solid var(--paper-dark); border-radius:10px; padding:16px;
  box-shadow:0 2px 8px rgba(40,25,10,.1);
}
.card .cat { font-size:12px; color:var(--red); font-weight:700; letter-spacing:.1em; }
.card h3 { margin:4px 0 8px; }
.card p { color:#4a3c28; font-size:14px; margin:0 0 10px; line-height:1.55; }
.stars { color:var(--gold); letter-spacing:2px; }

/* ---------- 招牌墙轮播 ---------- */
.sc-carousel { position:relative; }
#showcase { transition:opacity .25s ease; }
#showcase.sc-fade { opacity:0; }
.sc-arrow {
  position:absolute; top:50%; transform:translateY(-50%); z-index:5;
  width:40px; height:40px; border-radius:50%; border:none;
  background:var(--wood); color:var(--paper); font-size:24px; line-height:1;
  box-shadow:var(--shadow); opacity:.92; display:flex; align-items:center; justify-content:center;
}
.sc-arrow:hover { background:var(--wood-dark); opacity:1; }
.sc-arrow.prev { left:-14px; }
.sc-arrow.next { right:-14px; }
.sc-dots { display:flex; gap:8px; justify-content:center; margin-top:14px; }
.sc-dot { width:9px; height:9px; border-radius:50%; background:var(--paper-dark); cursor:pointer; transition:background .2s; }
.sc-dot.on { background:var(--red); }
@media (max-width:768px) { .sc-arrow.prev { left:-4px; } .sc-arrow.next { right:-4px; } }

/* ---------- 状态标签 ---------- */
.badge { display:inline-block; padding:3px 10px; border-radius:20px; font-size:12px; font-weight:700; }
.s-submitted{background:#e3d3a8;color:#6b531a;} .s-contacting{background:#cfe0f0;color:#2c537d;}
.s-confirmed{background:#d8ecd0;color:#3c6030;} .s-delivering{background:#f3e0c0;color:#8a5a16;}
.s-delivered{background:#cdeae0;color:#236655;} .s-closed{background:#cfcfcf;color:#444;}
.s-rejected{background:#eccece;color:#8c2420;}

/* ---------- 工作流时间线 ---------- */
.timeline { display:flex; gap:6px; flex-wrap:wrap; margin:10px 0; }
.step { flex:1; min-width:70px; text-align:center; font-size:11px; color:var(--muted); }
.step .dot { width:14px; height:14px; border-radius:50%; background:var(--paper-dark); margin:0 auto 4px; }
.step.done .dot { background:var(--green); }
.step.active .dot { background:var(--red); box-shadow:0 0 0 3px rgba(181,50,46,.25); }

/* ---------- 通知 / 列表 ---------- */
.notif { padding:10px 12px; border-left:3px solid var(--red); background:#fffdf6; border-radius:0 8px 8px 0; margin-bottom:8px; }
.notif.read { border-color:var(--paper-dark); opacity:.7; }
.notif .time { font-size:11px; color:var(--muted); }
.toast { position:fixed; bottom:24px; left:50%; transform:translateX(-50%); background:var(--ink); color:var(--paper); padding:12px 22px; border-radius:30px; box-shadow:var(--shadow); z-index:200; opacity:0; transition:.3s; }
.toast.show { opacity:1; }

.muted { color:var(--muted); }
.right { text-align:right; }
.flex { display:flex; align-items:center; gap:10px; }
.tabs { display:flex; gap:6px; flex-wrap:wrap; margin-bottom:16px; }
.tab { padding:8px 14px; border-radius:20px; background:#fffdf6; border:1px solid var(--paper-dark); font-weight:600; font-size:13px; }
.tab.active { background:var(--wood); color:var(--paper); border-color:var(--wood-dark); }
.empty { text-align:center; color:var(--muted); padding:40px 0; }
.kpi { display:flex; gap:14px; flex-wrap:wrap; }
.kpi .box { background:#fffdf6; border:1px solid var(--paper-dark); border-radius:10px; padding:14px 20px; text-align:center; flex:1; min-width:120px; }
.kpi .box .n { font-size:26px; font-weight:900; color:var(--red); }
.fee { font-size:18px; font-weight:800; color:var(--red); }
hr { border:none; border-top:1px dashed var(--paper-dark); margin:14px 0; }
