
:root {
  --ink: #1a3d28;
  --gold: #c9a84c;
  --gold-light: #e8c97a;
  --jade: #2d6644;
  --jade-mid: #3d7a55;
  --smoke: #f0ece0;
  --crimson: #7a1515;
  --mist: rgba(240,236,224,0.6);
}

* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }

body {
  background: var(--ink);
  color: var(--smoke);
  font-family: 'Cormorant Garamond', serif;
  overflow-x: hidden;
  min-height: 100vh;
}

body::after {
  content:'';
  position:fixed;
  inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
  pointer-events:none;
  z-index:9999;
}

/* ── NAV ── */
nav {
  position:fixed; top:0; width:100%; z-index:500;
  padding:1.2rem 3rem;
  display:flex; justify-content:space-between; align-items:center;
  background:linear-gradient(to bottom, rgba(20,50,32,0.97) 0%, rgba(20,50,32,0.7) 80%, transparent);
  backdrop-filter:blur(4px);
}
.nav-logo {
  font-family:'Cinzel',serif; font-size:1rem;
  letter-spacing:0.35em; color:var(--gold); text-decoration:none;
  cursor:pointer;
}
.nav-links { display:flex; gap:2rem; list-style:none; }
.nav-links a {
  font-family:'Cinzel',serif; font-size:0.62rem;
  letter-spacing:0.18em; color:var(--smoke); text-decoration:none;
  opacity:0.75; transition:all 0.3s; cursor:pointer;
}
.nav-links a:hover, .nav-links a.active { opacity:1; color:var(--gold); }
.lang-btn {
  font-family:'Cinzel',serif; font-size:0.6rem; letter-spacing:0.15em;
  color:var(--gold); opacity:0.75; cursor:pointer;
  border:1px solid rgba(201,168,76,0.3); padding:0.25rem 0.7rem;
  transition:all 0.3s; background:none;
}
.lang-btn:hover { opacity:1; border-color:var(--gold); }

/* ── PAGES ── */
.page { display:none; min-height:100vh; }
.page.active { display:block; }

/* ── SHARED ── */
.section-label {
  font-family:'Cinzel',serif; font-size:0.58rem; letter-spacing:0.5em;
  color:var(--gold); opacity:0.7; margin-bottom:1.5rem;
  display:flex; align-items:center; gap:1rem;
}
.section-label::after {
  content:''; height:1px; background:rgba(201,168,76,0.3); width:50px;
}
.section-label.center { justify-content:center; }
.section-label.center::after { display:none; }
.section-label.center::before { content:''; height:1px; background:rgba(201,168,76,0.3); width:50px; }

h2.serif {
  font-family:'Cinzel',serif; font-weight:400;
  color:var(--smoke); line-height:1.2;
}
.cn {
  font-family:'Noto Serif SC',serif; font-weight:300;
  color:var(--smoke); opacity:0.45; line-height:2.2;
}
.gold-cn {
  font-family:'Noto Serif SC',serif; font-weight:300;
  color:var(--gold); opacity:0.55; letter-spacing:0.3em;
}
.body-text {
  font-size:1.05rem; line-height:2; font-weight:300;
  color:var(--smoke); opacity:0.72;
}
.divider {
  width:1px; height:60px;
  background:linear-gradient(to bottom,transparent,var(--gold),transparent);
  margin:2.5rem auto; opacity:0.3;
}
.gold-line {
  width:50px; height:1px; background:var(--gold);
  opacity:0.35; margin:1.5rem 0;
}
.gold-line.center { margin:1.5rem auto; }

.btn-gold {
  font-family:'Cinzel',serif; font-size:0.68rem; letter-spacing:0.22em;
  color:var(--ink); background:var(--gold); padding:0.9rem 2.2rem;
  text-decoration:none; border:none; cursor:pointer;
  transition:all 0.3s; display:inline-block;
}
.btn-gold:hover { background:var(--gold-light); }
.btn-outline {
  font-family:'Cinzel',serif; font-size:0.68rem; letter-spacing:0.22em;
  color:var(--gold); border:1px solid rgba(201,168,76,0.4);
  padding:0.9rem 2.2rem; text-decoration:none; cursor:pointer;
  transition:all 0.3s; display:inline-block; background:none;
}
.btn-outline:hover { border-color:var(--gold); background:rgba(201,168,76,0.14); }

