:root{
  --bg:#f6f0e6;
  --bg-soft:#fbf8f2;
  --panel:rgba(255,255,255,.58);
  --sage:#95a28b;
  --sage-dark:#68755f;
  --gold:#b89468;
  --brown:#58473c;
  --rose:#8d7266;
  --line:rgba(88,71,60,.12);
  --shadow:0 20px 60px rgba(88,71,60,.10);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}

body{
  margin:0;
  font-family:'Noto Sans TC',sans-serif;
  font-size:18px;
  color:var(--brown);
  background:linear-gradient(180deg,#fcf8f2 0%,#f6eee3 55%,#f8f3ea 100%);
}

body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:1;
  opacity:.055;
  background-image:none;
}

.page-wrap{
  position:relative;
  z-index:2;
  opacity:0;
  transform:translateY(10px);
  transition:opacity .95s ease,transform .95s ease;
}

body.page-ready .page-wrap{
  opacity:1;
  transform:none;
}

body.page-leaving .page-wrap{
  opacity:0;
  transform:translateY(8px);
}

img{
  max-width:100%;
  display:block;
}

a{
  text-decoration:none;
  color:inherit;
}

.container{
  width:min(1220px,calc(100% - 42px));
  margin:0 auto;
}

.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(251,247,240,.82);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(88,71,60,.08);
}

.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(251,247,240,.82);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(88,71,60,.08);
}

.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:6px 0;
}

.nav-left{
  display:flex;
  align-items:center;
  gap:20px;
}

.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:2px 0;
}

.nav-logo img{
  height:82px;
  width:auto;
}

@media (max-width:1100px){
  .nav-logo img{height:74px}
}

@media (max-width:760px){
  .nav-logo img{height:62px}
}

.nav-links{
  display:flex;
  gap:20px;
  font-size:17px;
  color:rgba(88,71,60,.8);
  align-items:center;
  flex-wrap:wrap;
}

.nav-links a{
  padding:8px 2px;
  position:relative;
}

.nav-links a::after{
  content:"";
  position:absolute;
  left:0;
  bottom:0;
  width:0;
  height:1px;
  background:var(--gold);
  transition:width .3s ease;
}

.nav-links a:hover::after,
.nav-links a.active::after{
  width:100%;
}

.cta-btn,
.ghost-btn{
  border-radius:999px;
  padding:15px 26px;
  font-size:17px;
  font-weight:600;
  letter-spacing:.02em;
  transition:transform .28s ease,box-shadow .28s ease,background .28s ease,color .28s ease,border-color .28s ease;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}

.cta-btn:hover,
.ghost-btn:hover{
  transform:translateY(-1px);
}

.cta-btn{
  background:linear-gradient(135deg,var(--sage-dark),var(--sage));
  color:#fff;
  box-shadow:0 12px 30px rgba(104,117,95,.22);
}

.ghost-btn{
  border:1px solid rgba(88,71,60,.16);
  background:rgba(255,255,255,.42);
}

.mobile-toggle{
  display:none;
  background:none;
  border:none;
  color:var(--brown);
  font-size:28px;
}

.mobile-panel{
  display:none;
  padding:0 0 18px;
}

.mobile-panel a{
  padding:10px 0;
  border-bottom:1px solid rgba(88,71,60,.08);
}

/* ===== Hero 固定版型 ===== */
.hero{
  padding:48px 0 84px;
  overflow:hidden;
}

.hero-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) 620px;
  gap:56px;
  align-items:start;
}

.hero-grid > div:first-child{
  min-width:0;
  position:relative;
  z-index:1;
}

.kicker{
  font-size:13px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--sage-dark);
}

.hero h1,
.section-title,
.display{
  font-family:'Noto Serif TC',serif;
  line-height:1.15;
  font-weight:600;
}

.hero h1{
  font-size:clamp(38px,6vw,62px);
  margin:18px 0;
}

.hero p{
  font-size:20px;
  line-height:2;
  color:rgba(88,71,60,.76);
  max-width:680px;
}

.btn-row{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  margin-top:26px;
}

.note{
  font-size:14px;
  color:rgba(88,71,60,.56);
  margin-top:18px;
  line-height:1.8;
}

.hero-media{
  position:relative;
  width:620px;
  height:690px;
  margin-left:auto;
  z-index:2;
}

.photo-main,
.photo-secondary,
.photo-third{
  position:absolute;
  overflow:hidden;
  border-radius:34px;
  box-shadow:var(--shadow);
  border:1px solid rgba(255,255,255,.56);
  background:transparent;
}

.photo-main img,
.photo-secondary img,
.photo-third img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center center;
  transform:scale(1.02);
}

.photo-secondary img,
.photo-third img{
  transform:scale(1.04);
}

.photo-main{
  top:0;
  right:0;
  width:510px;
  height:510px;
  z-index:1;
}

.photo-secondary{
  left:24px;
  bottom:0;
  width:360px;
  height:250px;
  z-index:2;
}

.photo-third{
  right:24px;
  bottom:64px;
  width:190px;
  height:165px;
  z-index:3;
}

.floating-card{
  position:absolute;
  left:-36px;
  top:95px;
  width:220px;
  padding:24px 22px 20px;
  display:grid;
  gap:10px;
  z-index:4;
  border-radius:28px;
}

.floating-card strong{
  font-family:'Noto Serif TC',serif;
  font-size:24px;
  line-height:1.2;
}

.floating-card span{
  font-size:16px;
  line-height:1.75;
  color:rgba(88,71,60,.78);
}

.photo-main::after,
.photo-secondary::after,
.photo-third::after,
.page-hero .hero-image::after,
.story-photo::after,
.feature-img::after,
.process-photo::after,
.brand-story-photo-panel::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(255,255,255,.02),rgba(88,71,60,.06));
  pointer-events:none;
}

/* ===== Common ===== */
.section{
  padding:86px 0;
}

.section-alt{
  background:rgba(255,255,255,.34);
  border-top:1px solid rgba(255,255,255,.62);
  border-bottom:1px solid rgba(88,71,60,.05);
}

.section-title{
  font-size:clamp(30px,4.2vw,48px);
  margin:16px 0 20px;
}

.section-desc{
  max-width:840px;
  color:rgba(88,71,60,.72);
  line-height:2;
  font-size:19px;
  margin-bottom:34px;
}

.soft-card{
  background:var(--panel);
  border:1px solid rgba(255,255,255,.72);
  backdrop-filter:blur(8px);
  border-radius:30px;
  box-shadow:var(--shadow);
}
/* 圖片容器的 soft-card 不要白邊（避免邊框與圖片接縫處看到白線） */
.soft-card.hero-image,
.partners-hero-image.soft-card,
.faq-hero-image.soft-card,
.hero-image,
.partners-hero-image,
.faq-hero-image{
  border:0;
}

.badges,
.plans-grid,
.feature-grid,
.footer-grid,
.service-detail,
.story-grid,
.page-hero,
.trust-grid{
  display:grid;
  gap:24px;
}

.badges,
.plans-grid{
  grid-template-columns:repeat(3,1fr);
}

.badge{
  padding:28px;
}

.badge h3,
.plan h3,
.feature-copy h3,
.process-copy h3{
  font-family:'Noto Serif TC',serif;
  font-size:30px;
  margin:10px 0 12px;
}

.badge p,
.plan p,
.feature-copy p,
.process-copy p,
.story-text p,
.footer p{
  line-height:1.95;
  color:rgba(88,71,60,.72);
  font-size:18px;
}

