/* =========================================
   楠梓靈霄寶殿 – style.css
   台灣傳統宮廟文化 · 祝聖大典邀帖風格
   ========================================= */

@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+TC:wght@400;500;600;700;900&family=Noto+Sans+TC:wght@300;400;500;700&display=swap');

/* ── Variables ─────────────────────────── */
:root {
  /* Temple Red */
  --crimson:        #8B0000;
  --crimson-deep:   #5A0000;
  --crimson-rich:   #A31515;
  --crimson-light:  #C42020;

  /* Antique Gold */
  --gold-dark:      #6B4F0A;
  --gold:           #8B6914;
  --gold-warm:      #B8860B;
  --gold-mid:       #C9A44C;
  --gold-light:     #DDB96F;
  --gold-shine:     #F0D070;

  /* Parchment / Xuan Paper */
  --paper:          #F5ECD7;
  --paper-warm:     #EED9B3;
  --paper-cream:    #FAF3E3;
  --paper-deep:     #E8D5A0;

  /* Wood / Dark */
  --wood-darkest:   #180800;
  --wood-deep:      #250D00;
  --wood-dark:      #3A1500;
  --wood-med:       #5C2800;

  /* Text */
  --ink:            #1A0A00;
  --ink-mid:        #3D1800;
  --ink-warm:       #6B3A12;
  --ink-muted:      #8B6035;

  /* Borders */
  --bd-gold:        rgba(185,135,20,.28);
  --bd-gold-mid:    rgba(185,135,20,.48);
  --bd-gold-strong: rgba(185,135,20,.72);
  --bd-red:         rgba(139,0,0,.18);
  --bd-red-strong:  rgba(139,0,0,.42);

  /* Shadows */
  --sh-warm:  0 4px 24px rgba(80,20,0,.10);
  --sh-deep:  0 8px 40px rgba(60,15,0,.18);
  --sh-gold:  0 3px 16px rgba(140,100,10,.22);

  /* Typography */
  --font-serif: 'Noto Serif TC','KaiTi','標楷體',serif;
  --font-sans:  'Noto Sans TC','Microsoft JhengHei',sans-serif;

  --nav-h:    72px;
  --container:1200px;
  --radius:   4px;
  --radius-sm:2px;
  --ease:     all .35s ease;

  /* Backward-compatible aliases */
  --crimson-dark:  var(--crimson-deep);
  --gold-bright:   var(--gold-mid);
  --gold-text:     var(--gold-dark);
  --tx-dark:       var(--ink);
  --tx-mid:        var(--ink-mid);
  --tx-muted:      var(--ink-muted);
  --tx-light:      #B89060;
  --bg-page:       var(--paper-cream);
  --bg-alt:        var(--paper);
  --bg-alt2:       var(--paper-cream);
  --bg-card:       var(--paper-cream);
  --bg-card-warm:  var(--paper-cream);
  --bg-deep:       var(--wood-dark);
  --sh-sm:         var(--sh-warm);
  --sh-md:         var(--sh-warm);
  --sh-lg:         var(--sh-deep);
}

/* ── Reset ─────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0 }
html { scroll-behavior:smooth; font-size:16px }
body {
  font-family: var(--font-sans);
  background-color: var(--paper-cream);
  color: var(--ink);
  line-height: 1.8;
  overflow-x: hidden;
}
img  { max-width:100%; height:auto; display:block }
a    { color:inherit; text-decoration:none }
ul,ol{ list-style:none }
h1,h2,h3,h4,h5,h6 { font-family:var(--font-serif); font-weight:700; line-height:1.3; color:var(--crimson-deep) }
p    { margin-bottom:1em; color:var(--ink-mid) }
::selection { background:rgba(139,0,0,.18); color:var(--crimson-deep) }
::-webkit-scrollbar       { width:6px }
::-webkit-scrollbar-track { background:var(--wood-deep) }
::-webkit-scrollbar-thumb { background:var(--gold-mid); border-radius:3px }

/* ── Layout ────────────────────────────── */
.container   { max-width:var(--container); margin:0 auto; padding:0 1.5rem }
.section     { padding:clamp(3.5rem,8vw,6rem) 0; position:relative }
.section-alt { background:linear-gradient(180deg,var(--paper) 0%,var(--paper-warm) 100%) }
.section-alt2{ background:linear-gradient(180deg,var(--paper-cream) 0%,var(--paper) 100%) }

/* ── Section Heading ───────────────────── */
.sec-head { text-align:center; margin-bottom:3.5rem }
.sec-icon {
  display:inline-flex; align-items:center; justify-content:center;
  width:62px; height:62px; border-radius:50%;
  background:linear-gradient(145deg,var(--crimson-rich),var(--crimson-deep));
  border:2px solid var(--gold-mid);
  color:var(--gold-light); font-size:1.4rem;
  margin-bottom:1rem;
  box-shadow: 0 4px 20px rgba(139,0,0,.28), inset 0 1px 0 rgba(255,255,255,.08);
}
.sec-head h2 {
  font-size:clamp(1.7rem,3.5vw,2.4rem);
  color:var(--crimson-deep);
  letter-spacing:.24em;
  display:inline-block;
  position:relative;
}
.sec-head h2::after {
  content:'';
  display:block;
  height:2px;
  background:linear-gradient(90deg,transparent,var(--gold-warm),transparent);
  margin-top:.4rem;
}
.sec-ornament {
  display:flex; align-items:center; justify-content:center;
  gap:1rem; margin:.8rem auto; max-width:320px;
}
.sec-ornament::before,
.sec-ornament::after {
  content:''; flex:1; height:1px;
  background:linear-gradient(90deg,transparent,var(--gold-warm));
}
.sec-ornament::after { background:linear-gradient(270deg,transparent,var(--gold-warm)) }
.sec-ornament i { color:var(--gold-mid); font-size:1rem }
.sec-sub { font-size:.88rem; color:var(--ink-muted); letter-spacing:.12em; margin-top:.5rem }