.reveal { opacity:0; transform:translateY(30px); transition:opacity 0.8s ease, transform 0.8s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }

/* ── PAGE 1: HOME ── */
.hero {
  min-height:100vh; display:flex; align-items:center; justify-content:center;
  position:relative; overflow:hidden; padding:8rem 2rem 4rem;
}
.hero-bg {
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse 80% 60% at 50% 40%, rgba(30,74,50,0.12) 0%, transparent 70%),
    radial-gradient(ellipse 40% 40% at 15% 85%, rgba(139,26,26,0.05) 0%, transparent 60%),
    radial-gradient(ellipse 50% 40% at 85% 15%, rgba(201,168,76,0.14) 0%, transparent 60%);
}
.ring {
  position:absolute; border-radius:50%;
  border:1px solid rgba(201,168,76,0.14);
  top:50%; left:50%; transform:translate(-50%,-50%);
  animation:expand 10s ease-out infinite;
}
.ring:nth-child(1){ width:250px;height:250px;animation-delay:0s; }
.ring:nth-child(2){ width:500px;height:500px;animation-delay:2.5s; }
.ring:nth-child(3){ width:750px;height:750px;animation-delay:5s; }
.ring:nth-child(4){ width:1000px;height:1000px;animation-delay:7.5s; }
@keyframes expand {
  0%{opacity:0.5;transform:translate(-50%,-50%) scale(0.85);}
  100%{opacity:0;transform:translate(-50%,-50%) scale(1.15);}
}
.bagua-bg {
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  width:700px; height:700px; opacity:0.025;
  animation:spin 80s linear infinite;
}
@keyframes spin { to{transform:translate(-50%,-50%) rotate(360deg);} }

.hero-content { text-align:center; position:relative; z-index:2; max-width:820px; }
.eyebrow {
  font-family:'Cinzel',serif; font-size:0.6rem; letter-spacing:0.5em;
  color:var(--gold); opacity:0.75; margin-bottom:2rem;
  animation:fadeUp 1s ease both;
}
.hero-title {
  font-family:'Cinzel',serif; font-size:clamp(3.5rem,9vw,7rem);
  font-weight:600; line-height:0.95; letter-spacing:0.04em;
  margin-bottom:0.4rem; animation:fadeUp 1s 0.2s ease both;
}
.hero-title .gold { color:var(--gold); }
.hero-sub-cn {
  font-family:'Noto Serif SC',serif; font-size:clamp(1rem,2.5vw,1.6rem);
  font-weight:300; letter-spacing:0.55em; color:var(--gold); opacity:0.55;
  margin-bottom:2.5rem; animation:fadeUp 1s 0.35s ease both;
}
.hero-rule { width:55px; height:1px; background:var(--gold); opacity:0.35; margin:0 auto 2.5rem; animation:fadeUp 1s 0.45s ease both; }
.hero-desc {
  font-size:clamp(1rem,2vw,1.2rem); font-style:italic; font-weight:300;
  line-height:1.85; color:var(--smoke); opacity:0.72;
  max-width:560px; margin:0 auto 0.8rem;
  animation:fadeUp 1s 0.55s ease both;
}
.hero-desc-cn {
  font-family:'Noto Serif SC',serif; font-size:0.88rem; font-weight:300;
  line-height:2.2; color:var(--smoke); opacity:0.38;
  max-width:420px; margin:0 auto 3rem;
  animation:fadeUp 1s 0.65s ease both;
}
.hero-btns { display:flex; gap:1.5rem; justify-content:center; animation:fadeUp 1s 0.75s ease both; }
@keyframes fadeUp { from{opacity:0;transform:translateY(28px);} to{opacity:1;transform:translateY(0);} }