.page-hero{
  grid-template-columns:1.02fr .98fr;
  align-items:center;
}

.page-hero .hero-image{
  overflow:hidden;
  border-radius:34px;
  position:relative;
  box-shadow:var(--shadow);
}

.page-hero .hero-image img{
  width:100%;
  height:auto;
  display:block;
  object-fit:contain;
  object-position:center center;
  transform:none;
}

/* ===== Story ===== */
.story-grid{
  grid-template-columns:1fr 1fr;
  gap:24px;
  align-items:stretch;
}

.story-text{
  padding:34px;
  height:100%;
  min-height:620px;
}

.story-photo{
  overflow:hidden;
  border-radius:34px;
  position:relative;
  height:100%;
  min-height:500px;
  box-shadow:var(--shadow);
  background:#efe7df;
}

.story-photo img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center center;
  transform:none;
}

.story-grid-center{
  align-items:center;
}

/* 整張顯示、不裁切、跟文案置中對齊 */
.story-photo-contain{
  min-height:auto !important;
  height:auto !important;
  background:none !important;
  box-shadow:none !important;
  overflow:visible;
  display:flex;
  align-items:center;
  justify-content:center;
}

.story-photo-contain img{
  width:100%;
  height:auto !important;
  object-fit:contain !important;
  border-radius:34px;
  box-shadow:var(--shadow);
}

/* ===== Feature ===== */
.feature-grid{
  grid-template-columns:repeat(2,1fr);
}

.feature-img{
  border-radius:26px;
  overflow:hidden;
  min-height:260px;
  position:relative;
}

.feature-img img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center center;
  transform:none;
}

.feature-copy{
  padding:28px;
}

/* ===== Plans ===== */
.plan{
  padding:34px;
  display:flex;
  flex-direction:column;
  gap:18px;
  position:relative;
}

.plan .price{
  font-size:48px;
  font-family:'Cormorant Garamond',serif;
  color:var(--sage-dark);
}

.plan ul{
  padding-left:20px;
  display:grid;
  gap:10px;
  color:rgba(88,71,60,.72);
  line-height:1.8;
  font-size:17px;
}

.plans-hero-layout{
  align-items:center;
}

.plans-lead{
  font-size:20px;
  line-height:1.9;
  color:#c57d3f;
  font-weight:700;
  margin:0 0 10px;
}

.plans-subdesc{
  font-size:18px;
  line-height:2;
  color:rgba(88,71,60,.74);
  margin:0 0 18px;
}

.plans-chip-row{
  display:flex;
  flex-wrap:wrap;
  gap:10px 12px;
  margin:8px 0 4px;
}

.plan-chip{
  display:inline-flex;
  align-items:center;
  padding:9px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.72);
  border:1px solid rgba(184,148,104,.22);
  font-size:15px;
  line-height:1.4;
  color:rgba(88,71,60,.88);
  box-shadow:0 8px 24px rgba(88,71,60,.06);
}

.plans-hero-layout .hero-image{
  /* 讓圖用原始比例顯示，不強制高度 */
}

.plans-hero-layout .hero-image img{
  width:100%;
  height:auto;
  object-fit:contain;
  object-position:center center;
  transform:none;
}

.premium-plan-card{
  display:flex;
  flex-direction:column;
  min-height:100%;
  padding:36px 34px 30px;
}

.plan-kicker{
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(104,117,95,.78);
  margin-bottom:10px;
}

.plan-intro{
  font-size:17px;
  line-height:1.95;
  color:rgba(88,71,60,.72);
  margin:0 0 14px;
}

.plan-divider{
  height:1px;
  background:var(--line);
  margin:10px 0 18px;
}

.plan-section-title{
  font-size:13px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:12px;
  font-weight:700;
}

.plan-feature-list{
  padding-left:0;
  margin:0;
  list-style:none;
  display:grid;
  gap:10px;
}

.plan-feature-list li{
  position:relative;
  padding-left:26px;
  font-size:17px;
  line-height:1.85;
  color:rgba(88,71,60,.78);
  margin:0;
}

.plan-feature-list li::before{
  content:"✓";
  position:absolute;
  left:0;
  top:0;
  color:var(--sage-dark);
  font-weight:700;
}

.plan-quote{
  margin:18px 0 0;
  font-size:16px;
  line-height:1.85;
  color:rgba(88,71,60,.68);
}

.plan-actions{
  margin-top:auto;
  padding-top:22px;
}

.plan-summary-grid{
  grid-template-columns:1fr 1fr;
}

.plan-summary-card{
  min-height:100%;
}

.plan-cta-card{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  padding:30px 34px;
}

.plan-cta-card p{
  font-size:18px;
  line-height:1.95;
  color:rgba(88,71,60,.74);
}

/* ===== Process ===== */
.service-detail{
  grid-template-columns:1fr 1fr;
  align-items:center;
  padding:0;
  overflow:hidden;
  gap:0;
}

.service-detail.reverse .process-photo{
  order:2;
}

.service-detail.reverse .process-copy{
  order:1;
}

.process-photo{
  min-height:100%;
  background:transparent;
  padding:0;
  margin:0;
  display:block;
  border:0;
  position:relative;
  align-self:stretch;
  overflow:hidden;
}

.process-photo img{
  width:100%;
  height:100%;
  object-fit:cover;
  transform:none;
  border-radius:0;
  display:block;
}

.process-copy{
  padding:36px 40px;
}

.process-step-label{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:auto;
  height:auto;
  min-width:unset;
  min-height:unset;
  padding:0;
  border-radius:0;
  background:transparent;
  font-family:'Cormorant Garamond',serif;
  font-size:42px;
  line-height:1;
  letter-spacing:.04em;
  color:#d2b48c;
  margin-bottom:14px;
  box-shadow:none;
}

.process-copy ul{
  padding-left:24px;
  margin:18px 0 0;
}

.process-copy li{
  font-size:18px;
  line-height:2;
  color:rgba(88,71,60,.74);
  margin-bottom:8px;
  overflow-wrap:anywhere;
}

/* ===== Misc ===== */
.mini-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
  margin-top:22px;
}

.mini-card{
  padding:22px;
}

.mini-card h4{
  font-family:'Noto Serif TC',serif;
  font-size:21px;
  margin:0 0 8px;
}

.faq-grid{
  display:grid;
  gap:0;
}

.faq-item{
  padding:26px 0;
  border-bottom:1px solid var(--line);
}

.footer{
  padding:30px 0 72px;
  color:rgba(88,71,60,.76);
}

.footer-grid{
  grid-template-columns:1.3fr .9fr .9fr;
  gap:20px;
}

.footer-grid > div:nth-child(2){
  text-align:center;
  justify-self:center;
}

.footer-grid > div:nth-child(2) p{
  margin-left:auto;
  margin-right:auto;
}

.footer .nav-logo img{
  height:78px !important;
}

.footer p{
  font-size:15px;
  line-height:1.8;
  color:rgba(88,71,60,.72);
}

.footer small{
  display:block;
  font-size:14px;
  line-height:1.8;
  color:rgba(88,71,60,.64);
}

.footer strong{
  font-size:15px;
  line-height:1.4;
}

.footer a{
  font-size:15px;
  line-height:1.9;
}

.footer .legal-note{
  font-size:13px;
  line-height:1.8;
  color:rgba(88,71,60,.56);
  margin-top:10px;
}