/* ── Navbar ────────────────────────────── */
.navbar {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  height:var(--nav-h);
  background:linear-gradient(180deg,var(--wood-deep) 0%,var(--wood-dark) 100%);
  border-bottom:2px solid var(--gold-warm);
  box-shadow: 0 2px 20px rgba(0,0,0,.4), inset 0 -1px 0 rgba(201,164,76,.25);
  transition:var(--ease);
  display:flex; align-items:center;
}
.navbar.scrolled {
  background:linear-gradient(180deg,rgba(37,13,0,.98) 0%,rgba(58,21,0,.98) 100%);
  box-shadow: 0 4px 30px rgba(0,0,0,.5);
}
.nav-inner {
  max-width:var(--container); margin:0 auto; padding:0 1.5rem;
  width:100%; display:flex; align-items:center; justify-content:space-between;
}
.nav-brand { display:flex; align-items:center; gap:.85rem; flex-shrink:0 }
.nav-brand-text {
  font-family:var(--font-serif);
  font-size:1.05rem; font-weight:700;
  color:var(--gold-light); letter-spacing:.12em; line-height:1.2;
  text-shadow: 0 1px 6px rgba(0,0,0,.4);
}
.nav-brand-sub { display:block; font-size:.58rem; color:rgba(221,185,111,.6); letter-spacing:.14em; font-weight:400 }
.nav-menu { display:flex; align-items:center; gap:.05rem }
.nav-link {
  font-family:var(--font-serif);
  font-size:.84rem; color:rgba(221,185,111,.78);
  padding:.5rem .8rem; letter-spacing:.07em;
  transition:var(--ease); position:relative; white-space:nowrap;
}
.nav-link::after {
  content:''; position:absolute;
  bottom:3px; left:50%; transform:translateX(-50%);
  width:0; height:1.5px;
  background:var(--gold-light); border-radius:1px; transition:var(--ease);
}
.nav-link:hover,.nav-link.active { color:var(--gold-shine); text-shadow:0 0 12px rgba(240,208,112,.35) }
.nav-link:hover::after,.nav-link.active::after { width:80% }
.nav-toggle {
  display:none; flex-direction:column; gap:5px;
  background:none; border:none; cursor:pointer; padding:.5rem;
}
.nav-toggle span {
  display:block; width:24px; height:2px;
  background:var(--gold-light); transition:var(--ease); transform-origin:center;
}
.nav-toggle.open span:nth-child(1) { transform:rotate(45deg) translate(5px,5px) }
.nav-toggle.open span:nth-child(2) { opacity:0 }
.nav-toggle.open span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px) }

