/* ============================================================
   Muse+ Magazine Style — shared editorial typography for blog posts
   Applied via: <link rel="stylesheet" href="../css/magazine.css">
   Body class trigger: .article-body-editorial (already in markup)
   Adds: reading progress bar, drop caps, numbered H2, pull quotes,
   editorial figure styling, custom link underlines.
   ============================================================ */

/* Reading progress bar */
.mag-progress{position:fixed;top:0;left:0;right:0;height:3px;background:transparent;z-index:9999;pointer-events:none}
.mag-progress__fill{height:100%;width:0;background:linear-gradient(90deg,var(--accent),#dab98c);transition:width .15s ease-out}
@media(max-width:760px){.mag-progress{height:2.5px}}

/* Breadcrumb */
.bc{padding:calc(var(--nav-h) + .9rem) 0 .25rem;font-size:.78rem;color:var(--text-muted);background:var(--bg)}
.bc ol{display:flex;flex-wrap:wrap;list-style:none;gap:.4rem;padding:0;margin:0;align-items:center}
.bc li{display:flex;align-items:center;gap:.4rem}
.bc li:not(:last-child)::after{content:"›";color:var(--text-muted);opacity:.5}
.bc a{color:var(--text-muted);text-decoration:none;transition:color .2s;min-height:32px;display:inline-flex;align-items:center}
.bc a:hover{color:var(--accent)}
.bc [aria-current="page"]{color:var(--text);font-weight:600;min-height:32px;display:inline-flex;align-items:center;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
@media(max-width:760px){
  .bc{padding:calc(var(--nav-h) + .55rem) 0 .15rem;font-size:.72rem}
  .bc ol{gap:.3rem;flex-wrap:wrap;padding:0 .25rem}
  .bc li{gap:.3rem}
  .bc [aria-current="page"]{max-width:60vw}
  /* 唔好喺 container 內再收窄一行：靠 .mag-on .container 統一 gutter */
  .mag-on .bc ol{padding-left:0;padding-right:0}
}

/* ===== Magazine HERO — cinematic full-bleed (opt-in via .mag-hero) ===== */
.mag-hero{position:relative;min-height:clamp(460px,62vh,640px);margin-bottom:0;overflow:hidden;background:#0d0d0c;color:#fff;display:flex;align-items:flex-end}
.mag-hero__bg{position:absolute;inset:0;z-index:0}
.mag-hero__bg img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;filter:saturate(.95) contrast(1.02) brightness(.85)}
.mag-hero__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(13,13,12,.15) 0%,rgba(13,13,12,.45) 40%,rgba(13,13,12,.85) 80%,rgba(13,13,12,.95) 100%)}
.mag-hero__bg::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(13,13,12,.7) 0%,rgba(13,13,12,.35) 40%,rgba(13,13,12,0) 70%);z-index:1}
.mag-hero__inner{position:relative;z-index:2;width:100%;max-width:1280px;margin:0 auto;padding:clamp(1.6rem,5vw,3.5rem) clamp(1.25rem,5vw,3rem) clamp(2rem,4.5vw,3rem);text-shadow:0 2px 14px rgba(0,0,0,.45)}
.mag-hero__cat{display:inline-flex;align-items:center;gap:.5rem;font-size:.68rem;letter-spacing:.22em;font-weight:700;text-transform:uppercase;color:#E8C998;padding:.4rem .9rem;border:1px solid rgba(232,201,152,.55);border-radius:999px;margin-bottom:clamp(.9rem,2.5vw,1.4rem);backdrop-filter:blur(8px);background:rgba(0,0,0,.28);text-shadow:none}
.mag-hero__cat::before{content:"";display:inline-block;width:5px;height:5px;border-radius:50%;background:#E8C998}
.mag-hero__title{font-family:var(--f-head,'Playfair Display','Noto Serif TC',serif);font-size:clamp(2rem,4.8vw,3.8rem);line-height:1.12;letter-spacing:-.01em;font-weight:800;color:#fff;margin:0 0 clamp(.6rem,1.5vw,.95rem);max-width:18ch;text-wrap:balance}
.mag-hero__title em{display:block;font-style:normal;font-weight:300;color:rgba(255,255,255,.9);font-size:.62em;letter-spacing:.04em;margin-top:.35rem;line-height:1.3}
.mag-hero__title em::before{content:"";display:block;width:48px;height:1px;background:#E8C998;margin:0 0 .65rem;opacity:.85}
.mag-hero__sub{font-size:clamp(.9rem,1.3vw,1.05rem);line-height:1.65;color:rgba(255,255,255,.85);max-width:54ch;font-weight:400;margin:clamp(.8rem,2vw,1.2rem) 0 clamp(1.2rem,2.8vw,1.7rem)}
.mag-hero__byline{display:flex;flex-wrap:wrap;align-items:center;gap:.45rem .75rem;font-size:.72rem;letter-spacing:.06em;color:rgba(255,255,255,.7);margin-bottom:clamp(1.2rem,2.8vw,1.7rem);text-transform:uppercase;font-weight:600}
.mag-hero__byline svg{width:14px;height:14px;vertical-align:-2px;margin-right:.25rem;opacity:.8}
.mag-hero__byline .sep{opacity:.35}
.mag-hero__cta{display:flex;flex-wrap:wrap;gap:.7rem}
.mag-hero__cta .btn-wa{display:inline-flex;align-items:center;gap:.5rem;background:#25D366;color:#fff;font-weight:700;padding:.95rem 1.5rem;border-radius:999px;text-decoration:none;font-size:.95rem;box-shadow:0 8px 28px rgba(37,211,102,.35);transition:all .25s ease;min-height:48px}
.mag-hero__cta .btn-wa:hover{transform:translateY(-2px);box-shadow:0 12px 36px rgba(37,211,102,.5);color:#fff}
.mag-hero__cta .btn-tel{display:inline-flex;align-items:center;gap:.5rem;background:transparent;color:#fff;border:1px solid rgba(255,255,255,.3);font-weight:600;padding:.95rem 1.4rem;border-radius:999px;text-decoration:none;font-size:.92rem;transition:all .25s ease;min-height:48px;backdrop-filter:blur(8px)}
.mag-hero__cta .btn-tel:hover{background:rgba(255,255,255,.1);border-color:#fff}
.mag-hero__fp{margin-top:1rem;font-size:.72rem;color:rgba(255,255,255,.45);letter-spacing:.04em}
@media(max-width:760px){
  .mag-hero{min-height:auto;padding-top:calc(var(--nav-h) + .5rem)}
  .mag-hero__bg img{filter:saturate(.95) contrast(1.02) brightness(.7)}
  .mag-hero__bg::after{background:linear-gradient(180deg,rgba(13,13,12,.35) 0%,rgba(13,13,12,.6) 35%,rgba(13,13,12,.92) 75%,rgba(13,13,12,.98) 100%)}
  .mag-hero__bg::before{display:none}
  .mag-hero__inner{padding-top:1.4rem;padding-right:max(clamp(2rem,6vw,2.85rem),env(safe-area-inset-right,0px));padding-bottom:calc(1.7rem + env(safe-area-inset-bottom,0px));padding-left:max(clamp(2rem,6vw,2.85rem),env(safe-area-inset-left,0px))}
  .mag-hero__cat{font-size:.62rem;padding:.32rem .7rem;margin-bottom:.9rem;letter-spacing:.18em}
  .mag-hero__title{font-size:clamp(1.7rem,7.2vw,2.2rem);max-width:none;line-height:1.18;margin-bottom:.5rem}
  .mag-hero__title em{font-size:.62em;margin-top:.4rem}
  .mag-hero__title em::before{width:38px;margin-bottom:.5rem}
  .mag-hero__sub{font-size:.92rem;line-height:1.55;margin:.7rem 0 1.05rem;max-width:none}
  .mag-hero__byline{font-size:.64rem;gap:.3rem .55rem;margin-bottom:1rem}
  .mag-hero__byline svg{width:12px;height:12px}
  .mag-hero__cta{width:100%;flex-direction:column;gap:.55rem}
  .mag-hero__cta .btn-wa,.mag-hero__cta .btn-tel{width:100%;justify-content:center;font-size:.95rem;padding:.95rem 1.2rem;min-height:52px}
  .mag-hero__fp{margin-top:.85rem;font-size:.65rem;letter-spacing:.06em}
}
@media(max-width:380px){
  .mag-hero__inner{padding-top:1.25rem;padding-right:max(clamp(1.75rem,5.5vw,2.5rem),env(safe-area-inset-right,0px));padding-bottom:1.4rem;padding-left:max(clamp(1.75rem,5.5vw,2.5rem),env(safe-area-inset-left,0px))}
  .mag-hero__title{font-size:1.55rem}
  .mag-hero__title em{font-size:.66em}
  .mag-hero__byline .sep{display:none}
}

/* ===== Magazine BODY ===== */
.mag-shell{background:var(--bg);position:relative;overflow-x:hidden}
.mag-back{display:inline-flex;align-items:center;gap:.5rem;font-size:.78rem;font-weight:600;color:var(--text-muted);text-decoration:none;letter-spacing:.06em;text-transform:uppercase;margin:0 0 var(--s-md);transition:color .2s}
.mag-back:hover{color:var(--accent)}
.mag-shell .container--reading{max-width:760px;margin:0 auto;padding:0 clamp(1rem,4vw,2rem)}
.mag-meta-bar{max-width:760px;margin:0 auto;padding:1.5rem clamp(1rem,4vw,2rem);display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border);font-size:.78rem;color:var(--text-muted)}
.mag-meta-bar__share{display:flex;gap:.5rem;align-items:center}
.mag-meta-bar__share a{display:inline-flex;width:34px;height:34px;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:50%;color:var(--text-muted);transition:all .2s}
.mag-meta-bar__share a:hover{color:var(--accent);border-color:var(--accent)}
.mag-meta-bar__share svg{width:14px;height:14px}

/* Article body — magazine typography (applies wherever .article-body-editorial exists) */
.article-body-editorial{max-width:760px;margin:0 auto;padding:clamp(2rem,5vw,3.5rem) clamp(1rem,4vw,2rem) 0;counter-reset:mag-h2}
.article-body-editorial > p,
.article-body-editorial p{font-family:var(--f-body,'Inter','Noto Sans TC',sans-serif);font-size:clamp(1.04rem,1.18vw,1.18rem);line-height:1.95;color:var(--text-sec);margin:0 0 1.4em}
.article-body-editorial > p:first-of-type{font-size:clamp(1.08rem,1.3vw,1.2rem);line-height:1.8;color:var(--text);font-weight:400}
.article-body-editorial > p:first-of-type::first-letter{float:left;font-family:var(--f-head,'Playfair Display','Noto Serif TC',serif);font-size:3.6em;line-height:.9;font-weight:800;margin:.1em .15em -.05em -.02em;color:var(--accent)}
.article-body-editorial h2{font-family:var(--f-head,'Playfair Display','Noto Serif TC',serif);font-size:clamp(1.7rem,3vw,2.3rem);line-height:1.2;color:var(--text);margin:clamp(2.4rem,5vw,3.6rem) 0 clamp(.9rem,2vw,1.2rem);font-weight:800;letter-spacing:-.01em;position:relative;padding-top:2.4rem;border-top:1px solid var(--border)}
.article-body-editorial h2::before{counter-increment:mag-h2;content:counter(mag-h2,decimal-leading-zero);position:absolute;top:1rem;left:0;font-family:'Outfit',sans-serif;font-size:.72rem;font-weight:700;color:var(--accent);letter-spacing:.22em;background:var(--bg);padding:0 .6rem 0 0;display:inline-block}
.article-body-editorial h2 + p{margin-top:0}
.article-body-editorial h3{font-family:var(--f-head,'Playfair Display','Noto Serif TC',serif);font-size:clamp(1.2rem,1.8vw,1.4rem);color:var(--text);margin:1.8rem 0 .8rem;font-weight:700;letter-spacing:-.005em}
.article-body-editorial a:not(.btn):not(.bp-bcard__cta):not(.bp-rcard):not(.bp-nav__btn):not(.bp-nav__hub):not(.mag-back):not(.mag-meta-bar__share a):not(.mag-hero__cta a){color:var(--text);text-decoration:none;background-image:linear-gradient(transparent 65%,rgba(200,169,126,.32) 65%);background-size:100% 100%;transition:all .25s ease;font-weight:500;border-bottom:none}
.article-body-editorial a:not(.btn):not(.bp-bcard__cta):not(.bp-rcard):not(.bp-nav__btn):not(.bp-nav__hub):not(.mag-back):not(.mag-meta-bar__share a):not(.mag-hero__cta a):hover{background-image:linear-gradient(transparent 0%,rgba(200,169,126,.32) 0%);color:var(--accent)}
.article-body-editorial strong{color:var(--text);font-weight:600}
.article-body-editorial figure{margin:clamp(1.6rem,3.5vw,2.4rem) 0;width:100%;max-width:100%}
.article-body-editorial figure img{width:100%;height:auto;max-height:440px;object-fit:cover;border-radius:10px !important;box-shadow:0 8px 28px rgba(0,0,0,.08) !important;display:block}
.article-body-editorial figure figcaption{margin:.7rem 0 0;padding:0 0 0 .85rem;text-align:left !important;font-family:var(--f-head,serif);font-style:italic;font-size:.82rem !important;color:var(--text-muted) !important;letter-spacing:.01em;border-left:2px solid var(--accent)}
.article-body-editorial table{margin:1.8rem 0 !important;border:1px solid var(--border) !important;border-radius:8px;overflow:hidden}
.article-body-editorial table th{background:var(--bg-card);font-weight:700 !important;color:var(--text) !important;font-size:.85rem !important;text-transform:uppercase;letter-spacing:.05em;padding:.85rem 1rem !important;border-bottom:1px solid var(--border) !important}
.article-body-editorial table td{padding:.85rem 1rem !important;font-size:.92rem !important;border-bottom:1px solid var(--border) !important;color:var(--text-sec) !important}
.article-body-editorial table tr:last-child td{border-bottom:none !important}
.article-body-editorial ul li{font-size:1.02rem;line-height:1.95}

/* Layout overrides for legacy .article-detail-layout — when magazine kicks in,
   collapse the 2-column layout into single-column reading flow.
   NOTE: avoid overflow-x:hidden on <body> (breaks iOS Safari mobile nav).
   Containment is handled per-element instead. */
.mag-on .article-detail-layout{display:block !important;max-width:none !important;padding:0 !important;background:var(--bg);overflow-x:hidden}
.mag-on .article-detail-left{display:none !important}
.mag-on .article-detail-right{padding:0 !important;max-width:none !important;overflow-x:hidden}
.mag-on .article-body.article-body-editorial{overflow-x:hidden}

/* Magazine 頁：全站 .container 預設 clamp(1rem,4vw) 喺手機太窄，與正文唔一致 */
@media(max-width:760px){
  .mag-on .container{
    padding-left:max(clamp(2rem,6vw,2.85rem),env(safe-area-inset-left,0px));
    padding-right:max(clamp(2rem,6vw,2.85rem),env(safe-area-inset-right,0px));
  }
}
@media(max-width:380px){
  .mag-on .container{
    padding-left:max(clamp(1.75rem,5.5vw,2.5rem),env(safe-area-inset-left,0px));
    padding-right:max(clamp(1.75rem,5.5vw,2.5rem),env(safe-area-inset-right,0px));
  }
}

/* Pull quote treatment */
.mag-pull{font-family:var(--f-head,'Playfair Display','Noto Serif TC',serif);font-size:clamp(1.4rem,2.2vw,1.85rem);line-height:1.45;font-style:italic;font-weight:400;color:var(--text);text-align:center;margin:clamp(2.5rem,5vw,3.5rem) 0;padding:clamp(1.5rem,4vw,2.5rem) 1rem;border-top:2px solid var(--accent);border-bottom:2px solid var(--accent);position:relative;background:none}
.mag-pull::before{content:"\201C";position:absolute;top:-.6em;left:50%;transform:translateX(-50%);font-size:5em;color:var(--accent);background:var(--bg);padding:0 .25em;line-height:1;font-family:Georgia,serif}
.mag-pull cite{display:block;margin-top:1.2rem;font-size:.78rem;font-style:normal;letter-spacing:.18em;color:var(--text-muted);text-transform:uppercase;font-weight:600}

@media(max-width:760px){
  .article-body-editorial{padding:1.6rem max(clamp(2rem,6vw,2.85rem),env(safe-area-inset-right,0px)) 1rem max(clamp(2rem,6vw,2.85rem),env(safe-area-inset-left,0px));overflow-x:hidden}
  .article-body-editorial figure{margin:1.4rem 0}
  .article-body-editorial figure img{max-height:320px;border-radius:10px !important}
  .article-body-editorial figure figcaption{font-size:.76rem !important;padding-left:.7rem;margin-top:.55rem;line-height:1.6}
  .article-body-editorial > p:first-of-type{font-size:1rem;line-height:1.85}
  .article-body-editorial > p:first-of-type::first-letter{font-size:2.6em;margin:.05em .14em -.05em -.02em}
  .article-body-editorial > p,
  .article-body-editorial p{font-size:.98rem;line-height:1.9;margin-bottom:1.25em}
  .article-body-editorial h2{font-size:1.35rem;padding-top:1.9rem;margin:1.9rem 0 .8rem;line-height:1.35}
  .article-body-editorial h2::before{top:.7rem;font-size:.66rem;letter-spacing:.18em}
  .article-body-editorial h3{font-size:1.08rem;margin:1.4rem 0 .55rem}
  .article-body-editorial ul,.article-body-editorial ol{padding-left:1.25rem;margin:0 0 1.4em}
  .article-body-editorial ul li,.article-body-editorial ol li{font-size:.95rem;line-height:1.85;padding-left:.15rem}
  .mag-pull{font-size:1.12rem;line-height:1.55;margin:2rem 0;padding:1.5rem .8rem}
  .mag-pull::before{font-size:3em;top:-.55em}
  /* Tables: 留邊距 + 橫向滾動，避免直接貼邊 */
  .article-body-editorial table{display:block;overflow-x:auto;max-width:100%;-webkit-overflow-scrolling:touch;white-space:nowrap;font-size:.85rem;border-radius:8px}
  .article-body-editorial table th,.article-body-editorial table td{padding:.65rem .9rem !important;font-size:.84rem !important}
}
@media(max-width:380px){
  .article-body-editorial{padding:1.4rem max(clamp(1.75rem,5.5vw,2.5rem),env(safe-area-inset-right,0px)) 1rem max(clamp(1.75rem,5.5vw,2.5rem),env(safe-area-inset-left,0px))}
  .article-body-editorial figure{margin:1.2rem 0}
  .article-body-editorial h2{font-size:1.25rem}
  .article-body-editorial > p:first-of-type::first-letter{font-size:2.35em}
}

/* Existing rich sections fit magazine aesthetic */
.bp-section{padding:clamp(2.5rem,5vw,4rem) 0}
.bp-section h2{font-family:var(--f-head,serif);font-size:clamp(1.8rem,3vw,2.4rem);line-height:1.2;font-weight:800;letter-spacing:-.01em;margin-bottom:.5rem}
.bp-section .label{display:inline-block;font-size:.7rem;letter-spacing:.22em;font-weight:700;color:var(--accent);text-transform:uppercase;margin-bottom:.6rem}
.bp-section .lead{font-size:1.02rem;color:var(--text-sec);max-width:680px;line-height:1.85}

.bp-fp a{box-shadow:none}
.bp-fp__lbl{font-family:var(--f-head,serif)}

.bp-faq__item summary{font-family:var(--f-head,serif);font-size:1.05rem}
.bp-faq__body{font-size:.95rem}

.bp-rcard__title{font-family:var(--f-head,serif);font-size:1.05rem}

/* ===== 5月限定迎新禮 inline banner (Hero 下方高轉換位) ===== */
.bp-promo{background:linear-gradient(135deg,#1C1C1A 0%,#2A2A27 100%);border:1px solid rgba(200,169,126,.35);border-radius:var(--r-xl);padding:clamp(1.25rem,3vw,2.5rem);overflow:hidden;position:relative;margin:var(--s-xl) 0 var(--s-2xl)}
.bp-promo__grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.1fr);gap:clamp(1.25rem,3vw,2.5rem);align-items:center}
.bp-promo__media{border-radius:var(--r-lg);overflow:hidden;background:linear-gradient(135deg,#0e0e0d 0%,#1A1A18 100%);aspect-ratio:2/3;display:flex;align-items:center;justify-content:center;padding:1rem}
.bp-promo__media img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;display:block}
.bp-promo__body{color:#F5F0E8}
.bp-promo__tag{display:inline-flex;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;font-weight:700;color:#1C1C1A;background:#C8A97E;padding:.35rem .85rem;border-radius:999px}
.bp-promo__title{color:#fff;margin:.85rem 0 .5rem;font-size:clamp(1.35rem,2.6vw,2rem);line-height:1.25}
.bp-promo__title em{font-style:normal;color:#C8A97E}
.bp-promo__price{display:flex;align-items:baseline;gap:.6rem;margin-bottom:.85rem}
.bp-promo__price-l{font-size:.72rem;color:rgba(245,240,232,.6);letter-spacing:.05em;text-transform:uppercase}
.bp-promo__price-a{font-family:'Outfit',sans-serif;font-size:clamp(2rem,3.2vw,2.6rem);font-weight:800;color:#C8A97E;line-height:1}
.bp-promo__lead{color:rgba(245,240,232,.85);font-size:.95rem;line-height:1.75;margin:0 0 var(--s-sm)}
.bp-promo__lead strong{color:#C8A97E}
.bp-promo__list{list-style:none;padding:0;margin:0 0 var(--s-md);display:grid;grid-template-columns:1fr 1fr;gap:.5rem .9rem}
.bp-promo__list li{font-size:.85rem;color:rgba(245,240,232,.9);position:relative;padding-left:1.25rem;line-height:1.5}
.bp-promo__list li::before{content:"";position:absolute;left:0;top:.45rem;width:7px;height:7px;border-radius:50%;background:#C8A97E}
.bp-promo__cta{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;padding:.95rem 1.5rem;background:#25D366;color:#fff;font-weight:700;font-size:.95rem;border-radius:999px;text-decoration:none;box-shadow:0 8px 24px rgba(37,211,102,.3);min-height:48px}
.bp-promo__cta:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(37,211,102,.45);color:#fff}
.bp-promo__fp{font-size:.7rem;line-height:1.55;color:rgba(245,240,232,.5);margin:var(--s-sm) 0 0}
.bp-promo--top{margin-top:var(--s-xl);position:relative;z-index:3}
@media(max-width:760px){
  /* 橫向只靠 .mag-on .container；避免 container padding + margin 雙重收窄 */
  .bp-promo{padding:1.3rem 1.2rem 1.4rem;border-radius:var(--r-lg);margin:1rem 0 1.5rem}
  .bp-promo__grid{grid-template-columns:1fr;gap:.9rem}
  .bp-promo__media{aspect-ratio:auto;height:clamp(240px,38vh,320px);border-radius:12px;padding:.8rem}
  .bp-promo__media img{max-height:100%;width:auto}
  .bp-promo__tag{font-size:.62rem;padding:.3rem .7rem;letter-spacing:.14em}
  .bp-promo__title{font-size:1.32rem;margin:.65rem 0 .4rem;line-height:1.3}
  .bp-promo__price{margin-bottom:.65rem;gap:.45rem}
  .bp-promo__price-l{font-size:.65rem}
  .bp-promo__price-a{font-size:1.55rem}
  .bp-promo__lead{font-size:.88rem;line-height:1.65;margin-bottom:.7rem}
  .bp-promo__list{gap:.4rem .7rem;margin-bottom:.85rem}
  .bp-promo__list li{font-size:.78rem;padding-left:.9rem;line-height:1.45}
  .bp-promo__list li::before{top:.4rem;width:5px;height:5px}
  .bp-promo__cta{width:100%;padding:.95rem;font-size:.95rem;min-height:52px}
  .bp-promo__fp{font-size:.65rem;line-height:1.5;margin-top:.7rem}
  .bp-promo--top{margin-top:.8rem}
}
@media(max-width:380px){.bp-promo__list{grid-template-columns:1fr}.bp-promo__title{font-size:1.22rem}.bp-promo__price-a{font-size:1.5rem}}

/* Visible FAQ accordion (matches FAQPage schema) */
.bp-faq{padding:clamp(2rem,4vw,3rem) 0;max-width:760px;margin:clamp(2rem,5vw,3.5rem) auto 0}
.bp-faq__label{display:inline-block;font-size:.7rem;letter-spacing:.22em;font-weight:700;color:var(--accent);text-transform:uppercase;margin-bottom:.6rem}
.bp-faq__title{font-family:var(--f-head,serif);font-size:clamp(1.6rem,2.6vw,2.1rem);line-height:1.2;font-weight:800;letter-spacing:-.01em;margin:0 0 1.5rem;color:var(--text)}
.bp-faq__list{display:flex;flex-direction:column;gap:.7rem}
.bp-faq__item{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;overflow:hidden}
.bp-faq__item summary{padding:1.1rem 1.3rem;font-family:var(--f-head,serif);font-weight:600;cursor:pointer;color:var(--text);font-size:1rem;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1rem;line-height:1.4}
.bp-faq__item summary::-webkit-details-marker{display:none}
.bp-faq__item summary::after{content:"+";color:var(--accent);font-size:1.5rem;line-height:1;transition:transform .25s;flex-shrink:0}
.bp-faq__item[open] summary::after{transform:rotate(45deg)}
.bp-faq__body{padding:0 1.3rem 1.3rem;color:var(--text-sec);font-size:.95rem;line-height:1.85;border-top:1px solid var(--border);padding-top:1rem;margin-top:-2px}
.bp-faq__body a{color:var(--accent)}
@media(max-width:760px){
  .bp-faq{padding:1.5rem max(clamp(2rem,6vw,2.85rem),env(safe-area-inset-right,0px)) 2rem max(clamp(2rem,6vw,2.85rem),env(safe-area-inset-left,0px));margin:1.5rem auto 0}
  /* FAQ 已經喺 .article-body-editorial 入面 — 唔好再加橫向 padding（會三重留白） */
  .mag-on .article-body-editorial .bp-faq{padding-left:0;padding-right:0}
  .bp-faq__label{font-size:.65rem;letter-spacing:.18em;margin-bottom:.5rem}
  .bp-faq__title{font-size:1.4rem;line-height:1.3;margin-bottom:1.1rem}
  .bp-faq__list{gap:.55rem}
  .bp-faq__item{border-radius:12px}
  .bp-faq__item summary{font-size:.94rem;padding:1.05rem 1.1rem;min-height:52px;line-height:1.45;gap:.7rem}
  .bp-faq__item summary::after{font-size:1.35rem}
  .bp-faq__body{font-size:.9rem;line-height:1.8;padding:0 1.1rem 1.1rem;padding-top:.85rem}
}

