/* ===========================================================
   CGA — Page-specific styles
   =========================================================== */

.sec-pad { padding: 80px 0; }

/* =============== HERO (home) =============== */
.hero { position: relative; height: clamp(480px, 50vw, 820px); display: flex; align-items: center; overflow: hidden; }
.hero-bg {
  position: absolute; inset: 0; overflow: hidden;
  background:
    linear-gradient(90deg, rgba(40,28,15,.78) 0%, rgba(60,42,22,.45) 45%, rgba(40,28,15,.25) 100%),
    linear-gradient(180deg, rgba(30,20,10,.2), rgba(30,20,10,.55)),
    radial-gradient(120% 120% at 75% 30%, #e6b86a 0%, #b9853f 28%, #6e4a25 60%, #2c1c10 100%);
}
/* Full-bleed hero photo: the complete image sits centered, and the sides are
   filled with a warm golden "sunlight glow" gradient that blends with the
   photo's golden edges (feathered) for a seamless halo look. */
.hero-bg.has-photo::before,
.hero-bg.has-photo::after { content: ''; position: absolute; inset: 0; pointer-events: none; }
.hero-bg.has-photo::before {
  inset: -6%;
  background:
    url('/assets/img/glow-right.png') left center / auto 112% no-repeat,
    url('/assets/img/glow-left.png') right center / auto 112% no-repeat,
    var(--hero-img) center center / cover no-repeat;
  /* base = blurred copy of THIS page's photo (so the sides always match its
     colour); the ray images are blended on top only to add a soft sunbeam. */
  background-blend-mode: soft-light, soft-light, normal;
  filter: blur(12px) saturate(1.05);
  transform: scale(1.05);
}
.hero-bg.has-photo::after {
  background: var(--hero-img) center / contain no-repeat;
  -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 13%, #000 87%, transparent 100%);
          mask-image: linear-gradient(90deg, transparent 0, #000 13%, #000 87%, transparent 100%);
}
.hero-grain { position: absolute; inset: 0; opacity: .12; background-image: radial-gradient(rgba(255,255,255,.5) 1px, transparent 1px); background-size: 4px 4px; }
.hero-inner { position: relative; z-index: 2; color: #fff; max-width: 760px; }
.hero h1 { font-size: 46px; font-weight: 900; line-height: 1.35; text-shadow: 0 4px 24px rgba(0,0,0,.4); letter-spacing: 2px; }
.hero-sub { font-style: italic; font-size: 19px; margin-top: 14px; color: #f1dcb4; letter-spacing: 1px; }
.hero-desc { margin-top: 22px; font-size: 14.5px; color: #efe3cf; line-height: 2; opacity: .92; }
.hero-actions { display: flex; gap: 16px; margin-top: 32px; flex-wrap: wrap; }
.hero-dots { position: absolute; bottom: 26px; left: 50%; transform: translateX(-50%); display: flex; gap: 8px; z-index: 3; }
.hero-dots span { width: 8px; height: 8px; border-radius: 50%; background: rgba(255,255,255,.4); }
.hero-dots span.on { background: var(--gold-3); width: 22px; border-radius: 4px; }

/* =============== ABOUT block =============== */
.about-block { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: 48px; align-items: center;
  background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius); padding: 40px; box-shadow: var(--shadow-card); }
.ph-building {
  aspect-ratio: 4/3; border-radius: 10px;
  background: linear-gradient(160deg, #cdb487, #7c5f38 70%, #4b371f);
  display: grid; place-items: center; color: rgba(255,255,255,.6); font-size: 13px; letter-spacing: 1px;
  box-shadow: inset 0 0 60px rgba(0,0,0,.25);
}
.about-text h2 { font-size: 27px; color: var(--brown); letter-spacing: 1px; }
.about-en { color: var(--gold); font-style: italic; font-family: var(--serif); font-size: 14px; }
.about-text p { margin: 16px 0 24px; font-size: 14px; color: var(--ink-soft); line-height: 2; }
.stat-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; border-top: 1px dashed var(--line); padding-top: 22px; }
.stat b { display: block; font-size: 24px; color: var(--gold-deep); }
.stat span { font-size: 12px; color: var(--ink); display: block; margin-top: 4px; }
.stat span i { display: block; font-style: normal; color: var(--ink-soft); font-size: 10.5px; }

/* =============== PHILOSOPHY pillars =============== */
/* ===== decorative landscape background (refined modules) ===== */
.deco-bg { position: relative; background-color: var(--cream);
  background-image: url('/assets/img/section-bg.png');
  background-size: cover; background-position: center top; background-repeat: no-repeat; }
.deco-bg > .container { position: relative; z-index: 1; }

/* ===== ornate section header (refined modules) ===== */
.sec-orn { text-align: center; margin-bottom: 42px; }
.sec-orn .orn-top { display: block; color: var(--gold-3); font-size: 13px; letter-spacing: 8px; margin-bottom: 12px; }
.sec-orn h2 { font-family: var(--serif); font-size: 33px; color: var(--brown); letter-spacing: 5px; font-weight: 700;
  position: relative; display: inline-block; padding: 0 60px; }
.sec-orn h2::before, .sec-orn h2::after { content: "❖"; position: absolute; top: 50%; transform: translateY(-50%);
  color: var(--gold-3); font-size: 12px; }
.sec-orn h2::before { left: 18px; box-shadow: none; }
.sec-orn h2::after { right: 18px; }
.sec-orn h2 .hl { position: absolute; top: 50%; width: 30px; height: 1px; background: linear-gradient(90deg, transparent, var(--gold-3)); }
.sec-orn .en { display: block; font-style: italic; color: var(--gold); font-size: 16px; margin-top: 9px; letter-spacing: 2px; }
.sec-orn .lead { max-width: 760px; margin: 18px auto 0; font-size: 13.5px; color: var(--ink-soft); line-height: 1.9; }
.sec-orn .lead i { display: block; font-style: italic; color: #a18a63; font-size: 12px; margin-top: 4px; }

/* ===== five pillars (我们的理念) ===== */
.pillar-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 22px; }
.pillar {
  position: relative; overflow: hidden; background: linear-gradient(180deg, rgba(253,250,241,.86), rgba(246,238,216,.82));
  backdrop-filter: blur(2px); -webkit-backdrop-filter: blur(2px);
  border: 1px solid var(--gold-3); border-radius: 12px;
  padding: 40px 22px 62px; text-align: center; transition: all .3s; box-shadow: var(--shadow-soft);
}
.pillar::before { content: ""; position: absolute; inset: 8px; border: 1px solid rgba(184,140,60,.26); border-radius: 8px; pointer-events: none; z-index: 2; }
.pillar::after { content: ""; position: absolute; left: 14px; right: 14px; bottom: 12px; height: 46px;
  background: var(--wm, none) center bottom / contain no-repeat; opacity: .42; mix-blend-mode: multiply;
  pointer-events: none; z-index: 0; }
.pillar > * { position: relative; z-index: 1; }
.pillar:hover { transform: translateY(-6px); box-shadow: var(--shadow-card); }
.pillar-ic { position: relative; width: 76px; height: 76px; margin: 0 auto 18px; border-radius: 50%; display: grid; place-items: center;
  font-size: 32px; color: var(--gold-deep);
  background: radial-gradient(circle, #fdf3d8, #ecd6a6); border: 1px solid var(--gold-3);
  box-shadow: 0 0 0 5px rgba(216,184,106,.18), inset 0 0 14px rgba(154,112,31,.16); }
.pillar h3 { font-size: 21px; color: var(--brown); letter-spacing: 3px; }
.pillar > span { display: block; font-size: 12.5px; color: var(--gold); font-style: italic; margin-top: 5px; }
.pillar .p-zh { font-size: 13px; color: var(--ink); margin-top: 16px; padding-top: 14px; line-height: 1.85; border-top: 1px solid var(--line); }
.pillar .p-en { font-size: 11.5px; color: #a18a63; font-style: italic; margin-top: 8px; line-height: 1.7; }

/* =============== FEATURED EVENT =============== */
.featured { padding: 70px 0; background:
  linear-gradient(180deg, var(--paper), var(--paper)); }
.featured-card {
  display: grid; grid-template-columns: 1fr 1.25fr; gap: 0;
  border-radius: 18px; overflow: hidden; box-shadow: 0 20px 50px rgba(40,28,15,.25);
  background: linear-gradient(135deg, #2f2417, #221a10);
}
.featured-left { padding: 46px 40px; color: #f0e6cf; position: relative;
  background:
    linear-gradient(135deg, rgba(60,42,22,.4), rgba(34,26,16,.85)),
    radial-gradient(120% 140% at 20% 20%, #b9853f55, transparent 60%); }
.featured-left .tag { font-size: 11px; letter-spacing: 3px; color: var(--gold-3); }
.featured-left h2 { font-size: 28px; margin: 14px 0 6px; color: #fff; letter-spacing: 1px; }
.featured-left .f-en { font-style: italic; color: #cdb487; font-family: var(--serif); font-size: 14px; }
.featured-left .f-meta { font-size: 13px; color: #d4c4a3; margin-top: 12px; }
.featured-right { padding: 30px; display: grid; grid-template-columns: 1fr 1fr; gap: 16px; background: rgba(20,14,8,.4); }
.f-mini { background: rgba(255,255,255,.04); border: 1px solid rgba(216,184,106,.18); border-radius: 12px; padding: 20px;
  display: flex; flex-direction: column; gap: 4px; position: relative; transition: all .25s; }
.f-mini:hover { background: rgba(216,184,106,.1); transform: translateY(-3px); }
.f-mini .mi { font-size: 24px; }
.f-mini b { color: var(--gold-3); font-size: 16px; margin-top: 8px; }
.f-mini span { font-size: 11.5px; color: #b7a784; line-height: 1.6; }
.f-mini i { position: absolute; top: 18px; right: 18px; color: var(--gold-3); font-style: normal; }

/* =============== COMMITTEE carousel =============== */
.view-all { display: block; text-align: right; font-size: 12.5px; color: var(--gold-deep); margin: -28px 0 18px; }
.carousel { position: relative; }
.car-track { display: flex; gap: 18px; overflow-x: auto; scroll-snap-type: x mandatory; padding: 6px 2px 14px; scrollbar-width: none; }
.car-track::-webkit-scrollbar { display: none; }
.person-card { flex: 0 0 calc((100% - 90px)/6); min-width: 165px; scroll-snap-align: start;
  background: var(--paper); border: 1px solid var(--line); border-radius: 12px; padding: 16px; text-align: center; box-shadow: var(--shadow-soft); }
.person-card .portrait.p-sq { aspect-ratio: 1/1; border-radius: 10px; margin-bottom: 12px; }
.person-card h4 { font-size: 16px; color: var(--brown); }
.person-card span { font-size: 11px; color: var(--gold); font-style: italic; display: block; }
.person-card small { font-size: 11px; color: var(--ink-soft); display: block; margin: 6px 0 10px; min-height: 28px; }
.mini-link { font-size: 11px; color: var(--gold-deep); border: 1px solid var(--line); border-radius: 6px; padding: 5px 10px; display: inline-block; }
.mini-link:hover { background: var(--gold); color: #fff; border-color: var(--gold); }
.car-btn { position: absolute; top: 40%; width: 38px; height: 38px; border-radius: 50%; border: 1px solid var(--line);
  background: #fff; color: var(--gold-deep); cursor: pointer; font-size: 20px; box-shadow: var(--shadow-soft); z-index: 4; }
.car-btn.prev { left: -16px; } .car-btn.next { right: -16px; }
.car-btn:hover { background: var(--gold); color: #fff; }

/* =============== NETWORK + NEWS =============== */
.net-news { display: grid; grid-template-columns: 1.1fr 1fr 1fr; gap: 24px; align-items: start; }
.net-card { background: linear-gradient(160deg, #2f2417, #211910); border-radius: var(--radius); padding: 26px; color: #f0e6cf; }
.net-head b { font-family: var(--serif); font-size: 20px; color: var(--gold-3); }
.net-head span { font-size: 12px; color: #a8966f; margin-left: 8px; font-style: italic; }
.net-map { height: 170px; margin: 18px 0; border-radius: 10px; position: relative; overflow: hidden;
  background-color: #f3e7c9;
  background-size: cover; background-position: center; background-repeat: no-repeat;
  background-image:
    radial-gradient(circle at 30% 45%, rgba(216,184,106,.55) 0 2px, transparent 3px),
    radial-gradient(circle at 62% 38%, rgba(216,184,106,.55) 0 2px, transparent 3px),
    radial-gradient(circle at 78% 58%, rgba(216,184,106,.55) 0 2px, transparent 3px),
    linear-gradient(160deg, rgba(216,184,106,.12), rgba(0,0,0,.25));
}
/* interactive global-network nodes (data-driven) */
.net-map.has-nodes { background-image: none; }
.net-node { position: absolute; width: 11px; height: 11px; transform: translate(-50%, -50%);
  padding: 0; border: 2px solid #fff6e0; border-radius: 50%; cursor: pointer;
  background: var(--gold-3); box-shadow: 0 0 0 0 rgba(216,184,106,.6); z-index: 2;
  animation: nodePulse 2.4s infinite; }
.net-node:hover, .net-node:focus { z-index: 6; outline: none; }
@keyframes nodePulse {
  0% { box-shadow: 0 0 0 0 rgba(216,184,106,.55); }
  70% { box-shadow: 0 0 0 9px rgba(216,184,106,0); }
  100% { box-shadow: 0 0 0 0 rgba(216,184,106,0); }
}
.net-node .nn-tip { position: absolute; bottom: 160%; left: 50%; transform: translateX(-50%);
  background: rgba(20,14,8,.96); color: #f0e6cf; border: 1px solid rgba(216,184,106,.4);
  padding: 6px 10px; border-radius: 7px; font-size: 11.5px; line-height: 1.4; white-space: nowrap;
  opacity: 0; pointer-events: none; transition: opacity .18s; }
.net-node .nn-tip b { display: block; color: var(--gold-3); font-family: var(--serif); font-size: 12.5px; }
.net-node .nn-tip .nn-d { color: #c8b78f; font-size: 11px; }
.net-node:hover .nn-tip, .net-node:focus .nn-tip { opacity: 1; }
.net-node .nn-tip .nn-en { display: none; }
html.en .net-node .nn-tip .nn-zh { display: none; }
html.en .net-node .nn-tip .nn-en { display: inline; }
.net-stat { display: flex; align-items: center; gap: 14px; margin-bottom: 18px; }
.net-stat b { font-size: 40px; color: var(--gold-3); font-family: var(--serif); }
.net-stat span { font-size: 12.5px; color: #d4c4a3; }
.net-stat span i { display: block; font-style: normal; color: #a8966f; font-size: 11px; }
.list-card { background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius); padding: 22px; box-shadow: var(--shadow-soft); }
.lc-head { display: flex; justify-content: space-between; align-items: baseline; border-bottom: 1px solid var(--line); padding-bottom: 12px; margin-bottom: 14px; }
.lc-head b { font-family: var(--serif); font-size: 18px; color: var(--brown); }
.lc-head .more { font-size: 11.5px; color: var(--gold-deep); }
.lc-item { display: flex; gap: 14px; padding: 12px 0; border-bottom: 1px dashed var(--line-soft); }
.lc-item:last-child { border-bottom: none; }
.lc-thumb { flex: 0 0 78px; height: 58px; border-radius: 8px; background: linear-gradient(160deg, #cdb487, #6e5232); }
.lc-thumb.t2{background:linear-gradient(160deg,#b98b4f,#5e4524);} .lc-thumb.t3{background:linear-gradient(160deg,#a9b487,#566032);}
.lc-thumb.t4{background:linear-gradient(160deg,#c79a6a,#5e3f24);} .lc-thumb.t5{background:linear-gradient(160deg,#bfa06a,#5e4d24);} .lc-thumb.t6{background:linear-gradient(160deg,#c2926a,#5e3a24);}
.lc-item b { font-size: 13.5px; color: var(--brown); display: block; line-height: 1.5; }
.lc-item small { font-size: 11px; color: var(--ink-soft); display: block; margin: 3px 0; }
.lc-item i { font-size: 11px; color: var(--gold-deep); font-style: normal; }

/* =============== PARTNERS =============== */
.partners-band { padding: 50px 0; background: var(--cream); border-top: 1px solid var(--line); }
.partner-logos { display: flex; flex-wrap: wrap; justify-content: center; gap: 18px; }
.plogo { font-family: var(--serif); font-size: 14px; color: #8a7a59; letter-spacing: 1px;
  background: var(--paper-soft); border: 1px solid var(--line); border-radius: 8px; padding: 16px 26px; min-width: 130px; text-align: center; filter: grayscale(.3); transition: all .25s; }
.plogo:hover { color: var(--gold-deep); filter: none; border-color: var(--gold-3); }
.plogo img { max-height: 30px; width: auto; display: block; margin: 0 auto; }

/* =============== inner page hero =============== */
.page-hero { position: relative; height: clamp(420px, 46vw, 760px); display: flex; align-items: center; overflow: hidden; color: #fff; }
.page-hero .hero-bg { position: absolute; inset: 0; overflow: hidden;
  background:
    linear-gradient(90deg, rgba(40,28,15,.7), rgba(60,42,22,.3) 60%, rgba(40,28,15,.15)),
    radial-gradient(120% 130% at 70% 25%, #e6b86a, #b9853f 30%, #6e4a25 62%, #2c1c10 100%); }
.page-hero .crumb { font-size: 12px; color: var(--gold-3); letter-spacing: 2px; margin-bottom: 14px; }
.page-hero h1 { font-family: var(--serif); font-size: 44px; font-weight: 900; letter-spacing: 3px; text-shadow: 0 4px 20px rgba(0,0,0,.4); }
.page-hero .en { display:block; font-family: var(--serif); font-style: italic; font-size: 22px; color: #f1dcb4; margin-top: 6px; letter-spacing: 2px; }
.page-hero p { margin-top: 16px; max-width: 560px; font-size: 14px; color: #efe3cf; line-height: 1.9; }
.page-hero .inner { position: relative; z-index: 2; }

/* =============== ABOUT page =============== */
.intro-card { background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius); padding: 44px; box-shadow: var(--shadow-card); text-align: center; }
.intro-card h2 { font-size: 26px; color: var(--brown); letter-spacing: 1px; }
.intro-card .intro-en { color: var(--gold); font-style: italic; font-family: var(--serif); margin-bottom: 18px; display: block; }
.intro-card p { font-size: 13.5px; color: var(--ink-soft); line-height: 2; max-width: 880px; margin: 0 auto 14px; }

.mv-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 26px; }
.mv-card { background: var(--paper-soft); border: 1px solid var(--line); border-radius: var(--radius); padding: 34px; box-shadow: var(--shadow-soft); }
.mv-ic { width: 58px; height: 58px; border-radius: 50%; display: grid; place-items: center; font-size: 26px; background: radial-gradient(circle, #fbf1d8, #efdcb0); border: 1px solid var(--gold-3); margin-bottom: 18px; }
.mv-card h3 { font-size: 20px; color: var(--brown); }
.mv-card h3 i { font-style: italic; color: var(--gold); font-size: 14px; font-weight: 400; }
.mv-card p { font-size: 13.5px; color: var(--ink-soft); line-height: 1.9; margin-top: 12px; }
.mv-card .mv-en { font-size: 12px; color: #a18a63; font-style: italic; }

.timeline { display: grid; grid-template-columns: repeat(4,1fr); gap: 26px; position: relative; padding-top: 6px; }
.timeline::before { content: ""; position: absolute; top: 44px; left: 12.5%; right: 12.5%; height: 2px;
  background: linear-gradient(90deg, var(--gold-3), var(--gold-2) 50%, var(--gold-3)); z-index: 0; }
.tl-item { text-align: center; position: relative; }
.tl-ic { width: 78px; height: 78px; border-radius: 50%; display: grid; place-items: center; font-size: 32px; color: var(--gold-deep);
  background: radial-gradient(circle, #fdf3d8, #e9d09c); border: 2px solid var(--gold-2);
  box-shadow: 0 0 0 6px rgba(216,184,106,.2), 0 6px 16px rgba(154,112,31,.18);
  margin: 0 auto 24px; position: relative; z-index: 2; }
.tl-card { position: relative; overflow: hidden; background: linear-gradient(180deg, rgba(253,250,241,.86), rgba(246,238,216,.82));
  backdrop-filter: blur(2px); -webkit-backdrop-filter: blur(2px); border: 1px solid var(--gold-3);
  border-radius: 12px; padding: 22px 18px 78px; box-shadow: var(--shadow-soft); }
.tl-card::before { content: ""; position: absolute; inset: 6px; border: 1px solid rgba(184,140,60,.22); border-radius: 8px; pointer-events: none; z-index: 2; }
.tl-card::after { content: ""; position: absolute; left: 10px; right: 10px; bottom: 10px; height: 62px;
  background: var(--wm, none) center bottom / contain no-repeat; opacity: .5; mix-blend-mode: multiply;
  pointer-events: none; z-index: 0; }
.tl-card > * { position: relative; z-index: 1; }
.tl-card b { font-size: 30px; color: var(--gold-deep); font-family: var(--serif); display: block; letter-spacing: 1px; }
.tl-cn { font-size: 13px; color: var(--brown); display: block; margin-top: 8px; line-height: 1.6; }
.tl-en { font-size: 11.5px; color: var(--ink-soft); display: block; font-style: italic; margin-top: 4px; line-height: 1.55; }

.gn-grid { display: grid; grid-template-columns: 1.45fr 1fr; gap: 30px; align-items: stretch; }
.gn-map { position: relative; border-radius: 16px; padding: 32px; overflow: hidden;
  display: flex; flex-direction: column; gap: 16px;
  background: linear-gradient(155deg, rgba(252,249,241,.96), rgba(243,231,201,.9));
  border: 1px solid var(--gold-3); box-shadow: var(--shadow-card); min-height: 300px; }
.gn-badge { display: flex; align-items: center; gap: 16px; }
.gn-badge b { font-size: 50px; color: var(--gold-deep); font-family: var(--serif); line-height: 1; }
.gn-badge span { font-size: 13.5px; color: var(--brown); font-family: var(--serif); }
.gn-badge span i { display: block; font-style: italic; color: var(--gold); font-size: 11.5px; margin-top: 3px; }
.gn-desc { font-size: 13px; color: var(--ink-soft); line-height: 1.85; }
.gn-desc i { display: block; font-style: italic; color: #a18a63; font-size: 11.5px; margin-top: 4px; }
.gn-mapimg { flex: 1; min-height: 150px; border-radius: 10px; margin: 2px 0;
  background: center/contain no-repeat; opacity: .96; }
.gn-map .btn { align-self: flex-start; }
.gn-regions { display: flex; flex-direction: column; gap: 12px; justify-content: center; }
.gn-row { position: relative; overflow: hidden; display: flex; align-items: center; gap: 14px; background: rgba(255,253,247,.78);
  backdrop-filter: blur(2px); -webkit-backdrop-filter: blur(2px); border: 1px solid var(--line);
  border-radius: 12px; padding: 13px 20px; box-shadow: var(--shadow-soft); transition: all .2s; }
.gn-row::after { content: ""; position: absolute; right: 56px; top: 0; bottom: 0; width: 150px;
  background: var(--wm, none) right bottom / auto 165% no-repeat; opacity: .4; mix-blend-mode: multiply;
  pointer-events: none; z-index: 0; }
.gn-row > * { position: relative; z-index: 1; }
.gn-row:hover { border-color: var(--gold-3); transform: translateX(4px); box-shadow: var(--shadow-card); }
.gn-ic { width: 46px; height: 46px; flex-shrink: 0; border-radius: 50%; display: grid; place-items: center; font-size: 23px;
  background: radial-gradient(circle, #fdf3d8, #ecd6a6); border: 1px solid var(--gold-3); }
.gn-name { font-family: var(--serif); color: var(--brown); font-size: 16px; flex: 1; }
.gn-name i { color: var(--gold); font-style: italic; font-size: 13px; margin-left: 4px; }
.gn-row b { color: var(--gold-deep); font-size: 20px; }
.gn-row .arr-r { color: var(--gold); font-size: 18px; }

/* =============== SYMPOSIUM page =============== */
.sym-hero h1 { font-size: 50px; }
.quick-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 18px; }
.quick-card { display: flex; align-items: center; gap: 14px; padding: 22px; border-radius: 12px; position: relative;
  background: linear-gradient(135deg, #312615, #221a10); color: #f0e6cf; border: 1px solid rgba(216,184,106,.2); transition: all .25s; box-shadow: var(--shadow-card); }
.quick-card:hover { transform: translateY(-4px); border-color: var(--gold-3); }
.quick-card .qn { position: absolute; top: 12px; right: 16px; font-size: 11px; color: var(--gold-3); letter-spacing: 1px; }
.quick-card .qi { width: 46px; height: 46px; border-radius: 10px; display: grid; place-items: center; font-size: 22px; background: rgba(216,184,106,.12); }
.quick-card b { font-size: 16px; color: var(--gold-3); display: block; }
.quick-card small { font-size: 11px; color: #b7a784; }

.center-lead { text-align: center; max-width: 760px; margin: 0 auto 40px; font-size: 14px; color: var(--ink-soft); line-height: 2; }
.center-lead i { color: #a18a63; }
.theme-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.theme-card { background: var(--paper-soft); border: 1px solid var(--line); border-radius: var(--radius); padding: 32px 26px; text-align: center; box-shadow: var(--shadow-soft); transition: all .3s; }
.theme-card:hover { transform: translateY(-6px); border-color: var(--gold-3); }
.th-ic { width: 60px; height: 60px; margin: 0 auto 16px; border-radius: 50%; display: grid; place-items: center; font-size: 26px; background: radial-gradient(circle,#fbf1d8,#efdcb0); border: 1px solid var(--gold-3); }
.theme-card h3 { font-size: 20px; color: var(--brown); }
.theme-card span { font-size: 12px; color: var(--gold); font-style: italic; display: block; margin-bottom: 10px; }
.theme-card p { font-size: 13px; color: var(--ink-soft); line-height: 1.9; }

.agenda-grid { display: grid; grid-template-columns: 1fr 1fr 0.9fr; gap: 24px; }
.agenda-col { background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius); padding: 24px; box-shadow: var(--shadow-soft); }
.ag-day { font-family: var(--serif); font-size: 17px; color: var(--gold-deep); border-bottom: 2px solid var(--gold-3); padding-bottom: 10px; margin-bottom: 14px; }
.ag-day i { font-style: italic; color: var(--ink-soft); font-size: 12px; margin-left: 8px; }
.ag-row { display: flex; gap: 14px; padding: 10px 0; border-bottom: 1px dashed var(--line-soft); }
.ag-row b { flex: 0 0 92px; font-size: 12.5px; color: var(--gold-deep); }
.ag-row span { font-size: 12.5px; color: var(--brown); }
.ag-row span i { display: block; font-style: italic; color: var(--ink-soft); font-size: 11px; }
.ag-note { font-size: 11px; color: var(--ink-soft); margin-top: 14px; font-style: italic; }
.venue-col { background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius); padding: 24px; box-shadow: var(--shadow-soft); }
.venue-img { height: 150px; border-radius: 10px; margin-bottom: 16px; background: linear-gradient(160deg,#a9c0d6,#5b7a96 60%,#33485c); box-shadow: inset 0 0 50px rgba(0,0,0,.2); }
.venue-name { font-size: 18px; color: var(--brown); display: block; }
.venue-en { font-size: 12px; color: var(--ink-soft); margin: 4px 0; }
.venue-addr { font-size: 12px; color: var(--ink); }

.speaker-card { flex: 0 0 calc((100% - 72px)/5); min-width: 180px; scroll-snap-align: start; background: var(--paper); border: 1px solid var(--line); border-radius: 12px; padding: 18px; text-align: center; box-shadow: var(--shadow-soft); }
.speaker-card .portrait.p-sq { aspect-ratio: 1/1.05; border-radius: 10px; margin-bottom: 12px; }
.speaker-card h4 { font-size: 16px; color: var(--brown); }
.speaker-card span { font-size: 11px; color: var(--gold); font-style: italic; display: block; }
.speaker-card small { font-size: 11px; color: var(--ink-soft); display: block; margin: 6px 0 10px; min-height: 34px; }

/* =============== COMMITTEE page =============== */
.back-symp { position: absolute; right: 24px; bottom: 0; background: var(--paper); color: var(--gold-deep); font-size: 12.5px; padding: 12px 22px; border-radius: 30px; box-shadow: var(--shadow-card); }
.chair-card { display: grid; grid-template-columns: 0.6fr 1.4fr; gap: 40px; align-items: center; background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius); padding: 40px; box-shadow: var(--shadow-card); position: relative; }
.chair-portrait { aspect-ratio: 4/5; border-radius: 12px; }
.chair-tag { font-size: 12px; color: var(--gold); letter-spacing: 2px; }
.chair-info h2 { font-size: 34px; color: var(--brown); margin: 10px 0 2px; }
.chair-en { font-style: italic; color: var(--gold); font-family: var(--serif); }
.chair-role { color: var(--gold-deep); font-size: 14px; margin: 8px 0 16px; font-weight: 500; }
.chair-desc { font-size: 14px; color: var(--ink-soft); line-height: 2; max-width: 640px; }
.chair-medal { position: absolute; top: 36px; right: 40px; font-size: 40px; opacity: .5; }

.member-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.member-card { display: flex; gap: 18px; background: var(--paper); border: 1px solid var(--line); border-radius: 12px; padding: 20px; box-shadow: var(--shadow-soft); transition: all .25s; }
.member-card:hover { transform: translateY(-4px); border-color: var(--gold-3); }
.m-portrait { flex: 0 0 90px; height: 110px; border-radius: 10px; }
.m-portrait.sq { height: 90px; }
.member-card.small .m-portrait { flex-basis: 70px; }
.m-body h4 { font-size: 16px; color: var(--brown); }
.m-body span { font-size: 11px; color: var(--gold); font-style: italic; display: block; }
.m-body small { font-size: 11px; color: var(--gold-deep); display: block; margin: 5px 0; line-height: 1.5; }
.m-body p { font-size: 11.5px; color: var(--ink-soft); line-height: 1.7; margin-bottom: 10px; }
.member-note { text-align: center; font-size: 12px; color: var(--ink-soft); margin-top: 26px; font-style: italic; }

.cta-band { padding: 56px 0; background: linear-gradient(135deg, #2f2417, #221a10); }
.cta-inner { display: flex; align-items: center; justify-content: space-between; gap: 30px; flex-wrap: wrap; }
.cta-inner h2 { font-family: var(--serif); color: var(--cream); font-size: 26px; letter-spacing: 2px; }
.cta-inner p { color: #b7a784; font-style: italic; font-size: 13px; margin-top: 6px; }

/* =============== NEWS page =============== */
.news-featured { display: grid; grid-template-columns: 1fr 1.1fr; gap: 0; background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-card); }
.nf-img { position: relative; min-height: 320px; background: linear-gradient(135deg,#c79a5a,#7a5224 55%,#3a2712); }
.nf-badge { position: absolute; top: 18px; left: 18px; background: rgba(34,26,16,.7); color: var(--gold-3); font-size: 12px; padding: 6px 14px; border-radius: 4px; }
.nf-body { padding: 38px; }
.nf-body h2 { font-size: 24px; color: var(--brown); line-height: 1.5; }
.nf-body p { font-size: 13.5px; color: var(--ink-soft); line-height: 1.9; margin: 16px 0; }
.nf-meta { display: flex; gap: 18px; font-size: 12px; color: var(--gold-deep); margin-bottom: 18px; }

.news-tabs { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 30px; }
.ntab { background: var(--paper); border: 1px solid var(--line); border-radius: 8px; padding: 12px 20px; cursor: pointer; font-family: var(--sans); font-size: 13.5px; color: var(--ink); display: flex; flex-direction: column; align-items: center; transition: all .2s; }
.ntab i { font-style: italic; font-size: 10px; color: var(--ink-soft); }
.ntab.active { background: linear-gradient(135deg,#3a2c1a,#241b11); color: var(--gold-3); border-color: var(--gold-deep); }
.ntab.active i { color: #b7a784; }

.news-layout { display: grid; grid-template-columns: 1fr 300px; gap: 30px; align-items: start; }
.news-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; }
.news-card { background: var(--paper); border: 1px solid var(--line); border-radius: 12px; overflow: hidden; box-shadow: var(--shadow-soft); transition: all .25s; }
.news-card:hover { transform: translateY(-5px); border-color: var(--gold-3); }
.nc-img { height: 150px; background: linear-gradient(160deg,#cdb487,#6e5232); }
.nc-img.c2{background:linear-gradient(160deg,#d3b58a,#7a5a30);} .nc-img.c3{background:linear-gradient(160deg,#a9b487,#566032);}
.nc-img.c4{background:linear-gradient(160deg,#c79a6a,#5e3f24);} .nc-img.c5{background:linear-gradient(160deg,#b9956a,#5e4524);} .nc-img.c6{background:linear-gradient(160deg,#c0926a,#5e3a24);}
.nc-body { padding: 18px; }
.nc-body h4 { font-size: 15.5px; color: var(--brown); line-height: 1.5; }
.nc-meta { display: flex; flex-wrap: wrap; gap: 10px; font-size: 11px; color: var(--gold-deep); margin: 8px 0; }
.nc-body p { font-size: 12.5px; color: var(--ink-soft); line-height: 1.8; margin-bottom: 10px; }

.news-side { display: flex; flex-direction: column; gap: 20px; }
.side-box { background: var(--paper); border: 1px solid var(--line); border-radius: 12px; padding: 20px; box-shadow: var(--shadow-soft); }
.side-box input[type=search] { width: 100%; border: 1px solid var(--line); border-radius: 8px; padding: 11px 14px; font-size: 13px; background: var(--paper-soft); }
.sb-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 14px; }
.sb-head b { font-size: 16px; color: var(--brown); }
.sb-head span { font-size: 10.5px; color: var(--gold-deep); }
.tag-cloud { display: flex; flex-wrap: wrap; gap: 8px; }
.tag-cloud span { font-size: 11.5px; background: var(--paper-soft); border: 1px solid var(--line); color: var(--gold-deep); padding: 6px 12px; border-radius: 20px; cursor: pointer; }
.tag-cloud span:hover { background: var(--gold); color: #fff; border-color: var(--gold); }
.archive li { display: flex; justify-content: space-between; align-items: center; padding: 10px 4px; border-bottom: 1px solid var(--line-soft); font-size: 13px; color: var(--brown); cursor: pointer; }
.archive li i { color: var(--gold-deep); font-style: normal; }
.archive li.open { color: var(--gold-deep); font-weight: 500; }
.archive li.sub { padding-left: 18px; font-size: 12.5px; color: var(--ink-soft); }

.ec-head { display: flex; align-items: baseline; gap: 12px; margin-bottom: 24px; }
.ec-head b { font-family: var(--serif); font-size: 22px; color: var(--brown); }
.ec-head span { font-size: 12px; color: var(--gold); letter-spacing: 2px; }
.ec-head .more { margin-left: auto; font-size: 12px; color: var(--gold-deep); }
.ec-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 22px; }
.ec-card { background: var(--paper); border: 1px solid var(--line); border-radius: 12px; overflow: hidden; box-shadow: var(--shadow-soft); transition: all .25s; }
.ec-card:hover { transform: translateY(-4px); }
.ec-img { height: 130px; background: linear-gradient(160deg,#c79a5a,#5e3f24); }
.ec-img.e2{background:linear-gradient(160deg,#bfa06a,#5e4d24);} .ec-img.e3{background:linear-gradient(160deg,#a9966a,#4e3f24);} .ec-img.e4{background:linear-gradient(160deg,#c0926a,#5e3a24);}
.ec-card b { display: block; padding: 14px 16px 4px; font-size: 13.5px; color: var(--brown); line-height: 1.5; }
.ec-card small { display: block; padding: 0 16px 16px; font-size: 11.5px; color: var(--gold-deep); }

.news-sub-band { padding: 50px 0; background: linear-gradient(135deg,#2f2417,#221a10); }
.ns-inner { display: flex; align-items: center; justify-content: space-between; gap: 30px; flex-wrap: wrap; }
.ns-inner h2 { font-family: var(--serif); color: var(--cream); font-size: 24px; }
.ns-inner p { color: var(--gold-3); font-size: 12px; letter-spacing: 2px; margin: 4px 0; }
.ns-inner small { color: #b7a784; font-size: 12.5px; }
.ns-form { display: flex; gap: 10px; }
.ns-form input { width: 300px; max-width: 60vw; border: 1px solid rgba(216,184,106,.3); background: rgba(255,255,255,.06); border-radius: 6px; padding: 13px 16px; color: #f0e6cf; font-size: 13px; }

/* =============== CULTURE page =============== */
.culture-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.culture-card { background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-soft); transition: all .3s; }
.culture-card:hover { transform: translateY(-6px); border-color: var(--gold-3); box-shadow: var(--shadow-card); }
.cc-img { height: 180px; background: linear-gradient(160deg,#cdb487,#6e5232); position: relative; }
.culture-card:nth-child(2) .cc-img { background: linear-gradient(160deg,#a9b487,#566032); }
.culture-card:nth-child(3) .cc-img { background: linear-gradient(160deg,#c0926a,#6e3a24); }
.culture-card:nth-child(4) .cc-img { background: linear-gradient(160deg,#a9c0b0,#3a5a4c); }
.culture-card:nth-child(5) .cc-img { background: linear-gradient(160deg,#c79a5a,#5e3f24); }
.culture-card:nth-child(6) .cc-img { background: linear-gradient(160deg,#bfa06a,#5e4d24); }
.cc-body { padding: 22px; }
.cc-tag { font-size: 11px; color: var(--gold); background: #f6ecd2; border: 1px solid var(--line); border-radius: 4px; padding: 3px 10px; letter-spacing: 1px; }
.cc-body h3 { font-size: 19px; color: var(--brown); margin: 12px 0 2px; }
.cc-en { font-size: 12px; color: var(--gold); font-style: italic; }
.cc-body p { font-size: 13px; color: var(--ink-soft); line-height: 1.9; margin-top: 10px; }

.quote-band { text-align: center; max-width: 820px; margin: 0 auto; position: relative; padding: 30px; }
.quote-band .q-mark { font-size: 90px; color: var(--gold-3); line-height: 0; opacity: .5; display: block; height: 40px; }
.quote-band p { font-size: 22px; color: var(--brown); line-height: 1.9; letter-spacing: 1px; }
.quote-band small { display: block; margin-top: 18px; color: var(--gold-deep); font-size: 13px; }

/* =============== MEMBERSHIP page =============== */
.why-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 22px; }
.why-card { background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius); padding: 30px 22px; text-align: center; box-shadow: var(--shadow-soft); transition: all .25s; }
.why-card:hover { transform: translateY(-5px); border-color: var(--gold-3); }
.why-ic { width: 58px; height: 58px; margin: 0 auto 14px; border-radius: 50%; display: grid; place-items: center; font-size: 26px; background: radial-gradient(circle,#fbf1d8,#efdcb0); border: 1px solid var(--gold-3); }
.why-card h4 { font-size: 17px; color: var(--brown); }
.why-card p { font-size: 12.5px; color: var(--ink-soft); line-height: 1.8; margin-top: 8px; }

.tier-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; align-items: start; }
.tier-card { background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius); padding: 32px 28px; box-shadow: var(--shadow-soft); position: relative; transition: all .3s; }
.tier-card.featured { background: linear-gradient(165deg,#332715,#221a10); color: #f0e6cf; border-color: var(--gold-deep); transform: scale(1.04); box-shadow: 0 20px 44px rgba(40,28,15,.3); }
.tier-card:hover { transform: translateY(-4px); }
.tier-card.featured:hover { transform: scale(1.04) translateY(-4px); }
.tier-badge { position: absolute; top: -12px; left: 50%; transform: translateX(-50%); background: linear-gradient(135deg,#caa14d,#9a701f); color: #fff; font-size: 11px; padding: 5px 16px; border-radius: 20px; letter-spacing: 1px; }
.tier-head { text-align: center; border-bottom: 1px dashed var(--line); padding-bottom: 18px; margin-bottom: 18px; }
.tier-card.featured .tier-head { border-color: rgba(216,184,106,.25); }
.tier-ic { font-size: 32px; }
.tier-head h3 { font-size: 22px; color: var(--brown); margin-top: 8px; }
.tier-card.featured .tier-head h3 { color: #fff; }
.tier-en { font-size: 12px; color: var(--gold); font-style: italic; }
.tier-price { text-align: center; margin-bottom: 20px; }
.tier-price b { font-size: 34px; color: var(--gold-deep); font-family: var(--serif); }
.tier-card.featured .tier-price b { color: var(--gold-3); }
.tier-price small { font-size: 13px; color: var(--ink-soft); }
.tier-card.featured .tier-price small { color: #b7a784; }
.tier-list { margin-bottom: 22px; }
.tier-list li { font-size: 13px; color: var(--ink-soft); padding: 8px 0; border-bottom: 1px solid var(--line-soft); }
.tier-card.featured .tier-list li { color: #d4c4a3; border-color: rgba(216,184,106,.12); }

.steps-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 22px; }
.step-card { background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius); padding: 28px 22px; box-shadow: var(--shadow-soft); position: relative; }
.step-n { font-family: var(--serif); font-size: 40px; color: var(--gold-3); font-weight: 700; opacity: .6; }
.step-card h4 { font-size: 17px; color: var(--brown); margin: 6px 0 8px; }
.step-card p { font-size: 12.5px; color: var(--ink-soft); line-height: 1.8; }

/* =============== CONTACT page =============== */
.contact-cards { display: grid; grid-template-columns: repeat(4,1fr); gap: 22px; }
.contact-card { background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius); padding: 30px 22px; text-align: center; box-shadow: var(--shadow-soft); transition: all .25s; }
.contact-card:hover { transform: translateY(-5px); border-color: var(--gold-3); }
.cc-ic { width: 56px; height: 56px; margin: 0 auto 14px; border-radius: 50%; display: grid; place-items: center; font-size: 24px; background: radial-gradient(circle,#fbf1d8,#efdcb0); border: 1px solid var(--gold-3); }
.contact-card h4 { font-size: 16px; color: var(--brown); }
.contact-card p { font-size: 13px; color: var(--ink-soft); line-height: 1.9; margin-top: 8px; }

.contact-main { display: grid; grid-template-columns: 1.4fr 1fr; gap: 30px; align-items: start; }
.contact-form-box { background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius); padding: 34px; box-shadow: var(--shadow-card); }
.cf-row { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.contact-form label { display: block; margin-bottom: 16px; }
.contact-form label span { display: block; font-size: 12.5px; color: var(--ink-soft); margin-bottom: 6px; }
.contact-form input, .contact-form select, .contact-form textarea { width: 100%; border: 1px solid var(--line); border-radius: 8px; padding: 11px 14px; font-size: 13px; font-family: var(--sans); background: var(--paper-soft); color: var(--ink); }
.contact-form input:focus, .contact-form select:focus, .contact-form textarea:focus { outline: none; border-color: var(--gold); }
.contact-form textarea { resize: vertical; }
.contact-side { display: flex; flex-direction: column; gap: 20px; }
.map-box { height: 240px; border-radius: var(--radius); background: linear-gradient(160deg,#aebfcd,#5b7a96 60%,#33485c); display: grid; place-items: center; color: rgba(255,255,255,.85); font-size: 13px; box-shadow: var(--shadow-soft); }
.side-info { background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius); padding: 24px; box-shadow: var(--shadow-soft); }
.side-info h4 { font-size: 16px; color: var(--brown); }

@media (max-width: 1024px) {
  .culture-grid { grid-template-columns: 1fr 1fr; }
  .why-grid { grid-template-columns: 1fr 1fr; }
  .tier-grid { grid-template-columns: 1fr; }
  .tier-card.featured { transform: none; }
  .tier-card.featured:hover { transform: translateY(-4px); }
  .steps-grid { grid-template-columns: 1fr 1fr; }
  .contact-cards { grid-template-columns: 1fr 1fr; }
  .contact-main { grid-template-columns: 1fr; }
  .news-featured { grid-template-columns: 1fr; }
  .news-layout { grid-template-columns: 1fr; }
  .news-grid { grid-template-columns: 1fr 1fr; }
  .ec-grid { grid-template-columns: 1fr 1fr; }
  .chair-card { grid-template-columns: 1fr; }
  .member-grid { grid-template-columns: 1fr; }
  .quick-grid { grid-template-columns: 1fr 1fr; }
  .theme-grid { grid-template-columns: 1fr; }
  .agenda-grid { grid-template-columns: 1fr; }
  .speaker-card { flex-basis: 46%; }
  .mv-grid, .gn-grid { grid-template-columns: 1fr; }
  .timeline { grid-template-columns: 1fr 1fr; }
  .timeline::before { display: none; }
  .about-block { grid-template-columns: 1fr; }
  .pillar-grid { grid-template-columns: repeat(2, 1fr); }
  .featured-card { grid-template-columns: 1fr; }
  .net-news { grid-template-columns: 1fr; }
  .person-card { flex-basis: 46%; }
  .hero h1 { font-size: 34px; }
}
@media (max-width: 640px) {
  .stat-row { grid-template-columns: 1fr 1fr; }
  .pillar-grid { grid-template-columns: 1fr; }
  .featured-right { grid-template-columns: 1fr; }
  .person-card { flex-basis: 80%; }
  .hero { height: auto; padding: 70px 0; }
  .page-hero { height: clamp(300px, 72vw, 460px); }
  .hero { height: clamp(360px, 88vw, 560px); }
  .page-hero h1, .sym-hero h1 { font-size: 28px; }
  .page-hero .en { font-size: 16px; }
  .page-hero p { font-size: 13px; }
}