/* ── Hero ──────────────────────────────── */
#home {
  position:relative; min-height:100vh;
  display:flex; align-items:center; justify-content:center;
  padding-top:var(--nav-h); overflow:hidden;
  background:var(--wood-darkest);
}
.hero-bg {
  position:absolute; inset:0;
  background-image: url('../img/main.jpg');
  background-size:cover;
  background-position:center 15%;
}
.hero-bg::before {
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(ellipse at 50% 90%, rgba(180,80,0,.22) 0%,transparent 55%),
    radial-gradient(ellipse at 50% 0%,  rgba(0,0,0,.55)    0%,transparent 60%),
    linear-gradient(180deg,
      rgba(24,8,0,.80) 0%,
      rgba(40,12,0,.72) 45%,
      rgba(24,8,0,.84) 100%);
  animation: candleFlicker 6s ease-in-out infinite;
}
.hero-bg::after {
  content:''; position:absolute;
  bottom:-5%; left:50%; transform:translateX(-50%);
  width:80%; height:60%;
  background:radial-gradient(ellipse at 50% 80%,
    rgba(255,148,40,.1) 0%,
    rgba(255,90,0,.05)  45%,
    transparent         70%);
  pointer-events:none;
}
@keyframes candleFlicker {
  0%,100% { opacity:.88 }
  20%     { opacity:.82 }
  50%     { opacity:.92 }
  75%     { opacity:.84 }
}
.hero-particles { position:absolute; inset:0; pointer-events:none; overflow:hidden }
.smoke-particle {
  position:absolute; border-radius:50%;
  background:radial-gradient(ellipse,rgba(255,200,100,.28),rgba(255,150,60,.08) 55%,transparent 75%);
  filter:blur(5px);
  animation:smokeRise var(--dur,12s) var(--del,0s) infinite ease-in-out;
  pointer-events:none;
}
@keyframes smokeRise {
  0%   { opacity:0; transform:translateY(0)     translateX(0)               scale(.7) }
  10%  { opacity:.45 }
  40%  { opacity:.22; transform:translateY(-35vh) translateX(var(--sway,20px))  scale(1.6) }
  75%  { opacity:.08; transform:translateY(-70vh) translateX(var(--sway2,45px)) scale(2.4) }
  100% { opacity:0;  transform:translateY(-105vh) translateX(var(--sway2,45px)) scale(3.2) }
}
.hero-content {
  position:relative; z-index:2;
  text-align:center; padding:3rem 1.5rem; max-width:900px;
}
.hero-content::before {
  content:''; position:absolute; inset:0;
  border:1px solid rgba(201,164,76,.3);
  pointer-events:none; border-radius:2px;
}
.hero-content::after {
  content:''; position:absolute; inset:14px;
  border:1px solid rgba(201,164,76,.15);
  pointer-events:none; border-radius:1px;
}
.hero-ornament {
  display:flex; align-items:center; justify-content:center;
  gap:1rem; margin-bottom:1.5rem;
  color:var(--gold-mid); font-size:.85rem; letter-spacing:.4em; opacity:.75;
}
.hero-ornament::before,
.hero-ornament::after {
  content:''; flex:1; max-width:55px; height:1px;
  background:linear-gradient(90deg,transparent,var(--gold-mid));
}
.hero-ornament::after { background:linear-gradient(270deg,transparent,var(--gold-mid)) }
.hero-title {
  font-family:var(--font-serif); font-weight:900;
  font-size:clamp(3rem,10vw,6.5rem);
  color:var(--gold-light); letter-spacing:.25em; line-height:1.05;
  text-shadow:
    0 0 30px rgba(240,208,112,.55),
    0 0 70px rgba(200,100,0,.3),
    2px 4px 0 rgba(80,0,0,.9),
    4px 8px 24px rgba(0,0,0,.5);
  margin-bottom:.6rem;
  animation:titleGlow 4.5s ease-in-out infinite alternate;
}
@keyframes titleGlow {
  from { text-shadow: 0 0 20px rgba(240,208,112,.4),  0 0 45px rgba(200,100,0,.2),  2px 4px 0 rgba(80,0,0,.9), 4px 8px 24px rgba(0,0,0,.5) }
  to   { text-shadow: 0 0 45px rgba(240,208,112,.75), 0 0 90px rgba(200,100,0,.45), 2px 4px 0 rgba(80,0,0,.9), 4px 8px 24px rgba(0,0,0,.5) }
}
.hero-subtitle {
  font-family:var(--font-serif);
  font-size:clamp(.82rem,2vw,1rem);
  color:rgba(221,185,111,.6); letter-spacing:.4em; margin-bottom:1.5rem;
}
.hero-badge {
  display:inline-flex; align-items:center; gap:.6rem;
  background:linear-gradient(145deg,var(--crimson-deep),var(--crimson));
  border:1px solid var(--gold-mid); border-radius:var(--radius-sm);
  padding:.6rem 2rem; margin-bottom:2rem;
  font-family:var(--font-serif); font-size:clamp(.82rem,1.8vw,.97rem);
  color:var(--gold-light); letter-spacing:.16em;
  box-shadow: 0 4px 20px rgba(139,0,0,.3), inset 0 1px 0 rgba(255,255,255,.07);
}
.hero-desc {
  font-size:clamp(.9rem,1.8vw,1rem);
  color:rgba(238,217,179,.78); line-height:2.1;
  max-width:560px; margin:0 auto 2.2rem; letter-spacing:.06em;
}
.hero-btns { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap }
.hero-scroll {
  position:absolute; bottom:2rem; left:50%; transform:translateX(-50%);
  z-index:3; display:flex; flex-direction:column; align-items:center; gap:.4rem;
  color:rgba(221,185,111,.45); font-family:var(--font-serif);
  font-size:.68rem; letter-spacing:.2em;
  animation:scrollBounce 2.8s infinite;
}
@keyframes scrollBounce {
  0%,100% { transform:translateX(-50%) translateY(0) }
  50%     { transform:translateX(-50%) translateY(10px) }
}

/* ── Buttons ───────────────────────────── */
.btn {
  display:inline-flex; align-items:center; gap:.55rem;
  padding:.75rem 1.9rem; border-radius:var(--radius-sm);
  font-family:var(--font-serif); font-size:.9rem; letter-spacing:.12em;
  cursor:pointer; transition:var(--ease); border:none;
  position:relative; overflow:hidden;
}
.btn::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.07),transparent 60%);
  pointer-events:none;
}
.btn-primary {
  background:linear-gradient(145deg,var(--crimson-rich),var(--crimson-deep));
  color:var(--gold-light);
  border:1.5px solid var(--gold-warm);
  box-shadow: 0 4px 16px rgba(139,0,0,.28), inset 0 1px 0 rgba(255,255,255,.06);
}
.btn-primary:hover {
  background:linear-gradient(145deg,var(--crimson-light),var(--crimson-rich));
  box-shadow: 0 6px 28px rgba(139,0,0,.42), 0 0 16px rgba(201,164,76,.18);
  transform:translateY(-2px);
}
.btn-outline {
  background:linear-gradient(145deg,var(--paper-cream),var(--paper));
  color:var(--crimson-deep);
  border:1.5px solid var(--crimson);
  box-shadow: var(--sh-warm);
}
.btn-outline:hover {
  background:linear-gradient(145deg,var(--crimson-rich),var(--crimson-deep));
  color:var(--gold-light); border-color:var(--gold-warm);
  transform:translateY(-2px); box-shadow:var(--sh-deep);
}
.btn-gold {
  background:linear-gradient(145deg,var(--gold-mid),var(--gold-warm));
  color:var(--wood-dark); border:1.5px solid var(--gold-dark);
  box-shadow: var(--sh-gold);
}
.btn-gold:hover { background:linear-gradient(145deg,var(--gold-light),var(--gold-mid)); transform:translateY(-2px) }
.btn-sm { padding:.45rem 1.1rem; font-size:.8rem }
.btn i  { font-size:.85em }