/* Home sections */
.home-story { padding:7rem 2rem; }
.home-story-inner {
  max-width:1100px; margin:0 auto;
  display:grid; grid-template-columns:1fr 1fr; gap:7rem; align-items:center;
}
.glyph-card {
  display:flex; align-items:center; justify-content:center;
  border:1px solid rgba(201,168,76,0.12);
  background:linear-gradient(135deg,rgba(45,102,68,0.08),rgba(8,10,7,0.7));
  position:relative;
}
.glyph-card-main { width:280px; height:360px; margin:0 auto; }
.glyph-card-accent {
  width:160px; height:200px; position:absolute; bottom:-30px; right:-30px;
  border-color:rgba(139,26,26,0.25);
  background:linear-gradient(135deg,rgba(139,26,26,0.08),rgba(8,10,7,0.85));
}
.glyph-xl { font-family:'Noto Serif SC',serif; font-size:5rem; color:var(--gold); opacity:0.35; }
.glyph-md { font-family:'Noto Serif SC',serif; font-size:3rem; color:var(--crimson); opacity:0.45; }

.home-pillars { padding:6rem 2rem; background:rgba(45,102,68,0.04); }
.pillars-inner { max-width:1100px; margin:0 auto; }
.pillars-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; margin-top:4rem; }
.pillar {
  padding:3rem 2rem; border:1px solid rgba(201,168,76,0.12);
  transition:all 0.4s; position:relative; overflow:hidden;
}
.pillar::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(45,102,68,0.06),transparent);
  opacity:0; transition:opacity 0.4s;
}
.pillar:hover::before { opacity:1; }
.pillar:hover { border-color:rgba(201,168,76,0.22); }
.pillar-num {
  font-family:'Cinzel',serif; font-size:0.55rem; letter-spacing:0.3em;
  color:var(--gold); opacity:0.45; margin-bottom:2rem;
}
.pillar-glyph { font-family:'Noto Serif SC',serif; font-size:2.2rem; color:var(--gold); opacity:0.5; margin-bottom:1.2rem; display:block; }
.pillar-title { font-family:'Cinzel',serif; font-size:0.95rem; font-weight:400; letter-spacing:0.08em; margin-bottom:0.25rem; color:var(--smoke); }

/* ── PAGE 2: OUR STORY ── */
.story-page { padding-top:7rem; }
.story-hero {
  min-height:65vh; display:flex; align-items:center; justify-content:center;
  position:relative; overflow:hidden;
  background:linear-gradient(to bottom, var(--ink), rgba(0,0,0,0.25), var(--ink));
  padding:6rem 2rem 4rem;
}
.story-hero-bg-char {
  position:absolute; font-family:'Noto Serif SC',serif;
  font-size:55vw; color:rgba(45,102,68,0.04);
  top:50%; left:50%; transform:translate(-45%,-50%);
  pointer-events:none; line-height:1; user-select:none;
}
.story-hero-content { text-align:center; position:relative; z-index:2; max-width:700px; }
.page-title { font-family:'Cinzel',serif; font-size:clamp(2rem,5vw,4rem); font-weight:400; margin-bottom:0.5rem; }

.story-chapters { max-width:800px; margin:0 auto; padding:5rem 2rem 8rem; }
.chapter { margin-bottom:5rem; padding-bottom:5rem; border-bottom:1px solid rgba(201,168,76,0.12); }
.chapter:last-child { border-bottom:none; }
.chapter-num {
  font-family:'Cinzel',serif; font-size:0.55rem; letter-spacing:0.5em;
  color:var(--gold); opacity:0.5; margin-bottom:1.5rem;
}
.chapter-title { font-family:'Cinzel',serif; font-size:clamp(1.4rem,3vw,2.2rem); font-weight:400; margin-bottom:0.4rem; color:var(--smoke); }

