*{margin:0;padding:0;box-sizing:border-box}body{font-family:PingFang SC,Microsoft YaHei,sans-serif;background:#fff5f7;color:#333}header{background:linear-gradient(135deg,#e8506a,#c0325a);color:#fff;padding:0 2rem;display:flex;align-items:center;justify-content:space-between;height:64px;position:sticky;top:0;z-index:100;box-shadow:0 2px 12px #c0325a40}.logo{font-size:22px;font-weight:700;letter-spacing:2px}.logo span{font-size:13px;font-weight:400;margin-left:8px;opacity:.85}.header-btns{display:flex;gap:10px}.btn-outline{border:1.5px solid rgba(255,255,255,.8);background:transparent;color:#fff;padding:6px 18px;border-radius:20px;cursor:pointer;font-size:14px;font-family:inherit;transition:background .2s}.btn-outline:hover{background:#ffffff26}.btn-solid{background:#fff;color:#e8506a;border:none;padding:6px 18px;border-radius:20px;cursor:pointer;font-size:14px;font-weight:600;font-family:inherit;transition:opacity .2s}.btn-solid:hover{opacity:.9}.hero{background:linear-gradient(135deg,#fce4ec,#ffd6e0);text-align:center;padding:3.5rem 1rem 2.5rem;border-bottom:1px solid #f8b4c8}.hero h1{font-size:34px;color:#c0325a;margin-bottom:.5rem;font-weight:700}.hero p{font-size:15px;color:#b05070;margin-bottom:1.5rem}.hero-stats{display:flex;justify-content:center;gap:2.5rem;font-size:13px;color:#c0325a}.hero-stats strong{font-size:20px;display:block;font-weight:700}.filter-bar{background:#fff;padding:.9rem 2rem;display:flex;gap:12px;align-items:center;border-bottom:1px solid #f0d0da;flex-wrap:wrap}.filter-bar label{font-size:13px;color:#888}.filter-bar select{padding:5px 12px;border:1px solid #f0c0cc;border-radius:16px;font-size:13px;color:#555;background:#fff8fa;cursor:pointer;outline:none;font-family:inherit}.filter-bar select:focus{border-color:#e8506a}.tag{padding:4px 14px;border-radius:16px;font-size:12px;cursor:pointer;border:1px solid #f0c0cc;background:#fff0f4;color:#e8506a;transition:all .2s}.tag.active,.tag:hover{background:#e8506a;color:#fff;border-color:#e8506a}.section-title{padding:1.5rem 2rem .5rem;font-size:16px;color:#999}.section-title strong{color:#333;font-size:20px}.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;padding:1rem 2rem 1.5rem;max-width:1200px;margin:0 auto}.pagination{display:flex;justify-content:center;align-items:center;gap:8px;padding:1rem 0 3rem}.page-btn{width:38px;height:38px;border-radius:50%;border:1.5px solid #f0c0cc;background:#fff;color:#e8506a;font-size:14px;font-weight:500;cursor:pointer;font-family:inherit;transition:all .2s;display:flex;align-items:center;justify-content:center}.page-btn:hover{background:#fff0f4;border-color:#e8506a}.page-btn.active{background:#e8506a;color:#fff;border-color:#e8506a}.page-btn.prev-next{width:auto;padding:0 16px;border-radius:20px;font-size:13px}.card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 2px 12px #e8506a14;transition:transform .2s,box-shadow .2s;cursor:pointer;border:1px solid #fce0e8}.card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #e8506a2e}.card-photo{width:100%;aspect-ratio:3/4;object-fit:cover;display:block;background:#f8e8ee}.card-body{padding:12px 14px 14px}.card-name{font-size:15px;font-weight:600;color:#333;display:flex;align-items:center;gap:6px;margin-bottom:4px}.age-badge{font-size:11px;background:#fce4ec;color:#e8506a;padding:1px 7px;border-radius:10px;font-weight:500}.card-meta{font-size:12px;color:#aaa;margin-bottom:8px;display:flex;gap:8px}.card-meta span:before{content:"📍";font-size:10px;margin-right:2px}.card-tags{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:10px}.card-tag{font-size:11px;padding:2px 8px;border-radius:8px;background:#fff0f4;color:#e8506a;border:1px solid #fad0dc}.card-btn{width:100%;padding:7px 0;background:linear-gradient(135deg,#e8506a,#c0325a);color:#fff;border:none;border-radius:20px;font-size:13px;cursor:pointer;font-family:inherit;font-weight:500;transition:opacity .2s}.card-btn:hover{opacity:.88}.online-dot{width:8px;height:8px;background:#4caf50;border-radius:50%;border:1.5px solid white;display:inline-block}.modal-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:1000;align-items:center;justify-content:center}.modal-overlay.show{display:flex}.modal{background:#fff;border-radius:20px;width:90%;max-width:460px;overflow:hidden;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{background:linear-gradient(135deg,#e8506a,#c0325a);padding:1.5rem 1.5rem 1rem;color:#fff;text-align:center;position:relative}.modal-header h2{font-size:20px;font-weight:700;margin-bottom:4px}.modal-header p{font-size:13px;opacity:.88}.modal-close{position:absolute;top:12px;right:14px;background:#fff3;border:none;color:#fff;width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center}.modal-close:hover{background:#ffffff59}.modal-tab{flex:1;padding:12px;border:none;border-bottom:2px solid transparent;background:none;color:#aaa;font-size:14px;cursor:pointer;font-family:inherit;transition:color .2s,border-bottom-color .2s}.modal-tab-active{color:#e8506a!important;border-bottom-color:#e8506a!important;font-weight:600}.modal-body{padding:1.25rem 1.5rem}.form-group{margin-bottom:14px}.form-group label{display:block;font-size:12px;color:#999;margin-bottom:5px}.form-group input{width:100%;padding:9px 12px;border:1px solid #e8d0d8;border-radius:10px;font-size:14px;outline:none;font-family:inherit;transition:border-color .2s;color:#333}.form-group input:focus{border-color:#e8506a}.form-group input::placeholder{color:#ccc}.agree-line{font-size:11px;color:#bbb;text-align:center;margin-bottom:12px}.agree-line a{color:#e8506a;text-decoration:none}.submit-btn{width:100%;padding:11px;background:linear-gradient(135deg,#e8506a,#c0325a);color:#fff;border:none;border-radius:24px;font-size:15px;font-weight:600;cursor:pointer;font-family:inherit;transition:opacity .2s;letter-spacing:1px}.submit-btn:hover{opacity:.9}.divider{display:flex;align-items:center;gap:10px;margin:14px 0;font-size:12px;color:#ccc}.divider:before,.divider:after{content:"";flex:1;height:1px;background:#f0e0e8}.countdown-badge{position:fixed;bottom:20px;right:20px;background:#e8506a;color:#fff;border-radius:50%;width:50px;height:50px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:10px;z-index:500;cursor:pointer;box-shadow:0 4px 14px #e8506a66;transition:transform .2s}.countdown-badge:hover{transform:scale(1.1)}.countdown-badge strong{font-size:18px;line-height:1}footer{background:#333;color:#aaa;text-align:center;padding:1.5rem;font-size:12px;line-height:2}@media (min-width: 601px) and (max-width: 900px){.grid{grid-template-columns:repeat(3,1fr);gap:14px;padding:1rem 1.5rem 1.5rem}.section-title{padding:1rem 1.5rem .5rem}.filter-bar{padding:.75rem 1.5rem}.hero{padding:2.5rem 1rem 2rem}.hero h1{font-size:28px}}@media (max-width: 600px){header{height:52px;padding:0 1rem}.logo{font-size:17px;letter-spacing:1px}.logo span{display:none}.btn-outline,.btn-solid{padding:5px 12px;font-size:13px}.hero{padding:1.8rem 1rem 1.4rem}.hero h1{font-size:22px}.hero p{font-size:13px;margin-bottom:1rem}.hero-stats{gap:1.2rem;font-size:12px}.hero-stats strong{font-size:17px}.filter-bar{padding:.6rem 1rem;gap:6px}.filter-bar select{font-size:12px;padding:4px 8px}.tag{font-size:11px;padding:3px 10px}.section-title{padding:.9rem 1rem .4rem;font-size:14px}.section-title strong{font-size:16px}.grid{grid-template-columns:repeat(2,1fr);gap:10px;padding:.75rem 1rem 1rem}.card-body{padding:8px 10px 10px}.card-name{font-size:13px}.card-meta{font-size:11px;margin-bottom:6px}.card-tag{font-size:10px;padding:2px 6px}.card-btn{font-size:12px;padding:6px 0}.pagination{gap:5px;padding:.75rem 0 2rem}.page-btn{width:32px;height:32px;font-size:12px}.page-btn.prev-next{padding:0 10px;font-size:11px}.modal{width:95%;border-radius:16px;max-width:none}.modal-header{padding:1.2rem 1.2rem .8rem}.modal-header h2{font-size:17px}.modal-body{padding:1rem 1.2rem}.form-group input{font-size:16px}.submit-btn{font-size:14px}footer{font-size:11px;padding:1rem}.countdown-badge{width:44px;height:44px;bottom:14px;right:14px}.countdown-badge strong{font-size:16px}}@media (max-width: 360px){.grid{gap:8px;padding:.5rem}.header-btns .btn-outline{display:none}.hero h1{font-size:20px}.hero-stats{gap:.8rem}}