@media (max-width:980px){
  .footer{
    padding:24px 0 60px;
  }

  .footer-grid{
    grid-template-columns:1fr;
    gap:18px;
  }

  .footer-grid > div:nth-child(2){
    text-align:left;
    justify-self:start;
  }

  .footer-grid > div:nth-child(2) p{
    margin-left:0;
    margin-right:0;
  }

  .footer .nav-logo img{
    height:70px !important;
  }
}

@media (max-width:760px){
  .footer{
    padding:20px 0 52px;
  }

  .footer .nav-logo img{
    height:62px !important;
  }

  .footer p,
  .footer a{
    font-size:14px;
    line-height:1.75;
  }

  .footer small,
  .footer .legal-note{
    font-size:12px;
    line-height:1.75;
  }

  .footer strong{
    font-size:14px;
  }
}
.watermark{
  position:fixed;
  right:14px;
  bottom:14px;
  z-index:40;
  opacity:.10;
  pointer-events:none;
  transition:opacity .4s ease,transform .4s ease;
}

.watermark img{
  width:min(150px,18vw);
  filter:drop-shadow(0 6px 14px rgba(88,71,60,.08));
}

/* 品牌故事浮動影片框 — 取代 brand.html 的 watermark */
.brand-video-float{
  position:fixed;
  right:24px;
  bottom:24px;
  width:min(440px,40vw);
  aspect-ratio:16/9;
  border-radius:20px;
  overflow:hidden;
  background:#0d0a08;
  box-shadow:0 22px 56px rgba(58,48,40,.32),0 6px 16px rgba(58,48,40,.14);
  z-index:60;
  cursor:pointer;
  transition:transform .3s ease,box-shadow .3s ease;
}
.brand-video-float:hover{
  transform:translateY(-3px) scale(1.02);
  box-shadow:0 24px 60px rgba(58,48,40,.36),0 8px 18px rgba(58,48,40,.18);
}
.brand-video-float video{
  width:100%;height:100%;object-fit:cover;display:block;
}
.brand-video-overlay{
  position:absolute;inset:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;
  background:linear-gradient(180deg,rgba(255,248,240,.18) 0%,rgba(0,0,0,.32) 100%);
  transition:opacity .35s ease;pointer-events:none;
}
.brand-video-float.is-playing .brand-video-overlay{opacity:0}
.brand-video-play-icon{
  width:58px;height:58px;border-radius:50%;
  background:rgba(255,250,243,.95);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 16px rgba(0,0,0,.25);
  padding-left:4px;
}
.brand-video-label{
  color:#fff;font-size:12px;font-weight:600;letter-spacing:.08em;
  text-shadow:0 2px 6px rgba(0,0,0,.6);
  background:rgba(0,0,0,.42);padding:4px 10px;border-radius:12px;
}
.brand-video-close{
  position:absolute;top:6px;right:6px;
  width:24px;height:24px;border:none;border-radius:50%;
  background:rgba(0,0,0,.55);color:#fff;font-size:18px;line-height:1;
  cursor:pointer;opacity:0;transition:opacity .25s ease;
  z-index:2;padding:0;
  display:flex;align-items:center;justify-content:center;
}
.brand-video-float:hover .brand-video-close{opacity:1}
@media (max-width:600px){
  .brand-video-float{right:14px;bottom:14px;width:min(280px,68vw)}
  .brand-video-play-icon{width:50px;height:50px}
  .brand-video-label{font-size:11px;padding:3px 8px}
}

.reveal{
  opacity:0;
  transform:translateY(18px);
  transition:opacity 1.1s ease,transform 1.1s ease;
}

.reveal.is-visible{
  opacity:1;
  transform:none;
}

.highlight{
  color:var(--sage-dark);
}

.trust-grid{
  grid-template-columns:repeat(3,1fr);
}

.trust-card{
  padding:30px;
  min-height:240px;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  overflow:hidden;
}

.trust-step-number{
  display:block;
  font-family:'Cormorant Garamond',serif;
  font-size:36px;
  line-height:1;
  letter-spacing:.03em;
  color:#d2b48c;
  margin-bottom:14px;
}

.trust-card h3{
  font-family:'Noto Serif TC',serif;
  font-size:30px;
  font-weight:600;
  line-height:1.35;
  color:var(--brown);
  margin:0 0 12px;
  word-break:keep-all;
  overflow-wrap:normal;
}

.trust-card p{
  margin:0;
  font-size:18px;
  line-height:1.95;
  color:rgba(88,71,60,.72);
  word-break:normal;
  overflow-wrap:break-word;
}

.trust-card small{
  display:block;
  margin-top:12px;
  font-size:15px;
  line-height:1.8;
  color:rgba(88,71,60,.6);
  word-break:normal;
  overflow-wrap:break-word;
}

/* 安心機制頁主圖修正（取消強制高度，圖按原比例） */
.page-hero .hero-image.soft-card{
  padding:0;
  display:block;
  overflow:hidden;
}

.page-hero .hero-image.soft-card img{
  display:block;
  width:100%;
  height:auto;
  object-fit:contain;
  object-position:center center;
}

@media (max-width:980px){
  .page-hero .hero-image.soft-card{
    min-height:420px;
  }

  .page-hero .hero-image.soft-card img{
    min-height:420px;
  }
}

@media (max-width:760px){
  .page-hero .hero-image.soft-card{
    min-height:300px;
  }

  .page-hero .hero-image.soft-card img{
    min-height:300px;
  }
}

.sustain-list{
  padding-left:24px;
  margin:0;
}

.sustain-list li{
  margin-bottom:10px;
}

.quote-band{
  padding:38px;
  border-radius:30px;
  background:linear-gradient(135deg,rgba(149,162,139,.12),rgba(184,148,104,.10));
  border:1px solid rgba(149,162,139,.18);
}

.generated-visual{
  border-radius:34px;
  overflow:hidden;
  box-shadow:var(--shadow);
  border:1px solid rgba(255,255,255,.7);
  background:rgba(255,255,255,.56);
  padding:22px;
}

.generated-visual img{
  width:100%;
  height:auto;
  border-radius:28px;
  display:block;
}

.stat-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
  margin-top:28px;
}

.stat-card{
  padding:22px;
  text-align:center;
}

.stat-card strong{
  display:block;
  font-family:"Cormorant Garamond",serif;
  font-size:40px;
  color:var(--sage-dark);
  line-height:1;
  margin-bottom:10px;
}

.inline-list{
  padding-left:22px;
  margin:14px 0 0;
}

.inline-list li{
  font-size:18px;
  line-height:1.95;
  color:rgba(88,71,60,.74);
  margin-bottom:8px;
  overflow-wrap:anywhere;
}

.feature-copy .small-note,
.process-copy .small-note{
  font-size:15px;
  color:rgba(88,71,60,.58);
  line-height:1.9;
  margin-top:12px;
}

.dual-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
}

.strip-card{
  padding:28px;
}

.strip-card h3{
  font-family:'Noto Serif TC',serif;
  font-size:28px;
  margin:0 0 10px;
}

.strip-card p{
  font-size:18px;
  line-height:1.95;
  color:rgba(88,71,60,.74);
}

.strip-card ul{
  padding-left:22px;
  margin:14px 0 0;
}

.strip-card li{
  font-size:17px;
  line-height:1.9;
  color:rgba(88,71,60,.74);
  margin-bottom:6px;
}

.legal-note{
  font-size:14px;
  line-height:1.9;
  color:rgba(88,71,60,.54);
  margin-top:20px;
}

/* ===== Brand ===== */
.brand-story-section{
  padding-top:10px;
}

.brand-story-grid{
  grid-template-columns:1.02fr .98fr;
}