/* founder card */
.founder-card {
  display:grid; grid-template-columns:1fr 2fr; gap:4rem;
  align-items:center; margin:4rem 0; padding:3rem;
  border:1px solid rgba(201,168,76,0.15);
  background:linear-gradient(135deg,rgba(0,0,0,0.2),rgba(8,10,7,0.6));
}
.founder-portrait {
  aspect-ratio:3/4;
  background:linear-gradient(135deg,rgba(45,102,68,0.15),rgba(8,10,7,0.8));
  border:1px solid rgba(201,168,76,0.15);
  display:flex; align-items:center; justify-content:center;
}
.founder-glyph { font-family:'Noto Serif SC',serif; font-size:4rem; color:var(--gold); opacity:0.3; }
.founder-name { font-family:'Cinzel',serif; font-size:1.2rem; letter-spacing:0.15em; margin-bottom:0.3rem; color:var(--smoke); }
.founder-role { font-family:'Noto Serif SC',serif; font-size:0.8rem; color:var(--gold); opacity:0.55; letter-spacing:0.25em; margin-bottom:1.5rem; }

/* timeline */
.timeline { margin:3rem 0; }
.tl-item { display:grid; grid-template-columns:80px 1fr; gap:2rem; margin-bottom:2.5rem; }
.tl-year { font-family:'Cinzel',serif; font-size:0.7rem; letter-spacing:0.15em; color:var(--gold); opacity:0.6; padding-top:0.2rem; }
.tl-content-title { font-family:'Cinzel',serif; font-size:0.9rem; color:var(--smoke); margin-bottom:0.4rem; }

/* ── PAGE 3: PROTECTION ── */
.protection-page { padding-top:6rem; }
.protection-hero {
  min-height:55vh; display:flex; align-items:center; justify-content:center;
  padding:5rem 2rem 3rem; position:relative; overflow:hidden;
  background:linear-gradient(to bottom, var(--ink), rgba(139,26,26,0.04), var(--ink));
}
.protection-grid { max-width:1100px; margin:0 auto; padding:5rem 2rem 8rem; }
.protection-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; margin-top:4rem; }
.pcard {
  border:1px solid rgba(201,168,76,0.15); padding:3rem 2rem;
  position:relative; overflow:hidden; transition:all 0.4s;
  background:linear-gradient(to bottom,rgba(0,0,0,0.12),transparent);
}
.pcard:hover { border-color:rgba(201,168,76,0.28); transform:translateY(-5px); }
.pcard-glyph { font-family:'Noto Serif SC',serif; font-size:3rem; color:var(--gold); opacity:0.45; margin-bottom:1.5rem; display:block; }
.pcard-title { font-family:'Cinzel',serif; font-size:1.1rem; font-weight:400; margin-bottom:0.3rem; color:var(--smoke); }
.pcard-subtitle { font-family:'Noto Serif SC',serif; font-size:0.75rem; color:var(--gold); opacity:0.5; letter-spacing:0.2em; margin-bottom:1.2rem; }
.pcard-body { font-size:0.95rem; line-height:1.9; color:var(--smoke); opacity:0.62; font-weight:300; margin-bottom:0.8rem; }
.pcard-body-cn { font-family:'Noto Serif SC',serif; font-size:0.78rem; line-height:2.1; color:var(--smoke); opacity:0.35; }

/* ritual steps */
.ritual-section { background:rgba(201,168,76,0.03); padding:6rem 2rem; }
.ritual-inner { max-width:900px; margin:0 auto; }
.ritual-steps { margin-top:3rem; }
.rstep { display:grid; grid-template-columns:60px 1fr; gap:2rem; margin-bottom:3rem; padding-bottom:3rem; border-bottom:1px solid rgba(201,168,76,0.1); }
.rstep:last-child { border-bottom:none; }
.rstep-num {
  font-family:'Cinzel',serif; font-size:1.8rem; font-weight:600;
  color:var(--gold); opacity:0.2; line-height:1;
}
.rstep-title { font-family:'Cinzel',serif; font-size:1rem; color:var(--smoke); margin-bottom:0.3rem; }
.rstep-cn { font-family:'Noto Serif SC',serif; font-size:0.75rem; color:var(--gold); opacity:0.45; letter-spacing:0.2em; margin-bottom:0.8rem; }

