/* 38熊 Landing Page — 區塊視覺身份翻修（參考歐歐睏式滿版節奏） */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --cream:#fdf6e8;
  --cream2:#f0e6d3;
  --gold:#e3982e;
  --gold-light:#f5d9a0;
  --gold-bg:#fef7eb;
  --brown:#2a1a0e;
  --brown-soft:#3d2b1a;
  --brown-medium:#5a3d24;
  --red:#890b0b;
  --serif:'Noto Serif TC',serif;
  --sans:'Noto Sans TC',sans-serif;
  --pattern-dark:
    linear-gradient(135deg,rgba(255,255,255,.015) 25%,transparent 25%),
    linear-gradient(225deg,rgba(255,255,255,.015) 25%,transparent 25%),
    linear-gradient(45deg,rgba(255,255,255,.015) 25%,transparent 25%),
    linear-gradient(315deg,rgba(255,255,255,.015) 25%,transparent 25%);
}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--brown);background:var(--cream);-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}

/* ===== COMMON ===== */
.btn{display:inline-block;padding:1rem 2.5rem;background:var(--gold);color:var(--brown);font-family:var(--sans);font-weight:600;font-size:1rem;letter-spacing:.08em;border:none;border-radius:6px;cursor:pointer;transition:transform .3s,box-shadow .3s}
.btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(227,152,46,.4)}
.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
@keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
.sec-header{text-align:center;margin-bottom:2.5rem}
.sec-title{font-family:var(--serif);font-weight:600;font-size:clamp(1.4rem,3vw,2rem);letter-spacing:.08em;line-height:1.5}
.sec-title.light{color:var(--cream)}
.sec-sub{font-weight:400;font-size:.88rem;letter-spacing:.05em;color:rgba(42,26,14,.45);margin-top:.3rem}
.sec-sub.light{color:rgba(253,246,232,.4)}
.sec-cta{text-align:center;margin-top:2.5rem}
.gold{color:var(--gold)}

/* ===== 蛋捲碎屑：幾何三角形（靜態散落，加深層次好辨識） ===== */
.crumb{
  position:absolute;display:block;
  width:var(--cw,12px);height:var(--ch,10px);
  transform:rotate(var(--r,0deg));
  pointer-events:none;
}
.crumb--fill{
  background:var(--gold);opacity:.88;
  clip-path:polygon(50% 0%,0% 100%,100% 90%);
  filter:drop-shadow(0 0 6px rgba(227,152,46,.55)) drop-shadow(0 1px 2px rgba(0,0,0,.25));
}
.crumb--fill2{
  background:var(--gold);opacity:.62;
  clip-path:polygon(8% 12%,100% 0%,72% 100%);
  filter:drop-shadow(0 0 5px rgba(227,152,46,.4));
}
.crumb--mist{
  background:rgba(227,152,46,.38);
  clip-path:polygon(52% 0%,0% 100%,100% 68%);
  box-shadow:0 0 12px rgba(227,152,46,.2);
}
.crumb--mist2{
  background:rgba(227,152,46,.28);
  clip-path:polygon(0% 8%,100% 22%,40% 100%);
}
.hero-crumb-zone{
  position:absolute;left:0;right:0;bottom:0;height:120px;
  z-index:4;pointer-events:none;overflow:visible;
}
.texture-headline-wrap{position:relative;display:block}
.texture-headline-wrap .texture-crumbs{
  position:absolute;inset:-0.75rem -3rem 0.15rem -0.75rem;pointer-events:none;
}
.compare-crumb-zone{
  position:absolute;top:0;bottom:0;width:80px;pointer-events:none;z-index:1;
}
.compare-crumb-zone--left{left:clamp(-8px,-1vw,-4px)}
.compare-crumb-zone--right{right:clamp(-8px,-1vw,-4px)}
.cta{position:relative}
.cta-crumb-zone{
  position:absolute;inset:0;left:50%;transform:translateX(-50%);
  width:min(100%,820px);max-width:100%;pointer-events:none;z-index:0;
}
.cta .cta-block{position:relative;z-index:1}

