:root{color:#111827;background:#f5f6f7;font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}html{min-width:320px;background:#eef0f2}body{margin:0;min-width:320px;min-height:100vh;-webkit-font-smoothing:antialiased}button,input,textarea{font:inherit}button{border:0;cursor:pointer}.app-shell{position:relative;width:min(100vw,390px);min-height:100vh;margin:0 auto;overflow-x:hidden;background:#f7f8fa;color:#111827}.topbar{position:sticky;top:0;z-index:20;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;min-height:70px;padding:14px 16px 10px;background:#fffffff5;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.topbar h1{margin:0;font-size:20px;font-weight:800;line-height:1;white-space:nowrap}.location{display:flex;gap:8px;align-items:center;min-width:0;color:#111827;font-size:17px;font-weight:700}.location span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.icon-button{display:inline-flex;width:42px;height:42px;align-items:center;justify-content:flex-start;background:transparent;color:#111827}.mini-capsule{justify-self:end;display:flex;width:88px;height:34px;align-items:center;justify-content:space-around;padding:0 10px;border:1px solid #e6e8ec;border-radius:999px;background:#fff}.mini-capsule span{width:5px;height:5px;border-radius:50%;background:#111}.mini-capsule i{display:block;width:20px;height:20px;margin-left:6px;border:5px solid #111;border-radius:50%}.home-search{position:sticky;top:70px;z-index:15;padding:0 16px 12px;background:#fff;border-bottom:1px solid #edf0f2}.search-box{display:flex;height:48px;align-items:center;gap:10px;padding:0 15px;border:1px solid #e1e5e9;border-radius:13px;background:#fafafa;color:#8b929d;font-size:15px}.filter-row{display:grid;grid-template-columns:repeat(5,1fr);gap:0;margin-top:13px}.filter-row button{display:flex;min-width:0;height:30px;align-items:center;justify-content:center;gap:3px;border-left:1px solid #edf0f2;background:transparent;color:#111827;font-size:14px;font-weight:650}.filter-row button:first-child{border-left:0}.screen-content{padding:14px 14px 92px}.panel{border:1px solid #edf0f2;border-radius:16px;background:#fff}.today-panel{padding:17px 14px 16px}.section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.section-head h2,.panel h2{display:flex;align-items:center;gap:7px;margin:0;color:#111827;font-size:20px;font-weight:850;line-height:1.25}.section-head h3,.info-section h3,.review-block h3{margin:0;font-size:17px;font-weight:800}.section-head p{margin:6px 0 0;color:#7b8491;font-size:14px}.section-head p b{color:#17a661}.section-head button{display:inline-flex;align-items:center;gap:2px;padding:2px 0;background:transparent;color:#7d858f;font-size:14px}.compact{align-items:center}.slot-strip{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(74px,1fr);gap:8px;margin-top:16px;overflow-x:auto;scrollbar-width:none}.slot-strip::-webkit-scrollbar,.date-grid::-webkit-scrollbar,.booking-times::-webkit-scrollbar{display:none}.slot-strip button,.date-grid button{display:flex;min-height:68px;flex-direction:column;align-items:center;justify-content:center;gap:5px;border:1px solid #e5e8ec;border-radius:10px;background:#fff;color:#111827}.slot-strip button.selected,.date-grid button.selected{border-color:#18a85f;background:#f0fbf5;color:#149855}.slot-strip strong,.date-grid strong{font-size:15px;font-weight:800}.slot-strip span,.date-grid span{color:#9097a2;font-size:13px}.date-grid button.selected span,.date-grid button.selected b,.slot-strip button.selected span{color:#149855}.goal-tabs{display:flex;gap:8px;margin:12px 0;overflow-x:auto;scrollbar-width:none}.goal-tabs button,.review-tags button{flex:0 0 auto;min-height:34px;padding:0 13px;border:1px solid transparent;border-radius:999px;background:#fff;color:#4b5563;font-size:14px;font-weight:650}.goal-tabs button.active,.review-tags button.selected{border-color:#18a85f;background:#ecfbf3;color:#139654}.coach-list{border:1px solid #edf0f2;border-radius:16px;overflow:hidden;background:#fff}.coach-row{position:relative;display:grid;grid-template-columns:1fr 82px;gap:8px;padding:14px;border-bottom:1px solid #eef1f3}.coach-row:last-child{border-bottom:0}.coach-hit{display:grid;grid-template-columns:84px minmax(0,1fr);gap:12px;min-width:0;padding:0;text-align:left;background:transparent;color:inherit}.coach-hit img,.booking-coach img,.profile-head img,.mini-coach img{display:block;object-fit:cover;background:#e5e7eb}.coach-hit img{width:84px;height:104px;border-radius:10px}.coach-info{min-width:0}.coach-name-line{display:flex;align-items:center;gap:7px;min-width:0}.coach-name-line strong{overflow:hidden;font-size:18px;font-weight:850;text-overflow:ellipsis;white-space:nowrap}.coach-info p,.booking-coach p,.profile-card p,.mini-coach p{margin:6px 0 0;color:#606a76;font-size:13px;line-height:1.35}.tag-line{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.tag{display:inline-flex;max-width:100%;align-items:center;min-height:23px;padding:0 8px;border-radius:6px;background:#eaf8f1;color:#149855;font-size:12px;font-weight:700;line-height:1}.tag-gray{background:#f2f3f5;color:#5a6470}.available{display:flex;align-items:center;gap:5px;margin-top:9px;color:#7b8491;font-size:13px}.available svg,.nearby svg,.summary-line svg,.goal-summary svg,.info-row svg,.price-panel svg,.panel h2 svg,.section-head h2 svg{color:#17a661}.available b{color:#17a661}.coach-side{display:flex;flex-direction:column;align-items:flex-end;justify-content:space-between;color:#8b929d;font-size:13px}.coach-side b{display:inline-flex;align-items:center;gap:3px;color:#111827;font-size:14px}.coach-side b svg,.rating-line svg,.stars,.star-picker button.active{color:#ffae1a}.coach-side button,.sticky-book button,.checkout-bar button,.wide-button,.empty-state button{display:inline-flex;min-height:43px;align-items:center;justify-content:center;gap:6px;border-radius:999px;background:#16a45d;color:#fff;font-size:16px;font-weight:800}.coach-side button{width:74px;min-height:42px;font-size:15px}.trust-strip{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:10px;margin-top:12px;padding:14px;border-radius:14px;background:#ecf9f2;color:#158a51}.trust-strip div{min-width:0}.trust-strip strong{display:block;color:#111827;font-size:15px}.trust-strip span{display:block;margin-top:4px;overflow:hidden;color:#66717e;font-size:12px;text-overflow:ellipsis;white-space:nowrap}.bottom-nav{position:fixed;left:50%;bottom:0;z-index:25;display:grid;width:min(100vw,390px);grid-template-columns:repeat(4,1fr);min-height:76px;transform:translate(-50%);border-top:1px solid #e5e7eb;background:#fffffff7;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.bottom-nav button{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;background:transparent;color:#8a929e;font-size:12px;font-weight:700}.bottom-nav button.active{color:#17a661}.bottom-nav i{position:absolute;top:10px;right:calc(50% - 22px);min-width:17px;height:17px;padding:0 5px;border-radius:999px;background:#ef4444;color:#fff;font-size:11px;font-style:normal;line-height:17px}.detail-content{padding-bottom:104px;background:#fff}.profile-head{display:grid;grid-template-columns:104px minmax(0,1fr);gap:14px;align-items:center;padding:8px 4px 16px;border-bottom:1px solid #eff1f4}.profile-head img{width:104px;height:104px;border-radius:52px}.profile-name{display:flex;flex-wrap:wrap;align-items:center;gap:7px}.profile-name h2{margin:0;font-size:28px;font-weight:900;line-height:1.1}.profile-name span{color:#1f9fff;font-size:18px;font-weight:900}.rating-line{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin:8px 0 0;color:#111827;font-size:15px}.rating-line span{color:#56616d}.coach-bio{margin:16px 4px 18px;color:#3b4350;font-size:16px;line-height:1.7}.info-section,.review-block{padding:16px 4px;border-top:1px solid #eff1f4}.wide{gap:8px}.info-row{display:grid;width:100%;grid-template-columns:auto auto minmax(0,1fr) auto;align-items:center;gap:10px;padding:17px 4px;border-top:1px solid #eff1f4;background:transparent;color:inherit;text-align:left}.info-row strong{font-size:17px}.info-row span{min-width:0;overflow:hidden;color:#3f4752;font-size:15px;text-overflow:ellipsis;white-space:nowrap}.date-grid{display:grid;grid-auto-flow:column;grid-auto-columns:76px;gap:9px;margin-top:14px;overflow-x:auto;scrollbar-width:none}.date-grid button{min-height:82px}.date-grid b{color:#18a85f;font-size:13px}.time-grid,.booking-times{display:flex;gap:9px;margin-top:13px;overflow-x:auto;scrollbar-width:none}.time-grid button,.booking-times button{flex:0 0 auto;min-width:72px;height:42px;border-radius:9px;background:#f4f5f7;color:#202733;font-size:15px;font-weight:700}.time-grid button.selected,.booking-times button.selected{background:#17a661;color:#fff}.review-row{display:grid;grid-template-columns:44px minmax(0,1fr);gap:10px;margin-top:13px}.review-row img{width:44px;height:44px;object-fit:cover;border-radius:50%}.review-row strong{font-size:15px}.review-row p{margin:5px 0 0;color:#384150;font-size:14px;line-height:1.6}.review-row .stars{color:#ffae1a}.stars span{margin-left:8px;color:#8b929d}.guarantees{display:grid;grid-template-columns:repeat(4,1fr);gap:0;padding:17px 0;border-top:1px solid #eff1f4}.guarantees div{display:flex;min-width:0;flex-direction:column;align-items:center;gap:6px;border-left:1px solid #eff1f4;color:#18a85f;text-align:center}.guarantees div:first-child{border-left:0}.guarantees strong{color:#1f2937;font-size:13px;font-weight:800}.guarantees span{color:#8b929d;font-size:12px}.sticky-book,.checkout-bar{position:fixed;left:50%;bottom:0;z-index:28;display:grid;width:min(100vw,390px);grid-template-columns:1fr 190px;gap:14px;align-items:center;min-height:82px;padding:12px 14px;transform:translate(-50%);border-top:1px solid #e5e7eb;background:#fffffffa;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.sticky-book strong,.checkout-bar strong{color:#159654;font-size:25px;font-weight:900}.sticky-book span{color:#5c6672;font-size:14px}.sticky-book p{margin:2px 0 0;color:#8b929d;font-size:12px}.sticky-book button,.checkout-bar button{width:100%;border-radius:8px}.booking-content{padding-bottom:108px}.summary-line{display:grid;grid-template-columns:1fr auto 1fr auto;gap:10px;align-items:center;margin-bottom:10px;color:#111827;font-size:15px;font-weight:700}.summary-line span{display:flex;min-width:0;align-items:center;gap:5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.summary-line i{width:1px;height:22px;background:#dfe3e8}.summary-line button{background:transparent;color:#149855;font-weight:800}.goal-summary{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:12px;padding:13px;border-radius:12px;background:#eefaf4}.goal-summary span{display:inline-flex;align-items:center;gap:6px;color:#344054;font-size:14px;font-weight:700}.goal-summary button{min-height:36px;padding:0 14px;border:1px solid #17a661;border-radius:9px;background:#fff;color:#149855;font-size:15px;font-weight:800}.booking-content .panel,.price-panel{margin-bottom:12px;padding:15px 12px}.booking-coach{position:relative;display:grid;grid-template-columns:96px minmax(0,1fr) auto;gap:12px;margin-top:13px;align-items:start}.booking-coach img{width:96px;height:118px;border-radius:10px}.booking-coach>b{color:#111827;font-size:14px;white-space:nowrap}.booking-bio{display:-webkit-box;overflow:hidden;-webkit-line-clamp:2;-webkit-box-orient:vertical}.nearby{position:absolute;left:8px;bottom:8px;display:inline-flex;align-items:center;gap:3px;padding:4px 7px;border-radius:999px;background:#16a45d;color:#fff;font-size:12px;font-weight:800}.nearby svg{color:#fff}.place-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:14px}.place-grid button{display:flex;min-height:88px;flex-direction:column;align-items:center;justify-content:center;gap:5px;padding:8px;border:1px solid #e4e8ed;border-radius:11px;background:#fff;color:#4b5563}.place-grid button.selected{border-color:#18a85f;background:#f0fbf5;color:#149855}.place-grid strong{color:#111827;font-size:14px;font-weight:850}.place-grid span{color:#6b7280;font-size:12px}.address-line{margin:12px 0 0;color:#5e6875;font-size:13px;line-height:1.5}.gym-list{margin-top:12px;padding:11px;border-radius:12px;background:#f7f8fa}.gym-list-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-bottom:8px}.gym-list-head strong{font-size:15px;font-weight:850}.gym-list-head span{color:#8b929d;font-size:12px}.gym-list button{display:grid;width:100%;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center;padding:10px 0;border-top:1px solid #e8ebef;background:transparent;color:#111827;text-align:left}.gym-list button.selected{color:#149855}.gym-list button strong,.gym-list button span,.gym-list button em{display:block;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gym-list button strong{font-size:14px;font-weight:850}.gym-list button span{margin-top:4px;color:#6b7280;font-size:12px}.gym-list button em{margin-top:4px;color:#149855;font-size:12px;font-style:normal;font-weight:700}.gym-list button b{color:#6b7280;font-size:12px;font-weight:800}.gym-note{margin:8px 0 0;padding:9px 10px;border-radius:9px;background:#ecfbf3;color:#149855;font-size:12px;font-weight:750}.price-panel{border:1px solid #edf0f2;border-radius:16px;background:#fff}.price-panel p{display:flex;align-items:baseline;gap:8px;margin:17px 0 12px}.price-panel p strong{font-size:32px;font-weight:950}.price-panel p span{color:#111827;font-size:16px}.price-panel p em{color:#6b7280;font-size:13px;font-style:normal}.coupon{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:11px 12px;border-radius:10px;background:#fff5df;color:#b56a04;font-size:13px;font-weight:750}.coupon button{flex:0 0 auto;background:transparent;color:#ea580c;font-weight:850}.compact-guarantees{margin-bottom:0;border:1px solid #edf0f2;border-radius:16px;background:#fff}.checkout-bar{grid-template-columns:110px 1fr}.checkout-bar span{display:block;color:#333b46;font-size:13px}.success-content{min-height:calc(100vh - 70px);display:flex;flex-direction:column;justify-content:center;padding-bottom:30px}.success-hero{display:flex;flex-direction:column;align-items:center;margin-bottom:20px;color:#17a661;text-align:center}.success-hero h2{margin:13px 0 6px;color:#111827;font-size:24px;font-weight:900}.success-hero p{width:min(280px,100%);margin:0;color:#6b7280;font-size:14px;line-height:1.6}.order-summary,.order-card{padding:15px}.section-head span{color:#149855;font-size:13px;font-weight:800}.mini-coach{display:grid;grid-template-columns:58px minmax(0,1fr);gap:11px;align-items:center;margin:14px 0}.mini-coach img{width:58px;height:58px;border-radius:10px}.mini-coach strong{font-size:17px;font-weight:850}.mini-coach span{display:block;margin-top:5px;color:#149855;font-size:13px;font-weight:800}.wide-button{width:100%;margin-top:8px;border-radius:10px}.plain-button{width:100%;min-height:42px;margin-top:8px;border-radius:10px;background:#f0fbf5;color:#149855;font-size:15px;font-weight:800}.empty-state{display:flex;min-height:420px;flex-direction:column;align-items:center;justify-content:center;color:#8b929d;text-align:center}.empty-state h2{margin:16px 0 6px;color:#111827;font-size:22px}.empty-state p{margin:0 0 18px;color:#6b7280;font-size:14px}.empty-state button{padding:0 24px}.done-note{margin:12px 0 0;padding:12px;border-radius:10px;background:#f0fbf5;color:#149855;font-size:14px;font-weight:750;text-align:center}.review-content{padding-bottom:30px}.star-picker{display:flex;justify-content:center;gap:8px;margin:20px 0}.star-picker button{display:inline-flex;width:38px;height:38px;align-items:center;justify-content:center;background:transparent;color:#d0d5dd}.review-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}textarea{display:block;width:100%;min-height:122px;padding:12px;resize:none;border:1px solid #e4e8ed;border-radius:12px;outline:0;color:#111827;font-size:15px;line-height:1.55}textarea:focus{border-color:#18a85f;box-shadow:0 0 0 3px #18a85f1f}.message-list{border:1px solid #edf0f2;border-radius:16px;overflow:hidden;background:#fff}.message-list button{display:grid;width:100%;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:12px;padding:16px 14px;border-bottom:1px solid #eef1f3;background:#fff;color:#111827;text-align:left}.message-list button:last-child{border-bottom:0}.message-list svg{color:#17a661}.message-list strong{font-size:16px;font-weight:850}.message-list p{margin:5px 0 0;color:#6b7280;font-size:13px}.profile-card{display:flex;align-items:center;gap:13px;padding:18px 14px;border-radius:16px;background:#fff}.user-avatar{display:flex;width:58px;height:58px;align-items:center;justify-content:center;border-radius:50%;background:#16a45d;color:#fff;font-size:24px;font-weight:900}.profile-card strong{font-size:19px;font-weight:900}.profile-actions{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:12px}.profile-actions button{display:flex;min-height:88px;flex-direction:column;align-items:center;justify-content:center;gap:8px;border:1px solid #edf0f2;border-radius:14px;background:#fff;color:#111827;font-size:15px;font-weight:800}.profile-actions svg{color:#17a661}@media(max-width:360px){.coach-row{grid-template-columns:1fr}.coach-side{flex-direction:row;align-items:center}.booking-coach,.profile-head{grid-template-columns:82px minmax(0,1fr)}.booking-coach img{width:82px;height:104px}.profile-head img{width:82px;height:82px}.profile-name h2{font-size:23px}.sticky-book,.checkout-bar{grid-template-columns:1fr}}
