/* ===== Reset ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --red:#D4382C;--red-bg:#FFF5F5;--red-dark:#A01A0A;
  --gold:#FAAD14;--gold-bg:#FFFBE6;
  --text:#2D1B1B;--text-light:#999;--text-mid:#666;
  --bg:#FFF;--bg-alt:#FFFAF8;--bg-warm:#FFF8F0;
  --border:#F5E0DC;--radius:8px;
  --shadow:0 2px 8px rgba(180,60,40,.06);
  --shadow-hover:0 4px 16px rgba(180,60,40,.12);
  --max-w:1180px;--header-h:56px;
}
html{scroll-behavior:smooth}
body{font-family:-apple-system,BlinkMacSystemFont,"PingFang SC","Hiragino Sans GB","Microsoft YaHei",sans-serif;color:var(--text);background:var(--bg);line-height:1.5}
a{color:var(--red);text-decoration:none}
a:hover{color:var(--red-dark)}
.container{max-width:var(--max-w);margin:0 auto;padding:0 20px}

/* ===== Header ===== */
.header{position:fixed;top:0;left:0;right:0;height:var(--header-h);background:rgba(255,255,255,.97);backdrop-filter:blur(6px);border-bottom:1px solid var(--border);z-index:100;transition:box-shadow .3s}
.header.scrolled{box-shadow:0 2px 12px rgba(180,60,40,.08)}
.header-inner{display:flex;align-items:center;gap:16px;height:var(--header-h)}
.logo{font-size:22px;font-weight:800;color:var(--text);white-space:nowrap}
.logo span{color:var(--red)}
.header-search{flex:1;max-width:320px}
.header-search input{width:100%;padding:7px 14px;border:1px solid var(--border);border-radius:20px;font-size:13px;outline:none;background:var(--bg-warm);transition:border-color .2s}
.header-search input:focus{border-color:var(--red)}
.nav{display:flex;gap:20px}
.nav a{font-size:14px;color:var(--text-mid);font-weight:500}
.nav a:hover{color:var(--red)}
.menu-toggle{display:none;background:none;border:none;font-size:22px;cursor:pointer;color:var(--text)}

