@import "https://fonts.googleapis.com/css2?family=Baloo+2:wght@400;500;600;700&display=swap";@import "https://fonts.googleapis.com/css2?family=ZCOOL+KuaiLe&display=swap";@import "https://fonts.googleapis.com/css2?family=Noto+Sans+SC:wght@300;400;500;700&display=swap";:root{--font-brand:"Baloo 2", "ZCOOL KuaiLe", "Noto Sans SC", sans-serif;--font-display:"Baloo 2", "Noto Sans SC", "Microsoft YaHei", sans-serif;--font-body:"Baloo 2", "Noto Sans SC", "Microsoft YaHei", sans-serif;--coffee-ink:#2b2825;--coffee-deep:#3a2a22;--coffee-roast:#6f604f;--coffee-caramel:#a47b52;--coffee-cream:#faf8f4;--coffee-milk:#fff;--coffee-latte:#eee8de;--coffee-muted:#726c64;--coffee-line:#2b28251f;--coffee-shadow:#2b282512}body,#root{font-family:var(--font-body);font-weight:400}*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0;padding:0}body{background:var(--coffee-cream);min-width:320px;color:var(--coffee-ink)}.app-shell{background:var(--coffee-cream);min-height:100vh;color:var(--coffee-ink);font-family:var(--font-body);line-height:1.65}button,select{font:inherit}button{border:0}.site-header{z-index:10;border-bottom:1px solid var(--coffee-line);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#ffffffeb;justify-content:space-between;align-items:center;gap:24px;min-height:72px;padding:14px clamp(18px,4vw,56px);display:flex;position:sticky;top:0}.brand{color:var(--coffee-deep);cursor:pointer;letter-spacing:0;text-align:left;background:0 0;font-family:"Baloo 2",sans-serif;font-size:30px;font-weight:700;line-height:1;display:inline-block}.site-nav{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex}.site-nav button,.sort-bar button{border:1px solid var(--coffee-line);background:var(--coffee-milk);min-height:38px;color:var(--coffee-deep);cursor:pointer;font-family:var(--font-brand);border-radius:8px;padding:8px 13px}.site-nav button:hover,.sort-bar button:hover,.sort-bar .is-active{background:var(--coffee-latte);color:var(--coffee-ink);border-color:#9b7a5557}.content-page{width:min(1160px,100% - 36px);margin:0 auto}.home{width:min(1320px,100% - 36px);margin:0 auto}.hero{background:linear-gradient(90deg,#30221b8f,#9b7a5514),url(/background.png) 100%/92% no-repeat;border-radius:8px;align-items:flex-end;min-height:calc(100vh - 132px);margin-top:24px;display:flex;position:relative;overflow:hidden}.hero__content{width:min(820px,100%);color:var(--coffee-milk);padding:clamp(32px,6vw,72px)}.eyebrow{color:var(--coffee-caramel);letter-spacing:0;margin:0 0 18px;font-weight:700;line-height:1.45}.hero .eyebrow{color:#d99a6f;margin-bottom:32px}h1,h2,h3{font-family:var(--font-display);letter-spacing:0;font-weight:700}p{letter-spacing:0}.hero h1,.page-intro h1,.text-panel h1,.detail-panel h1{margin:0;line-height:1.16}.hero h1{max-width:11em;font-size:clamp(44px,7vw,86px)}.hero__copy{color:#fff8edd6;max-width:660px;margin:28px 0 0;font-size:18px;line-height:1.9}.hero__actions,.page-actions{flex-wrap:wrap;align-items:center;gap:14px;margin-top:34px;display:flex}.button{cursor:pointer;min-height:42px;font-family:var(--font-brand);border-radius:8px;padding:13px 20px;font-weight:700;transition:transform .18s,background .18s,border-color .18s}.button:hover{transform:translateY(-1px)}.button--primary{background:var(--coffee-deep);color:var(--coffee-milk)}.button--light,.button--small,.button--ghost{border:1px solid var(--coffee-line);background:var(--coffee-milk);color:var(--coffee-deep)}.button--large{min-height:56px;padding:18px 30px;font-size:18px}.button--small{min-height:36px;padding:10px 15px}.button--ghost{width:100%;margin-top:26px}.stats-strip{border:1px solid var(--coffee-line);background:var(--coffee-milk);border-radius:8px;grid-template-columns:repeat(3,1fr);margin:18px 0 56px;display:grid}.stats-strip div{border-right:1px solid var(--coffee-line);padding:26px}.stats-strip div:last-child{border-right:0}.stats-strip strong{color:var(--coffee-roast);font-family:var(--font-brand);font-size:30px;display:block}.stats-strip span{color:var(--coffee-muted)}.section-grid{grid-template-columns:.85fr 1.15fr;gap:34px;padding-bottom:78px;display:grid}.feature-panel,.feature-list article,.page-intro,.filters,.empty-state,.bean-card,.detail-panel,.text-panel,.question-card{border:1px solid var(--coffee-line);background:var(--coffee-milk);box-shadow:0 16px 44px var(--coffee-shadow);border-radius:8px}.feature-panel,.feature-list article{padding:32px}.feature-panel h2{max-width:12em;color:var(--coffee-ink);margin:0;font-size:clamp(28px,4vw,48px);line-height:1.2}.feature-list{gap:18px;display:grid}.feature-list strong{color:var(--coffee-roast);font-size:20px}.feature-list p{color:var(--coffee-muted);margin:14px 0 0;line-height:1.85}.guide-teaser{border:1px solid var(--coffee-line);background:var(--coffee-milk);box-shadow:0 16px 44px var(--coffee-shadow);border-radius:8px;justify-content:space-between;align-items:center;gap:28px;margin:-42px 0 78px;padding:clamp(28px,4vw,42px);display:flex}.guide-teaser h2{max-width:760px;color:var(--coffee-ink);margin:0;font-size:clamp(30px,4vw,50px);line-height:1.16}.guide-teaser p:last-child{max-width:720px;color:var(--coffee-muted);margin:18px 0 0;line-height:1.85}.question-page{background:linear-gradient(120deg, #faf8f48f, #faf8f480), url(/question-bg.png) center / cover no-repeat, var(--coffee-cream);justify-content:center;align-items:center;height:calc(100vh - 72px);min-height:680px;padding:46px 18px;display:flex;overflow:auto}.question-card{width:min(100%,540px);padding:36px}.question-progress{color:var(--coffee-muted);gap:14px;font-size:14px;display:grid}.progress-track,.meter__track{background:var(--coffee-latte);border-radius:999px;height:8px;overflow:hidden}.progress-fill,.meter__fill{border-radius:inherit;background:linear-gradient(90deg, var(--coffee-deep), var(--coffee-roast));height:100%}.question-card h1{color:var(--coffee-ink);margin:30px 0 16px;font-size:clamp(28px,5vw,42px);line-height:1.22}.question-card p{color:var(--coffee-muted);margin:0;line-height:1.85}.option-list{gap:16px;margin-top:30px;display:grid}.option-button{border:1px solid var(--coffee-line);background:var(--coffee-milk);width:100%;color:var(--coffee-ink);cursor:pointer;font-family:var(--font-body);text-align:left;border-radius:8px;gap:9px;padding:18px 20px;display:grid}.option-button strong{font-family:var(--font-brand);font-size:18px}.option-button:hover{background:#f4efe7;border-color:#9b7a555c}.option-button span{color:var(--coffee-muted);font-size:14px;line-height:1.7}.content-page{padding:42px 0 84px}.page-intro{justify-content:space-between;align-items:flex-end;gap:32px;padding:clamp(30px,4vw,48px);display:flex}.page-intro .eyebrow{margin-bottom:15px}.page-intro h1,.detail-panel h1{max-width:780px;color:var(--coffee-ink);font-size:clamp(32px,5vw,56px)}.text-panel h1{max-width:860px;color:var(--coffee-ink);font-size:clamp(32px,4.6vw,48px)}.page-intro p,.detail-panel p{max-width:700px;color:var(--coffee-muted);margin:20px 0 0;line-height:1.9}.text-panel p{max-width:700px;color:var(--coffee-muted);margin:0;line-height:1.85}.sort-bar{flex-wrap:wrap;gap:10px;margin:24px 0;display:flex}.filters{grid-template-columns:repeat(4,1fr);gap:16px;margin:24px 0;padding:22px;display:grid}.filters label{color:var(--coffee-muted);gap:10px;font-size:14px;display:grid}.filters select,.filters input{border:1px solid var(--coffee-line);background:var(--coffee-milk);width:100%;min-height:42px;color:var(--coffee-ink);border-radius:8px;padding:8px 10px}.filters input::placeholder{color:var(--coffee-muted)}.filters--advanced{margin-top:-10px}.result-count{color:var(--coffee-muted);margin:6px 0 18px}.bean-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;display:grid}.bean-card{flex-direction:column;gap:13px;min-height:280px;padding:20px;display:flex}.bean-card__topline,.bean-card__footer{justify-content:space-between;align-items:center;gap:12px;display:flex}.bean-card__topline{color:var(--coffee-muted);font-size:14px}.bean-card__topline strong{color:var(--coffee-caramel)}.bean-card h3{color:var(--coffee-ink);margin:0;font-size:24px;line-height:1.2}.bean-card__meta{color:var(--coffee-muted);margin:0;line-height:1.55}.tag-row{flex-wrap:wrap;gap:7px;display:flex}.tag-row span{color:var(--coffee-roast);background:#f6f1e9;border:1px solid #6f5b462e;border-radius:999px;padding:6px 10px;font-size:13px}.reason{color:var(--coffee-muted);margin:0;line-height:1.65}.bean-card__footer{color:var(--coffee-muted);margin-top:auto}.empty-state,.text-panel{text-align:left;padding:clamp(34px,5vw,60px)}.text-panel{align-content:start;gap:26px;display:grid}.text-panel .eyebrow{margin:0 0 4px}.text-panel .button{justify-self:start;margin-top:4px}.empty-state h2{color:var(--coffee-ink);margin:0;font-size:30px}.empty-state p{max-width:620px;color:var(--coffee-muted);line-height:1.9}.detail-panel{grid-template-columns:minmax(0,1.3fr) minmax(280px,.7fr);gap:34px;padding:clamp(30px,5vw,52px);display:grid}.detail-panel__main,.detail-panel__side{align-content:start;gap:24px;display:grid}.detail-note{border-left:4px solid var(--coffee-caramel);background:#f7f1e8;padding:22px}.price-badge{background:var(--coffee-deep);color:var(--coffee-milk);font-family:var(--font-brand);text-align:center;border-radius:8px;padding:20px;font-size:26px;font-weight:700}.meter{gap:10px;display:grid}.meter__label{color:var(--coffee-muted);justify-content:space-between;display:flex}.detail-facts{grid-template-columns:repeat(2,1fr);gap:14px;display:grid}.detail-facts div{border:1px solid var(--coffee-line);background:var(--coffee-milk);border-radius:8px;padding:16px}.detail-facts span,.detail-facts strong{display:block}.detail-facts span{color:var(--coffee-muted);font-size:13px}.detail-facts strong{color:var(--coffee-ink);margin-top:8px}.loading-page{background:var(--coffee-cream);min-height:100vh;color:var(--coffee-ink);place-items:center;display:grid}.loading-page div{text-align:center;gap:10px;display:grid}.loading-page strong{font-size:32px}.loading-page span{color:var(--coffee-muted)}.about-panel{max-width:980px}.about-copy{gap:18px;max-width:820px;display:grid}.about-copy p{color:var(--coffee-muted);margin:0;line-height:1.95}.guide-layout{grid-template-columns:minmax(240px,.34fr) minmax(0,1fr);gap:18px;margin-top:24px;display:grid}.guide-categories,.guide-panel,.guide-term-card{border:1px solid var(--coffee-line);background:var(--coffee-milk);box-shadow:0 16px 44px var(--coffee-shadow);border-radius:8px}.guide-categories{align-content:start;gap:10px;padding:14px;display:grid}.guide-categories button{width:100%;color:var(--coffee-ink);cursor:pointer;text-align:left;background:0 0;border:1px solid #0000;border-radius:8px;gap:6px;padding:14px;display:grid}.guide-categories button:hover,.guide-categories .is-active{border-color:var(--coffee-line);background:#f6f1e9}.guide-categories strong{font-family:var(--font-brand);font-size:20px}.guide-categories span{color:var(--coffee-muted);font-size:14px;line-height:1.6}.guide-panel{gap:22px;padding:clamp(24px,4vw,40px);display:grid}.guide-panel__header h2{color:var(--coffee-ink);margin:0;font-size:clamp(30px,4vw,48px);line-height:1.16}.guide-panel__header p:last-child{max-width:680px;color:var(--coffee-muted);margin:14px 0 0;line-height:1.8}.guide-term-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;display:grid}.guide-term-card{box-shadow:none;padding:18px}.guide-term-card h3{color:var(--coffee-ink);margin:0;font-size:24px;line-height:1.2}.guide-term-card p{color:var(--coffee-muted);margin:12px 0 0;line-height:1.75}@media (width<=1000px){.site-header,.page-intro,.guide-teaser,.bean-card__topline,.bean-card__footer{flex-direction:column;align-items:stretch}.site-header{position:static}.site-nav{justify-content:flex-start}.hero{background:linear-gradient(90deg,#30221b8f,#9b7a5514),url(/background.png) 50%/cover;min-height:680px}.hero h1{font-size:46px}.stats-strip,.section-grid,.filters,.detail-panel,.detail-facts,.guide-layout{grid-template-columns:1fr}.stats-strip div{border-right:0;border-bottom:1px solid var(--coffee-line)}.stats-strip div:last-child{border-bottom:0}}@media (width<=520px){.content-page{width:min(100% - 24px,1160px)}.home{width:calc(100% - 24px)}.hero{background:linear-gradient(90deg,#30221b8f,#9b7a5514),url(/background.png) right 8% top 72px/auto 58% no-repeat;min-height:720px}.hero__content,.question-card{padding:24px}.hero h1{font-size:38px}}