/* 右下角膠囊懸浮：長條＋圓皆毛玻璃，白細邊界定輪廓 */
.fab-shop{
  position:fixed;
  right:max(.75rem, env(safe-area-inset-right, 0px));
  bottom:max(1.35rem, calc(env(safe-area-inset-bottom, 0px) + 1rem));
  z-index:90;
  display:flex;
  align-items:stretch;
  max-width:min(calc(100vw - 1.35rem), 440px);
  background:rgba(61,43,26,.55);
  -webkit-backdrop-filter:blur(16px);
  backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,.15);
  border-radius:999px;
  box-shadow:0 4px 20px rgba(42,26,14,.25);
  color:#fdf6e8;
  font-family:var(--sans);
  font-weight:600;
  font-size:clamp(1.02rem, 4.1vw, 1.14rem);
  letter-spacing:.065em;
  line-height:1.3;
  text-decoration:none;
  overflow:hidden;
  transition:transform .2s ease, box-shadow .2s ease;
}
.fab-shop:hover{
  transform:translateY(-2px);
  box-shadow:0 6px 26px rgba(42,26,14,.32);
  color:#fdf6e8;
}
.fab-shop:active{transform:translateY(0)}
.fab-shop__text{
  display:flex;
  align-items:center;
  flex:1;
  min-width:0;
  padding:1.05rem 1.1rem 1.05rem 1.45rem;
}
.fab-shop__circle{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  width:64px;
  min-width:64px;
  align-self:stretch;
  background:rgba(227,152,46,.75);
  -webkit-backdrop-filter:blur(8px);
  backdrop-filter:blur(8px);
  border-left:1px solid rgba(255,255,255,.15);
  color:#fff;
}
.fab-shop__arrow{display:block;flex-shrink:0;width:28px;height:28px}

@media (min-width:769px){
  /* 大鈕不壓住頁尾可讀區 */
  body{
    padding-bottom:max(7rem, calc(env(safe-area-inset-bottom, 0px) + 6rem));
  }
  .fab-shop{
    right:max(1.5rem, env(safe-area-inset-right, 0px));
    bottom:max(2.35rem, calc(env(safe-area-inset-bottom, 0px) + 1.5rem));
    max-width:min(calc(100vw - 3rem), 560px);
    font-size:clamp(1.22rem, 1.35vw, 1.42rem);
    letter-spacing:.07em;
    box-shadow:0 4px 20px rgba(42,26,14,.25);
  }
  .fab-shop:hover{
    box-shadow:0 6px 26px rgba(42,26,14,.32);
  }
  .fab-shop__text{
    padding:1.35rem 1.45rem 1.35rem 2rem;
  }
  .fab-shop__circle{
    width:84px;
    min-width:84px;
  }
  .fab-shop__arrow{width:36px;height:36px}
}

.curve-top,.curve-bottom,.section-curve,.section-curve-top{width:100%;line-height:0;overflow:hidden}
.curve-top svg,.curve-bottom svg,.section-curve svg,.section-curve-top svg{width:100%;height:50px;display:block}

/* 深色區頂部弧形：僅 FAQ（米白 → 深咖），避免與 Hero／Compare 底部弧重疊 */
.faq{position:relative}
.faq::before{
  content:'';
  position:absolute;top:-28px;left:0;width:100%;height:28px;
  background-color:var(--brown-soft);
  clip-path:ellipse(55% 100% at 50% 100%);
  pointer-events:none;z-index:1;
}

/* ===== S1 HERO ===== */
.hero{position:relative;width:100%;height:100vh;min-height:500px;overflow:hidden}
.hero::after{
  content:'';
  position:absolute;bottom:-2px;left:0;width:100%;height:60px;
  background:var(--brown-soft);
  clip-path:ellipse(55% 100% at 50% 100%);
  z-index:3;pointer-events:none;
}
.hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center}
.hero-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(42,26,14,.08) 0%,rgba(42,26,14,.35) 50%,rgba(42,26,14,.6) 100%)}
.hero-content{
  position:relative;z-index:4;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;color:var(--cream);padding:0 1.25rem 4.5rem;
}
.hero-panel{
  width:100%;max-width:min(32rem,100%);
  padding:clamp(1.25rem,4vw,2rem) clamp(1.25rem,5vw,2.25rem);
  background:rgba(22,16,12,.38);
  backdrop-filter:saturate(1.08) blur(10px);
  -webkit-backdrop-filter:saturate(1.08) blur(10px);
  border:1px solid rgba(253,246,232,.18);border-radius:16px;
  box-shadow:0 10px 36px rgba(0,0,0,.28),inset 0 1px 0 rgba(255,255,255,.08);
}
@supports not ((backdrop-filter:blur(2px)) or (-webkit-backdrop-filter:blur(2px))){
  .hero-panel{background:rgba(26,18,12,.72)}
}
.hero-brand{
  font-weight:400;font-size:.9rem;letter-spacing:.8em;margin-bottom:1rem;opacity:0;animation:fadeUp .8s .2s ease forwards;
  text-shadow:0 1px 10px rgba(0,0,0,.35);
}
.hero-title{
  font-family:var(--serif);font-weight:500;font-size:clamp(2rem,5.5vw,3.8rem);letter-spacing:.2em;margin-bottom:1rem;opacity:0;animation:fadeUp .8s .5s ease forwards;
  text-shadow:0 2px 16px rgba(0,0,0,.35);
}
.hero-sub{
  font-weight:400;font-size:.85rem;letter-spacing:.2em;margin-bottom:1rem;opacity:0;animation:fadeUp .8s .8s ease forwards;
  text-shadow:0 1px 8px rgba(0,0,0,.3);
}
.hero-badges{
  display:flex;gap:.6rem;margin-bottom:2rem;flex-wrap:wrap;justify-content:center;
  opacity:0;animation:fadeUp .8s .95s ease forwards;
}
.hero-badges span,.hero-badge{
  background:rgba(0,0,0,.35);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.15);color:#fff;font-size:.75rem;font-weight:500;
  padding:.45rem 1rem;border-radius:50px;letter-spacing:.03em;
}
.hero-panel .btn{margin-top:.25rem;width:100%;max-width:100%;opacity:0;animation:fadeUp .8s 1.15s ease forwards}