.brand-page-hero{
  align-items:center;
}

.brand-page-single{
  grid-template-columns:minmax(0,860px);
  justify-content:center;
}

.brand-page-single > div:first-child{
  width:100%;
}

.brand-page-hero .hero-image{
  min-height:760px;
}

.brand-story-copy{
  padding:30px;
}

.brand-story-copy p{
  font-size:18px;
  line-height:2;
  color:rgba(88,71,60,.74);
  margin:0 0 16px;
}

.brand-lead{
  margin-bottom:18px;
}

.brand-story-overlap{
  display:grid;
  grid-template-columns:1fr;
  align-items:start;
  gap:22px;
  margin-top:12px;
  position:relative;
  max-width:860px;
}

.brand-story-photo-panel{
  position:relative;
  width:100%;
  aspect-ratio:16/9;
  border-radius:32px;
  overflow:hidden;
  box-shadow:0 22px 60px rgba(90,72,60,.14);
  background:#efe7df;
  z-index:1;
}

.brand-story-photo-panel img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center center;
  transform:none;
}

.brand-story-float-card{
  position:relative;
  width:100%;
  padding:34px 36px 30px;
  border-radius:32px;
  background:rgba(252,248,243,.96);
  backdrop-filter:blur(3px);
  box-shadow:0 18px 45px rgba(90,72,60,.10);
  z-index:2;
  display:flex;
  flex-direction:column;
  justify-content:center;
}

.brand-story-float-card h2{
  font-family:"Noto Serif TC",serif;
  font-size:clamp(28px,3vw,40px);
  line-height:1.2;
  color:var(--brown);
  margin:0 0 16px;
}

.brand-story-float-card p{
  font-size:16px;
  line-height:1.9;
  color:rgba(88,71,60,.78);
  margin:0 0 10px;
}

.brand-story-float-card .btn-row{
  margin-top:18px;
}

.brand-page-hero .display,
.brand-page-hero .brand-lead{
  display:none;
}

.footer a[href^="mailto:"],
.footer a[href^="https://line.me"],
.note a[href^="mailto:"],
.btn-row a[href^="https://line.me"]{
  color:inherit;
}

.footer a[href^="mailto:"],
.footer a[href^="https://line.me"]{
  text-decoration:underline;
  text-decoration-color:rgba(88,71,60,.22);
  text-underline-offset:3px;
}

/* ===== Responsive ===== */
@media (max-width:1100px){
  .nav-logo img{height:74px}
  .nav-links{gap:16px;font-size:15px}
  .hero-grid{grid-template-columns:minmax(0,1fr) 560px;gap:40px}
  .hero-media{width:560px;height:640px}
  .photo-main{width:460px;height:460px}
  .photo-secondary{width:320px;height:220px}
  .photo-third{width:170px;height:145px}
  .brand-story-photo-panel{aspect-ratio:16/9}
  .brand-story-float-card{padding:30px 32px 28px}
}

@media (max-width:980px){
  .hero-grid,
  .story-grid,
  .page-hero,
  .footer-grid,
  .feature-grid,
  .service-detail,
  .service-detail.reverse{
    grid-template-columns:1fr;
  }

  .plans-grid,
  .trust-grid,
  .badges,
  .mini-grid,
  .stat-grid,
  .dual-grid,
  .plan-summary-grid{
    grid-template-columns:1fr;
  }

  .hero{
    padding:32px 0 72px;
  }

  .hero-media{
    width:100%;
    max-width:620px;
    height:690px;
    margin:0 auto;
  }

  .photo-main{
    top:0;
    right:0;
    width:510px;
    height:510px;
  }

  .photo-secondary{
    left:24px;
    bottom:0;
    width:360px;
    height:250px;
  }

  .photo-third{
    right:24px;
    bottom:24px;
    width:190px;
    height:165px;
  }

  .floating-card{
    left:-24px;
    top:95px;
  }

  .service-detail.reverse .process-photo,
  .service-detail.reverse .process-copy{
    order:initial;
  }

  .brand-story-grid{
    grid-template-columns:1fr;
  }

  .brand-page-hero .hero-image{
    min-height:540px;
  }

  .brand-story-photo-panel{
    aspect-ratio:16/10;
  }

  .brand-story-float-card{
    min-height:auto;
  }

  .plan-cta-card{
    flex-direction:column;
    align-items:flex-start;
  }
}

