/* Core Theme */
:root{
  --red:#d4191e;
  --red-dark:#9f0f13;
  --gold:#ffcf40;
  --ink:#1a1a1a;
  --paper:#fff7f0;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--paper);color:#2a2a2a;font-family:'Noto Sans SC',system-ui,Segoe UI,Arial,sans-serif;}

/* Decorative Chinese background with clouds & waves */
body::before{
  content:'';position:fixed;inset:0;z-index:-2;
  background:
    radial-gradient(1000px 500px at 10% -10%, rgba(255,255,255,.35), transparent 60%),
    radial-gradient(800px 400px at 90% 0%, rgba(255,255,255,.25), transparent 60%),
    linear-gradient(180deg, #fff6ef 0%, #ffe3d8 100%);
}
body::after{
  content:'';position:fixed;inset:0;z-index:-3;opacity:.15;
  background-image:
    radial-gradient(circle at 20% 10%, var(--gold) 2px, transparent 2px),
    radial-gradient(circle at 40% 30%, var(--gold) 2px, transparent 2px),
    radial-gradient(circle at 60% 20%, var(--gold) 2px, transparent 2px);
  background-size: 120px 120px;
}

/* Parallax Hero */
.hero{position:relative;display:grid;place-items:center;min-height:85vh;overflow:hidden}
.hero-banner{max-width:min(1200px,96vw);width:95%;border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.2)}
.hero .hero-glow{position:absolute;inset:-40%;background:radial-gradient(circle at 50% 50%, rgba(212,25,30,.35), transparent 50%);filter:blur(40px);z-index:-1;}
.hero .title-cn{font-family:'Ma Shan Zheng','ZCOOL KuaiLe',cursive;font-size:clamp(28px,5vw,54px);color:var(--red);text-shadow:0 2px 0 #fff, 0 10px 30px rgba(212,25,30,.25)}
.hero .title-en{font-family:'ZCOOL KuaiLe','Noto Sans SC',sans-serif;letter-spacing:1px}
.hero .lead{max-width:900px;line-height:1.6}
.hero .cta-row{display:flex;gap:12px;margin-top:18px;flex-wrap:wrap}
.lanterns .lantern{position:absolute;top:5%;width:70px;height:110px;border-radius:40px;background:linear-gradient(180deg,#ff5a5a,#b10c10);box-shadow:0 10px 30px rgba(0,0,0,.25);animation:float 4s ease-in-out infinite}
.lantern-left{left:4%}
.lantern-right{right:4%;animation-delay:1s}
.lantern::after{content:'';position:absolute;top:-18px;left:50%;transform:translateX(-50%);width:30px;height:18px;background:#333;border-radius:6px}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* Nav */
.nav{position:sticky;top:0;z-index:50;background:rgba(255,247,240,.85);backdrop-filter:saturate(1.4) blur(8px);border-bottom:1px solid #f5d6c3}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:10px 20px;max-width:1200px;margin:0 auto}
.brand{display:flex;align-items:center;gap:10px}
.brand-logo{width:40px;height:40px;filter:drop-shadow(0 2px 6px rgba(0,0,0,.2))}
.brand-title{font-family:'ZCOOL KuaiLe','Noto Sans SC',sans-serif;font-size:22px;letter-spacing:2px;margin:0}
.brand-sub{font-size:12px;color:#a1551e;margin-top:-6px}
.nav-links a{padding:8px 10px;border-radius:10px;text-decoration:none;color:#5a2b20;font-weight:700;font-family:'ZCOOL KuaiLe';transition:.25s}
.nav-links a:hover{background:#ffe6cf;transform:translateY(-2px)}

/* Sections */
.section{padding:64px 20px}
.section-alt{background:linear-gradient(180deg,#fff7f1,#ffece1)}
.container{max-width:1200px;margin:0 auto}
.section-title{font-size:32px;margin:0 0 16px;font-weight:900}
.section-title .accent{color:var(--red)}
.center{text-align:center}

/* Layout */
.grid{display:grid;gap:24px}
.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid.three{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
@media(max-width:900px){.grid.two{grid-template-columns:1fr}}

/* Cards + effects */
.card{background:#fff;border-radius:16px;box-shadow:0 12px 30px rgba(0,0,0,.12);padding:10px;transition:transform .25s, box-shadow .25s}
.card img{width:100%;display:block;border-radius:12px}
.tilt{transform:perspective(600px) rotateX(2deg) rotateY(-2deg)}
.tilt:hover{transform:perspective(600px) rotateX(0deg) rotateY(0deg) translateY(-4px)}

/* Values */
.vcard{background:#fff;border-radius:16px;padding:20px;box-shadow:0 10px 24px rgba(0,0,0,.12);text-align:center}
.vicon{font-size:36px;margin-bottom:8px}
.hover-pop{transition:transform .2s, box-shadow .2s}
.hover-pop:hover{transform:translateY(-6px) scale(1.02);box-shadow:0 18px 40px rgba(0,0,0,.18)}

/* Buttons */
.btn{cursor:pointer;border:0;border-radius:14px;padding:12px 18px;font-weight:900;font-family:'ZCOOL KuaiLe','Noto Sans SC',sans-serif;letter-spacing:1px;transition:transform .15s, box-shadow .2s;box-shadow:0 8px 18px rgba(0,0,0,.16)}
.btn:active{transform:translateY(1px) scale(.98)}
.btn-gold{background:linear-gradient(180deg,#ffe47a,#ffcf40);color:#733d00}
.btn-dragon{background:linear-gradient(180deg,var(--red),var(--red-dark));color:#fff}
.btn-outline{background:#fff;border:2px solid var(--red);color:var(--red)}
.hover-wiggle:hover{animation:wiggle .25s ease-in-out 2}
@keyframes wiggle{0%{transform:rotate(0)}25%{transform:rotate(-2deg)}75%{transform:rotate(2deg)}100%{transform:rotate(0)}}
.spin-slow{animation:spin 12s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.floaty{animation:float 5s ease-in-out infinite}

/* Badges */
.badges{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}
.pill{background:#ffe6b3;color:#7a3b00;border-radius:999px;padding:6px 12px;font-weight:700}

/* Masonry gallery */
.masonry{columns:3 260px;column-gap:16px}
.masonry .card{display:inline-block;margin:0 0 16px;width:100%}

/* Footer */
.footer{padding:24px 20px;background:#120b0b;color:#ffdb9b}
.footer .fwrap{display:flex;justify-content:space-between;gap:16px;max-width:1200px;margin:0 auto}
.footer a{color:#ffd86a}

/* Confetti canvas */
#bgConfetti{position:fixed;inset:0;pointer-events:none;z-index:5}
