/* 无限臀山 组件样式 */

/* Hero 首屏 */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(44,44,44,.35) 0%,rgba(44,44,44,.55) 100%);z-index:1}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0;transform:scale(1.05);animation:slowZoom 20s ease-in-out infinite alternate}
@keyframes slowZoom{to{transform:scale(1.12)}}
.hero-inner{position:relative;z-index:2;max-width:840px;padding:0 var(--space-4)}
.hero-eyebrow{font-family:var(--font-mono);letter-spacing:.4em;font-size:.85rem;color:var(--secondary);text-transform:uppercase;margin-bottom:var(--space-3)}
.hero h1{color:#fff;font-size:clamp(2.4rem,5.5vw,4.4rem);font-weight:400;letter-spacing:.05em;margin-bottom:var(--space-4)}
.hero p{font-size:1.15rem;color:rgba(255,255,255,.92);max-width:640px;margin:0 auto var(--space-5)}
.hero-actions{display:flex;justify-content:center;gap:var(--space-3);flex-wrap:wrap}
.hero-scroll{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:3;color:#fff;font-size:.78rem;letter-spacing:.2em;opacity:.7;animation:bob 2s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}

/* Trust 信任背书 */
.trust{background:#fff;padding:var(--space-7) 0}
.trust-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:var(--space-5);align-items:center}
.trust-intro h2{margin-top:0}
.stat{text-align:center;padding:var(--space-3)}
.stat-num{font-family:var(--font-mono);font-size:2.6rem;color:var(--accent);font-weight:600;display:block;line-height:1}
.stat-label{font-size:.88rem;color:var(--text-light);margin-top:6px;display:block}

/* 服务卡片 */
.service-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-5)}
.service-card{background:var(--card-bg);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm);transition:all var(--transition);display:flex;flex-direction:column}
.service-card:hover{transform:translateY(-5px);box-shadow:0 10px 30px rgba(0,0,0,.08)}
.service-card .thumb{aspect-ratio:4/3;overflow:hidden;background:var(--secondary)}
.service-card .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.service-card:hover .thumb img{transform:scale(1.05)}
.service-card .body{padding:var(--space-4);flex:1;display:flex;flex-direction:column;gap:10px}
.service-card .tag{display:inline-block;font-size:.75rem;background:rgba(125,157,156,.12);color:var(--accent);padding:3px 10px;border-radius:99px;align-self:flex-start}
.service-card h3{margin:6px 0}
.service-card .desc{color:var(--text-light);font-size:.93rem;flex:1}
.service-card .meta{display:flex;justify-content:space-between;align-items:center;padding-top:var(--space-3);border-top:1px solid var(--border)}
.service-card .price{font-family:var(--font-mono);color:var(--accent);font-weight:600;font-size:1.15rem}
.service-card .price small{color:var(--text-light);font-weight:400;font-size:.7rem;margin-right:3px}
.service-card .duration{font-family:var(--font-mono);font-size:.85rem;color:var(--text-light)}

