
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --jd-red:#E4393C;--jd-dark:#C62B2B;--orange:#FF8C00;
  --text:#1a1a1a;--text-sec:#666;--text-light:#999;--text-faint:#bbb;
  --bg:#f0f0f0;--bg-white:#fff;--border:#e5e5e5;
  --shadow:0 1px 6px rgba(0,0,0,.08);--shadow-hover:0 6px 24px rgba(0,0,0,.12);
  --radius:8px;--gold:#F5A623;--green:#52C41A;
  --max-w:1200px;
  --hover-bg:#f5f5f5;--card-border:#f0f0f0;
  --skeleton-base:#f0f0f0;--skeleton-shine:#e8e8e8;
  --banner-bg:linear-gradient(90deg,#fff8f0,#fff2e8);--banner-border:#ffd9b3;
  --fav-border:#eee;--input-bg:#fafafa;--footer-bg:#2f2f2f;--footer-text:#e6e6e6;
}
:root.dark{
  --text:#e0e0e0;--text-sec:#aaa;--text-light:#777;--text-faint:#555;
  --bg:#141414;--bg-white:#1f1f1f;--border:#333;
  --shadow:0 1px 6px rgba(0,0,0,.4);--shadow-hover:0 6px 24px rgba(0,0,0,.5);
  --hover-bg:#2a2a2a;--card-border:#2a2a2a;
  --skeleton-base:#2a2a2a;--skeleton-shine:#363636;
  --banner-bg:linear-gradient(90deg,#2a1f15,#2a1a10);--banner-border:#5a3a1a;
  --fav-border:#333;--input-bg:#2a2a2a;--footer-bg:#0a0a0a;--footer-text:#999;
}
html{scroll-behavior:smooth;-webkit-tap-highlight-color:transparent}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","PingFang SC","Hiragino Sans GB","Microsoft YaHei","Helvetica Neue",Helvetica,Arial,sans-serif;color:var(--text);background:var(--bg);line-height:1.6;font-size:15px;min-height:100vh;display:flex;flex-direction:column}
body.no-scroll{overflow:hidden}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
img{display:block;max-width:100%}
.container{max-width:var(--max-w);margin:0 auto;padding:0 16px}
.header{background:var(--bg-white);padding:10px 0;position:sticky;top:0;z-index:90;box-shadow:0 2px 8px rgba(0,0,0,.05)}
.header .container{display:flex;align-items:center;gap:14px;min-height:46px}
.logo{display:flex;align-items:center;gap:8px;flex-shrink:0;cursor:pointer}
.logo-icon{width:38px;height:38px}
.logo-group{display:flex;flex-direction:column}
.logo-text{font-size:22px;font-weight:900;color:var(--text);line-height:1.1}
.logo-sub{font-size:12px;color:var(--text-light);letter-spacing:1px}
.search-box{flex:1;max-width:480px;position:relative}
.search-box input{width:100%;height:38px;border:2px solid var(--jd-red);border-radius:4px 0 0 4px;padding:0 78px 0 14px;outline:none;font-size:15px;transition:box-shadow .2s;background:var(--bg-white);color:var(--text)}
.search-box input:focus{box-shadow:inset 0 0 0 1px rgba(228,57,60,.2)}
.search-clear{position:absolute;right:56px;top:50%;transform:translateY(-50%);width:22px;height:22px;border-radius:50%;display:none;align-items:center;justify-content:center;color:var(--text-light);font-size:17px;line-height:1;transition:all .15s;z-index:2}
.search-clear:hover{background:var(--hover-bg);color:var(--jd-red)}
.search-clear.show{display:flex}
.search-box .sbtn{position:absolute;right:0;top:0;width:52px;height:38px;background:var(--jd-red);color:#fff;border-radius:0 4px 4px 0;display:flex;align-items:center;justify-content:center;transition:background .15s}
.search-box .sbtn:hover{background:var(--jd-dark)}
.search-tags{display:flex;gap:6px;margin-left:4px;flex-shrink:0}
.search-tag{font-size:13px;color:var(--text-sec);cursor:pointer;transition:color .15s;white-space:nowrap}
.search-tag:hover{color:var(--jd-red)}
.search-tag.hot{color:var(--jd-red);font-weight:500}
.h-right{display:flex;align-items:center;gap:6px;flex-shrink:0}
.header-nav{display:flex;align-items:center;gap:2px;flex-shrink:0;margin-left:auto}
.header-link{height:34px;padding:0 8px;border-radius:4px;display:inline-flex;align-items:center;justify-content:center;font-size:14px;color:var(--text-sec);white-space:nowrap;transition:all .15s}
.header-link:hover{background:var(--hover-bg);color:var(--jd-red)}
.header-link.important{color:var(--jd-red);font-weight:600}
.header-link.hidden{display:none}
.h-act{height:34px;min-width:34px;display:flex;align-items:center;justify-content:center;padding:0 8px;border-radius:4px;font-size:13px;color:var(--text-sec);transition:all .15s;position:relative;gap:4px}
.h-act:hover{background:var(--hover-bg);color:var(--jd-red)}
.h-act svg{width:18px;height:18px;flex-shrink:0}
.fav-badge{position:absolute;top:-2px;right:-2px;min-width:16px;height:16px;border-radius:8px;background:var(--jd-red);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 4px;opacity:0;transform:scale(0);transition:all .2s}
.fav-badge.show{opacity:1;transform:scale(1)}
.theme-toggle{width:34px;height:34px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:17px;color:var(--text-sec);transition:all .15s;cursor:pointer}
.theme-toggle:hover{background:var(--hover-bg);color:var(--jd-red)}
.search-dropdown{position:absolute;top:100%;left:0;right:52px;background:var(--bg-white);border:1px solid var(--border);border-top:none;border-radius:0 0 6px 6px;box-shadow:0 4px 12px rgba(0,0,0,.1);z-index:100;display:none;max-height:260px;overflow-y:auto}
.search-dropdown.show{display:block}
.search-dropdown-item{padding:9px 14px;font-size:15px;color:var(--text-sec);cursor:pointer;transition:all .15s}
.search-dropdown-item:hover{background:var(--hover-bg);color:var(--jd-red)}
.search-dropdown-item .match{color:var(--jd-red);font-weight:600}
.main-wrap{padding:12px 0;flex:1 0 auto}
.main-wrap .container{display:flex;flex-direction:column}
.search-banner{display:none;background:var(--banner-bg);border:1px solid var(--banner-border);border-left:3px solid var(--orange);border-radius:4px;padding:10px 14px;margin-bottom:10px;align-items:center;gap:10px;animation:fadeUp .3s ease}
.search-banner.show{display:flex}
.search-banner-icon{width:28px;height:28px;background:var(--orange);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff;font-size:14px;font-weight:700}
.search-banner-text{flex:1;font-size:14px}
.search-banner-kw{font-weight:700;color:var(--jd-red);font-size:15px}
.search-banner-sub{font-size:13px;color:var(--text-sec);margin-top:1px}
.search-banner-close{font-size:16px;color:var(--text-light);cursor:pointer;padding:4px}
.sort-bar{background:var(--bg-white);padding:0 12px;display:flex;align-items:center;margin-bottom:10px;border-radius:var(--radius);box-shadow:0 1px 3px rgba(0,0,0,.04);position:sticky;top:69px;z-index:10;gap:8px}
.sort-tabs{display:flex;flex:1;min-width:0;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.sort-tabs::-webkit-scrollbar{display:none}
.sort-tab{padding:10px 14px;font-size:14px;color:var(--text-sec);cursor:pointer;transition:color .15s;position:relative;user-select:none;white-space:nowrap;flex:0 0 auto}
.sort-tab:hover{color:var(--text)}
.sort-tab.active{color:var(--jd-red);font-weight:600}
.sort-tab.active::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:16px;height:2px;background:var(--jd-red)}
.result-info{font-size:13px;color:var(--text-light);white-space:nowrap;margin:0 8px;display:flex;align-items:center;gap:8px}
.data-freshness{font-size:12px;color:var(--text-faint)}
.view-toggle{display:flex;gap:4px;margin-left:8px}
.view-btn{width:30px;height:30px;border-radius:4px;display:flex;align-items:center;justify-content:center;color:var(--text-light);transition:all .15s;cursor:pointer}
.view-btn:hover{background:var(--hover-bg);color:var(--text)}
.view-btn.active{background:var(--jd-red);color:#fff}
.product-list{display:flex;flex-direction:column;gap:8px}
.product-list.grid-view{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:10px}
.deal-card{background:var(--bg-white);border-radius:var(--radius);padding:12px;display:flex;gap:12px;transition:box-shadow .2s;position:relative;overflow:hidden;border:1px solid var(--card-border)}
.deal-card:hover{box-shadow:var(--shadow-hover);border-color:transparent}
.deal-card:hover .deal-img img{transform:scale(1.03)}
.grid-view .deal-card{flex-direction:column;padding:0}
.grid-view .deal-card .deal-img{width:100%;height:auto;aspect-ratio:1}
.grid-view .deal-card .deal-info{padding:10px}
.grid-view .deal-card .deal-actions{flex-direction:row;padding:0 10px 10px;justify-content:space-between}
.grid-view .deal-card .deal-link{flex:1;text-align:center}
.deal-img{width:140px;height:140px;flex-shrink:0;border-radius:6px;overflow:hidden;background:var(--skeleton-base);position:relative;display:block}
.deal-img img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.deal-img .tag-hot{position:absolute;top:6px;left:6px;background:var(--jd-red);color:#fff;font-size:11px;padding:1px 6px;border-radius:3px;font-weight:700}
.deal-info{flex:1;display:flex;flex-direction:column;justify-content:space-between;min-width:0}
.title-row{display:flex;align-items:flex-start;gap:5px;margin-bottom:4px}
.self-badge{display:inline-block;font-size:13px;font-weight:700;color:#fff;background:var(--jd-red);padding:1px 6px;border-radius:3px;flex-shrink:0;margin-top:3px;line-height:1.4}
.deal-title{font-size:15px;font-weight:600;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;color:var(--text);text-decoration:none;transition:color .15s;flex:1;min-width:0}
.deal-title:hover{color:var(--jd-red)}
.deal-tags{display:flex;gap:4px;margin-bottom:6px;flex-wrap:wrap}
.d-tag{font-size:12px;padding:1px 5px;border-radius:2px;font-weight:500}
.d-tag-red{background:#fff0f0;color:var(--jd-red);border:1px solid #ffd0d0}
.d-tag-gold{background:#fffbe6;color:#b38600;border:1px solid #ffe58f}
.d-tag-green{background:#f0fff0;color:#389e0d;border:1px solid #b7eb8f}
.d-tag-blue{background:#e6f7ff;color:#096dd9;border:1px solid #91d5ff}
.d-tag-gray{background:#f5f5f5;color:#888;border:1px solid #e0e0e0}
.d-tag-purple{background:#f9f0ff;color:#722ed1;border:1px solid #d3adf7}
:root.dark .d-tag-red{background:#2a1515;color:#ff6b6b;border-color:#5a2020}
:root.dark .d-tag-gold{background:#2a2510;color:#d4a017;border-color:#5a4a1a}
:root.dark .d-tag-green{background:#152a15;color:#52c41a;border-color:#2a5a2a}
:root.dark .d-tag-blue{background:#102040;color:#40a9ff;border-color:#204080}
:root.dark .d-tag-gray{background:#2a2a2a;color:#888;border-color:#444}
:root.dark .d-tag-purple{background:#251a30;color:#b37feb;border-color:#4a3060}
.deal-price-row{display:flex;align-items:baseline;gap:6px;margin-bottom:4px;margin-top:auto}
.deal-price{font-size:22px;font-weight:900;color:var(--jd-red);line-height:1}
.deal-price .yen{font-size:15px;font-weight:700}
.deal-original{font-size:13px;color:var(--text-faint);text-decoration:line-through}
.deal-coupon{display:inline-flex;align-items:center;background:linear-gradient(90deg,var(--jd-red),#FF6B35);color:#fff;font-size:11px;padding:0 5px;border-radius:2px;font-weight:600;line-height:18px}
.deal-meta{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--text-light);flex-wrap:wrap;margin-top:4px}
.deal-meta .good{color:var(--orange)}
.deal-meta .shop{display:flex;align-items:center;gap:3px}
.deal-meta .time{color:var(--text-faint)}
.deal-actions{display:flex;align-items:flex-end;flex-direction:column;gap:6px;justify-content:center;flex-shrink:0}
.deal-link{padding:6px 14px;background:var(--jd-red);color:#fff;border-radius:3px;font-size:13px;font-weight:600;transition:all .15s;white-space:nowrap;display:inline-block}
.deal-link:hover{background:var(--jd-dark);color:#fff!important}
.deal-link:focus,.deal-link:visited{color:#fff}
.deal-link:active{transform:scale(.96);color:#fff!important}
.deal-fav{width:28px;height:28px;border-radius:50%;border:1px solid var(--fav-border);display:flex;align-items:center;justify-content:center;font-size:14px;transition:all .15s;color:var(--text-light)}
.deal-fav:hover{border-color:var(--jd-red);color:var(--jd-red)}
.deal-fav.active{color:var(--jd-red);border-color:var(--jd-red);background:#fff0f0}
.deal-bottom-group{margin-top:4px}
.detail-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);z-index:1000;opacity:0;visibility:hidden;transition:all .25s}
.detail-overlay.open{opacity:1;visibility:visible}
.detail-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(.92);width:520px;max-width:94vw;max-height:80vh;background:var(--bg-white);border-radius:12px;z-index:1001;display:flex;flex-direction:column;overflow:hidden;opacity:0;visibility:hidden;transition:all .3s cubic-bezier(.16,1,.3,1);box-shadow:0 20px 60px rgba(0,0,0,.3)}
.detail-modal.open{opacity:1;visibility:visible;transform:translate(-50%,-50%) scale(1)}
.detail-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);flex-shrink:0}
.detail-head-title{font-size:18px;font-weight:700}
.detail-close{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--text-sec);transition:all .15s}
.detail-close:hover{background:var(--bg)}
.detail-body{flex:1;overflow-y:auto;padding:20px}
.detail-product{display:flex;gap:16px}
.detail-img{width:180px;height:180px;border-radius:8px;overflow:hidden;flex-shrink:0;background:var(--skeleton-base)}
.detail-img img{width:100%;height:100%;object-fit:cover}
.detail-info{flex:1;min-width:0}
.detail-name{font-size:17px;font-weight:600;line-height:1.5;margin-bottom:10px;display:flex;align-items:flex-start;gap:6px}
.detail-name .self-badge{margin-top:2px}
.detail-price-row{display:flex;align-items:baseline;gap:8px;margin-bottom:10px;flex-wrap:wrap}
.detail-price{font-size:28px;font-weight:900;color:var(--jd-red);line-height:1}
.detail-price .yen{font-size:17px;font-weight:700}
.detail-original{font-size:15px;color:var(--text-faint);text-decoration:line-through}
.detail-tags{display:flex;gap:4px;margin-bottom:12px;flex-wrap:wrap}
.detail-meta{display:flex;flex-direction:column;gap:6px;font-size:14px;color:var(--text-sec)}
.detail-meta .shop{display:flex;align-items:center;gap:4px}
.detail-meta .good{color:var(--orange)}
.detail-delivery{font-size:15px;font-weight:600;display:inline-flex;align-items:center;gap:6px;margin-top:4px}
.detail-delivery.jd-express{color:var(--green)}
.detail-delivery.jd-express::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--green);flex-shrink:0}
.detail-delivery.normal-express{color:var(--text-light)}
.detail-delivery.normal-express::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--text-light);flex-shrink:0}
.detail-footer{padding:16px 20px;border-top:1px solid var(--border);flex-shrink:0}
.detail-countdown-bar{width:100%;height:3px;background:#eee;border-radius:2px;overflow:hidden;margin-bottom:8px}
.detail-countdown-progress{height:100%;background:var(--jd-red);border-radius:2px;transition:width 1s linear;width:100%}
.detail-countdown-text{font-size:14px;color:var(--text-light);text-align:center;margin-bottom:14px}
.detail-actions{display:flex;gap:10px}
.detail-btn-cancel{flex:1;height:40px;border:1px solid var(--border);border-radius:6px;font-size:15px;color:var(--text-sec);background:var(--bg-white);transition:all .15s}
.detail-btn-cancel:hover{border-color:var(--jd-red);color:var(--jd-red)}
.detail-btn-share{flex:1;height:40px;border:1px solid var(--border);border-radius:6px;font-size:15px;color:var(--text-sec);background:var(--bg-white);transition:all .15s}
.detail-btn-share:hover{border-color:var(--orange);color:var(--orange)}
.detail-btn-go{flex:2;height:40px;background:var(--jd-red);color:#fff;border-radius:6px;font-size:16px;font-weight:600;display:flex;align-items:center;justify-content:center;transition:all .15s}
.detail-btn-go:hover{background:var(--jd-dark)}
.skeleton-card{background:var(--bg-white);border-radius:var(--radius);padding:12px;display:flex;gap:12px}
.skeleton-img{width:140px;height:140px;border-radius:6px;background:linear-gradient(90deg,var(--skeleton-base) 25%,var(--skeleton-shine) 50%,var(--skeleton-base) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;flex-shrink:0}
.skeleton-body{flex:1;display:flex;flex-direction:column;gap:8px;padding:8px 0}
.skeleton-line{height:16px;border-radius:3px;background:linear-gradient(90deg,var(--skeleton-base) 25%,var(--skeleton-shine) 50%,var(--skeleton-base) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}
.skeleton-line.w80{width:80%}.skeleton-line.w50{width:50%}.skeleton-line.w30{width:30%}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.load-more{display:flex;align-items:center;justify-content:center;padding:24px 0;color:var(--text-light);font-size:14px;gap:8px}
.load-more .loading-spinner{width:16px;height:16px}
.no-more{display:flex;align-items:center;justify-content:center;padding:24px 0;color:var(--text-faint);font-size:14px;gap:6px}
.no-more::before,.no-more::after{content:'';width:40px;height:1px;background:var(--border)}
.pagination-bar{display:flex;align-items:center;justify-content:center;gap:6px;padding:20px 0 26px;flex-wrap:wrap}
.page-btn{min-width:34px;height:32px;padding:0 10px;border-radius:4px;border:1px solid var(--border);background:var(--bg-white);color:var(--text-sec);font-size:14px;transition:all .15s}
.page-btn:hover{border-color:var(--jd-red);color:var(--jd-red)}
.page-btn.active{background:var(--jd-red);border-color:var(--jd-red);color:#fff;font-weight:700}
.page-btn:disabled{opacity:.45;cursor:not-allowed;border-color:var(--border);color:var(--text-light);background:var(--hover-bg)}
.page-ellipsis{font-size:14px;color:var(--text-light);padding:0 3px}
.footer{background:var(--footer-bg);color:var(--footer-text);padding:18px 0 14px;margin-top:18px;flex-shrink:0}
.footer-inner{display:flex;flex-direction:column;align-items:center;gap:8px}
.footer-links-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:4px 10px;font-size:16px;line-height:1.65;text-align:center}
.footer-links-label{color:var(--footer-text)}
.footer-links-row a{color:var(--footer-text);transition:color .15s}
.footer-links-row a:hover{color:#fff;text-decoration:underline}
.footer-sep{color:#888}
.footer-meta{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:4px 12px;font-size:15px;color:var(--footer-text);line-height:1.65;text-align:center}
.footer-meta a{color:var(--footer-text);transition:color .15s}
.footer-meta a:hover{color:#fff;text-decoration:underline}
.footer-disclaimer{font-size:15px;color:var(--text-light);text-align:center;line-height:1.65;max-width:980px;margin:0 auto;white-space:pre-line}
.side-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);backdrop-filter:blur(4px);z-index:1000;opacity:0;visibility:hidden;transition:all .25s}
.side-overlay.open{opacity:1;visibility:visible}
.side-panel{position:fixed;top:0;right:0;width:400px;max-width:100vw;height:100vh;background:var(--bg-white);z-index:1001;transform:translateX(100%);transition:transform .3s cubic-bezier(.16,1,.3,1);display:flex;flex-direction:column;overflow:hidden}
.side-panel.open{transform:translateX(0)}
.side-head{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 14px;border-bottom:1px solid var(--border);flex-shrink:0}
.side-head-title{font-size:19px;font-weight:700;display:flex;align-items:center;gap:8px}
.side-head-count{font-size:14px;font-weight:400;color:var(--text-light)}
.side-close{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--text-sec);transition:all .15s}
.side-close:hover{background:var(--bg)}
.side-tabs{display:flex;border-bottom:1px solid var(--border);padding:0 16px;flex-shrink:0}
.side-tab{padding:12px 0;margin-right:20px;font-size:15px;color:var(--text-sec);border-bottom:2px solid transparent;cursor:pointer;transition:all .15s;user-select:none}
.side-tab:hover{color:var(--text)}
.side-tab.active{color:var(--jd-red);border-bottom-color:var(--jd-red);font-weight:500}
.login-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);backdrop-filter:blur(4px);z-index:1000;opacity:0;visibility:hidden;transition:all .25s}
.login-overlay.open{opacity:1;visibility:visible}
.login-panel{position:fixed;top:0;right:0;width:400px;max-width:100vw;height:100vh;background:var(--bg-white);z-index:1001;transform:translateX(100%);transition:transform .3s cubic-bezier(.16,1,.3,1);display:flex;flex-direction:column;overflow-y:auto}
.login-panel.open{transform:translateX(0)}
.login-head{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 12px;border-bottom:1px solid var(--border)}
.login-head-title{font-size:20px;font-weight:700}
.login-close{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--text-sec);transition:all .15s}
.login-close:hover{background:var(--bg)}
.login-tabs{display:flex;border-bottom:1px solid var(--border);padding:0 24px}
.login-tab{padding:12px 0;margin-right:24px;font-size:15px;color:var(--text-sec);border-bottom:2px solid transparent;transition:all .15s;cursor:pointer}
.login-tab:hover{color:var(--text)}
.login-tab.active{color:var(--jd-red);border-bottom-color:var(--jd-red);font-weight:500}
.login-body{flex:1;padding:20px 24px}
.login-form{display:none}
.login-form.active{display:block}
.login-field{margin-bottom:14px}
.login-field label{display:block;font-size:14px;color:var(--text-sec);margin-bottom:5px;font-weight:500}
.login-input{width:100%;height:40px;border:1px solid var(--border);border-radius:4px;padding:0 12px;font-size:16px;outline:none;transition:all .15s;background:var(--input-bg);color:var(--text)}
.login-input:focus{border-color:var(--jd-red);box-shadow:0 0 0 2px rgba(228,57,60,.08)}
.login-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;font-size:14px}
.login-check{display:flex;align-items:center;gap:5px;cursor:pointer;color:var(--text-sec)}
.login-check input{accent-color:var(--jd-red);width:14px;height:14px}
.login-link{color:var(--jd-red);cursor:pointer}
.login-link:hover{text-decoration:underline}
.login-btn{width:100%;height:40px;background:var(--jd-red);color:#fff;border-radius:4px;font-size:16px;font-weight:600;transition:all .15s}
.login-btn:hover{background:var(--jd-dark)}
.login-btn:active{transform:scale(.98)}
.login-sms-row{display:flex;gap:8px}
.login-sms-row .login-input{flex:1}
.sms-btn{flex-shrink:0;width:110px;height:40px;border:1px solid var(--jd-red);color:var(--jd-red);border-radius:4px;font-size:14px;font-weight:500;background:var(--bg-white);transition:all .15s;white-space:nowrap}
.sms-btn:hover{background:var(--hover-bg)}
.sms-btn:disabled{border-color:var(--border);color:var(--text-light);cursor:not-allowed;background:var(--hover-bg)}
.login-terms{margin-top:16px;text-align:center;font-size:13px;color:var(--text-light);line-height:1.8}
.login-terms a{color:var(--jd-red)}
.login-terms a:hover{text-decoration:underline}
.fav-body{flex:1;overflow-y:auto;padding:12px 16px}
.fav-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-light);gap:12px}
.fav-empty-icon{font-size:42px;opacity:.3}
.fav-empty-text{font-size:15px}
.fav-item{display:flex;gap:10px;padding:10px 0;border-bottom:1px solid var(--fav-border);animation:fadeUp .3s ease}
.fav-item:last-child{border-bottom:none}
.fav-item-img{width:72px;height:72px;border-radius:6px;overflow:hidden;flex-shrink:0;background:var(--skeleton-base)}
.fav-item-img img{width:100%;height:100%;object-fit:cover}
.fav-item-info{flex:1;display:flex;flex-direction:column;justify-content:space-between;min-width:0}
.fav-item-name{font-size:14px;font-weight:600;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.fav-item-price{font-size:17px;font-weight:900;color:var(--jd-red)}
.fav-item-price .yen{font-size:13px}
.fav-item-shop{font-size:12px;color:var(--text-light)}
.fav-item-actions{display:flex;flex-direction:column;gap:4px;flex-shrink:0;align-items:center;justify-content:center}
.fav-goto{padding:4px 10px;background:var(--jd-red);color:#fff;border-radius:3px;font-size:12px;font-weight:600;transition:all .15s;white-space:nowrap}
.fav-goto:hover{background:var(--jd-dark);color:#fff!important}
.fav-goto:focus,.fav-goto:visited,.fav-goto:active{color:#fff!important}
.fav-remove{font-size:12px;color:var(--text-light);cursor:pointer;transition:color .15s}
.fav-remove:hover{color:var(--jd-red)}
.fav-footer{padding:12px 16px;border-top:1px solid var(--border);flex-shrink:0;display:flex;gap:8px}
.fav-clear-btn{flex:1;height:36px;border:1px solid var(--border);border-radius:4px;font-size:14px;color:var(--text-sec);background:var(--bg-white);transition:all .15s}
.fav-clear-btn:hover{border-color:var(--jd-red);color:var(--jd-red)}
.search-suggest-tag{display:inline-block;padding:4px 14px;border:1px solid var(--border);border-radius:16px;font-size:14px;color:var(--text-sec);cursor:pointer;transition:all .15s}
.search-suggest-tag:hover{border-color:var(--jd-red);color:var(--jd-red);background:var(--hover-bg)}
.toast{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(.8);background:rgba(0,0,0,.75);color:#fff;padding:10px 20px;border-radius:6px;font-size:15px;z-index:9999;pointer-events:none;opacity:0;transition:all .25s}
.toast.show{opacity:1;transform:translate(-50%,-50%) scale(1)}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.anim{opacity:0;animation:fadeUp .4s ease forwards}
.anim-d1{animation-delay:.05s}.anim-d2{animation-delay:.1s}.anim-d3{animation-delay:.15s}.anim-d4{animation-delay:.2s}.anim-d5{animation-delay:.25s}
.loading-state{display:flex;align-items:center;justify-content:center;padding:60px 0;color:var(--text-light);font-size:15px;gap:8px}
.loading-spinner{width:20px;height:20px;border:2px solid var(--skeleton-base);border-top-color:var(--jd-red);border-radius:50%;animation:spin .6s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.back-to-top{position:fixed;bottom:30px;right:30px;width:44px;height:44px;border-radius:50%;background:var(--jd-red);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 12px rgba(228,57,60,.3);opacity:0;visibility:hidden;transition:all .3s;cursor:pointer;z-index:50;font-size:18px}
.back-to-top.show{opacity:1;visibility:visible}
.back-to-top:hover{background:var(--jd-dark);transform:translateY(-2px)}
@media(max-width:960px){.product-list.grid-view{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}}
@media(max-width:640px){
  .header{padding:8px 0}.header .container{flex-wrap:wrap;gap:8px}
  .logo{order:1}.logo-icon{width:32px;height:32px}.logo-text{font-size:19px}.logo-sub{display:none}
  .header-nav{order:2;margin-left:auto;gap:0}.header-link{height:30px;padding:0 6px;font-size:13px}.header-link.optional{display:none}
  .h-right{order:3}.h-right .h-act span{display:none}.h-act{height:30px;min-width:30px;padding:0 6px}
  .theme-toggle{width:30px;height:30px;font-size:15px}
  .search-box{order:4;flex:0 0 100%;max-width:none}.search-box input{height:36px;font-size:14px;padding-right:72px}
  .search-clear{right:50px}.search-box .sbtn{height:36px;width:46px}.search-tags{display:none}
  .sort-bar{top:95px;padding:0 8px;gap:4px}.sort-tab{padding:10px 11px;font-size:14px}.result-info{display:none}
  .view-toggle{margin-left:0;flex-shrink:0}
  .side-panel,.login-panel{width:100vw}
  .deal-card{flex-wrap:wrap}.deal-img{width:100px;height:100px}.deal-title{font-size:14px}.deal-price{font-size:19px}
  .deal-actions{flex-direction:row;width:100%}.deal-link{flex:1;text-align:center}
  .product-list.grid-view .deal-card{flex-direction:column}.product-list.grid-view{grid-template-columns:repeat(2,1fr)}
  .fav-item-img{width:60px;height:60px}
  .detail-modal{width:100%;max-width:100vw;max-height:90vh;border-radius:12px 12px 0 0;top:auto;bottom:0;left:0;right:0;transform:translateY(100%)}
  .detail-modal.open{transform:translateY(0)}.detail-product{flex-direction:column}
  .detail-img{width:100%;height:auto;aspect-ratio:1}
  .back-to-top{bottom:20px;right:20px;width:38px;height:38px;font-size:16px}
}
@media(max-width:400px){.container{padding:0 10px}.deal-img{width:80px;height:80px}}
::-webkit-scrollbar{width:5px}::-webkit-scrollbar-thumb{background:#ddd;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ccc}
:root.dark ::-webkit-scrollbar-thumb{background:#444}:root.dark ::-webkit-scrollbar-thumb:hover{background:#555}


/* ========== 重写版补充样式 ========== */
.image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--skeleton-base);color:var(--text-light);font-size:13px}
.deal-img .image-placeholder{border-radius:6px}
.detail-img .image-placeholder,.fav-item-img .image-placeholder{border-radius:6px}
.search-dropdown-empty{padding:10px 14px;font-size:14px;color:var(--text-light)}
.side-product-click{cursor:pointer}
.phone-login-tip{font-size:13px;color:var(--text-light);line-height:1.6;margin:-2px 0 14px}
.layui-laypage a,.layui-laypage span{border-radius:4px!important}
.layui-laypage .layui-laypage-curr .layui-laypage-em{background-color:var(--jd-red)!important;border-radius:4px!important}
#paginationBar .layui-laypage{margin:0}
.share-preview-overlay{position:fixed;inset:0;background:rgba(0,0,0,.78);backdrop-filter:blur(6px);z-index:9998;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;cursor:pointer;animation:fadeUp .25s ease}
.share-preview-card{cursor:default;max-width:390px;width:100%}
.share-preview-img{width:100%;border-radius:10px;box-shadow:0 8px 32px rgba(0,0,0,.4);display:block}
.share-preview-hint{color:rgba(255,255,255,.55);font-size:13px;margin-top:14px;text-align:center}
.share-preview-actions{display:flex;gap:10px;margin-top:18px;justify-content:center}
.share-preview-download{padding:10px 32px;background:var(--jd-red);color:#fff;border-radius:6px;font-size:15px;font-weight:600;text-decoration:none;transition:background .15s}
.share-preview-download:hover{background:var(--jd-dark);color:#fff}
.share-preview-close{padding:10px 32px;background:transparent;color:rgba(255,255,255,.7);border:1px solid rgba(255,255,255,.2);border-radius:6px;font-size:15px;cursor:pointer;transition:all .15s}
.share-preview-close:hover{color:#fff;border-color:rgba(255,255,255,.4)}
