:root {
  --red: #df3c2f;
  --red-dark: #a8231e;
  --ink: #2a211f;
  --muted: #7d716d;
  --cream: #f7f3ec;
  --line: #e8e0d8;
  --white: #fff;
  --shadow: 0 18px 50px rgba(70, 42, 28, .09);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: #fffdf9; font-family: "Microsoft YaHei", "PingFang SC", Arial, sans-serif; }
button, input, select { font: inherit; }
button, a { -webkit-tap-highlight-color: transparent; }
button { cursor: pointer; }
a { color: inherit; text-decoration: none; }
.container { width: min(1240px, calc(100% - 48px)); margin: 0 auto; }

.announcement { background: #2c201d; color: #e8ddd7; font-size: 12px; }
.announcement-inner { height: 34px; display: flex; align-items: center; justify-content: space-between; }
.announcement-links { display: flex; align-items: center; gap: 26px; }
.plain-button { border: 0; color: inherit; background: none; padding: 0; }
.plain-button b { color: #ffb39e; margin-left: 3px; }

.site-header { background: rgba(255, 253, 249, .95); border-bottom: 1px solid rgba(230, 219, 208, .75); position: sticky; top: 0; z-index: 30; backdrop-filter: blur(14px); }
.header-inner { height: 86px; display: flex; align-items: center; gap: 55px; }
.brand { display: inline-flex; align-items: center; gap: 11px; min-width: 176px; }
.brand-mark { width: 48px; height: 48px; display: grid; place-items: center; border-radius: 14px; background: #fff0e6; overflow: hidden; }
.brand-mark img { width: 54px; height: 54px; object-fit: contain; }
.brand > span:last-child { display: flex; flex-direction: column; }
.brand strong { font-size: 22px; letter-spacing: 3px; line-height: 1.1; }
.brand small { font-size: 7px; letter-spacing: 1.3px; color: var(--muted); margin-top: 5px; }
.search { height: 46px; flex: 1; max-width: 620px; border: 1.5px solid #d7ccc3; background: #fff; border-radius: 7px; display: flex; align-items: center; overflow: hidden; }
.search:focus-within { border-color: var(--red); box-shadow: 0 0 0 3px rgba(223, 60, 47, .08); }
.search-icon { margin-left: 17px; font-size: 24px; color: #877871; transform: rotate(-15deg); }
.search input { flex: 1; min-width: 0; border: 0; outline: 0; padding: 0 14px; color: var(--ink); background: transparent; }
.search button { height: 100%; border: 0; background: var(--red); color: #fff; padding: 0 30px; font-weight: 600; }
.header-actions { margin-left: auto; display: flex; gap: 26px; }
.mobile-category-tabs { display: none; }
.icon-action { border: 0; background: none; color: var(--ink); display: flex; flex-direction: column; align-items: center; gap: 3px; position: relative; }
.icon-action > span { font-size: 23px; line-height: 1; }
.icon-action small { font-size: 11px; }
.cart-badge { position: absolute; top: -9px; right: -8px; min-width: 18px; height: 18px; padding: 0 4px; border-radius: 20px; display: grid; place-items: center; background: var(--red); color: #fff; border: 2px solid #fff; font-size: 9px; }

.tao-home { padding: 18px 0 10px; background: linear-gradient(180deg, #fff7f0, #fffdf9); }
.tao-layout { display: grid; grid-template-columns: 205px minmax(0, 1fr) 205px; gap: 12px; align-items: stretch; }
.tao-category-panel, .tao-user-panel { border-radius: 12px; background: #fff; box-shadow: 0 6px 24px rgba(79,42,24,.06); }
.tao-category-panel { padding: 15px 12px 12px; }
.tao-category-panel h2 { margin: 0 7px 10px; font-size: 16px; }
.tao-category-panel > div { display: flex; flex-direction: column; }
.tao-category-panel > div button { height: 38px; padding: 0 7px; border: 0; border-radius: 5px; background: transparent; color: #5f514b; text-align: left; font-size: 11px; }
.tao-category-panel > div button:hover { background: #fff1e8; color: var(--red); }
.tao-category-panel > div span { display: inline-block; width: 27px; font-size: 16px; }
.tao-category-panel > div b { float: right; color: #b5a69e; font-size: 17px; font-weight: 400; }
.tao-category-panel > button { width: 100%; margin-top: 7px; padding: 8px; border: 0; border-radius: 5px; background: #f8f3ee; color: #826f65; font-size: 10px; }
.tao-center { min-width: 0; display: grid; grid-template-rows: 42px 1fr 88px; gap: 10px; }
.tao-channel-nav { border-radius: 10px; padding: 0 12px; display: flex; align-items: center; justify-content: space-around; background: linear-gradient(90deg, #ff5a26, #ef352b); color: #fff; overflow: hidden; }
.tao-channel-nav button { border: 0; background: none; color: #fff; padding: 12px 7px; font-size: 12px; font-weight: 700; }
.tao-mini-banners { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.tao-mini-banners button { border: 0; border-radius: 10px; padding: 13px 18px; background: linear-gradient(100deg, #ffe0d4, #fff2e8); text-align: left; position: relative; overflow: hidden; }
.tao-mini-banners button:last-child { background: linear-gradient(100deg, #e2efff, #f2f7ff); }
.tao-mini-banners span { display: block; color: var(--red); font-size: 9px; }
.tao-mini-banners strong { display: block; margin-top: 3px; font-size: 15px; }
.tao-mini-banners b { position: absolute; right: 15px; top: 31px; color: #b37259; font-size: 10px; }
.tao-user-panel { padding: 24px 15px 15px; text-align: center; }
.tao-user-panel > img { width: 64px; height: 64px; object-fit: contain; border-radius: 50%; background: #fff1e8; }
.tao-user-panel h3 { margin: 9px 0 4px; font-size: 14px; }
.tao-user-panel p { margin: 0 0 12px; color: var(--muted); font-size: 9px; }
.tao-user-panel > div { display: grid; grid-template-columns: 1fr 1fr; gap: 7px; }
.tao-user-panel > div button { border: 1px solid var(--red); border-radius: 4px; padding: 8px; background: var(--red); color: #fff; font-size: 10px; }
.tao-user-panel > div button:last-child { background: #fff; color: var(--red); }
.tao-user-panel ul { list-style: none; margin: 18px 0; padding: 13px 0; border-block: 1px solid var(--line); display: grid; grid-template-columns: repeat(3, 1fr); }
.tao-user-panel li { color: #88766d; font-size: 8px; }
.tao-user-panel li b { display: block; margin-bottom: 4px; color: var(--red); font-size: 15px; }
.tao-user-panel section { display: flex; flex-direction: column; gap: 8px; text-align: left; }
.tao-user-panel section strong { margin-bottom: 2px; font-size: 12px; }
.tao-user-panel section a { color: #75655e; font-size: 9px; }
.panel-link, .footer-button { border: 0; background: none; color: inherit; padding: 0; text-align: left; font-size: inherit; }
.panel-link { color: var(--red); font-weight: 700; }
.hero { height: 465px; border-radius: 14px; overflow: hidden; position: relative; background: #f8c39e; box-shadow: var(--shadow); }
.tao-center .hero { height: 345px; box-shadow: none; }
.hero::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(255,240,215,.5), transparent 56%); }
.hero > img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.hero-copy { position: relative; z-index: 2; width: 48%; height: 100%; display: flex; flex-direction: column; justify-content: center; padding: 22px 0 22px 50px; }
.eyebrow { color: var(--red-dark); letter-spacing: 3px; font-size: 12px; font-weight: 800; }
.eyebrow.dark { color: #a48e82; }
.hero h1 { font-size: clamp(48px, 5vw, 72px); line-height: 1.08; letter-spacing: -4px; margin: 14px 0 14px; font-weight: 900; }
.tao-center .hero h1 { font-size: clamp(38px, 4vw, 55px); }
.hero h1 em { color: var(--red); font-style: normal; }
.hero p { color: #6a4b40; font-size: 15px; margin: 0 0 25px; }
.hero-actions { display: flex; gap: 12px; }
.primary-button, .secondary-button { min-height: 45px; border-radius: 5px; padding: 0 24px; border: 1px solid var(--red); display: inline-flex; align-items: center; gap: 20px; font-weight: 700; }
.primary-button, .secondary-button { white-space: nowrap; }
.primary-button { background: var(--red); color: #fff; }
.secondary-button { background: rgba(255,255,255,.55); color: var(--red-dark); }
.hero-proof { display: flex; gap: 24px; margin-top: 28px; color: #826358; font-size: 11px; }
.hero-proof b { color: var(--red-dark); font-size: 14px; margin-right: 3px; }

.category-section, .products-section { padding: 55px 0; }
.section-heading { display: flex; justify-content: space-between; align-items: end; margin-bottom: 32px; }
.section-heading h2 { margin: 8px 0 0; font-size: 30px; letter-spacing: -1px; }
.text-button { border: 0; background: none; color: var(--muted); font-size: 13px; }
.text-button span { color: var(--red); margin-left: 5px; }
.category-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: 12px; }
.category-item { border: 1px solid var(--line); background: #fff; min-width: 0; height: 122px; border-radius: 10px; padding: 12px 7px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 6px; transition: .25s; color: #5a4b46; }
.category-item:hover, .category-item.active { transform: translateY(-4px); border-color: #e86d61; box-shadow: 0 12px 30px rgba(158, 72, 55, .12); color: var(--red); }
.category-icon { font-size: 31px; filter: saturate(.8); }
.category-item span:nth-child(2) { font-size: 12px; font-weight: 600; white-space: nowrap; }
.category-item small { color: #ad9d95; font-size: 9px; font-weight: 500; }

.feature-strip { padding: 0 0 20px; }
.feature-grid { display: grid; grid-template-columns: 1.1fr 1fr 1fr; gap: 18px; }
.feature-card { height: 218px; border-radius: 12px; padding: 29px 30px; overflow: hidden; position: relative; display: flex; justify-content: space-between; }
.feature-card > div:first-child { position: relative; z-index: 2; }
.feature-card span { font-size: 11px; font-weight: 800; letter-spacing: 2px; }
.feature-card h3 { font-size: 25px; line-height: 1.35; margin: 11px 0 17px; }
.feature-card button { border: 0; background: none; padding: 0; font-size: 12px; font-weight: 700; color: inherit; }
.feature-game { background: #2c2827; color: #fff; }
.feature-digital { background: #e8eff3; color: #29434e; }
.feature-snack { background: #f4ded4; color: #713b2f; }
.feature-art { font-size: 92px; align-self: center; transform: rotate(-10deg); filter: drop-shadow(0 16px 15px rgba(30,20,15,.2)); }

.products-section { background: #f7f3ed; margin-top: 55px; }
.product-heading { margin-bottom: 22px; }
.sort-wrap { display: flex; align-items: center; gap: 8px; color: var(--muted); font-size: 12px; }
.sort-wrap select { border: 1px solid #ddd3ca; background: #fff; padding: 9px 33px 9px 12px; border-radius: 5px; color: var(--ink); outline: 0; }
.filter-row { display: flex; gap: 8px; overflow-x: auto; scrollbar-width: none; padding-bottom: 3px; }
.filter-row::-webkit-scrollbar { display: none; }
.filter-button { flex: 0 0 auto; padding: 8px 17px; border: 1px solid #ded5cc; border-radius: 30px; background: transparent; color: #796b65; font-size: 12px; }
.filter-button.active { border-color: var(--red); background: var(--red); color: #fff; }
.data-notice { margin-top: 16px; padding: 11px 14px; border: 1px solid #e2d7ca; border-radius: 6px; background: #fffaf3; color: #846f62; font-size: 10px; line-height: 1.6; }
.result-summary { color: var(--muted); font-size: 12px; margin: 22px 0 14px; }
.result-summary b { color: var(--red); }
.product-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.product-card { background: #fff; border-radius: 10px; overflow: hidden; transition: .25s; border: 1px solid transparent; position: relative; }
.product-card:hover { transform: translateY(-5px); box-shadow: var(--shadow); border-color: #eadfd7; }
.product-visual { height: 245px; display: grid; place-items: center; position: relative; overflow: hidden; background: #f7f5f2; }
.product-image { width: 100%; height: 100%; object-fit: cover; padding: 0; transition: transform .35s ease; mix-blend-mode: normal; }
.product-card:hover .product-image { transform: scale(1.055); }
.brand-product-card .product-visual { background: #fff; }
.brand-product-card .product-image { width: 100%; height: 100%; padding: 0; margin: 0; object-fit: cover; mix-blend-mode: normal; image-rendering: auto; }
.product-card:has(.product-image[src^="data:image/svg+xml"]) .product-image { padding: 0; mix-blend-mode: normal; }
.virtual-product-card .product-visual { background: #fff; }
.virtual-product-card .product-image { width: 100%; height: 100%; padding: 0; mix-blend-mode: normal; }
.virtual-brand-logo { position: absolute; z-index: 2; left: 50%; top: 26%; width: 21%; height: 21%; transform: translate(-50%, -50%); object-fit: contain; }
.brand-image-caption { position: absolute; left: 18px; right: 18px; bottom: 17px; text-align: center; display: flex; flex-direction: column; gap: 3px; }
.brand-image-caption strong { font-size: 15px; color: var(--ink); }
.brand-image-caption span { font-size: 9px; color: var(--muted); }
.product-tag { position: absolute; left: 12px; top: 12px; z-index: 3; color: #fff; background: var(--red); padding: 4px 8px; font-size: 9px; font-weight: 700; border-radius: 3px; }
.favorite { position: absolute; right: 12px; top: 12px; z-index: 3; width: 30px; height: 30px; border-radius: 50%; border: 0; background: rgba(255,255,255,.8); color: #8d7a71; font-size: 18px; }
.favorite.active { color: var(--red); }
.product-info { padding: 17px; }
.product-brand-row { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.product-brand { color: var(--red); font-size: 10px; letter-spacing: .5px; font-weight: 700; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.rating { color: #a68155; font-size: 10px; flex: 0 0 auto; }
.product-info h3 { margin: 7px 0 8px; font-size: 15px; white-space: nowrap; text-overflow: ellipsis; overflow: hidden; }
.product-desc { color: var(--muted); font-size: 11px; white-space: nowrap; text-overflow: ellipsis; overflow: hidden; margin: 0 0 14px; }
.merchant-row { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-bottom: 12px; padding-top: 9px; border-top: 1px solid #f0ebe6; }
.merchant-row span { color: #87756d; font-size: 9px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.merchant-row button { flex: 0 0 auto; border: 1px solid #e2a699; border-radius: 3px; background: #fff7f4; color: var(--red); padding: 4px 7px; font-size: 9px; }
.product-bottom { display: flex; justify-content: space-between; align-items: center; }
.product-bottom > div { display: flex; flex-wrap: wrap; align-items: baseline; gap: 0 7px; }
.price { color: var(--red); font-weight: 800; font-size: 18px; }
.price small { display: block; color: #9a8980; font-size: 8px; font-weight: 500; }
.original-price { color: #b9aaa2; font-size: 9px; text-decoration: line-through; }
.sales { width: 100%; color: #a7968c; font-size: 9px; margin-top: 4px; }
.add-cart { width: 34px; height: 34px; border: 0; border-radius: 50%; background: #2e2421; color: #fff; font-size: 18px; display: grid; place-items: center; transition: .2s; }
.add-cart:hover { background: var(--red); }
.load-more { display: block; margin: 38px auto 0; border: 1px solid #cfc2b8; background: transparent; color: #6c5d56; padding: 12px 26px; border-radius: 4px; font-size: 12px; }
.load-more span { margin-left: 12px; color: var(--red); }
.pagination { display: flex; justify-content: center; align-items: center; gap: 7px; margin-top: 38px; }
.pagination button { min-width: 36px; height: 36px; padding: 0 11px; border: 1px solid #d7ccc3; border-radius: 4px; background: #fff; color: #6f6059; font-size: 11px; }
.pagination button.active { border-color: var(--red); background: var(--red); color: #fff; }
.pagination button:disabled { opacity: .35; cursor: not-allowed; }
.pagination span { color: #9e8e86; }

.member-banner { background: #f7f3ed; padding: 0 0 72px; }
.member-inner { min-height: 126px; border-radius: 10px; padding: 25px 42px; background: #342725; color: #fff; display: flex; align-items: center; gap: 22px; position: relative; overflow: hidden; }
.member-inner::after { content: "绘"; position: absolute; right: 220px; top: -65px; font-size: 180px; line-height: 1; font-weight: 900; color: rgba(255,255,255,.025); }
.member-icon { width: 65px; height: 65px; border-radius: 50%; display: grid; place-items: center; border: 1px solid #d99d70; background: #fff0e6; overflow: hidden; }
.member-icon img { width: 69px; height: 69px; object-fit: contain; }
.member-inner span { color: #d59b72; letter-spacing: 2px; font-size: 9px; }
.member-inner h2 { font-size: 21px; margin: 7px 0 0; }
.member-inner button { margin-left: auto; position: relative; z-index: 2; border: 1px solid #c89169; color: #f2c19e; background: transparent; border-radius: 4px; padding: 12px 22px; }
.member-inner button span { margin-left: 18px; font-size: 14px; }

.services { padding: 47px 0; border-top: 1px solid var(--line); }
.service-grid { display: grid; grid-template-columns: repeat(4, 1fr); }
.service-grid > div { display: grid; grid-template-columns: 44px 1fr; padding-left: 35px; border-right: 1px solid var(--line); }
.service-grid > div:last-child { border: 0; }
.service-grid > div > span { grid-row: 1 / 3; font-size: 25px; color: var(--red); align-self: center; }
.service-grid strong { font-size: 13px; }
.service-grid small { color: var(--muted); font-size: 10px; margin-top: 5px; }

footer { background: #251c1a; color: #b8aaa4; padding: 55px 0 20px; }
.footer-main { display: grid; grid-template-columns: 2fr repeat(3, 1fr) 1.4fr; gap: 35px; }
.brand.light strong { color: #fff; }
.brand.light small { color: #98847b; }
.footer-brand p { font-size: 11px; margin: 18px 0 0; }
.footer-main > div:not(:first-child) { display: flex; flex-direction: column; gap: 11px; font-size: 11px; }
.footer-main > div > strong { color: #fff; font-size: 13px; margin-bottom: 5px; }
.footer-contact b { color: #e0a376; font-size: 20px; }
.footer-contact span { font-size: 10px; }
.copyright { border-top: 1px solid #3d302d; margin-top: 40px; padding-top: 18px; font-size: 9px; text-align: center; line-height: 1.9; }
.copyright a { color: #d3b09a; }

.mobile-nav { display: none; }
.overlay { position: fixed; inset: 0; z-index: 80; background: rgba(25,16,13,.48); opacity: 0; visibility: hidden; transition: .25s; }
.overlay.show { opacity: 1; visibility: visible; }
.cart-drawer { position: fixed; right: 0; top: 0; bottom: 0; width: min(440px, 92vw); z-index: 90; background: #fffdf9; transform: translateX(100%); transition: .3s; display: flex; flex-direction: column; box-shadow: -20px 0 60px rgba(30,20,15,.18); }
.cart-drawer.open { transform: none; }
.drawer-header { padding: 28px; border-bottom: 1px solid var(--line); display: flex; justify-content: space-between; }
.drawer-header span { color: #aa9186; font-size: 9px; letter-spacing: 2px; }
.drawer-header h2 { margin: 4px 0 0; font-size: 24px; }
.drawer-header button, .modal-close { border: 0; background: none; font-size: 29px; color: #8e7d75; }
.cart-items { overflow: auto; flex: 1; padding: 18px 28px; }
.empty-cart { text-align: center; color: var(--muted); padding: 85px 0; }
.empty-cart span { display: block; font-size: 55px; opacity: .35; margin-bottom: 15px; }
.cart-item { display: grid; grid-template-columns: 74px 1fr auto; gap: 13px; padding: 13px 0; border-bottom: 1px solid var(--line); align-items: center; }
.cart-thumb { height: 74px; border-radius: 7px; display: grid; place-items: center; overflow: hidden; background: #f5f2ed; }
.cart-thumb img { width: 100%; height: 100%; object-fit: contain; mix-blend-mode: multiply; }
.cart-brand { color: var(--red); font-size: 8px; font-weight: 700; }
.cart-item h4 { margin: 0 0 6px; font-size: 13px; }
.cart-item small { color: #998880; font-size: 9px; }
.cart-item p { margin: 0; color: var(--red); font-weight: 700; font-size: 13px; }
.quantity { display: flex; align-items: center; gap: 9px; margin-top: 9px; }
.quantity button { width: 24px; height: 24px; border: 1px solid var(--line); background: #fff; border-radius: 3px; }
.remove-item { border: 0; background: none; color: #ab9a92; font-size: 18px; }
.cart-footer { border-top: 1px solid var(--line); padding: 22px 28px 28px; }
.cart-footer > div { display: flex; justify-content: space-between; align-items: center; }
.cart-footer strong { color: var(--red); font-size: 24px; }
.cart-footer > button { width: 100%; border: 0; background: var(--red); color: #fff; padding: 14px; margin: 17px 0 8px; border-radius: 4px; font-weight: 700; }
.cart-footer small { display: block; text-align: center; color: #a19088; font-size: 10px; }

.modal { position: fixed; z-index: 100; left: 50%; top: 50%; width: min(850px, 92vw); max-height: 90vh; overflow: auto; background: #fff; border-radius: 12px; transform: translate(-50%, -46%) scale(.97); opacity: 0; visibility: hidden; transition: .25s; box-shadow: 0 30px 100px rgba(25,16,13,.28); }
.modal.show { transform: translate(-50%, -50%) scale(1); opacity: 1; visibility: visible; }
.modal-close { position: absolute; right: 15px; top: 10px; z-index: 3; }
.modal-product { display: grid; grid-template-columns: 1fr 1.05fr; }
.modal-visual { min-height: 445px; display: grid; place-items: center; overflow: hidden; background: #f6f3ef; }
.modal-visual img { width: 100%; height: 445px; object-fit: contain; padding: 28px; mix-blend-mode: multiply; }
.modal-details { padding: 55px 45px 40px; }
.modal-details .eyebrow { font-size: 10px; }
.modal-details h2 { font-size: 29px; margin: 12px 0; }
.modal-details .modal-desc { color: var(--muted); line-height: 1.9; font-size: 13px; }
.modal-rating { color: #9b7a52; font-size: 11px; }
.merchant-panel { display: flex; align-items: center; justify-content: space-between; gap: 12px; border: 1px solid #eadfd8; border-radius: 7px; padding: 11px 12px; margin: 15px 0; background: #fffbf7; }
.merchant-panel > div { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.merchant-panel strong { font-size: 12px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.merchant-panel span { color: var(--muted); font-size: 9px; }
.merchant-panel button { flex: 0 0 auto; border: 0; border-radius: 4px; background: #2e2421; color: #fff; padding: 8px 10px; font-size: 10px; }
.sku-line { display: flex; justify-content: space-between; background: var(--cream); padding: 11px 13px; border-radius: 5px; font-size: 11px; }
.sku-line span { color: var(--muted); }
.modal-price { color: var(--red); font-size: 30px; font-weight: 900; margin: 22px 0; }
.modal-price small { color: #928078; font-size: 10px; font-weight: 500; }
.modal-meta { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin-bottom: 25px; }
.modal-meta span { background: var(--cream); padding: 12px 5px; text-align: center; font-size: 10px; color: #796a64; border-radius: 5px; }
.modal-add { border: 0; width: 100%; padding: 14px; background: var(--red); color: #fff; border-radius: 4px; font-weight: 700; }
.source-link { display: block; margin-top: 13px; text-align: center; color: #89776e; font-size: 10px; text-decoration: underline; }
.empty-results { grid-column: 1 / -1; }
.info-modal { width: min(650px, 92vw); }
.info-page { padding: 55px 52px 45px; }
.info-page h2 { font-size: 29px; margin: 8px 0 24px; }
.info-page ol { margin: 0; padding: 0; list-style: none; counter-reset: steps; }
.info-page li { counter-increment: steps; position: relative; padding: 13px 15px 13px 48px; border-bottom: 1px solid var(--line); line-height: 1.7; font-size: 13px; }
.info-page li::before { content: counter(steps); position: absolute; left: 9px; top: 12px; width: 24px; height: 24px; display: grid; place-items: center; border-radius: 50%; background: #f8e4dd; color: var(--red); font-size: 10px; font-weight: 800; }
.info-page > p { color: var(--muted); font-size: 10px; line-height: 1.8; margin: 24px 0 0; }
.merchant-modal { width: min(680px, 94vw); overflow: hidden; }
.merchant-join-modal { width: min(860px, 94vw); }
.merchant-join-page { padding: 45px 48px 42px; }
.merchant-join-page h2 { margin: 7px 0 8px; font-size: 29px; }
.join-intro { margin: 0 0 20px; color: var(--muted); font-size: 11px; line-height: 1.7; }
.join-types { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.join-types article { padding: 16px; border: 1px solid var(--line); border-radius: 8px; background: #fffaf5; }
.join-types b { display: block; color: var(--red); margin-bottom: 7px; }
.join-types span { color: var(--muted); font-size: 10px; line-height: 1.65; }
.join-requirements { margin: 18px 0; padding: 16px 20px; border-radius: 8px; background: var(--cream); }
.join-requirements h3 { margin: 0 0 8px; font-size: 14px; }
.join-requirements ol { margin: 0; padding-left: 19px; color: #695b55; font-size: 10px; line-height: 1.85; }
.join-rule-link { display: inline-block; margin-top: 9px; color: var(--red); font-size: 10px; text-decoration: underline; }
.merchant-join-form { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.merchant-join-form label { display: flex; flex-direction: column; gap: 6px; color: #6f6059; font-size: 10px; }
.merchant-join-form input, .merchant-join-form select, .merchant-join-form textarea { width: 100%; border: 1px solid #ded4cc; border-radius: 5px; padding: 10px 11px; outline: 0; background: #fff; color: var(--ink); }
.merchant-join-form textarea { min-height: 76px; resize: vertical; }
.merchant-join-form input:focus, .merchant-join-form select:focus, .merchant-join-form textarea:focus { border-color: var(--red); }
.join-wide { grid-column: 1 / -1; }
.join-agree { flex-direction: row !important; align-items: center; }
.join-agree input { width: auto; }
.join-submit { border: 0; border-radius: 5px; padding: 13px; background: var(--red); color: #fff; font-weight: 700; }
.account-modal { width: min(430px, 92vw); }
.account-page { padding: 45px 42px 38px; }
.account-page h2 { margin: 7px 0 20px; font-size: 28px; }
.account-tabs { display: grid; grid-template-columns: repeat(3, 1fr); margin-bottom: 18px; border-bottom: 1px solid var(--line); }
.account-tabs button { border: 0; border-bottom: 2px solid transparent; background: none; padding: 11px; color: var(--muted); }
.account-tabs button.active { border-color: var(--red); color: var(--red); font-weight: 700; }
.account-form { display: flex; flex-direction: column; gap: 12px; }
.account-form label { display: flex; flex-direction: column; gap: 6px; color: #70615b; font-size: 10px; }
.account-form input { border: 1px solid #ded4cc; border-radius: 5px; padding: 11px; outline: 0; }
.account-form input:focus { border-color: var(--red); }
.account-form button { border: 0; border-radius: 5px; padding: 13px; background: var(--red); color: #fff; font-weight: 700; }
.account-error { min-height: 18px; margin: 10px 0 0; color: #c43127; font-size: 10px; }
.payment-modal { width: min(470px, 92vw); }
.payment-page { padding: 44px 40px 38px; }
.payment-page h2 { margin: 7px 0 12px; font-size: 27px; }
.payment-page > p { color: var(--muted); font-size: 12px; }
.payment-page > p strong { float: right; color: var(--red); font-size: 20px; }
.payment-methods { display: grid; gap: 10px; margin: 25px 0 16px; }
.payment-methods button { border: 1px solid var(--line); border-radius: 8px; background: #fff; padding: 15px 17px; text-align: left; display: flex; justify-content: space-between; align-items: center; }
.payment-methods button:hover { border-color: var(--red); background: #fff9f5; }
.payment-methods b { font-size: 14px; }
.payment-methods span, .payment-page > small { color: var(--muted); font-size: 9px; }
.address-modal { width: min(610px, 94vw); }
.address-page { padding: 44px 42px 38px; }
.address-page h2 { margin: 7px 0 18px; }
.address-list { display: grid; gap: 8px; margin-bottom: 18px; }
.address-item { border: 1px solid var(--line); border-radius: 7px; padding: 12px; display: flex; justify-content: space-between; gap: 12px; }
.address-item b { font-size: 12px; }
.address-item p { margin: 5px 0 0; color: var(--muted); font-size: 10px; line-height: 1.6; }
.address-item button { border: 0; background: none; color: var(--red); font-size: 10px; }
.address-default-badge { color: var(--red); margin-left: 7px; font-size: 9px; }
.address-form { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; padding-top: 17px; border-top: 1px solid var(--line); }
.address-form label { display: flex; flex-direction: column; gap: 5px; color: var(--muted); font-size: 10px; }
.address-form label:nth-child(3), .address-form label:nth-child(4), .address-form > button { grid-column: 1/-1; }
.address-form input, .address-form textarea { border: 1px solid var(--line); border-radius: 5px; padding: 10px; outline: 0; }
.address-form textarea { min-height: 65px; resize: vertical; }
.address-default { flex-direction: row !important; align-items: center; }
.address-default input { width: auto; }
.address-form > button { border: 0; border-radius: 5px; background: var(--red); color: #fff; padding: 12px; font-weight: 700; }
.merchant-contact { padding: 48px 44px 38px; text-align: center; }
.merchant-avatar { width: 68px; height: 68px; margin: 0 auto 15px; border-radius: 18px; display: grid; place-items: center; background: linear-gradient(135deg, #f28a5d, #df3c2f); color: #fff; font-size: 29px; font-weight: 900; }
.merchant-contact h2 { margin: 7px 0 20px; }
.merchant-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.merchant-stats span { min-height: 64px; padding: 10px 5px; border-radius: 6px; background: var(--cream); color: var(--muted); font-size: 9px; display: flex; flex-direction: column; justify-content: center; gap: 5px; }
.merchant-stats b { color: var(--ink); font-size: 12px; }
.chat-preview { text-align: left; margin: 18px 0; padding: 14px; border: 1px solid var(--line); border-radius: 7px; }
.chat-preview small { color: var(--red); }
.chat-preview strong { display: block; margin: 5px 0 10px; font-size: 12px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.chat-preview p { margin: 0; padding: 10px; border-radius: 5px; background: #f5f1ec; color: #6f625c; font-size: 11px; }
.contact-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 9px; }
.contact-actions button { border: 1px solid var(--red); border-radius: 4px; padding: 11px; background: var(--red); color: #fff; }
.contact-actions button:last-child { background: #fff; color: var(--red); }
.contact-note { color: #9a8981; font-size: 9px; margin: 14px 0 0; }
.chat-shell { height: min(720px, 88vh); display: flex; flex-direction: column; background: #f5f2ee; }
.chat-header { min-height: 78px; padding: 14px 50px 14px 18px; background: #fff; border-bottom: 1px solid var(--line); display: flex; align-items: center; gap: 12px; }
.chat-header .merchant-avatar { width: 46px; height: 46px; margin: 0; border-radius: 12px; font-size: 18px; }
.chat-header > div:nth-child(2) { min-width: 0; flex: 1; }
.chat-header h2 { margin: 0 0 5px; font-size: 15px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.chat-header span { color: #8d7d75; font-size: 9px; }
.chat-header span i { display: inline-block; width: 7px; height: 7px; margin-right: 4px; border-radius: 50%; background: #45b96b; }
.chat-header > button { border: 1px solid #e2d8d1; border-radius: 4px; background: #fff; color: #6f5e56; padding: 7px 10px; font-size: 9px; }
.chat-product { margin: 11px 16px 0; padding: 9px; border-radius: 7px; background: #fff; display: flex; align-items: center; gap: 10px; box-shadow: 0 4px 18px rgba(50,35,28,.04); }
.chat-product img { width: 48px; height: 48px; object-fit: contain; border-radius: 5px; background: #f7f4f0; padding: 4px; }
.chat-product > div { min-width: 0; display: flex; flex-direction: column; gap: 3px; }
.chat-product small { color: var(--red); font-size: 8px; }
.chat-product strong { font-size: 11px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.chat-product span { color: #9a8981; font-size: 9px; }
.chat-messages { flex: 1; min-height: 180px; overflow-y: auto; padding: 18px 18px 10px; }
.chat-message { display: flex; align-items: flex-start; gap: 8px; margin-bottom: 14px; }
.chat-message.from-customer { flex-direction: row-reverse; }
.message-avatar { flex: 0 0 auto; width: 30px; height: 30px; border-radius: 9px; display: grid; place-items: center; background: #3a2c28; color: #fff; font-size: 10px; }
.from-customer .message-avatar { background: var(--red); }
.chat-message > div:last-child { max-width: 72%; }
.chat-message p { margin: 0; border-radius: 3px 12px 12px 12px; background: #fff; padding: 10px 12px; color: #4e413c; line-height: 1.6; font-size: 11px; box-shadow: 0 3px 12px rgba(50,35,28,.04); }
.from-customer p { border-radius: 12px 3px 12px 12px; background: #df3c2f; color: #fff; }
.chat-message time { display: block; margin-top: 4px; color: #a3948c; font-size: 8px; }
.from-customer time { text-align: right; }
.quick-questions { padding: 8px 16px; display: flex; gap: 6px; overflow-x: auto; scrollbar-width: none; }
.quick-questions button { flex: 0 0 auto; border: 1px solid #e5d9d2; border-radius: 20px; background: #fff; color: #7d6c64; padding: 6px 10px; font-size: 9px; }
.chat-compose { padding: 10px 16px 14px; border-top: 1px solid var(--line); background: #fff; }
.chat-compose textarea { width: 100%; height: 72px; resize: none; border: 0; outline: 0; padding: 5px; color: var(--ink); font-size: 12px; }
.chat-compose > div { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.chat-compose span { color: #a19088; font-size: 8px; }
.chat-compose button { border: 0; border-radius: 4px; background: var(--red); color: #fff; padding: 8px 20px; font-size: 10px; }
.chat-compose button:disabled { opacity: .55; }
.toast { position: fixed; left: 50%; bottom: 40px; z-index: 120; transform: translate(-50%, 20px); opacity: 0; visibility: hidden; color: #fff; background: #2c201d; padding: 11px 20px; border-radius: 30px; font-size: 12px; transition: .25s; box-shadow: var(--shadow); }
.toast.show { opacity: 1; visibility: visible; transform: translate(-50%, 0); }

@media (max-width: 1000px) {
  .tao-layout { grid-template-columns: 180px 1fr; }
  .tao-user-panel { display: none; }
  .tao-center .hero-copy { width: 52%; padding-left: 36px; }
  .tao-center .primary-button, .tao-center .secondary-button { padding-inline: 14px; gap: 8px; }
  .header-inner { gap: 25px; }
  .category-grid { grid-template-columns: repeat(6, 1fr); }
  .product-grid { grid-template-columns: repeat(3, 1fr); }
  .feature-grid { grid-template-columns: 1fr 1fr; }
  .feature-card:last-child { display: none; }
  .footer-main { grid-template-columns: 2fr repeat(2, 1fr); }
  .footer-main > div:nth-child(4), .footer-contact { display: none !important; }
}

@media (max-width: 700px) {
  body { padding-bottom: 67px; }
  .container { width: min(100% - 28px, 600px); }
  .announcement { display: none; }
  .site-header { position: static; border: 0; }
  .header-inner { height: auto; padding: 10px 0 8px; display: grid; grid-template-columns: 1fr; gap: 8px; }
  .brand { min-width: 0; }
  .brand-mark { width: 30px; height: 30px; font-size: 16px; }
  .brand-mark img { width: 36px; height: 36px; }
  .brand strong { font-size: 17px; }
  .brand small { display: none; }
  .header-actions { display: none; }
  .mobile-category-tabs { display: flex; gap: 20px; overflow-x: auto; padding: 3px 2px 7px; scrollbar-width: none; }
  .mobile-category-tabs::-webkit-scrollbar { display: none; }
  .mobile-category-tabs button { flex: 0 0 auto; border: 0; background: none; color: #3f3430; padding: 0 0 6px; font-size: 15px; font-weight: 600; position: relative; }
  .mobile-category-tabs button.active { color: #f04b23; font-size: 18px; font-weight: 800; }
  .mobile-category-tabs button.active::after { content: ""; position: absolute; left: 50%; bottom: 0; width: 18px; height: 3px; border-radius: 5px; background: #f04b23; transform: translateX(-50%); }
  .search { grid-column: 1 / -1; height: 42px; max-width: none; border: 2px solid #f04b23; background: #fff; border-radius: 22px; }
  .search button { display: block; border-radius: 20px; padding: 0 21px; background: linear-gradient(90deg, #ff712f, #f04b23); }
  .search-icon { font-size: 20px; }
  .tao-home { padding-top: 2px; }
  .tao-layout { display: flex; flex-direction: column; gap: 9px; }
  .tao-category-panel, .tao-user-panel { display: none; }
  .tao-center { display: flex; flex-direction: column; gap: 9px; }
  .tao-channel-nav { order: 2; padding: 8px 2px; border-radius: 9px; background: #fff; color: var(--ink); display: grid; grid-template-columns: repeat(5, 1fr); gap: 2px; overflow: visible; }
  .tao-channel-nav button { color: #5d4f49; padding: 8px 1px; font-size: 9px; font-weight: 600; }
  .tao-channel-nav button::before { content: "◉"; display: block; width: 35px; height: 35px; margin: 0 auto 5px; border-radius: 12px; background: linear-gradient(145deg, #ff8768, #f04a30); color: #fff; line-height: 35px; font-size: 14px; }
  .tao-channel-nav button:nth-child(2)::before { content: "游"; }
  .tao-channel-nav button:nth-child(3)::before { content: "数"; background: linear-gradient(145deg, #709ce8, #4772c0); }
  .tao-channel-nav button:nth-child(4)::before { content: "服"; background: linear-gradient(145deg, #e977a0, #c94c7c); }
  .tao-channel-nav button:nth-child(5)::before { content: "食"; background: linear-gradient(145deg, #e6a94f, #ca7626); }
  .tao-channel-nav button:nth-child(6) { display: none; }
  main { display: flex; flex-direction: column; }
  .tao-home { order: 1; }
  .products-section { order: 2; }
  .category-section { order: 3; }
  .feature-strip { order: 4; }
  .member-banner { order: 5; }
  .services { order: 6; }
  .tao-center .hero { order: 1; height: 132px; border-radius: 11px; }
  .hero > img { object-position: 61% center; }
  .hero::after { background: linear-gradient(90deg, rgba(255,232,205,.98) 0%, rgba(255,232,205,.78) 44%, rgba(255,232,205,.04) 76%); }
  .tao-center .hero-copy { width: 58%; height: auto; padding: 17px 0 0 15px; justify-content: flex-start; text-align: left; align-items: flex-start; }
  .tao-center .hero h1 { font-size: 22px; letter-spacing: -1px; margin: 3px 0 8px; white-space: nowrap; }
  .tao-center .hero .eyebrow { font-size: 7px; }
  .hero p { display: none; }
  .hero-proof { display: none; }
  .hero-actions { gap: 8px; }
  .primary-button, .secondary-button { min-height: 29px; padding: 0 10px; font-size: 9px; gap: 7px; }
  .hero-actions .secondary-button { display: none; }
  .tao-mini-banners { display: none; }
  .category-section, .feature-strip { display: none; }
  .products-section { margin-top: 0; padding: 18px 0 35px; }
  .product-heading { margin-bottom: 12px; }
  .product-heading .eyebrow { display: none; }
  .product-heading h2 { font-size: 21px; }
  .sort-wrap { display: none; }
  .filter-row, .data-notice, .result-summary { display: none; }
  .section-heading { margin-bottom: 22px; }
  .section-heading h2 { font-size: 23px; margin-top: 4px; }
  .eyebrow { font-size: 9px; letter-spacing: 2px; }
  .category-grid { display: flex; overflow-x: auto; margin-right: -14px; padding: 0 14px 12px 0; scrollbar-width: none; }
  .category-item { min-width: 81px; height: 94px; padding: 9px 5px; }
  .category-icon { font-size: 25px; }
  .feature-grid { display: flex; overflow-x: auto; margin-right: -14px; padding-right: 14px; scrollbar-width: none; }
  .feature-card, .feature-card:last-child { display: flex; min-width: 292px; height: 180px; padding: 23px; }
  .feature-card h3 { font-size: 20px; }
  .feature-art { font-size: 68px; }
  .products-section { margin-top: 30px; }
  .sort-wrap label { display: none; }
  .sort-wrap select { max-width: 115px; padding: 7px 25px 7px 8px; font-size: 10px; }
  .result-summary { margin-top: 17px; }
  .product-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .product-visual { height: 165px; }
  .product-image { padding: 0; }
  .brand-product-card .product-image { width: 100%; height: 100%; padding: 0; margin: 0; }
  .brand-image-caption { bottom: 12px; }
  .brand-image-caption strong { font-size: 12px; }
  .product-emoji { font-size: 72px; }
  .product-visual::after { width: 88px; bottom: 22px; }
  .product-info { padding: 12px; }
  .product-info h3 { font-size: 13px; margin: 5px 0; }
  .product-desc { display: none; }
  .merchant-row span { max-width: 86px; }
  .price { font-size: 16px; }
  .sales { display: none; }
  .original-price { display: none; }
  .add-cart { width: 30px; height: 30px; font-size: 16px; }
  .pagination { gap: 4px; margin-top: 25px; }
  .pagination button { min-width: 31px; height: 33px; padding: 0 8px; }
  .member-banner { padding-bottom: 45px; }
  .member-inner { min-height: 165px; padding: 23px; flex-wrap: wrap; }
  .member-icon { width: 50px; height: 50px; font-size: 23px; }
  .member-inner > div:nth-child(2) { width: calc(100% - 75px); }
  .member-inner h2 { font-size: 16px; }
  .member-inner button { margin: 0; width: 100%; }
  .services { padding: 30px 0; }
  .service-grid { grid-template-columns: 1fr 1fr; gap: 22px 0; }
  .service-grid > div { padding-left: 10px; grid-template-columns: 36px 1fr; }
  .service-grid > div:nth-child(2) { border: 0; }
  .service-grid small { font-size: 8px; }
  footer { padding: 35px 0 20px; }
  .footer-main { display: block; }
  .footer-main > div:not(:first-child) { display: none; }
  .copyright { margin-top: 25px; }
  .mobile-nav { position: fixed; bottom: 0; left: 0; right: 0; z-index: 50; height: 66px; background: rgba(255,255,255,.97); border-top: 1px solid var(--line); display: grid; grid-template-columns: repeat(5, 1fr); padding-bottom: env(safe-area-inset-bottom); backdrop-filter: blur(12px); }
  .mobile-nav a, .mobile-nav button { border: 0; background: none; color: #8c7c74; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 3px; font-size: 9px; position: relative; }
  .mobile-nav span { font-size: 20px; line-height: 1; }
  .mobile-nav .active { color: var(--red); }
  .mobile-nav .cart-badge { right: calc(50% - 21px); top: 4px; color: #fff; font-size: 8px; }
  .modal-product { display: block; }
  .modal { max-height: 86vh; }
  .merchant-modal {
    position: fixed;
    inset: 0;
    width: 100vw;
    max-width: none;
    height: 100dvh;
    max-height: none;
    border-radius: 0;
    transform: none;
  }
  .merchant-modal.show { transform: none; }
  .merchant-modal .modal-close {
    position: fixed;
    top: max(9px, env(safe-area-inset-top));
    right: 10px;
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background: rgba(255,255,255,.92);
  }
  .modal-visual { min-height: 240px; }
  .modal-visual img { height: 240px; padding: 18px; }
  .modal-details { padding: 25px 24px 28px; }
  .modal-details h2 { font-size: 23px; }
  .info-page, .merchant-contact { padding: 42px 22px 28px; }
  .merchant-join-page { padding: 38px 20px 24px; }
  .account-page { padding: 38px 22px 28px; }
  .payment-page { padding: 38px 22px 28px; }
  .address-page { padding: 38px 20px 25px; }
  .address-form { grid-template-columns: 1fr; }
  .address-form label:nth-child(3), .address-form label:nth-child(4), .address-form > button { grid-column: auto; }
  .merchant-join-page h2 { font-size: 23px; }
  .join-types { grid-template-columns: 1fr; }
  .join-types article { padding: 12px; }
  .merchant-join-form { grid-template-columns: 1fr; }
  .join-wide { grid-column: auto; }
  .chat-shell { height: 100dvh; max-height: 100dvh; }
  .chat-header { padding: max(12px, env(safe-area-inset-top)) 50px 10px 12px; min-height: 68px; }
  .chat-header > button { display: none; }
  .chat-product { margin: 8px 10px 0; }
  .chat-messages { padding: 13px 10px 8px; }
  .chat-message > div:last-child { max-width: 80%; }
  .chat-compose { padding: 8px 10px max(10px, env(safe-area-inset-bottom)); }
  .chat-compose textarea { height: 54px; }
}