/* 套餐价格表 - 手风琴 */
.pricing-table{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-4)}
.package{background:#fff;border-radius:var(--radius-md);padding:var(--space-5);border:1px solid var(--border);transition:all var(--transition);position:relative}
.package.featured{border:2px solid var(--accent);transform:scale(1.03);box-shadow:var(--shadow-md)}
.package .ribbon{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--accent);color:#fff;padding:5px 16px;border-radius:99px;font-size:.78rem;letter-spacing:.1em}
.package h3{font-size:1.3rem;text-align:center;margin-bottom:6px}
.package .price-big{text-align:center;font-family:var(--font-mono);color:var(--accent);font-size:2.4rem;font-weight:600;margin:var(--space-3) 0}
.package .price-big small{font-size:.85rem;color:var(--text-light);font-weight:400}
.package ul{list-style:none;padding:0;margin:var(--space-3) 0}
.package li{padding:8px 0;border-bottom:1px dashed var(--border);font-size:.92rem;display:flex;gap:8px}
.package li::before{content:'✓';color:var(--accent);font-weight:700}
.package .btn{width:100%;margin-top:var(--space-3)}
.accordion{border-top:1px solid var(--border);margin-top:var(--space-3)}
.accordion details{border-bottom:1px solid var(--border)}
.accordion summary{padding:14px 0;cursor:pointer;font-weight:500;list-style:none;display:flex;justify-content:space-between;align-items:center}
.accordion summary::after{content:'+';color:var(--accent);font-size:1.4rem;transition:transform .3s}
.accordion details[open] summary::after{content:'−'}
.accordion .content{padding-bottom:var(--space-3);color:var(--text-light)}

/* 技师轮播 */
.therapist-carousel{position:relative;padding:var(--space-5) 0}
.therapist-track{display:flex;gap:var(--space-4);overflow-x:auto;scroll-snap-type:x mandatory;padding:var(--space-3) var(--space-3);scrollbar-width:none}
.therapist-track::-webkit-scrollbar{display:none}
.therapist-card{flex:0 0 280px;background:#fff;border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm);scroll-snap-align:center;transition:all var(--transition)}
.therapist-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.therapist-card .portrait{aspect-ratio:4/5;overflow:hidden}
.therapist-card .portrait img{width:100%;height:100%;object-fit:cover}
.therapist-card .info{padding:var(--space-3) var(--space-4) var(--space-4);text-align:center}
.therapist-card h4{margin:0 0 4px}
.therapist-card .title{color:var(--accent);font-size:.85rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:8px}
.therapist-card .quote{font-size:.92rem;color:var(--text-light);font-style:italic}
.stars{color:#f0b429;letter-spacing:2px;font-size:.9rem;margin:8px 0}

/* 时间选择器 */
.booking-steps{display:flex;justify-content:space-between;margin-bottom:var(--space-5);position:relative}
.booking-steps::before{content:'';position:absolute;top:18px;left:5%;right:5%;height:2px;background:var(--border)}
.step{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:8px;flex:1}
.step-num{width:36px;height:36px;border-radius:50%;background:#fff;border:2px solid var(--border);color:var(--text-light);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-weight:600}
.step.active .step-num{background:var(--primary);color:#fff;border-color:var(--primary)}
.step.done .step-num{background:var(--accent);color:#fff;border-color:var(--accent)}
.step span{font-size:.85rem;color:var(--text-light)}
.step.active span{color:var(--accent);font-weight:500}
.time-slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:10px;margin-top:var(--space-3)}
.slot{padding:10px;text-align:center;border-radius:8px;background:var(--secondary);color:var(--text);cursor:pointer;font-family:var(--font-mono);font-size:.92rem;transition:all .25s}
.slot:hover{background:var(--primary);color:#fff}
.slot.taken{background:#eee;color:#bbb;text-decoration:line-through;cursor:not-allowed}
.slot.selected{background:var(--primary);color:#fff;box-shadow:0 4px 12px rgba(125,157,156,.4)}

/* 会员进度条 */
.member-card{background:linear-gradient(135deg,#5F8A8B,#7D9D9C);color:#fff;padding:var(--space-5);border-radius:var(--radius-md);box-shadow:var(--shadow-md)}
.member-card h3{color:#fff}
.progress{height:10px;background:rgba(255,255,255,.18);border-radius:99px;overflow:hidden;margin:var(--space-3) 0 8px}
.progress-bar{height:100%;background:#fff;border-radius:99px;transition:width 1.2s ease-out}
.member-card .meta{display:flex;justify-content:space-between;font-size:.88rem;opacity:.9}

/* 画廊 - Masonry */
.gallery-grid{columns:3 280px;column-gap:var(--space-3)}
.gallery-grid figure{margin:0 0 var(--space-3);break-inside:avoid;border-radius:var(--radius-md);overflow:hidden;background:var(--secondary);position:relative}
.gallery-grid img{width:100%;height:auto;transition:transform .6s ease}
.gallery-grid figure:hover img{transform:scale(1.04)}
.gallery-grid figcaption{position:absolute;bottom:0;left:0;right:0;padding:14px;background:linear-gradient(transparent,rgba(0,0,0,.7));color:#fff;font-size:.88rem;opacity:0;transition:opacity .3s}
.gallery-grid figure:hover figcaption{opacity:1}

/* 评价 */
.testimonials{background:var(--card-bg);padding:var(--space-7) 0;position:relative}
.testimonial-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-4)}
.testimonial{background:var(--bg);padding:var(--space-5);border-radius:var(--radius-md);position:relative}
.testimonial::before{content:'"';position:absolute;top:8px;right:18px;font-size:5rem;color:var(--secondary);opacity:.4;font-family:Georgia,serif;line-height:1}
.testimonial p{font-size:.95rem;color:var(--text);line-height:1.8;margin-bottom:var(--space-3)}
.testimonial .author{display:flex;justify-content:space-between;align-items:center;font-size:.88rem;color:var(--text-light);padding-top:var(--space-3);border-top:1px solid var(--border)}

/* 快捷预约 CTA */
.cta-band{background:var(--bg);padding:var(--space-7) 0;position:relative;overflow:hidden}
.cta-band::before{content:'';position:absolute;inset:0;background:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 200 200"><path fill="%237D9D9C" fill-opacity="0.05" d="M50 30 Q60 50 50 80 Q40 110 60 130 Z"/></svg>') repeat;opacity:.5}
.cta-inner{position:relative;display:grid;grid-template-columns:1.2fr 1fr;gap:var(--space-6);align-items:center;background:#fff;padding:var(--space-6);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}
.cta-inner h2{margin-top:0}
.quick-form{display:grid;gap:var(--space-3)}
.quick-form label{font-size:.88rem;color:var(--text-light);display:block;margin-bottom:4px}
.quick-form input,.quick-form select{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:8px;background:var(--card-bg);transition:border-color .25s}
.quick-form input:focus,.quick-form select:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px rgba(125,157,156,.15)}

/* 表单 */
.form-grid{display:grid;gap:var(--space-3)}
.form-grid label{font-size:.9rem;color:var(--text);display:block;margin-bottom:4px;font-weight:500}
.form-grid input,.form-grid select,.form-grid textarea{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:8px;background:#fff}
.form-grid input:focus,.form-grid select:focus,.form-grid textarea:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px rgba(125,157,156,.15)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}
.checkbox-line{display:flex;gap:8px;align-items:flex-start;font-size:.86rem;color:var(--text-light)}
.checkbox-line input{width:auto;margin-top:3px}

/* 文章排版 */
.prose{max-width:860px;margin:0 auto;font-size:1.02rem}
.prose h2{margin-top:var(--space-6)}
.prose h3{margin-top:var(--space-5);color:var(--accent)}
.prose p{margin-bottom:var(--space-3);text-align:justify}
.prose figure{margin:var(--space-5) 0}
.prose figure img{border-radius:var(--radius-md)}
.prose figcaption{text-align:center;color:var(--text-light);font-size:.85rem;margin-top:8px}
.prose blockquote{border-left:3px solid var(--accent);padding:8px 18px;color:var(--text-light);font-style:italic;margin:var(--space-4) 0;background:var(--card-bg);border-radius:0 8px 8px 0}

/* 404 */
.error-page{min-height:80vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:var(--space-7) var(--space-4)}
.error-page h1{font-size:8rem;color:var(--primary);margin:0;font-family:var(--font-mono);font-weight:700}

/* 搜索 */
.search-box{display:flex;gap:8px;max-width:680px;margin:0 auto var(--space-5)}
.search-box input{flex:1;padding:14px 18px;border:1px solid var(--border);border-radius:99px;background:#fff;font-size:1rem}
.search-box button{padding:14px 28px;border-radius:99px;background:var(--primary);color:#fff}
.search-suggest{font-size:.88rem;color:var(--text-light);text-align:center;margin-bottom:var(--space-5)}
.search-suggest a{margin:0 8px;color:var(--accent)}

/* 时间轴 */
.timeline{border-left:2px solid var(--secondary);padding-left:var(--space-4);margin:var(--space-4) 0}
.timeline-item{position:relative;margin-bottom:var(--space-4);padding-left:var(--space-3)}
.timeline-item::before{content:'';position:absolute;left:-28px;top:6px;width:12px;height:12px;background:var(--primary);border-radius:50%;border:3px solid var(--bg)}
.timeline-item time{display:block;font-family:var(--font-mono);color:var(--accent);font-size:.88rem;margin-bottom:4px}

/* 两栏布局 */
.two-col{display:grid;grid-template-columns:2fr 1fr;gap:var(--space-5)}
.aside{background:#fff;padding:var(--space-4);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);align-self:start;position:sticky;top:100px}
.aside h4{margin-top:0}
.aside ul{list-style:none;padding:0;margin:0}
.aside li{padding:10px 0;border-bottom:1px solid var(--border);font-size:.9rem}
.aside li:last-child{border:0}

/* FAQ */
.faq-list{max-width:780px;margin:0 auto}

/* APP 下载 */
.app-hero{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6);align-items:center;padding:var(--space-7) 0}
.app-mock{background:linear-gradient(135deg,var(--primary),var(--accent));border-radius:var(--radius-lg);aspect-ratio:9/16;max-width:300px;margin:0 auto;box-shadow:var(--shadow-lg);display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--font-serif);font-size:1.4rem;padding:var(--space-5);text-align:center}
.qr-row{display:flex;gap:var(--space-4);margin-top:var(--space-4)}
.qr-row .qr-placeholder{width:140px;height:140px;font-size:.85rem;background:var(--bg);border:1px dashed var(--border);color:var(--text-light)}

/* 标签 */
.chip{display:inline-block;background:rgba(125,157,156,.12);color:var(--accent);padding:4px 12px;border-radius:99px;font-size:.78rem;margin:0 4px 4px 0}

@media (max-width: 960px){
  .trust-grid{grid-template-columns:1fr 1fr}
  .cta-inner{grid-template-columns:1fr;padding:var(--space-5)}
  .two-col{grid-template-columns:1fr}
  .aside{position:static}
  .form-row{grid-template-columns:1fr}
  .app-hero{grid-template-columns:1fr;gap:var(--space-5)}
  .booking-steps{font-size:.75rem}
}
@media (max-width: 560px){
  .package.featured{transform:none}
  .gallery-grid{columns:1}
  .hero{min-height:88vh}
}