/* ── Quick Nav ─────────────────────────── */
.quick-nav-wrap {
  background:linear-gradient(180deg,var(--paper-warm) 0%,var(--paper) 100%);
  padding:2rem 0;
  border-top:2px solid var(--gold-warm);
  border-bottom:2px solid var(--gold-warm);
  position:relative;
}
.quick-nav-wrap::before,
.quick-nav-wrap::after {
  content:''; position:absolute;
  left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,rgba(139,0,0,.15),transparent);
}
.quick-nav-wrap::before { top:4px }
.quick-nav-wrap::after  { bottom:4px }
.quick-nav {
  display:grid; grid-template-columns:repeat(6,1fr); gap:.85rem;
}
.qn-item {
  background:linear-gradient(160deg,var(--paper-cream),var(--paper));
  border:1px solid var(--bd-gold-mid); border-radius:var(--radius-sm);
  padding:1.35rem .5rem; text-align:center;
  display:flex; flex-direction:column; align-items:center; gap:.5rem;
  transition:var(--ease); box-shadow:var(--sh-warm);
  position:relative; overflow:hidden;
}
.qn-item::before {
  content:''; position:absolute;
  top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--crimson-deep),var(--crimson));
  transform:scaleX(0); transition:var(--ease);
}
.qn-item:hover::before { transform:scaleX(1) }
.qn-item:hover {
  background:linear-gradient(145deg,var(--crimson-deep),var(--crimson-rich));
  border-color:var(--gold-warm); transform:translateY(-4px);
  box-shadow:var(--sh-deep);
}
.qn-item i { font-size:1.55rem; color:var(--crimson); transition:var(--ease) }
.qn-item:hover i { color:var(--gold-light) }
.qn-label {
  font-family:var(--font-serif); font-size:.82rem;
  color:var(--ink-mid); letter-spacing:.07em; transition:var(--ease);
}
.qn-item:hover .qn-label { color:var(--gold-light) }

/* ── About ─────────────────────────────── */
.about-grid { display:grid; grid-template-columns:1fr 1.6fr; gap:2.5rem; align-items:start }
.about-emblem {
  background-image: url('../img/main.jpg');
  background-size:cover; background-position:center top;
  border-radius:var(--radius); padding:2.5rem; text-align:center;
  box-shadow:var(--sh-deep); position:relative; overflow:hidden;
}
.about-emblem::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(175deg,rgba(80,0,0,.82) 0%,rgba(35,8,0,.9) 60%,rgba(24,5,0,.94) 100%);
}
.about-emblem::after {
  content:''; position:absolute; inset:14px;
  border:1px solid rgba(201,164,76,.32); pointer-events:none;
}
.about-emblem > * { position:relative; z-index:1 }
.emblem-icon { font-size:4rem; color:var(--gold-light); display:block; margin-bottom:1rem; filter:drop-shadow(0 2px 12px rgba(201,164,76,.38)) }
.emblem-name { font-family:var(--font-serif); font-size:1.4rem; color:var(--gold-light); letter-spacing:.2em; margin-bottom:.4rem; text-shadow:0 2px 10px rgba(0,0,0,.4) }
.emblem-sub  { font-size:.8rem; color:rgba(238,217,179,.72); letter-spacing:.12em; line-height:2 }

.about-text-wrap {
  background:linear-gradient(160deg,var(--paper-cream),var(--paper));
  border:1px solid var(--bd-gold-mid); border-radius:var(--radius);
  padding:2rem 2.5rem; box-shadow:var(--sh-warm); position:relative;
}
.about-text-wrap::before {
  content:''; position:absolute;
  top:0; left:0; right:0; height:4px;
  background:linear-gradient(90deg,var(--crimson-deep),var(--crimson-light),var(--crimson-deep));
}
.about-text-wrap::after {
  content:''; position:absolute;
  top:4px; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,var(--bd-gold-mid),transparent);
}

/* ── Deities ───────────────────────────── */
.main-deity {
  background:linear-gradient(160deg,var(--paper-cream),var(--paper));
  border:1.5px solid var(--bd-gold-strong); border-radius:var(--radius);
  overflow:hidden; margin-bottom:2.5rem; box-shadow:var(--sh-deep);
  position:relative;
}
.main-deity::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--crimson-deep),var(--crimson-light),var(--crimson-deep));
}
.md-top {
  background:linear-gradient(145deg,var(--crimson-deep) 0%,var(--crimson) 65%,var(--crimson-deep) 100%);
  padding:2rem 2.5rem; display:flex; align-items:center; gap:2rem;
  border-bottom:2px solid var(--bd-gold-strong); position:relative; overflow:hidden;
}
.md-top::before {
  content:''; position:absolute; inset:0;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60'%3E%3Crect x='5' y='5' width='50' height='50' fill='none' stroke='rgba(201,164,76,0.07)' stroke-width='1'/%3E%3Crect x='15' y='15' width='30' height='30' fill='none' stroke='rgba(201,164,76,0.04)' stroke-width='1'/%3E%3C/svg%3E") repeat;
  pointer-events:none;
}
.md-top > * { position:relative; z-index:1 }
.md-name  { font-family:var(--font-serif); font-size:1.55rem; color:var(--gold-light); letter-spacing:.15em; margin-bottom:.3rem; text-shadow:0 2px 10px rgba(0,0,0,.3) }
.md-alias { font-size:.85rem; color:rgba(238,217,179,.68); letter-spacing:.1em }
.md-body  { padding:1.75rem 2.5rem; display:grid; grid-template-columns:repeat(3,1fr) 2fr; gap:1.25rem; align-items:start }
.md-stat  { background:linear-gradient(160deg,var(--paper-warm),var(--paper-deep)); border:1px solid var(--bd-gold-mid); border-radius:var(--radius-sm); padding:.85rem 1rem; text-align:center }
.md-stat-l{ font-family:var(--font-serif); font-size:.7rem; color:var(--gold-dark); letter-spacing:.1em; margin-bottom:.3rem; display:flex; align-items:center; justify-content:center; gap:.4rem }
.md-stat-v{ font-family:var(--font-serif); font-size:.95rem; color:var(--crimson-deep) }
.md-desc  { font-size:.88rem; color:var(--ink-mid); line-height:2; margin:0 }