@media (max-width:760px){
  /* ── 全域：圖片不溢出 + 字級縮小 ── */
  img{
    max-width:100%;
    height:auto;
  }

  .soft-card,
  .story-photo,
  .feature-img,
  .brand-story-photo-panel,
  .photo-main,
  .photo-secondary,
  .photo-third,
  .plans-legacy-image,
  .faq-hero-image,
  .page-hero .hero-image{
    overflow:hidden;
  }

  .container{
    width:calc(100% - 32px);
  }

  .kicker{
    font-size:11px;
    letter-spacing:.14em;
  }

  .section-title{
    font-size:clamp(20px,5vw,28px) !important;
    margin:10px 0 12px;
  }

  .section-desc{
    font-size:15px;
    line-height:1.8;
    margin-bottom:20px;
  }

  .section{
    padding:36px 0;
  }

  /* ── 導覽列：Logo 縮小 + 漢堡選單 ── */
  .nav-links,
  .nav-right{
    display:none !important;
  }

  .mobile-toggle{
    display:block;
    font-size:24px;
  }

  .mobile-panel.open{
    display:grid;
    gap:6px;
  }

  .mobile-panel a{
    font-size:15px;
    padding:8px 0;
  }

  .nav-logo img{
    height:48px;
  }

  .nav{
    padding:4px 0;
  }

  /* ── 按鈕：全部縮小，三顆擠同一排 ── */
  .cta-btn,
  .ghost-btn{
    padding:10px 16px;
    font-size:14px;
  }

  .btn-row{
    gap:8px;
    margin-top:16px;
  }

  /* ── Hero 區 ── */
  .hero{
    padding:16px 0 32px;
  }

  .hero h1{
    font-size:clamp(22px,6vw,30px) !important;
    margin:10px 0;
  }

  .hero p{
    font-size:15px;
    line-height:1.75;
  }

  .note{
    font-size:12px;
    margin-top:10px;
  }

  .hero-grid{
    grid-template-columns:1fr;
    gap:16px;
  }

  .hero-media{
    width:100%;
    height:auto;
    max-width:none;
    margin-left:0;
    position:relative;
    display:grid;
    grid-template-columns:1fr 1fr;
    grid-template-rows:auto auto;
    gap:6px;
  }

  .photo-main,
  .photo-secondary,
  .photo-third{
    position:relative;
    top:auto;
    left:auto;
    right:auto;
    bottom:auto;
    border-radius:16px;
    overflow:hidden;
  }

  .photo-main img,
  .photo-secondary img,
  .photo-third img{
    transform:none;
  }

  .photo-main{
    width:100%;
    height:340px;
    grid-column:1 / -1;
  }

  .photo-main img{
    object-position:center 15%;
  }

  .photo-secondary{
    width:100%;
    height:150px;
  }

  .photo-third{
    width:100%;
    height:150px;
  }

  .floating-card{
    position:relative;
    left:auto;
    top:auto;
    width:100%;
    padding:14px 16px 12px;
    border-radius:16px;
    grid-column:1 / -1;
  }

  .floating-card strong{
    font-size:17px;
  }

  .floating-card span{
    font-size:14px;
    line-height:1.65;
  }

  /* ── 三大承諾 badges ── */
  .badges{
    grid-template-columns:1fr !important;
    gap:10px;
  }

  .badge{
    padding:18px;
  }

  .badge h3{
    font-size:18px;
  }

  .badge p{
    font-size:14px;
    line-height:1.7;
  }

  /* ── 統計數字 ── */
  .stat-grid{
    grid-template-columns:1fr 1fr !important;
    gap:8px;
  }

  .stat-card{
    padding:16px;
  }

  .stat-card strong{
    font-size:22px;
  }

  .stat-card span{
    font-size:13px;
  }

  /* ── Story 區 ── 單欄，圖上文下 ── */
  .story-grid{
    grid-template-columns:1fr !important;
    gap:14px;
  }

  .story-text{
    min-height:auto;
    padding:20px;
  }

  .story-text h2{
    font-size:18px !important;
    line-height:1.45;
    margin:8px 0 10px;
  }

  .story-text li{
    font-size:14px;
    line-height:1.75;
  }

  .story-text p{
    font-size:14px;
    line-height:1.75;
  }

  .story-text .note{
    font-size:12px;
  }

  .story-photo{
    min-height:200px;
    max-height:280px;
    border-radius:16px;
    overflow:hidden;
  }

  .story-photo img{
    transform:none;
  }

  /* ── Feature 區（安心機制、永續等）── 單欄，圖上文下 ── */
  .feature-grid{
    grid-template-columns:1fr;
    gap:16px;
  }

  .feature-grid .feature-img{
    height:180px;
    min-height:180px;
    border-radius:16px 16px 0 0;
    overflow:hidden;
  }

  .feature-grid .feature-img img{
    transform:none;
  }

  .feature-copy{
    padding:16px;
  }

  .feature-copy h3{
    font-size:17px;
    margin:6px 0 8px;
  }

  .feature-copy p{
    font-size:14px;
    line-height:1.75;
  }

  .small-note{
    font-size:12px;
  }

  /* ── 信任卡片 ── */
  .trust-grid{
    grid-template-columns:1fr !important;
    gap:10px;
  }

  .trust-card{
    padding:20px;
    min-height:auto;
  }

  .trust-step-number{
    font-size:28px;
    margin-bottom:8px;
  }

  .trust-card h3{
    font-size:20px !important;
    margin-bottom:8px;
  }

  .trust-card p{
    font-size:14px;
    line-height:1.75;
  }

  .trust-card small{
    font-size:13px;
  }

  /* ── Plans 方案頁 ── */
  .plans-hero-legacy{
    grid-template-columns:1fr !important;
  }

  .plans-legacy-lead{
    font-size:17px;
  }

  .plans-legacy-desc{
    font-size:15px;
    line-height:1.75;
  }

  .plans-legacy-image{
    min-height:auto;
    max-height:200px;
    border-radius:16px;
    overflow:hidden;
  }

  .plans-hero-crop{
    transform:none;
    width:100%;
    height:200px;
    object-fit:cover;
    object-position:center center;
    display:block;
  }

  .plans-legacy-grid{
    grid-template-columns:1fr !important;
    gap:14px;
  }

  .legacy-plan-card{
    padding:22px 18px 20px;
  }

  .legacy-plan-card h3{
    font-size:18px;
  }

  .legacy-price{
    font-size:20px;
  }

  .legacy-plan-intro{
    font-size:14px;
    line-height:1.75;
  }

  .legacy-plan-note{
    font-size:14px;
  }

  .legacy-btn-row .ghost-btn,
  .legacy-btn-row .cta-btn{
    min-width:100px;
    padding:8px 14px;
    font-size:13px;
  }

  .plan-feature-list{
    font-size:14px;
  }

  .plan-chip{
    font-size:12px;
    padding:6px 10px;
  }

  .plans-lead{
    font-size:15px;
  }

  .plans-subdesc{
    font-size:14px;
  }

  /* ── Page hero（各子頁面） ── */
  .page-hero{
    grid-template-columns:1fr !important;
    gap:16px;
  }

  .page-hero .hero-image.soft-card{
    min-height:200px;
  }

  .page-hero .hero-image.soft-card img{
    min-height:200px;
  }

  .page-hero h1{
    font-size:clamp(20px,5vw,28px) !important;
  }

  .page-hero p{
    font-size:15px;
    line-height:1.75;
  }

  /* ── FAQ ── */
  .faq-hero-image{
    min-height:200px;
    border-radius:16px;
  }

  .faq-hero-image img{
    min-height:200px;
  }

  /* ── Brand story ── */
  .brand-page-hero .hero-image{
    min-height:250px;
  }

  .brand-page-hero .hero-image img{
    min-height:250px;
  }

  .brand-story-grid{
    grid-template-columns:1fr !important;
  }

  .brand-story-copy{
    padding:20px;
  }

  .brand-story-copy h2{
    font-size:18px !important;
  }

  .brand-story-copy p{
    font-size:14px;
    line-height:1.75;
  }

  .brand-story-float-card{
    padding:18px;
    border-radius:16px;
  }

  .brand-story-float-card h2{
    font-size:20px !important;
  }

  .brand-story-float-card p{
    font-size:14px;
    line-height:1.7;
  }

  .brand-story-photo-panel{
    border-radius:16px;
    aspect-ratio:4/3;
    overflow:hidden;
  }

  .brand-story-photo-panel img{
    transform:none;
  }

  .brand-story-overlap{
    gap:14px;
  }

  /* ── Footer ── */
  .footer{
    padding:20px 0 40px;
  }

  .footer-grid{
    grid-template-columns:1fr !important;
    gap:16px;
  }

  .footer .nav-logo img{
    height:40px !important;
  }

  .footer p{
    font-size:13px;
    line-height:1.7;
  }

  .footer strong{
    font-size:14px;
  }

  .footer-grid > div:nth-child(2) p{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:4px 12px;
  }

  .footer-grid > div:nth-child(2) p br{
    display:none;
  }

  .footer small,
  .footer .legal-note{
    font-size:11px;
  }

  /* ── 浮水印 ── */
  .watermark img{
    width:min(80px,20vw);
  }

  /* ── 通用：inline-list、small-note ── */
  .inline-list li{
    font-size:14px;
    line-height:1.75;
  }

  .small-note{
    font-size:12px;
  }

  /* ── Process 服務流程頁 ── */
  .service-detail{
    grid-template-columns:1fr !important;
    gap:0;
  }

  .process-photo{
    min-height:200px;
    max-height:250px;
    overflow:hidden;
  }

  .process-photo img{
    transform:none;
  }

  .process-copy{
    padding:20px;
  }

  .process-copy h3{
    font-size:18px;
  }

  .process-copy p,
  .process-copy li{
    font-size:14px;
    line-height:1.75;
  }

  /* ── Partners 異業合作頁 ── */
  .partners-grid{
    grid-template-columns:1fr !important;
    gap:16px;
  }

  .partner-card-v2 h3{
    font-size:20px;
  }

  .partner-card-v2 p{
    font-size:14px;
    line-height:1.75;
  }

  .partner-card-body{
    padding:18px 20px 22px;
  }

  .partner-badge{
    padding:22px 20px;
  }

  .partner-badge h3{
    font-size:20px;
  }

  .partner-badge p{
    font-size:14px;
    line-height:1.75;
  }

  /* ── Plans Quiz 區 ── */
  .quiz-section{
    padding-top:40px;
    padding-bottom:40px;
  }

  .quiz-box{
    padding:20px;
  }

  .plan-summary-grid{
    grid-template-columns:1fr !important;
  }

  .plan-cta-card{
    flex-direction:column;
    align-items:flex-start;
    padding:20px;
  }

  .plan-cta-card p{
    font-size:14px;
  }

  /* ── Contact 聯繫頁 ── */
  .contact-form{
    padding:20px;
  }

  .form-row{
    grid-template-columns:1fr !important;
  }

  /* ── FAQ 頁 ── */
  .faq-page-hero{
    grid-template-columns:1fr !important;
  }

  .faq-hero-image{
    min-height:200px !important;
    border-radius:16px;
  }

  .faq-hero-image img{
    min-height:200px !important;
    transform:none;
  }
}
/* ===== Plans legacy restore ===== */
.plans-legacy-grid > article:nth-child(1),
.plans-legacy-grid > article:nth-child(3){
  background: rgba(255,255,255,.58) !important;
  border: 1px solid rgba(255,255,255,.72) !important;
}

