:root{
  --xx-black:#050505;
  --xx-card:#111;
  --xx-gold:#d4af37;
  --xx-gold2:#f7d77a;
  --xx-text:#fff8e6;
  --xx-muted:#c9b98f;
}
body{
  font-family:"Noto Sans TC","Microsoft JhengHei",sans-serif;
  background:radial-gradient(circle at top,#2a210f,#050505 58%);
  color:var(--xx-text);
}
.s2o-hero,.xx-s2o-hero{
  padding:96px 18px 72px;
  background:linear-gradient(135deg,#050505,#17110a 55%,#2b210f);
  color:#fff;
  text-align:center;
}
.s2o-hero h1,.xx-s2o-hero h1{
  font-size:clamp(34px,6vw,72px);
  letter-spacing:.06em;
  color:var(--xx-gold2);
}
.s2o-card,.s2o-day-card,.xx-card{
  background:rgba(17,17,17,.88);
  border:1px solid rgba(212,175,55,.35);
  border-radius:24px;
  padding:24px;
  box-shadow:0 18px 48px rgba(0,0,0,.38);
}
.s2o-timeline{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
  max-width:1180px;
  margin:40px auto;
  padding:0 18px;
}
.s2o-timeline h3{color:var(--xx-gold2)}
.s2o-fixed-cta{
  position:fixed;
  left:12px;
  right:12px;
  bottom:14px;
  z-index:9999;
  display:flex;
  gap:10px;
  justify-content:center;
}
.s2o-fixed-cta a{
  background:linear-gradient(135deg,var(--xx-gold2),var(--xx-gold));
  color:#111;
  padding:13px 18px;
  border-radius:999px;
  font-weight:900;
  text-decoration:none;
  box-shadow:0 10px 28px rgba(0,0,0,.35);
}
.s2o-lightbox-img{cursor:zoom-in}
#s2oLightbox{
  position:fixed;
  inset:0;
  z-index:10000;
  background:rgba(0,0,0,.9);
  display:none;
  align-items:center;
  justify-content:center;
  padding:24px;
}
#s2oLightbox img{
  max-width:96vw;
  max-height:88vh;
  border-radius:18px;
}
@media(max-width:768px){
  .s2o-timeline{grid-template-columns:1fr}
  .s2o-fixed-cta a{flex:1;text-align:center;font-size:14px}
}