.deity-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(175px,1fr)); gap:1.1rem }
.deity-card {
  background:linear-gradient(160deg,var(--paper-cream),var(--paper));
  border:1px solid var(--bd-gold-mid); border-radius:var(--radius);
  overflow:hidden; transition:var(--ease); cursor:pointer; box-shadow:var(--sh-warm);
}
.deity-card:hover { border-color:var(--crimson); transform:translateY(-5px); box-shadow:var(--sh-deep) }
.deity-icon-wrap {
  height:90px;
  background:linear-gradient(160deg,var(--crimson-deep) 0%,var(--crimson) 65%,var(--crimson-rich) 100%);
  display:flex; align-items:center; justify-content:center;
  border-bottom:1px solid var(--bd-gold-strong); position:relative; overflow:hidden;
}
.deity-icon-wrap::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse at 50% 50%,rgba(255,220,150,.14),transparent 70%);
}
.deity-icon-wrap::after {
  content:''; position:absolute; z-index:0;
  width:64px; height:64px; border-radius:50%;
  border:1.5px solid rgba(201,164,76,.38); pointer-events:none;
}
.deity-char {
  font-family:var(--font-serif); font-size:2.4rem; font-weight:900;
  color:var(--gold-light); position:relative; z-index:1;
  text-shadow:0 0 20px rgba(201,164,76,.65), 0 2px 0 rgba(80,0,0,.8);
  line-height:1; display:block;
}
.deity-body   { padding:1rem }
.deity-name   { font-family:var(--font-serif); font-size:.92rem; color:var(--crimson-deep); letter-spacing:.08em; margin-bottom:.2rem }
.deity-role   { font-size:.72rem; color:var(--ink-muted); letter-spacing:.05em; margin-bottom:.4rem; line-height:1.5 }
.deity-bday   { font-size:.72rem; color:var(--gold-dark); display:flex; align-items:center; gap:.35rem }
.deity-extra  { display:none; padding:.85rem 1rem; border-top:1px solid var(--bd-gold-mid); background:linear-gradient(160deg,var(--paper-warm),var(--paper-deep)); font-size:.8rem; color:var(--ink-mid); line-height:1.8 }
.deity-card.open .deity-extra { display:block }

/* ── Services ──────────────────────────── */
.svc-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(230px,1fr)); gap:1.5rem }
.svc-card {
  background:linear-gradient(160deg,var(--paper-cream),var(--paper));
  border:1px solid var(--bd-gold-mid); border-radius:var(--radius);
  padding:2rem 1.5rem; text-align:center;
  transition:var(--ease); position:relative; overflow:hidden;
  display:flex; flex-direction:column; box-shadow:var(--sh-warm);
}
.svc-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:5px;
  background:linear-gradient(90deg,var(--crimson-deep),var(--crimson-light),var(--crimson-deep));
}
.svc-card::after {
  content:''; position:absolute; top:5px; left:0; right:0; height:1.5px;
  background:linear-gradient(90deg,transparent,var(--bd-gold-mid),transparent);
}
.svc-card:hover { border-color:var(--bd-red-strong); transform:translateY(-5px); box-shadow:var(--sh-deep) }
.svc-icon-wrap {
  width:68px; height:68px; border-radius:50%; margin:0 auto 1rem;
  background:linear-gradient(145deg,var(--crimson-rich),var(--crimson-deep));
  border:2px solid var(--gold-mid);
  display:flex; align-items:center; justify-content:center;
  font-size:1.5rem; color:var(--gold-light);
  box-shadow:0 4px 16px rgba(139,0,0,.2);
}
.svc-name  { font-family:var(--font-serif); font-size:1.2rem; color:var(--crimson-deep); letter-spacing:.12em; margin-bottom:.5rem }
.svc-badge { display:inline-block; padding:.24rem .9rem; background:rgba(139,0,0,.07); border:1px solid rgba(139,0,0,.2); border-radius:var(--radius-sm); font-size:.78rem; color:var(--crimson); margin-bottom:.85rem; font-family:var(--font-serif); letter-spacing:.06em }
.svc-desc  { font-size:.85rem; color:var(--ink-muted); line-height:1.9; flex:1; margin-bottom:1rem }
.svc-btn   { margin-top:auto }

/* ── Events ────────────────────────────── */
.events-grid { display:grid; grid-template-columns:1fr 1fr; gap:1.5rem }
.ev-card {
  background:linear-gradient(160deg,var(--paper-cream),var(--paper));
  border:1.5px solid var(--bd-gold-mid); border-radius:var(--radius);
  overflow:hidden; transition:var(--ease); display:flex; box-shadow:var(--sh-warm);
}
.ev-card:hover { border-color:var(--bd-red-strong); box-shadow:var(--sh-deep); transform:translateY(-3px) }
.ev-date {
  background:linear-gradient(160deg,var(--crimson-deep),var(--crimson));
  width:115px; flex-shrink:0;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  padding:1.25rem .75rem; border-right:2px solid var(--bd-gold-strong); text-align:center;
  position:relative;
}
.ev-date::after { content:''; position:absolute; inset:10px; border:1px solid rgba(201,164,76,.18); pointer-events:none }
.ev-lunar { font-family:var(--font-serif); font-size:.68rem; color:rgba(238,217,179,.68); letter-spacing:.1em; margin-bottom:.15rem }
.ev-day   { font-family:var(--font-serif); font-size:2.2rem; color:var(--gold-light); font-weight:900; line-height:1 }
.ev-month { font-family:var(--font-serif); font-size:.78rem; color:var(--gold-mid); letter-spacing:.12em; margin-top:.25rem }
.ev-body  { padding:1.5rem }
.ev-title { font-family:var(--font-serif); font-size:1.2rem; color:var(--crimson-deep); letter-spacing:.12em; margin-bottom:.4rem }
.ev-time  { font-size:.82rem; color:var(--ink-muted); margin-bottom:.6rem; display:flex; align-items:center; gap:.4rem }
.ev-desc  { font-size:.86rem; color:var(--ink-mid); line-height:1.85; margin-bottom:.9rem }