.plans-legacy-grid > article:nth-child(2){
  background: linear-gradient(
    180deg,
    rgba(203,214,194,.70) 0%,
    rgba(197,209,188,.48) 38%,
    rgba(247,244,238,.78) 78%,
    rgba(255,255,255,.58) 100%
  ) !important;
  border: 1px solid rgba(149,162,139,.24) !important;
  box-shadow: 0 24px 56px rgba(88,71,60,.12) !important;
}

.plans-hero-legacy{
  align-items:center;
}

.plans-legacy-lead{
  font-size:22px;
  line-height:1.8;
  color:#c57d3f;
  font-weight:700;
  margin:0 0 12px;
}

.plans-legacy-desc{
  font-size:18px;
  line-height:1.95;
  color:rgba(88,71,60,.74);
  margin:0 0 18px;
}

.plans-legacy-image{
  overflow:hidden;
  border-radius:34px;
  position:relative;
  box-shadow:var(--shadow);
  background:transparent;
  display:flex;
  align-items:center;
  justify-content:center;
}

.plans-hero-crop{
  display:block;
  width:100%;
  height:auto;
  margin:0 auto;
  transform:none;
}

.plans-legacy-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}

.legacy-plan-card{
  position:relative;
  padding:32px 24px 26px;
  min-height:100%;
  display:flex;
  flex-direction:column;
}

.legacy-plan-card h3{
  font-family:'Noto Serif TC',serif;
  font-size:22px;
  line-height:1.4;
  color:var(--brown);
  margin:8px 0 10px;
  font-weight:600;
}

.legacy-plan-featured{
  box-shadow:0 24px 56px rgba(88,71,60,.12);
}

.legacy-badge{
  position:absolute;
  top:12px;
  right:12px;
  padding:6px 10px;
  border-radius:999px;
  background:rgba(212,186,140,.18);
  color:#c7a36b;
  font-size:12px;
  line-height:1;
}

.legacy-price{
  font-family:'Cormorant Garamond',serif;
  font-size:24px;
  line-height:1.2;
  color:rgba(88,71,60,.78);
  margin:4px 0 14px;
  font-weight:400;
  letter-spacing:0;
}

.legacy-plan-intro{
  font-size:17px;
  line-height:1.9;
  color:rgba(88,71,60,.72);
  margin:0 0 14px;
}

.legacy-plan-note{
  font-size:16px;
  line-height:1.85;
  color:rgba(88,71,60,.68);
  margin:18px 0 0;
}

.legacy-btn-row{
  margin-top:auto;
  padding-top:22px;
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  justify-content:center;
  align-items:center;
}

.legacy-btn-row .ghost-btn,
.legacy-btn-row .cta-btn{
  min-width:124px;
}

@media (max-width:980px){
  .plans-legacy-grid{
    grid-template-columns:1fr;
  }
}

.trust-step-number{
  display:block;
  font-family:'Cormorant Garamond',serif;
  font-size:36px;
  line-height:1;
  letter-spacing:.03em;
  color:#d2b48c;
  margin-bottom:16px;
}

.trust-card h3{
  font-size:30px;
  line-height:1.35;
  overflow-wrap:normal;
  word-break:keep-all;
}

.trust-card p,
.trust-card small{
  word-break:normal;
  overflow-wrap:break-word;
}

/* ===== Sustainability cards align fix ===== */
.feature-grid > article{
  display:flex;
  flex-direction:column;
  height:100%;
}

.feature-grid .feature-img{
  height:320px;
  min-height:320px;
  overflow:hidden;
  border-radius:26px 26px 0 0;
}

.feature-grid .feature-img img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center center;
  display:block;
}

.feature-grid .feature-copy{
  flex:1;
  display:flex;
  flex-direction:column;
}

@media (max-width:980px){
  .feature-grid .feature-img{
    height:300px;
    min-height:300px;
  }
}

@media (max-width:760px){
  .feature-grid .feature-img{
    height:240px;
    min-height:240px;
  }
}

.faq-hero-image{
  padding:0 !important;
  overflow:hidden;
  min-height:540px;
}

.faq-hero-image img{
  display:block;
  width:100%;
  height:100%;
  min-height:540px;
  object-fit:cover;
  object-position:center center;
  transform:scale(1.03);
}

@media (max-width:980px){
  .faq-hero-image{
    min-height:420px;
  }

  .faq-hero-image img{
    min-height:420px;
  }
}

@media (max-width:760px){
  .faq-hero-image{
    min-height:300px;
  }

  .faq-hero-image img{
    min-height:300px;
  }
}

/* ===== FAQ final clean version ===== */
.faq-page-hero{
  align-items:center;
}

.faq-hero-image{
  position:relative;
  min-height:620px;
  border-radius:34px;
  overflow:hidden;
  padding:0 !important;
  background:transparent !important;
  border:none !important;
  box-shadow:none !important;
  outline:none !important;
}

.faq-hero-image::before,
.faq-hero-image::after{
  content:none !important;
  display:none !important;
}

.faq-hero-image img{
  display:block;
  position:absolute;
  top:-2%;
  left:-4%;
  width:108%;
  height:108%;
  min-height:620px;
  object-fit:cover;
  object-position:center center;
  transform:none !important;
  border:none !important;
  box-shadow:none !important;
  outline:none !important;
  filter:none !important;
  backface-visibility:hidden;
}

/* FAQ 白色內容盒 */
.faq-shell{
  padding:34px;
  overflow:hidden;
}



/* ===== FAQ old style restore final ===== */
.faq-old-hero-section{
  padding-top:72px;
  padding-bottom:96px;
}

.faq-old-hero{
  grid-template-columns:1fr 620px;
  align-items:center;
  gap:64px;
}

.faq-old-copy{
  padding-left:12px;
  max-width:700px;
}

.faq-old-copy .kicker{
  margin-bottom:12px;
}

.faq-old-copy .display{
  font-family:'Noto Serif TC',serif;
  font-size:clamp(42px,5.4vw,64px);
  line-height:1.15;
  font-weight:600;
  color:var(--brown);
  margin:0 0 22px;
  max-width:620px;
}

.faq-old-desc{
  max-width:620px;
  font-family:'Noto Sans TC',sans-serif;
  font-size:18px;
  line-height:1.95;
  color:rgba(88,71,60,.72);
  margin:0;
}

.faq-old-image{
  position:relative;
  width:100%;
  min-height:700px;
  border-radius:34px;
  overflow:hidden;
  background:transparent;
  border:none;
  box-shadow:none;
  outline:none;
}

.faq-old-image::before,
.faq-old-image::after{
  content:none !important;
  display:none !important;
}