/* ── PAGE 4: ANCESTORS ── */
.ancestors-page { padding-top:6rem; }
.ancestors-hero {
  min-height:70vh; display:flex; align-items:center; justify-content:center;
  padding:5rem 2rem 3rem; position:relative; overflow:hidden;
}
.ancestors-hero-bg {
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse 60% 80% at 50% 50%, rgba(139,26,26,0.08) 0%, transparent 70%),
    radial-gradient(ellipse 100% 50% at 50% 100%, rgba(0,0,0,0.2) 0%, transparent 60%);
}
.quote-block {
  border-left:2px solid rgba(201,168,76,0.4); padding-left:2rem;
  margin:3rem 0;
}
.quote-text { font-size:clamp(1.2rem,2.5vw,1.8rem); font-style:italic; font-weight:300; line-height:1.7; color:var(--smoke); opacity:0.85; margin-bottom:0.5rem; }
.quote-source { font-family:'Cinzel',serif; font-size:0.62rem; letter-spacing:0.35em; color:var(--gold); opacity:0.55; }

.ancestors-content { max-width:900px; margin:0 auto; padding:5rem 2rem 8rem; }
.dual-column { display:grid; grid-template-columns:1fr 1fr; gap:5rem; margin:4rem 0; }
.culture-card {
  padding:2.5rem; border:1px solid rgba(201,168,76,0.15);
  background:linear-gradient(to bottom,rgba(0,0,0,0.15),transparent);
}
.culture-icon { font-family:'Noto Serif SC',serif; font-size:2.5rem; color:var(--gold); opacity:0.45; margin-bottom:1rem; display:block; }
.culture-title { font-family:'Cinzel',serif; font-size:1rem; font-weight:400; color:var(--smoke); margin-bottom:0.3rem; }
.culture-subtitle { font-family:'Noto Serif SC',serif; font-size:0.75rem; color:var(--gold); opacity:0.5; letter-spacing:0.2em; margin-bottom:1rem; }

/* ── PAGE 5: SHOP ── */
.shop-page { padding-top:6rem; }
.shop-hero { min-height:45vh; display:flex; align-items:center; justify-content:center; padding:5rem 2rem 3rem; }
.shop-grid-outer { max-width:1200px; margin:0 auto; padding:4rem 2rem 8rem; }
.shop-filter { display:flex; gap:1rem; margin-bottom:3rem; flex-wrap:wrap; }
.filter-btn {
  font-family:'Cinzel',serif; font-size:0.6rem; letter-spacing:0.18em;
  color:var(--smoke); opacity:0.5; border:1px solid rgba(201,168,76,0.15);
  padding:0.5rem 1.2rem; cursor:pointer; background:none; transition:all 0.3s;
}
.filter-btn.active, .filter-btn:hover { opacity:1; color:var(--gold); border-color:rgba(201,168,76,0.4); }
.shop-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.5rem; }
.scard {
  border:1px solid rgba(201,168,76,0.12); cursor:pointer;
  transition:all 0.4s; position:relative;
}
.scard:hover { border-color:rgba(201,168,76,0.28); transform:translateY(-4px); }
.scard-img {
  aspect-ratio:1; background:linear-gradient(135deg,rgba(0,0,0,0.25),rgba(8,10,7,0.8));
  display:flex; align-items:center; justify-content:center;
  border-bottom:1px solid rgba(201,168,76,0.1);
}
.scard-glyph { font-family:'Noto Serif SC',serif; font-size:3rem; color:var(--gold); opacity:0.3; }
.scard-body { padding:1.5rem; }
.scard-name { font-family:'Cinzel',serif; font-size:0.8rem; letter-spacing:0.08em; color:var(--smoke); margin-bottom:0.2rem; }
.scard-name-cn { font-family:'Noto Serif SC',serif; font-size:0.7rem; color:var(--gold); opacity:0.45; letter-spacing:0.15em; margin-bottom:0.8rem; }
.scard-desc { font-size:0.82rem; line-height:1.7; color:var(--smoke); opacity:0.5; font-style:italic; margin-bottom:1rem; }
.scard-tag {
  position:absolute; top:0.8rem; right:0.8rem;
  font-family:'Cinzel',serif; font-size:0.48rem; letter-spacing:0.18em;
  color:var(--gold); opacity:0.6; border:1px solid rgba(201,168,76,0.2); padding:0.2rem 0.5rem;
}
.notify-form { display:flex; gap:0; margin-top:0.5rem; }
.notify-input {
  flex:1; padding:0.5rem 0.8rem; background:rgba(201,168,76,0.04);
  border:1px solid rgba(201,168,76,0.2); border-right:none;
  color:var(--smoke); font-family:'Cormorant Garamond',serif; font-size:0.8rem;
  outline:none;
}
.notify-input::placeholder { opacity:0.35; }
.notify-submit {
  padding:0.5rem 0.8rem; background:rgba(201,168,76,0.15);
  border:1px solid rgba(201,168,76,0.2); color:var(--gold);
  font-family:'Cinzel',serif; font-size:0.55rem; letter-spacing:0.12em;
  cursor:pointer; transition:all 0.3s;
}
.notify-submit:hover { background:rgba(201,168,76,0.25); }