/* Notice Board — 黃榜風格 */
.notice-board {
  background:linear-gradient(160deg,#FFF8E0,#F5E8B8);
  border:2px solid var(--gold-warm); border-radius:var(--radius);
  overflow:hidden; margin-top:2rem; box-shadow:var(--sh-gold);
  position:relative;
}
.notice-board::before {
  content:''; position:absolute; inset:7px;
  border:1px solid rgba(185,135,20,.28); pointer-events:none;
}
.nb-head {
  background:linear-gradient(135deg,var(--crimson-deep),var(--crimson));
  padding:.9rem 1.5rem; display:flex; align-items:center; gap:.7rem;
  border-bottom:2px solid var(--gold-warm); position:relative;
}
.nb-head::after {
  content:''; position:absolute; bottom:-1px; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,var(--gold-shine),transparent);
}
.nb-head h3 { font-family:var(--font-serif); font-size:.95rem; color:var(--gold-light); letter-spacing:.12em }
.nb-item {
  display:flex; align-items:flex-start; gap:1rem;
  padding:.8rem 1.5rem; border-bottom:1px solid rgba(185,135,20,.22);
  transition:var(--ease); position:relative;
}
.nb-item:last-child { border-bottom:none }
.nb-item:hover { background:rgba(185,135,20,.07) }
.nb-date { font-size:.76rem; color:var(--gold-dark); min-width:80px; font-family:var(--font-serif); white-space:nowrap }
.nb-text  { font-size:.88rem; color:var(--ink-mid) }
.nb-tag   { display:inline-block; padding:.1rem .5rem; border-radius:var(--radius-sm); font-size:.7rem; letter-spacing:.04em; margin-right:.35rem }
.tag-red  { background:rgba(139,0,0,.1); border:1px solid rgba(139,0,0,.3); color:var(--crimson) }
.tag-gold { background:rgba(185,135,20,.12); border:1px solid rgba(185,135,20,.35); color:var(--gold-dark) }

/* ── Traffic ───────────────────────────── */
.addr-bar {
  background:linear-gradient(145deg,var(--crimson-deep),var(--crimson));
  border-radius:var(--radius); border:1px solid var(--bd-gold-strong);
  padding:1.5rem 2rem;
  display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:1.2rem;
  margin-bottom:1.75rem; box-shadow:var(--sh-deep); position:relative; overflow:hidden;
}
.addr-bar::before {
  content:''; position:absolute; inset:0;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60'%3E%3Crect x='5' y='5' width='50' height='50' fill='none' stroke='rgba(201,164,76,0.07)' stroke-width='1'/%3E%3C/svg%3E") repeat;
  pointer-events:none;
}
.addr-bar > * { position:relative; z-index:1 }
.addr-left { display:flex; align-items:center; gap:1.25rem }
.addr-left i  { font-size:2.2rem; color:var(--gold-mid) }
.addr-name    { font-family:var(--font-serif); font-size:1.1rem; color:var(--gold-light); letter-spacing:.12em; margin-bottom:.15rem }
.addr-text    { font-size:.9rem; color:rgba(238,217,179,.85); letter-spacing:.06em }
.map-wrap     { border:2px solid var(--bd-gold-strong); border-radius:var(--radius); overflow:hidden; margin-bottom:2rem; box-shadow:var(--sh-gold) }
.map-wrap iframe { display:block; width:100%; height:400px; border:none }
.map-note     { text-align:center; font-size:.76rem; color:var(--ink-muted); margin-top:.6rem; margin-bottom:2rem }
.map-note a   { color:var(--crimson); text-decoration:underline }

.parking-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(230px,1fr)); gap:1.1rem }
.pk-card {
  background:linear-gradient(160deg,var(--paper-cream),var(--paper));
  border:1px solid var(--bd-gold-mid); border-radius:var(--radius);
  padding:1.5rem; display:flex; gap:.9rem; align-items:flex-start;
  transition:var(--ease); box-shadow:var(--sh-warm);
}
.pk-card:hover { border-color:var(--bd-red-strong); box-shadow:var(--sh-deep); transform:translateY(-3px) }
.pk-card i    { font-size:1.8rem; color:var(--crimson); flex-shrink:0; margin-top:.15rem }
.pk-name      { font-family:var(--font-serif); font-size:.95rem; color:var(--crimson-deep); letter-spacing:.06em; margin-bottom:.35rem }
.pk-desc      { font-size:.8rem; color:var(--ink-muted); line-height:1.7 }
.pk-badge     { display:inline-block; padding:.12rem .55rem; font-size:.7rem; border-radius:var(--radius-sm); background:rgba(185,135,20,.1); border:1px solid rgba(185,135,20,.3); color:var(--gold-dark); margin-top:.4rem; margin-right:.3rem }
.pk-badge-warn{ background:rgba(139,0,0,.08); border-color:rgba(139,0,0,.25); color:var(--crimson) }
.pk-nav       { margin-top:.85rem }
.pk-nav .btn  { font-size:.76rem; padding:.38rem .9rem; gap:.35rem }
.pk-nav .btn i{ font-size:.8em }