/* ===== S2 TEXTURE ===== */
.texture{
  background-color:var(--brown-soft);
  background-image:
    var(--pattern-dark),
    radial-gradient(ellipse at 30% 50%,rgba(227,152,46,.08) 0%,transparent 60%),
    radial-gradient(ellipse at 20% 30%,rgba(227,152,46,.06) 0%,transparent 50%);
  background-size:20px 20px,auto,auto;
  background-position:10px 0,0 0,0 0;
  padding:3.5rem 1rem;
}
.texture-split{
  max-width:1200px;margin:0 auto;display:flex;flex-direction:column;gap:1.5rem;position:relative;z-index:2;
}
.texture-visual{position:relative}
.texture-visual img{width:100%;border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.2);display:block}
.badge{
  position:absolute;bottom:1rem;left:1rem;background:var(--gold);color:var(--brown);
  font-weight:700;font-size:clamp(.95rem,2.2vw,1.15rem);padding:.75rem 1.45rem;border-radius:50px;letter-spacing:.06em;
  box-shadow:0 4px 14px rgba(0,0,0,.18);
}
.texture-copy{color:var(--cream);position:relative}
.texture-headline{font-family:var(--serif);font-weight:600;font-size:clamp(1.6rem,3.5vw,2.4rem);letter-spacing:.08em;line-height:1.5;margin-bottom:1.8rem;position:relative}
.texture-headline::before{content:'"';font-family:Georgia,serif;font-size:4rem;color:var(--gold);opacity:.3;position:absolute;top:-1.5rem;left:-1.5rem;line-height:1;pointer-events:none}
.texture-copy::after{content:'';display:block;width:60px;height:3px;background:linear-gradient(to right,var(--gold),transparent);margin-top:2rem}
.texture-body{font-weight:400;font-size:1rem;line-height:2;letter-spacing:.03em;color:rgba(253,246,232,.8)}
.texture-body strong{color:var(--gold);font-weight:500}
.texture-body .brand{color:var(--cream);font-weight:500}

/* ===== S3 STORY ===== */
.story{
  position:relative;width:100%;overflow:hidden;
  background:var(--gold-bg);padding-bottom:clamp(2rem,5vh,3.5rem);
}
.story-split{display:flex;flex-direction:column}
.story-visual{order:-1;position:relative;width:100%}
.story-visual .story-bg{
  width:100%;height:300px;object-fit:cover;object-position:center 28%;display:block;
}
.story-copy-col{
  position:relative;z-index:2;padding:2.5rem 1.2rem;text-align:center;
  border-top:4px solid var(--gold);padding-top:2rem;
}
.story-content{position:relative;max-width:36rem;margin:0 auto}
.story-watermark{display:none}
.story-headline{font-family:var(--serif);font-weight:600;font-size:clamp(1.3rem,2.8vw,1.9rem);letter-spacing:.06em;line-height:1.7;margin-bottom:.5rem;color:var(--brown)}
.story-sub{font-family:var(--serif);font-weight:400;font-size:clamp(1.1rem,2.2vw,1.4rem);letter-spacing:.08em;color:var(--gold);margin-bottom:1.5rem}
.story-number{
  font-family:var(--serif);font-size:3em;font-weight:700;color:var(--gold);line-height:1;
  display:inline-block;vertical-align:middle;margin:0 .05em;
}
.story-detail{font-family:var(--serif);font-weight:400;font-size:clamp(.9rem,1.6vw,1rem);line-height:2;letter-spacing:.05em;color:rgba(42,26,14,.62)}
.story-break{display:block;height:1rem}