/* ===== Hero (compact) ===== */
.hero{padding:calc(var(--header-h) + 32px) 0 28px;background:linear-gradient(135deg,#FFF5F5 0%,#FFE8E0 50%,#FFF8F0 100%);text-align:center}
.hero h1{font-size:28px;font-weight:800;margin-bottom:6px;color:var(--text)}
.hero p{font-size:14px;color:var(--text-light);margin-bottom:20px}
.hero-stats{display:flex;justify-content:center;gap:40px}
.stat strong{display:block;font-size:24px;font-weight:800;color:var(--red)}
.stat span{font-size:12px;color:var(--text-light)}

/* ===== Filter ===== */
.filter-section{background:var(--bg);border-bottom:1px solid var(--border);padding:14px 0}
.filter-row{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.filter-row:last-child{margin-bottom:0}
.filter-label{font-size:13px;color:var(--text-mid);font-weight:600;white-space:nowrap;min-width:48px}
.filter-group{display:flex;gap:6px;flex-wrap:wrap}
.ftag{padding:4px 14px;border:1px solid var(--border);border-radius:16px;background:#fff;color:var(--text-mid);font-size:12px;cursor:pointer;transition:all .2s;white-space:nowrap}
.ftag:hover{border-color:var(--red);color:var(--red)}
.ftag.active{background:var(--red);color:#fff;border-color:var(--red)}

/* ===== Section ===== */
.section{padding:40px 0}
.section-alt{background:var(--bg-alt)}
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.section-header h2{font-size:20px;font-weight:700}
.rank-switch{display:flex;gap:4px}
.rbtn{padding:5px 14px;border:1px solid var(--border);border-radius:14px;background:#fff;color:var(--text-mid);font-size:12px;cursor:pointer;transition:all .2s}
.rbtn.active{background:var(--red);color:#fff;border-color:var(--red)}
.result-count{font-size:13px;color:var(--text-light)}

/* ===== Rank Top5 ===== */
.rank-top5{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
.top5-card{background:#fff;border:1px solid var(--border);border-radius:10px;padding:14px 10px;text-align:center;position:relative;transition:all .25s;cursor:pointer}
.top5-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px)}
.top5-card .rank-badge{width:28px;height:28px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-size:13px;margin:0 auto 6px}
.rank-badge.gold{background:linear-gradient(135deg,#FFD700,#FFA500);color:#fff}
.rank-badge.silver{background:linear-gradient(135deg,#C0C0C0,#A0A0A0);color:#fff}
.rank-badge.bronze{background:linear-gradient(135deg,#CD7F32,#A0522D);color:#fff}
.rank-badge.normal{background:var(--red-bg);color:var(--red)}
.top5-card h4{font-size:13px;font-weight:600;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.top5-card .score-big{font-size:22px;font-weight:800;color:var(--red);margin:2px 0}
.top5-card .score-label{font-size:10px;color:var(--text-light)}
.top5-card .tags{display:flex;gap:3px;justify-content:center;margin-top:6px;flex-wrap:wrap}
.tag-type{padding:1px 6px;background:var(--red-bg);color:var(--red);font-size:10px;border-radius:6px}
.tag-city{padding:1px 6px;background:var(--gold-bg);color:#B8860B;font-size:10px;border-radius:6px}
.top5-card .meta{font-size:11px;color:var(--text-light);margin-top:4px}

/* ===== Compact Card Grid ===== */
.card{padding:12px 14px;border:1px solid var(--border);border-radius:10px;transition:all .25s;cursor:pointer;display:flex;flex-direction:column;justify-content:space-between;min-height:145px}
.card:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px);border-color:var(--red)}
.card-name{font-size:13px;font-weight:600;margin-bottom:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-bottom:6px;border-bottom:1px solid var(--border)}
.card-score{font-size:12px;color:var(--red);font-weight:700;margin-bottom:6px}
.card-score .star{color:var(--gold);font-size:13px}
.card-desc{font-size:11px;color:var(--text-light);margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.5}
.card-tags{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:8px}
.card-footer{display:flex;justify-content:space-between;align-items:center;font-size:10px;color:var(--text-light);padding-top:6px;border-top:1px solid var(--border)}

/* ===== Center Grid ===== */
.center-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.card{background:#fff;border:1px solid var(--border);border-radius:10px;padding:14px;transition:all .25s;cursor:pointer}
.card:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px);border-color:var(--red)}
.card-name{font-size:14px;font-weight:600;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card-score{font-size:13px;color:var(--red);font-weight:700;margin-bottom:6px}
.card-score .star{color:var(--gold)}
.card-desc{font-size:12px;color:var(--text-light);margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-tags{display:flex;gap:4px;flex-wrap:wrap}
.card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:8px;font-size:11px;color:var(--text-light)}

/* ===== About ===== */
.about-box{max-width:800px;margin:0 auto;text-align:center;padding:0 20px}
.about-box h2{font-size:20px;font-weight:700;margin-bottom:12px}
.about-box p{font-size:14px;color:var(--text-mid);margin-bottom:8px;line-height:1.8}

/* ===== City Filter Tabs ===== */
.city-tabs{display:flex;gap:4px;flex-wrap:wrap}
.ctab{padding:5px 16px;border:1px solid var(--border);border-radius:16px;background:#fff;color:var(--text-mid);font-size:12px;cursor:pointer;transition:all .2s;white-space:nowrap}
.ctab:hover{border-color:var(--red);color:var(--red)}
.ctab.active{background:var(--red);color:#fff;border-color:var(--red)}
.city-filter-content{display:flex;gap:6px;flex-wrap:wrap;padding-top:8px;min-height:32px}
.city-filter-content .ftag-city{padding:4px 12px;border:1px solid var(--border);border-radius:14px;background:#fff;color:var(--text-mid);font-size:12px;cursor:pointer;transition:all .2s}
.city-filter-content .ftag-city:hover{border-color:var(--red);color:var(--red);background:var(--red-bg)}
.city-filter-content .ftag-city.active{background:var(--red);color:#fff;border-color:var(--red)}

/* ===== City List (bottom section) ===== */
.city-list-wrap{display:flex;flex-direction:column;gap:16px}
.city-list-group{}
.city-list-group-title{font-size:14px;font-weight:700;color:var(--text);margin-bottom:8px;display:flex;align-items:center;gap:6px}
.city-list-group-title .dot{width:6px;height:6px;border-radius:50%;background:var(--red);display:inline-block}
.city-list-cities{display:flex;gap:6px;flex-wrap:wrap}
.city-link{padding:3px 10px;border:1px solid var(--border);border-radius:12px;font-size:12px;color:var(--text-mid);text-decoration:none;transition:all .2s}
.city-link:hover{border-color:var(--red);color:var(--red);background:var(--red-bg)}
.city-list-collapsed .city-list-cities{display:none}
.city-list-toggle{padding:5px 14px;border:1px solid var(--border);border-radius:14px;background:#fff;color:var(--text-mid);font-size:12px;cursor:pointer;transition:all .2s}
.city-list-toggle:hover{border-color:var(--red);color:var(--red)}

/* ===== Footer ===== */
.footer{background:#2D1B1B;color:rgba(255,255,255,.6);padding:20px 0;text-align:center;font-size:12px}

/* ===== Back top ===== */
.back-top{position:fixed;bottom:24px;right:24px;width:40px;height:40px;border-radius:50%;background:var(--red);color:#fff;font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;pointer-events:none;transition:opacity .3s;box-shadow:0 3px 10px rgba(180,60,40,.3);z-index:99}
.back-top.show{opacity:1;pointer-events:auto}

/* ===== Modal ===== */
.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:200;display:none;align-items:flex-start;justify-content:center;padding:60px 20px;overflow-y:auto}
.modal-overlay.open{display:flex}
.modal{background:#fff;border-radius:16px;max-width:640px;width:100%;position:relative;margin:20px 0;animation:slideUp .3s}
@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.modal-close{position:absolute;top:12px;right:16px;background:none;border:none;font-size:24px;cursor:pointer;color:#999;z-index:1}
.modal-close:hover{color:var(--red)}
.modal-body{padding:32px 28px}
.modal-body h3{font-size:22px;font-weight:700;margin-bottom:8px}
.modal-body .detail-score{font-size:32px;font-weight:800;color:var(--red);margin:8px 0}
.modal-body .detail-tags{display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap}
.modal-body .detail-section{margin-bottom:20px}
.modal-body .detail-section h4{font-size:15px;font-weight:600;margin-bottom:8px;color:var(--text)}
.modal-body .detail-section p{font-size:14px;color:var(--text-mid);line-height:1.7}
.detail-contact{background:var(--bg-warm);border-radius:10px;padding:16px;margin-top:16px}
.detail-contact p{font-size:13px;color:var(--text-mid);margin-bottom:4px}
.detail-contact strong{color:var(--text)}
/* Rating */
.rate-section{margin-top:20px;padding-top:20px;border-top:1px solid var(--border)}
.rate-section h4{font-size:15px;font-weight:600;margin-bottom:12px}
.star-rate{display:flex;gap:4px;margin-bottom:12px}
.star-rate span{font-size:28px;cursor:pointer;color:#ddd;transition:color .15s}
.star-rate span.active,.star-rate span:hover{color:var(--gold)}
.rate-textarea{width:100%;height:80px;border:1px solid var(--border);border-radius:8px;padding:10px;font-size:13px;resize:vertical;outline:none;margin-bottom:10px}
.rate-textarea:focus{border-color:var(--red)}
.rate-submit{padding:8px 24px;background:var(--red);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}
.rate-submit:hover{background:#A01A0A}
/* Reviews list */
.reviews-list{margin-top:16px}
.review-item{padding:12px 0;border-bottom:1px solid var(--border)}
.review-item:last-child{border-bottom:none}
.review-item .r-user{font-size:13px;font-weight:600;color:var(--text)}
.review-item .r-score{color:var(--gold);font-size:13px}
.review-item .r-text{font-size:13px;color:var(--text-mid);margin-top:4px}
.review-item .r-time{font-size:11px;color:var(--text-light);margin-top:2px}

/* ===== Mobile ===== */
@media(max-width:900px){
  .center-grid{grid-template-columns:repeat(2,1fr)}
  .rank-top5{grid-template-columns:repeat(3,1fr)}
  .rank-top3{grid-template-columns:1fr}
}
@media(max-width:640px){
  .hero h1{font-size:22px}
  .hero-stats{gap:24px}
  .stat strong{font-size:20px}
  .center-grid{grid-template-columns:1fr}
  .rank-top5{grid-template-columns:repeat(2,1fr)}
  .header-search{display:none}
  .nav{display:none;flex-direction:column;position:absolute;top:var(--header-h);left:0;right:0;background:#fff;border-bottom:1px solid var(--border);padding:12px 20px;gap:12px}
  .nav.open{display:flex}
  .menu-toggle{display:block}
  .filter-section{padding:10px 0}
  .filter-row{flex-wrap:wrap}
  /* Horizontal scroll for type filter on mobile */
  .filter-group{overflow-x:auto;flex-wrap:nowrap;padding-bottom:4px;white-space:nowrap;-webkit-overflow-scrolling:touch}
  .filter-group::-webkit-scrollbar{height:2px}
  .filter-group::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}
  .city-filter-content{overflow-x:auto;flex-wrap:nowrap;gap:4px;padding-bottom:4px;-webkit-overflow-scrolling:touch}
  .city-tabs{overflow-x:auto;flex-wrap:nowrap;padding-bottom:4px;-webkit-overflow-scrolling:touch}
}