/* ── Contact ───────────────────────────── */
.contact-focus {
  max-width:640px; margin:0 auto;
  background:linear-gradient(160deg,var(--paper-cream),var(--paper));
  border:1.5px solid var(--bd-gold-mid); border-radius:var(--radius);
  padding:3rem 2.5rem; text-align:center;
  box-shadow:var(--sh-warm); position:relative;
}
.contact-focus::before {
  content:''; position:absolute; top:0; left:0; right:0; height:4px;
  background:linear-gradient(90deg,var(--crimson-deep),var(--crimson-light),var(--crimson-deep));
}
.contact-focus::after {
  content:''; position:absolute; top:4px; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,var(--bd-gold-mid),transparent);
}
.cf-icon-wrap {
  width:80px; height:80px; border-radius:50%; margin:0 auto 1.25rem;
  background:linear-gradient(145deg,var(--crimson-rich),var(--crimson-deep));
  border:2px solid var(--gold-mid);
  display:flex; align-items:center; justify-content:center;
  font-size:1.8rem; color:var(--gold-light);
  box-shadow:0 4px 20px rgba(139,0,0,.28);
}
.cf-title { font-family:var(--font-serif); font-size:1.35rem; color:var(--crimson-deep); letter-spacing:.15em; margin-bottom:.4rem }
.cf-sub   { font-size:.88rem; color:var(--ink-muted); letter-spacing:.08em; margin-bottom:0 }
.cf-divider { height:1px; margin:1.75rem 0; background:linear-gradient(90deg,transparent,var(--bd-gold-strong),transparent) }
.cf-phones  { display:flex; flex-direction:column; gap:1rem; text-align:left }
.cf-phone-row {
  display:flex; align-items:center; justify-content:space-between;
  background:linear-gradient(160deg,var(--paper-warm),var(--paper-deep));
  border:1px solid var(--bd-gold-mid); border-radius:var(--radius-sm);
  padding:1rem 1.5rem; gap:1rem; transition:var(--ease);
}
.cf-phone-row:hover { border-color:var(--bd-red-strong); box-shadow:var(--sh-deep) }
.cf-phone-info { display:flex; flex-direction:column; gap:.2rem }
.cf-phone-tag { font-size:.7rem; color:var(--gold-dark); font-family:var(--font-serif); letter-spacing:.1em }
.cf-phone-num { font-family:var(--font-serif); font-size:1.4rem; color:var(--crimson-deep); letter-spacing:.06em; font-weight:700 }
.cf-note { margin-top:1.5rem; margin-bottom:0; font-size:.82rem; color:var(--ink-muted); letter-spacing:.05em; display:flex; align-items:center; justify-content:center; gap:.45rem }
.cf-note i { color:var(--crimson); font-size:.85em }
@media(max-width:480px) {
  .cf-phone-row { flex-direction:column; align-items:flex-start }
  .contact-focus { padding:2rem 1.25rem }
}

/* ── Caution ───────────────────────────── */
.caution {
  background:linear-gradient(160deg,#FFF5F0,#FFEAEA);
  border:1px solid rgba(139,0,0,.2); border-left:4px solid var(--crimson);
  border-radius:var(--radius); padding:1.25rem 1.5rem; box-shadow:var(--sh-warm);
}
.caution h4   { font-family:var(--font-serif); color:var(--crimson-deep); font-size:.95rem; letter-spacing:.08em; margin-bottom:.6rem; display:flex; align-items:center; gap:.5rem }
.caution ul li{ font-size:.85rem; color:var(--ink-mid); padding:.2rem 0 .2rem 1.1rem; position:relative; line-height:1.75 }
.caution ul li::before { content:'◆'; position:absolute; left:0; color:var(--crimson); font-size:.52rem; top:.44rem }

/* ── Footer ────────────────────────────── */
.footer {
  background:linear-gradient(180deg,var(--wood-dark) 0%,var(--wood-darkest) 100%);
  border-top:3px solid var(--gold-warm); padding:4.5rem 0 2rem; position:relative;
}
.footer::before {
  content:''; position:absolute; top:3px; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,rgba(240,208,112,.45),transparent);
}
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr; gap:2rem; margin-bottom:2rem }
.ft-brand-name { font-family:var(--font-serif); font-size:1.25rem; color:var(--gold-light); letter-spacing:.18em; margin-bottom:.2rem }
.ft-brand-sub  { font-size:.8rem; color:rgba(221,185,111,.58); letter-spacing:.12em; margin-bottom:.9rem }
.ft-desc       { font-size:.8rem; color:rgba(238,217,179,.48); line-height:1.95; max-width:300px }
.ft-head       { font-family:var(--font-serif); font-size:.9rem; color:var(--gold-mid); letter-spacing:.12em; margin-bottom:.85rem; padding-bottom:.4rem; border-bottom:1px solid rgba(185,135,20,.28) }
.ft-links      { display:flex; flex-direction:column; gap:.4rem }
.ft-link       { font-size:.84rem; color:rgba(238,217,179,.52); transition:var(--ease); letter-spacing:.04em }
.ft-link:hover { color:var(--gold-light) }
.ft-ci         { display:flex; align-items:flex-start; gap:.5rem; font-size:.84rem; color:rgba(238,217,179,.52); margin-bottom:.4rem }
.ft-ci i       { color:var(--gold-mid); margin-top:.22rem; width:14px; flex-shrink:0 }
.ft-divider    { height:1px; background:linear-gradient(90deg,transparent,rgba(185,135,20,.38),transparent); margin-bottom:1.5rem }
.ft-bottom     { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:.5rem; font-size:.76rem; color:rgba(238,217,179,.32) }