/* ===== S4 INGREDIENTS ===== */
.ingredients{
  position:relative;width:100%;min-height:50vh;display:flex;flex-direction:column;align-items:stretch;overflow:hidden;
  background-color:var(--brown-soft);
  background-image:url(images/s4-ingredients.png);
  background-size:cover;background-position:center;background-repeat:no-repeat;
}
.ingredients-overlay{position:absolute;inset:0;background:rgba(30,15,5,.65);z-index:1}
.ingredients-content{
  position:relative;z-index:2;flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;color:var(--cream);
  padding:4.5rem 1.5rem 2rem;max-width:min(1200px,100%);margin:0 auto;width:100%;
}
.ingredients-title{font-family:var(--serif);font-weight:600;font-size:clamp(1.4rem,3vw,2rem);letter-spacing:.1em;line-height:1.6;margin-bottom:.4rem}
.ingredients-sub{font-family:var(--serif);font-weight:400;font-size:clamp(.9rem,1.8vw,1.1rem);letter-spacing:.06em;color:rgba(253,246,232,.55);margin-bottom:2rem}
.ingredients-body{font-weight:400;font-size:1rem;line-height:2;letter-spacing:.04em;color:rgba(253,246,232,.8);margin-bottom:2rem;max-width:42rem}
.ingredient-cards{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;width:100%;max-width:min(920px,100%);
}
.ingredient-card{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.07);border-radius:14px;
  padding:1.35rem 1rem;text-align:center;box-shadow:0 6px 24px rgba(0,0,0,.14);
}
.ingredient-card-title{font-weight:600;font-size:.92rem;color:var(--cream);margin-bottom:.35rem;letter-spacing:.04em}
.ingredient-card-desc{font-size:.78rem;color:rgba(253,246,232,.52);line-height:1.55}
.section-curve{position:relative;z-index:2;flex-shrink:0}
.section-curve svg{height:32px}
.section-curve--to-cream path{fill:#f0e6d3}

/* ===== S5 COMPARE ===== */
.compare{
  background:var(--cream2);
  background-image:repeating-linear-gradient(45deg,transparent,transparent 40px,rgba(42,26,14,.025) 40px,rgba(42,26,14,.025) 41px);
  padding:4.5rem 1.5rem 6rem;position:relative;margin-top:-1px;
}
.compare::after{
  content:'';
  position:absolute;bottom:-2px;left:0;width:100%;height:50px;
  background:var(--brown-soft);
  clip-path:ellipse(55% 100% at 50% 100%);
  z-index:1;pointer-events:none;
}
.compare .sec-header{position:relative;z-index:2}
.compare-inner{position:relative;max-width:min(1100px,100%);margin:0 auto;z-index:2;padding:0 1.5rem}
.compare-grid{
  max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:start;position:relative;
}
.compare-grid::before{
  content:'VS';
  position:absolute;top:30%;left:50%;transform:translate(-50%,-50%);
  width:55px;height:55px;background:var(--gold);color:var(--brown);
  font-family:var(--serif);font-weight:700;font-size:.95rem;border-radius:50%;
  display:flex;align-items:center;justify-content:center;z-index:3;
  box-shadow:0 4px 15px rgba(227,152,46,.4);
}
.compare-item{text-align:center;position:relative;z-index:2}
.compare-img{
  width:100%;max-width:520px;margin:0 auto 1rem;aspect-ratio:1;overflow:hidden;border-radius:12px;background:var(--cream);
  border:1px solid rgba(42,26,14,.08);box-shadow:0 6px 24px rgba(42,26,14,.1);
}
.compare-img img{width:100%;height:100%;object-fit:cover}
.compare-label{font-family:var(--serif);font-weight:500;font-size:1rem;letter-spacing:.06em;margin-bottom:.3rem}
.compare-desc{font-size:.82rem;color:rgba(42,26,14,.5);letter-spacing:.03em;line-height:1.6}

/* ===== S6 FLAVORS ===== */
.flavors{
  background-color:var(--brown-soft);
  background-image:
    var(--pattern-dark),
    radial-gradient(ellipse at 30% 50%,rgba(227,152,46,.08) 0%,transparent 60%),
    radial-gradient(ellipse at 20% 30%,rgba(227,152,46,.06) 0%,transparent 50%);
  background-size:20px 20px,auto,auto;
  background-position:10px 0,0 0,0 0;
  padding:3rem 1.5rem 4.5rem;margin-top:-1px;
}
.flavors .sec-header{position:relative;z-index:2;padding-top:1rem;margin-bottom:2.5rem}
.flavors .sec-header::before{
  content:'10';
  font-family:var(--serif);
  font-size:clamp(6rem,15vw,12rem);
  font-weight:700;
  color:rgba(253,246,232,.04);
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  pointer-events:none;z-index:0;line-height:1;
}
.flavors .sec-header .sec-title,.flavors .sec-header .sec-sub{position:relative;z-index:1}
.flavors-inner{max-width:min(1200px,100%);margin:0 auto;padding:0 1.5rem}
.flavors-grid{margin:0 auto;display:grid;grid-template-columns:repeat(5,1fr);gap:.85rem;position:relative;z-index:2}
.flavor-card{
  transition:transform .3s,border-color .3s;
  border:1px solid rgba(253,246,232,.08);border-radius:8px;overflow:hidden;background:rgba(0,0,0,.15);
}
.flavor-card:hover{transform:translateY(-3px);border-color:var(--gold)}
.flavor-img{width:100%;aspect-ratio:1;overflow:hidden;border-radius:6px;background:#000}
.flavor-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.flavor-card:hover .flavor-img img{transform:scale(1.05)}
.flavor-info{padding:.65rem .2rem .75rem;text-align:center}
.flavor-name{font-family:var(--serif);font-weight:500;font-size:.85rem;letter-spacing:.06em;color:var(--cream);margin-bottom:.1rem}
.flavor-diet{font-size:.65rem;color:rgba(253,246,232,.35);margin-bottom:.2rem}
.flavor-desc{font-size:.72rem;color:rgba(253,246,232,.55);line-height:1.45;margin-top:.15rem}

/* ===== S7 SCENES ===== */
.scenes{background:var(--cream);padding:4.5rem 1.5rem}
.scenes-grid{
  max-width:min(1200px,100%);margin:0 auto;display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;
}
.scene-card{
  position:relative;overflow:hidden;border-radius:12px;
  box-shadow:0 4px 24px rgba(42,26,14,.1);border:none;
}
.scene-img{position:relative;width:100%;aspect-ratio:16/10;overflow:hidden}
.scene-img img{width:100%;height:100%;object-fit:cover;object-position:center center;transition:transform .4s}
.scene-card--focus-top .scene-img img{object-position:center 22%}
.scene-card:hover .scene-img img{transform:scale(1.03)}
.scene-overlay{
  position:absolute;bottom:0;left:0;right:0;
  background:linear-gradient(to top,rgba(0,0,0,.72) 0%,rgba(0,0,0,.35) 45%,transparent 50%);
  padding:2.25rem 1.25rem 1.25rem;color:#fff;text-align:left;
}
.scene-card--overlay-strong .scene-overlay{
  background:linear-gradient(to top,rgba(0,0,0,.78) 0%,rgba(0,0,0,.42) 48%,transparent 52%);
}
.scene-label{
  font-family:var(--serif);font-weight:600;font-size:1.05rem;margin-bottom:.25rem;color:#fff;letter-spacing:.05em;
  text-shadow:0 1px 3px rgba(0,0,0,.85),0 2px 12px rgba(0,0,0,.5);
}
.scene-desc{
  font-size:.8rem;color:rgba(255,255,255,.92);letter-spacing:.03em;line-height:1.55;
  text-shadow:0 1px 2px rgba(0,0,0,.8),0 2px 8px rgba(0,0,0,.45);
}

/* ===== S8 SOCIAL ===== */
.social{background:var(--cream2);padding:4.5rem 1.5rem}
.social .sec-header{position:relative}
.social .sec-header::before{
  content:'';
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:min(90vw,520px);height:min(90vw,520px);border-radius:50%;
  border:1px solid rgba(42,26,14,.06);pointer-events:none;
}
.social .sec-header .sec-title{position:relative;z-index:1}
.social-region{max-width:min(1400px,100%);margin:0 auto 2.5rem;padding:0 clamp(1rem,4vw,2.5rem)}
.social-region:last-child{margin-bottom:0}
.social-label{display:inline-block;background:var(--red);color:var(--cream);padding:.35rem 1.1rem;border-radius:6px;font-size:.8rem;font-weight:600;letter-spacing:.1em;margin-bottom:1rem;box-shadow:0 2px 8px rgba(137,11,11,.2)}
.social-scroll{display:flex;gap:.8rem;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding-bottom:.5rem;scrollbar-width:none}
.social-scroll::-webkit-scrollbar{display:none}
.social-card{flex:0 0 auto;scroll-snap-align:start;border-radius:10px;overflow:hidden;background:#0a0604;box-shadow:0 4px 20px rgba(0,0,0,.12);border:1px solid rgba(255,255,255,.06)}
.social-card img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.social-card:hover img{transform:scale(1.03)}
.social-card--lead{width:320px;height:450px}
.social-card--thumb{width:250px;height:400px}

/* ===== S9 REVIEWS（Google 地圖評論風格／非官方） ===== */
.reviews{
  background:#f8f9fa;padding:4.5rem 1.5rem;
  font-family:system-ui,-apple-system,'Segoe UI',Roboto,'Noto Sans TC',sans-serif;
}
.reviews .sec-header{display:flex;flex-direction:column;align-items:center}
.reviews .sec-title{color:#202124}
.reviews-maps-summary{
  display:inline-flex;align-items:center;gap:1rem;margin-top:.75rem;padding:.85rem 1.25rem;
  background:#fff;border:1px solid #dadce0;border-radius:8px;
  box-shadow:0 1px 2px rgba(60,64,67,.12);
}
.reviews-maps-summary__score{
  font-size:1.65rem;font-weight:400;color:#202124;line-height:1;
}
.reviews-maps-summary__main{text-align:left}
.reviews-maps-summary__count{margin:0;font-size:.8rem;color:#5f6368;letter-spacing:.02em}
.g-stars{display:flex;gap:0;line-height:1}
.g-stars--summary{margin-bottom:.2rem}
.g-stars--summary .g-star{font-size:1.1rem}
.g-stars--inline .g-star{font-size:.95rem}
.g-star{color:#fbbc04;text-shadow:none}
.g-star--dim{color:#dadce0}
/* 4.9 等：第五顆以比例填色（底灰＋上金裁切），避免整顆空白像 4.0 */
.g-star--partial{display:inline-block;vertical-align:baseline}
.g-partial-star{
  position:relative;display:inline-block;width:1em;line-height:1;text-align:left;vertical-align:0;
}
.g-partial-star__track{color:#dadce0;display:block;line-height:1}
.g-partial-star__fill{
  position:absolute;left:0;top:0;overflow:hidden;width:calc(var(--g-star-fill, 0.9) * 100%);
  color:#fbbc04;pointer-events:none;line-height:1;white-space:nowrap;
}
.reviews-google{max-width:min(1200px,100%);margin:1.75rem auto 0;padding:0 clamp(1rem,4vw,60px)}
.g-review{
  background:#fff;border:1px solid #dadce0;border-radius:8px;padding:1rem 1.15rem;
  box-shadow:0 1px 2px rgba(60,64,67,.1);
  text-align:left;
}
.g-review--featured{
  padding:1.15rem 1.25rem 1.25rem;
  box-shadow:0 1px 2px rgba(60,64,67,.2),0 2px 8px rgba(60,64,67,.08);
  margin-bottom:1rem;
}
.g-review__head{display:flex;gap:.75rem;align-items:flex-start;margin-bottom:.65rem}
.g-review__avatar{
  flex-shrink:0;width:40px;height:40px;border-radius:50%;
  background:var(--g-av,#5f6368);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:1rem;font-weight:500;
}
.g-review__avatar--darktxt{color:#3c4043}
.g-review__meta{min-width:0;flex:1;display:flex;flex-direction:column;gap:.1rem}
.g-review__name{font-size:.9rem;font-weight:500;color:#202124;letter-spacing:.02em}
.g-review__when{font-size:.72rem;color:#5f6368}
.g-review__text{
  margin:0;font-size:.9rem;line-height:1.55;color:#3c4043;letter-spacing:.02em;
}
.g-review--featured .g-review__text{font-size:clamp(.95rem,2.2vw,1.05rem);line-height:1.6}
.g-review__src{margin:.55rem 0 0;font-size:.72rem;color:#5f6368;letter-spacing:.02em}
.reviews-google__grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}

/* ===== S10 FAQ ===== */
.faq{
  background-color:var(--brown-soft);
  background-image:
    var(--pattern-dark),
    radial-gradient(ellipse at 30% 50%,rgba(227,152,46,.08) 0%,transparent 60%),
    radial-gradient(ellipse at 20% 30%,rgba(227,152,46,.06) 0%,transparent 50%);
  background-size:20px 20px,auto,auto;
  background-position:10px 0,0 0,0 0;
  padding:4.5rem 1.5rem;
}
.faq .sec-header{position:relative;z-index:2}
.faq .sec-header::before{
  content:'?';
  font-family:var(--serif);
  font-size:clamp(5rem,12vw,10rem);
  font-weight:700;
  color:rgba(253,246,232,.03);
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  pointer-events:none;line-height:1;
}
.faq .sec-header .sec-title{position:relative;z-index:1}
.faq-list{
  max-width:min(1000px,100%);margin:0 auto;position:relative;z-index:2;
  column-count:1;column-gap:1.25rem;
}
.faq-item{
  background:rgba(253,246,232,.04);border:1px solid rgba(253,246,232,.06);border-radius:8px;
  padding:1.2rem 1.5rem;margin-bottom:.6rem;cursor:pointer;border-bottom:none;
  transition:border-color .3s,background .3s;
  break-inside:avoid;page-break-inside:avoid;
}
.faq-item.open{
  border-color:var(--gold);
  background:rgba(253,246,232,.08);
}
.faq-q{font-family:var(--serif);font-weight:500;font-size:.95rem;letter-spacing:.05em;color:var(--cream);position:relative;padding-right:2rem}
.faq-q::after{content:'+';position:absolute;right:0;top:0;font-size:1.2rem;color:var(--gold);transition:transform .3s}
.faq-item.open .faq-q::after{content:'−'}
.faq-a{font-size:.88rem;line-height:1.8;color:rgba(253,246,232,.55);max-height:0;overflow:hidden;transition:max-height .4s,padding .3s;padding-top:0}
.faq-item.open .faq-a{max-height:22rem;padding-top:.8rem}

/* ===== 桌機 ≥1024px：滿版節奏、加寬內容 ===== */
@media (min-width:1024px){
  .texture{
    padding:0;
  }
  .texture-split{
    max-width:none;margin:0;
    display:grid;grid-template-columns:1.3fr 1fr;gap:0;align-items:stretch;
    min-height:min(70vh,680px);
  }
  .texture-visual{
    position:relative;min-height:min(70vh,680px);
  }
  .texture-visual img{
    position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
    border-radius:0;box-shadow:none;
  }
  .texture-copy{
    display:flex;flex-direction:column;justify-content:center;
    padding:clamp(2.5rem,5vw,5rem) clamp(2rem,5vw,4rem);
  }

  .story{padding:0;min-height:0}
  .story-split{
    display:grid;grid-template-columns:12fr 13fr;align-items:stretch;
    min-height:min(72vh,860px);
  }
  .story-copy-col{
    order:0;display:flex;align-items:center;justify-content:flex-start;
    text-align:left;border-top:none;border-left:4px solid var(--gold);
    padding:clamp(2.5rem,4vw,4.5rem) clamp(2rem,5vw,60px);
  }
  .story-visual{
    order:0;position:relative;min-height:min(72vh,860px);
  }
  .story-visual .story-bg{
    position:absolute;inset:0;width:100%;height:100%;
    object-fit:cover;object-position:right center;
  }
  .story-watermark{
    display:block;position:absolute;left:-.5rem;top:50%;transform:translateY(-50%);
    font-family:var(--serif);font-size:clamp(5.5rem,12vw,10rem);font-weight:700;
    color:var(--gold);opacity:.08;line-height:1;pointer-events:none;z-index:0;
  }
  .story-content{
    position:relative;z-index:1;margin:0;max-width:28rem;
  }

  .ingredients-content{
    max-width:1200px;padding-left:60px;padding-right:60px;
  }

  .compare .sec-header{
    max-width:1100px;margin-left:auto;margin-right:auto;padding:0 1.5rem;
  }
  .compare-inner{padding:0 60px}
  .compare-grid{gap:2.25rem}
  .compare-grid::before{
    width:66px;height:66px;font-size:1.05rem;top:32%;
  }
  .compare-img{
    max-width:min(520px,100%);min-height:0;
  }

  .flavors{padding-left:0;padding-right:0}
  .flavors-inner{max-width:none;padding:0 60px}
  .flavors-grid{max-width:1200px}

  .scenes{padding:4.5rem 60px}
  .scenes-grid{
    max-width:none;width:100%;gap:.4rem;
  }
  .scene-card{border-radius:10px}
  .scene-overlay{
    background:linear-gradient(to top,rgba(0,0,0,.7) 0%,transparent 50%);
  }
  .scene-card--overlay-strong .scene-overlay{
    background:linear-gradient(to top,rgba(0,0,0,.75) 0%,transparent 52%);
  }

  .social{
    padding-left:clamp(40px,5vw,72px);padding-right:clamp(40px,5vw,72px);
  }
  .social .sec-header{max-width:1200px;margin-left:auto;margin-right:auto;padding:0}
  .social-region{
    max-width:min(1400px,100%);width:100%;margin-left:auto;margin-right:auto;
    padding:0;
  }
  .social-scroll{
    gap:1rem;
    /* 日本列 5 張：末端留白要夠，否則最後一張像被吃掉；proximity 才容易完整捲入視野 */
    padding-right:clamp(3.5rem, 12vw, 10rem);
    padding-left:0;
    scroll-padding-inline:clamp(1rem,2vw,1.5rem) clamp(3.5rem, 12vw, 10rem);
    scroll-snap-type:x proximity;
  }
  .social-card--lead{width:380px;height:520px}
  .social-card--thumb{width:300px;height:440px}

  .reviews{padding-left:0;padding-right:0}
  .reviews .sec-header{padding:0 60px}
  .reviews-google{
    max-width:1200px;padding:0 60px;
  }
  .reviews-google__grid{
    grid-template-columns:repeat(2,1fr);gap:1rem;
  }

  .faq{padding-left:clamp(1.5rem,4vw,60px);padding-right:clamp(1.5rem,4vw,60px)}
  .faq .sec-header{max-width:1200px;margin-left:auto;margin-right:auto}
  .faq-list{
    column-count:2;max-width:1000px;
  }
}

/* ===== S11 CTA ===== */
.cta{background:var(--cream);padding:3rem 1.5rem 4rem;border-top:none}
.cta-block{
  max-width:700px;margin:0 auto;background:var(--gold);border-radius:20px;
  padding:3rem 2rem;text-align:center;box-shadow:0 8px 30px rgba(227,152,46,.25);
}
.cta-hook{
  font-family:var(--serif);font-weight:600;font-size:clamp(1.2rem,2.5vw,1.6rem);
  color:var(--brown);margin-bottom:.5rem;letter-spacing:.06em;
}
.cta-hook-sub{font-size:.9rem;color:rgba(42,26,14,.6);margin-bottom:1.5rem;letter-spacing:.04em}
.cta-block .btn{background:var(--brown);color:var(--cream);padding:1.1rem 3rem;font-size:1.05rem}
.cta-block .btn:hover{box-shadow:0 6px 20px rgba(42,26,14,.3)}
.btn-lg{padding:1.2rem 3.5rem;font-size:1.1rem}

/* ===== FOOTER ===== */
footer{background:var(--brown-soft);color:rgba(253,246,232,.5);padding:3rem 1.5rem;text-align:center;border-top:2px solid var(--red)}
.footer-inner{max-width:560px;margin:0 auto}
.footer-brand{font-family:var(--serif);font-weight:500;font-size:1.1rem;letter-spacing:.15em;color:var(--cream);margin-bottom:1.5rem}
.footer-info{font-size:.78rem;line-height:2;letter-spacing:.03em;margin-bottom:1.5rem}
.footer-info a{color:rgba(253,246,232,.55);text-decoration:underline;text-underline-offset:.2em;transition:color .3s}
.footer-info a:hover{color:var(--gold)}
.footer-links{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;font-size:.78rem}
.footer-links a{color:rgba(253,246,232,.4);transition:color .3s}
.footer-links a:hover{color:var(--gold)}

/* ===== MOBILE ===== */
@media(max-width:768px){
  /* 懸浮選購鈕不擋住頁尾最後幾行 */
  body{padding-bottom:max(6.25rem, calc(env(safe-area-inset-bottom, 0px) + 5rem))}
  .hero-brand{font-size:.75rem;letter-spacing:.5em}
  .hero-title{letter-spacing:.15em}
  .hero-sub{font-size:.78rem;letter-spacing:.15em}
  .hero-content{padding:0 1rem 3rem}
  .hero-panel{border-radius:14px;padding:1.15rem 1.1rem}
  .texture{padding:3.5rem 1rem}
  .texture-split{max-width:100%}
  /* 碎屑曾用負 inset／負 right 伸出標題區，手機易露出深咖區外；裁切在文案欄內 */
  .texture-copy{overflow-x:hidden}
  .texture-headline-wrap .texture-crumbs{
    inset:-0.5rem 0 0.12rem -0.5rem;
  }
  .texture-headline::before{font-size:3rem;top:-1rem;left:-.5rem}
  .story-visual .story-bg{height:300px;object-position:center 28%}
  .story-copy-col{padding:2.5rem 1.2rem}
  .story-content{max-width:100%}
  .compare-inner{padding:0 1rem}
  .flavors-inner{padding:0 1rem}
  .social-region{padding-left:1rem;padding-right:1rem;max-width:100%}
  .reviews-google{padding:0 1rem}
  .faq-list{column-count:1}
  .ingredient-cards{grid-template-columns:1fr;max-width:100%}
  .compare-grid{gap:1rem}
  .compare-grid::before{width:48px;height:48px;font-size:.85rem;top:28%}
  .flavors{padding:2.5rem 1rem 3.5rem}
  .flavors-grid{grid-template-columns:repeat(2,1fr);gap:.6rem}
  .scenes-grid{grid-template-columns:1fr;gap:1rem;max-width:100%}
  .social-card--lead{width:280px;height:400px}
  .social-card--thumb{width:220px;height:360px}
  .reviews-maps-summary{flex-wrap:wrap;justify-content:center;text-align:center}
  .reviews-maps-summary__main{text-align:center}
  .reviews-google__grid{grid-template-columns:1fr}
  .btn{width:100%;text-align:center;min-height:52px}
  .btn-lg{padding:1.1rem 1.5rem;font-size:1rem}
  .cta-block{padding:2.25rem 1.5rem}
}