/* ── PAGE 6: RITUAL ── */
.ritual-page { padding-top:6rem; }
.ritual-hero { min-height:55vh; display:flex; align-items:center; justify-content:center; padding:5rem 2rem 3rem; }
.ritual-content { max-width:900px; margin:0 auto; padding:4rem 2rem 8rem; }
.ritual-guide { margin:4rem 0; }
.guide-card {
  display:grid; grid-template-columns:1fr 2fr; gap:4rem;
  align-items:start; margin-bottom:5rem; padding-bottom:5rem;
  border-bottom:1px solid rgba(201,168,76,0.12);
}
.guide-card:last-child { border-bottom:none; }
.guide-card.reverse { direction:rtl; }
.guide-card.reverse > * { direction:ltr; }
.guide-visual {
  aspect-ratio:1; border:1px solid rgba(201,168,76,0.12);
  background:linear-gradient(135deg,rgba(0,0,0,0.2),rgba(8,10,7,0.7));
  display:flex; align-items:center; justify-content:center;
}
.guide-glyph { font-family:'Noto Serif SC',serif; font-size:4rem; color:var(--gold); opacity:0.3; }
.guide-step { font-family:'Cinzel',serif; font-size:0.55rem; letter-spacing:0.4em; color:var(--gold); opacity:0.5; margin-bottom:1rem; }
.guide-title { font-family:'Cinzel',serif; font-size:clamp(1.2rem,2.5vw,1.8rem); font-weight:400; color:var(--smoke); margin-bottom:0.3rem; }
.guide-title-cn { font-family:'Noto Serif SC',serif; font-size:0.82rem; color:var(--gold); opacity:0.5; letter-spacing:0.25em; margin-bottom:1.2rem; }

/* ── FOOTER ── */
footer {
  padding:3.5rem 3rem; border-top:1px solid rgba(201,168,76,0.14);
  display:flex; justify-content:space-between; align-items:center;
}
.footer-logo { font-family:'Cinzel',serif; font-size:0.9rem; letter-spacing:0.3em; color:var(--gold); opacity:0.65; }
.footer-links { display:flex; gap:2rem; list-style:none; }
.footer-links a { font-family:'Cinzel',serif; font-size:0.58rem; letter-spacing:0.18em; color:var(--smoke); opacity:0.35; text-decoration:none; transition:opacity 0.3s; cursor:pointer; }
.footer-links a:hover { opacity:0.75; }
.footer-copy { font-size:0.75rem; color:var(--smoke); opacity:0.2; font-style:italic; }

/* ── RESPONSIVE ── */
@media(max-width:860px){
  nav { padding:1.2rem 1.5rem; }
  .nav-links { display:none; }
  .home-story-inner, .dual-column, .founder-card, .guide-card { grid-template-columns:1fr; gap:2rem; }
  .glyph-card-accent { display:none; }
  .pillars-grid, .protection-cards { grid-template-columns:1fr; }
  .shop-grid { grid-template-columns:repeat(2,1fr); }
  footer { flex-direction:column; gap:2rem; text-align:center; }
  .guide-card.reverse { direction:ltr; }
}