/* ── Back to top ───────────────────────── */
.btt {
  position:fixed; bottom:2rem; right:2rem;
  width:48px; height:48px;
  background:linear-gradient(145deg,var(--crimson-rich),var(--crimson-deep));
  border:2px solid var(--gold-warm); border-radius:var(--radius-sm);
  display:flex; align-items:center; justify-content:center;
  color:var(--gold-light); font-size:1.1rem; cursor:pointer; transition:var(--ease);
  opacity:0; pointer-events:none; z-index:100; box-shadow:var(--sh-deep);
}
.btt.show   { opacity:1; pointer-events:auto }
.btt:hover  { transform:translateY(-3px); box-shadow:var(--sh-deep), 0 0 20px rgba(201,164,76,.18) }

/* ── Placeholder ───────────────────────── */
.ph-notice {
  background:linear-gradient(160deg,var(--paper-warm),var(--paper-deep));
  border:1.5px dashed var(--bd-gold-mid); border-radius:var(--radius);
  padding:1.75rem; text-align:center; color:var(--ink-muted);
  font-size:.86rem; letter-spacing:.06em;
}
.ph-notice i { font-size:2.2rem; color:var(--gold-mid); opacity:.6; display:block; margin-bottom:.65rem }

/* ── Animations ────────────────────────── */
@keyframes fadeUp {
  from { opacity:0; transform:translateY(30px) }
  to   { opacity:1; transform:translateY(0)    }
}
.fade-up         { opacity:0 }
.fade-up.visible { animation:fadeUp .75s ease forwards }
.fade-up.d1      { animation-delay:.15s }
.fade-up.d2      { animation-delay:.3s  }
.fade-up.d3      { animation-delay:.45s }

/* ── Responsive ────────────────────────── */
@media(max-width:1100px) {
  .quick-nav      { grid-template-columns:repeat(3,1fr) }
  .md-body        { grid-template-columns:1fr 1fr 1fr }
  .md-body .md-desc{ grid-column:1/-1 }
}
@media(max-width:900px) {
  .about-grid     { grid-template-columns:1fr }
  .events-grid    { grid-template-columns:1fr }
  .footer-grid    { grid-template-columns:1fr 1fr }
  .md-top         { flex-direction:column; text-align:center }
  .md-body        { grid-template-columns:1fr 1fr }
  .md-body .md-desc{ grid-column:1/-1 }
  .parking-grid   { grid-template-columns:1fr 1fr }
}
@media(max-width:768px) {
  :root { --nav-h:62px }
  .nav-menu {
    position:fixed; top:var(--nav-h); left:0; right:0;
    background:linear-gradient(180deg,var(--wood-deep),var(--wood-dark));
    border-bottom:2px solid var(--gold-warm);
    flex-direction:column; gap:0; padding:.5rem 0;
    transform:translateY(-110%);
    transition:transform .3s ease, visibility 0s linear .3s;
    max-height:calc(100vh - var(--nav-h)); overflow-y:auto;
    z-index:999; visibility:hidden;
  }
  .nav-menu.open {
    transform:translateY(0);
    visibility:visible;
    transition:transform .3s ease, visibility 0s linear 0s;
  }
  .nav-link        { width:100%; padding:.85rem 1.5rem; border-bottom:1px solid rgba(185,135,20,.18); font-size:.9rem; min-height:44px; display:flex; align-items:center }
  .nav-link::after { display:none }
  .nav-toggle      { display:flex }
  .quick-nav       { grid-template-columns:repeat(3,1fr); gap:.6rem }
  .qn-item         { padding:1rem .4rem }
  .qn-label        { font-size:.75rem }
  .hero-btns       { flex-direction:column; align-items:center }
  .addr-bar        { flex-direction:column }
  .map-wrap iframe { height:280px }
  .footer-grid     { grid-template-columns:1fr }
  .ft-bottom       { justify-content:center; text-align:center }
  .deity-grid      { grid-template-columns:repeat(auto-fill,minmax(148px,1fr)) }
  .svc-grid        { grid-template-columns:1fr 1fr }
  .sec-head        { margin-bottom:2.5rem }
  .hero-content    { padding:2rem 1rem }
  .md-body         { padding:1.25rem 1.5rem }
  .parking-grid    { grid-template-columns:1fr 1fr }
  .about-text-wrap { padding:1.5rem }
  .hero-content::before,
  .hero-content::after { display:none }
}
@media(max-width:600px) {
  .events-grid    { grid-template-columns:1fr }
  .parking-grid   { grid-template-columns:1fr }
  .svc-grid       { grid-template-columns:1fr 1fr }
  .quick-nav      { gap:.5rem }
  .qn-item        { padding:.85rem .3rem }
  .qn-label       { font-size:.7rem; letter-spacing:.02em }
  .qn-item i      { font-size:1.35rem }
}
@media(max-width:480px) {
  .container      { padding:0 .9rem }
  .quick-nav      { grid-template-columns:repeat(3,1fr) }
  .svc-grid       { grid-template-columns:1fr }
  .deity-grid     { grid-template-columns:repeat(2,1fr) }
  .parking-grid   { grid-template-columns:1fr }
  .ev-card        { flex-direction:column }
  .ev-date        { width:100%; flex-direction:row; gap:.75rem; padding:.85rem 1.25rem; border-right:none; border-bottom:2px solid var(--bd-gold-strong); justify-content:flex-start }
  .md-top         { padding:1.5rem }
  .hero-badge     { padding:.45rem 1.1rem; font-size:.8rem }
  .btn            { padding:.65rem 1.35rem }
}
@media(max-width:375px) {
  .quick-nav      { grid-template-columns:repeat(2,1fr) }
  .deity-grid     { grid-template-columns:repeat(2,1fr) }
  .hero-title     { letter-spacing:.12em }
  .nav-brand-sub  { display:none }
  .container      { padding:0 .75rem }
}