.faq-old-image img{
  position:absolute;
  top:-2%;
  left:-4%;
  width:108%;
  height:108%;
  min-height:700px;
  object-fit:cover;
  object-position:center center;
  display:block;
  border:none;
  box-shadow:none;
  outline:none;
  filter:none;
  transform:none;
}

/* FAQ list */
.faq-list-section .container{
  max-width:1140px;
}

.faq-shell{
  padding:0 36px;
  overflow:hidden;
}

.faq-grid{
  display:grid;
  gap:0;
}

.faq-item{
  padding:46px 0 40px;
  border-bottom:1px solid var(--line);
}

.faq-item:last-child{
  border-bottom:none;
}

.faq-item h3{
  font-family:'Noto Serif TC',serif;
  font-size:28px;
  line-height:1.35;
  font-weight:600;
  color:var(--brown);
  margin:0 0 18px;
}

.faq-item p{
  font-family:'Noto Sans TC',sans-serif;
  font-size:18px;
  line-height:1.95;
  color:rgba(88,71,60,.72);
  margin:0;
}

@media (max-width:980px){
  .faq-old-hero{
    grid-template-columns:1fr;
    gap:32px;
    align-items:start;
  }

  .faq-old-copy{
    padding-left:0;
    max-width:none;
  }

  .faq-old-copy .display{
    max-width:none;
    font-size:clamp(34px,6vw,52px);
  }

  .faq-old-desc{
    max-width:none;
  }

  .faq-old-image{
    min-height:480px;
  }

  .faq-old-image img{
    min-height:480px;
    top:-2%;
    left:-3%;
    width:106%;
    height:106%;
  }

  .faq-item{
    padding:34px 0 30px;
  }

  .faq-item h3{
    font-size:24px;
  }
}

@media (max-width:760px){
  .faq-old-hero-section{
    padding-top:36px;
    padding-bottom:72px;
  }

  .faq-old-image{
    min-height:340px;
    border-radius:24px;
  }

  .faq-old-image img{
    min-height:340px;
    top:-1.5%;
    left:-3%;
    width:106%;
    height:106%;
  }

  .faq-shell{
    padding:0 24px;
  }

  .faq-item{
    padding:26px 0 22px;
  }

  .faq-item h3{
    font-size:21px;
    margin-bottom:12px;
  }

  .faq-item p{
    font-size:17px;
    line-height:1.85;
  }
}

/* ===== Quiz (plans.html) ===== */
.quiz-section{padding-top:72px;padding-bottom:72px;}
.quiz-box{max-width:760px;margin:32px auto 0;padding:40px 44px;position:relative;}
.quiz-progress-wrap{display:flex;align-items:center;gap:16px;margin-bottom:24px;}
.quiz-progress{flex:1;height:6px;background:rgba(88,71,60,.1);border-radius:99px;overflow:hidden;}
.quiz-progress-bar{height:100%;width:20%;background:linear-gradient(90deg,#b89468,#95a28b);border-radius:99px;transition:width .5s ease;}
.quiz-step-counter{font-family:'Cormorant Garamond',serif;font-size:20px;color:#68755f;letter-spacing:.05em;}
.quiz-question{font-family:'Noto Serif TC',serif;font-size:24px;line-height:1.6;color:#58473c;margin:0 0 24px;}
.quiz-options{display:flex;flex-direction:column;gap:12px;}
.quiz-option{display:flex;align-items:center;gap:14px;padding:18px 22px;border:1px solid rgba(88,71,60,.14);border-radius:16px;background:rgba(255,255,255,.6);cursor:pointer;transition:all .3s ease;font-size:16px;color:rgba(88,71,60,.82);}
.quiz-option:hover{border-color:#95a28b;background:rgba(255,255,255,.95);transform:translateX(4px);}
.quiz-option input{accent-color:#68755f;width:18px;height:18px;cursor:pointer;flex-shrink:0;}
.quiz-option input:checked + span{color:#58473c;font-weight:500;}
.quiz-option:has(input:checked){border-color:#68755f;background:rgba(149,162,139,.12);}
.quiz-nav{display:flex;justify-content:space-between;gap:12px;margin-top:32px;}
.quiz-nav button:disabled{opacity:.35;cursor:not-allowed;}
.quiz-result{text-align:center;padding:20px 0;}
.quiz-result-icon{font-size:64px;margin-bottom:12px;}
.quiz-result-plan{font-family:'Noto Serif TC',serif;font-size:36px;color:#58473c;margin:8px 0 6px;}
.quiz-result-price{font-family:'Cormorant Garamond',serif;font-size:22px;color:#b89468;letter-spacing:.04em;margin-bottom:16px;}
.quiz-result-desc{font-size:17px;line-height:1.9;color:rgba(88,71,60,.78);max-width:520px;margin:0 auto 8px;}

@media (max-width:720px){
  .quiz-box{padding:28px 22px;}
  .quiz-question{font-size:20px;}
  .quiz-option{padding:14px 16px;font-size:15px;}
  .quiz-result-plan{font-size:28px;}
}

/* ===== Contact form ===== */
.contact-hero{grid-template-columns:1.2fr 1fr;gap:48px;align-items:center;}
.contact-hero-image{border-radius:28px;overflow:hidden;box-shadow:var(--shadow);}
.contact-hero-image img{width:100%;height:100%;object-fit:cover;display:block;}
.contact-form-wrap{max-width:820px;margin:0 auto;}
.contact-form{padding:44px 48px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px;}
.form-group{display:flex;flex-direction:column;gap:8px;margin-bottom:20px;}
.form-row .form-group{margin-bottom:0;}
.form-group label{font-family:'Noto Serif TC',serif;font-size:15px;color:#58473c;font-weight:500;}
.form-group .req{color:#b85450;font-weight:700;margin-left:2px;}
.form-group .optional{color:rgba(88,71,60,.5);font-size:13px;font-weight:400;margin-left:4px;}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:14px 18px;border:1px solid rgba(88,71,60,.16);border-radius:12px;background:rgba(255,255,255,.7);font-family:'Noto Sans TC',sans-serif;font-size:15px;color:#58473c;transition:all .3s ease;font-family:inherit;}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#68755f;background:rgba(255,255,255,.95);box-shadow:0 0 0 3px rgba(149,162,139,.15);}
.form-group textarea{resize:vertical;min-height:120px;line-height:1.7;font-family:'Noto Sans TC',sans-serif;}
.form-actions{margin-top:28px;display:flex;flex-direction:column;align-items:center;gap:14px;}
.form-actions .cta-btn{min-width:200px;justify-content:center;}
.form-note{font-size:13px;color:rgba(88,71,60,.55);text-align:center;line-height:1.7;max-width:440px;margin:0;}
.botcheck{display:none !important;}
.contact-success{text-align:center;padding:60px 40px;max-width:620px;margin:0 auto;}
.contact-success-icon{font-size:72px;margin-bottom:16px;}
.contact-success h2{font-family:'Noto Serif TC',serif;font-size:30px;color:#58473c;margin:0 0 12px;line-height:1.5;}
.contact-success p{font-size:18px;color:rgba(88,71,60,.78);margin:0;}

@media (max-width:720px){
  .contact-hero{grid-template-columns:1fr;}
  .contact-form{padding:28px 22px;}
  .form-row{grid-template-columns:1fr;gap:0;}
  .form-row .form-group{margin-bottom:20px;}
}

/* ===== Partners page ===== */
.partners-hero{grid-template-columns:1fr 1fr;gap:48px;align-items:center;}
.partners-hero-image{border-radius:28px;overflow:hidden;box-shadow:var(--shadow);}
.partners-hero-image img{width:100%;height:auto;display:block;transform:none;}

/* 置中標題（kicker + 標題 + 描述） */
.center-head{text-align:center;}
.center-head .kicker{display:block;}
.center-head .section-desc{margin-left:auto;margin-right:auto;}
.partner-card{display:flex;flex-direction:column;gap:14px;padding:32px 28px;}
.partner-card-header{margin-bottom:4px;}
.partner-icon{font-size:42px;margin-bottom:8px;}
.partner-card h3{font-family:'Noto Serif TC',serif;font-size:26px;color:#58473c;margin:6px 0 12px;}
.partner-card p{font-size:15.5px;line-height:1.9;color:rgba(88,71,60,.78);margin:0 0 8px;}
.partner-card .inline-list{padding:0;list-style:none;margin:8px 0 0;}
.partner-card .inline-list li{font-size:14.5px;line-height:1.9;color:rgba(88,71,60,.75);padding:6px 0;border-top:1px solid rgba(88,71,60,.08);}
.partner-card .inline-list li:first-child{border-top:0;padding-top:0;}

@media (max-width:720px){
  .partners-hero{grid-template-columns:1fr;}
}

/* ===== Partners page (v2 — no hero image, centered) ===== */
.partners-hero-section{padding:120px 0 80px;}
.partners-hero-center{text-align:center;max-width:820px;margin:0 auto;}
.partners-hero-lead{font-family:'Cormorant Garamond',serif;font-size:24px;letter-spacing:.08em;color:#b89468;margin:18px 0 14px;}
.partners-hero-desc{font-size:17px;line-height:2;color:rgba(88,71,60,.78);margin:0 auto 32px;max-width:680px;}

.partners-badges{grid-template-columns:repeat(3,1fr) !important;gap:24px;margin-top:32px;align-items:stretch;}
.partner-badge{display:flex;flex-direction:column;padding:36px 30px;text-align:left;}
.partner-badge .partner-icon{font-size:44px;margin-bottom:12px;line-height:1;}
.partner-badge .kicker{margin-bottom:6px;}
.partner-badge h3{font-family:'Noto Serif TC',serif;font-size:26px;color:#58473c;margin:0 0 14px;}
.partner-badge p{font-size:15px;line-height:1.9;color:rgba(88,71,60,.78);margin:0 0 18px;flex:1;}
.partner-tags{display:flex;flex-wrap:wrap;gap:8px;margin:auto 0 0;}
.partner-tags span{display:inline-flex;align-items:center;padding:6px 14px;border-radius:99px;background:rgba(149,162,139,.15);color:#68755f;font-size:13px;letter-spacing:.03em;font-weight:500;}

.partners-levels{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:40px;align-items:stretch;}
.level-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:44px 32px;position:relative;}
.level-card .level-number{font-family:'Cormorant Garamond',serif;font-size:52px;color:#b89468;letter-spacing:.04em;line-height:1;margin-bottom:12px;}
.level-card .level-title{font-family:'Noto Serif TC',serif;font-size:28px;color:#58473c;margin:0 0 16px;}
.level-card .level-desc{font-size:15px;line-height:1.9;color:rgba(88,71,60,.78);margin:0 0 24px;max-width:240px;}
.level-card .level-reward{padding:12px 20px;border-top:1px solid rgba(88,71,60,.1);width:100%;font-size:14px;color:rgba(88,71,60,.65);letter-spacing:.04em;margin-top:auto;}
.level-card .level-reward strong{color:#68755f;font-size:16px;}
.level-card.level-featured{background:rgba(149,162,139,.12);border:1px solid rgba(149,162,139,.28);transform:scale(1.03);}
.level-card.level-featured .level-number{color:#68755f;}

.partners-cta-section{text-align:center;max-width:720px;margin:0 auto;padding:60px 0;}
.partners-cta-text{font-size:17px;line-height:2;color:rgba(88,71,60,.78);margin:24px auto 20px;}

@media (max-width:900px){
  .partners-badges{grid-template-columns:1fr !important;}
  .partners-levels{grid-template-columns:1fr;}
  .level-card.level-featured{transform:none;}
  .partners-hero-section{padding:80px 0 60px;}
}


/* ===== Quiz section center ===== */
.quiz-section .section-title,
.quiz-section .section-desc{text-align:center;}
.quiz-section .kicker{text-align:center;display:block;}

/* ===== FAQ image rounded corners ===== */
.faq-old-image{border-radius:28px;overflow:hidden;box-shadow:var(--shadow);}
.faq-old-image img{border-radius:28px;display:block;width:100%;height:auto;}

/* ===== Anchor scroll offset ===== */
#kiboQuiz,.quiz-section{scroll-margin-top:110px;}

/* ===== FAQ image override (fix bleeding) ===== */
.faq-old-image{
  border-radius:28px !important;
  overflow:hidden !important;
  position:relative !important;
  box-shadow:var(--shadow) !important;
  transform:translateZ(0);
  -webkit-mask-image:-webkit-radial-gradient(white,black);
}
.faq-old-image img{
  position:absolute !important;
  top:0 !important;
  left:0 !important;
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
  object-position:center center !important;
  border-radius:28px !important;
  display:block !important;
}

/* ===== Quiz kicker + all headers force center ===== */
.quiz-section{text-align:center;}
.quiz-section .kicker,
.quiz-section .section-title,
.quiz-section .section-desc{text-align:center !important;display:block;margin-left:auto;margin-right:auto;}
.quiz-section .quiz-box{text-align:left;}
.quiz-section .quiz-question{text-align:left;}

/* ===== Partners with images (v3) ===== */
.partners-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:40px;align-items:stretch;}
.partner-card-v2{display:flex;flex-direction:column;padding:0;overflow:hidden;}
.partner-img-wrap{width:100%;aspect-ratio:3/2;overflow:hidden;background:rgba(88,71,60,.08);border-bottom:1px solid rgba(88,71,60,.08);}
.partner-img-wrap img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s ease;}
.partner-card-v2:hover .partner-img-wrap img{transform:scale(1.04);}
.partner-card-body{padding:28px 30px 32px;display:flex;flex-direction:column;flex:1;}
.partner-card-v2 .partner-icon{font-size:36px;margin-bottom:8px;line-height:1;}
.partner-card-v2 .kicker{margin-bottom:6px;}
.partner-card-v2 h3{font-family:'Noto Serif TC',serif;font-size:26px;color:#58473c;margin:4px 0 14px;}
.partner-card-v2 p{font-size:15px;line-height:1.9;color:rgba(88,71,60,.78);margin:0 0 18px;flex:1;}
.partner-card-v2 .partner-tags{display:flex;flex-wrap:wrap;gap:8px;margin:auto 0 0;}

@media (max-width:900px){
  .partners-grid{grid-template-columns:1fr;}
}

/* ===== Partners grid image size fix (v4) ===== */
.partners-grid .partner-img-wrap{
  width:100% !important;
  height:220px !important;
  aspect-ratio:auto !important;
  overflow:hidden !important;
  display:block !important;
}
.partners-grid .partner-img-wrap img{
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
  object-position:center center !important;
  display:block !important;
}

/* ===== Partners grid equal height force (v5) ===== */
.partners-grid{align-items:stretch !important;}
.partners-grid .partner-card-v2{height:100% !important;min-height:100% !important;}
.partners-grid > .partner-card-v2{align-self:stretch !important;}
