/* ===================================================
   黄竹烟追远堂 - 公开网站主样式
   =================================================== */
:root {
    --red:       #8B1A1A;
    --red-dark:  #5C0F0F;
    --red-light: #B52B2B;
    --gold:      #C9A84C;
    --gold-light:#E8C35A;
    --gold-pale: rgba(201,168,76,0.15);
    --dark:      #1C0A00;
    --dark-2:    #2C1A0A;
    --dark-3:    #3D2A10;
    --cream:     #FDF6E3;
    --cream-dim: #F2E8CC;
    --text:      #3A2010;
    --text-light:#6B5040;
    --shadow:    0 8px 32px rgba(28,10,0,0.35);
    --shadow-sm: 0 4px 16px rgba(28,10,0,0.2);
    --radius:    8px;
    --radius-lg: 16px;
    --transition: 0.35s cubic-bezier(0.4,0,0.2,1);
    --font-serif: 'Noto Serif SC','Ma Shan Zheng',serif;
    --font-sans:  'Noto Sans SC',sans-serif;
    --font-calligraphy: 'Ma Shan Zheng','Noto Serif SC',serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-sans);background:var(--cream);color:var(--text);line-height:1.8;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit;transition:var(--transition)}
button{cursor:pointer;border:none;background:none}
ul{list-style:none}

/* Loader */
.loader{position:fixed;inset:0;z-index:9999;background:var(--dark);display:flex;align-items:center;justify-content:center;transition:opacity .6s ease,visibility .6s ease}
.loader.hidden{opacity:0;visibility:hidden;pointer-events:none}
.loader-inner{text-align:center;position:relative}
.loader-ring{width:100px;height:100px;border:3px solid rgba(201,168,76,.2);border-top-color:var(--gold);border-radius:50%;animation:spinRing 1.2s linear infinite;margin:0 auto 20px}
.loader-logo{position:absolute;top:50%;left:50%;transform:translate(-50%,-65%);display:flex;gap:4px}
.loader-char{font-family:var(--font-calligraphy);color:var(--gold);font-size:1.4rem;animation:loaderCharIn .5s ease both}
.loader-char:nth-child(1){animation-delay:.2s}
.loader-char:nth-child(2){animation-delay:.4s}
.loader-char:nth-child(3){animation-delay:.6s}
@keyframes spinRing{to{transform:rotate(360deg)}}
@keyframes loaderCharIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

.container{max-width:1200px;margin:0 auto;padding:0 20px}

/* ===== NAVIGATION ===== */
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:0;transition:background .4s ease,box-shadow .4s ease}
.navbar.scrolled{background:rgba(28,10,0,.97);box-shadow:0 2px 20px rgba(0,0,0,.5);backdrop-filter:blur(12px)}
.nav-container{max-width:1280px;margin:0 auto;padding:16px 24px;display:flex;align-items:center;justify-content:space-between;transition:padding .4s}
.navbar.scrolled .nav-container{padding-top:10px;padding-bottom:10px}
.nav-logo{display:flex;align-items:center;gap:12px}
.nav-logo-icon{width:44px;height:44px;background:linear-gradient(135deg,var(--red),var(--red-dark));border:2px solid var(--gold);border-radius:6px;font-family:var(--font-calligraphy);color:var(--gold);font-size:1.4rem;display:flex;align-items:center;justify-content:center;box-shadow:0 0 12px rgba(201,168,76,.3);transition:var(--transition);flex-shrink:0}
.nav-logo:hover .nav-logo-icon{box-shadow:0 0 20px rgba(201,168,76,.6)}
.nav-logo-text{display:flex;flex-direction:column}
.nav-logo-main{font-family:var(--font-serif);color:var(--cream);font-size:1.05rem;font-weight:700;line-height:1.2}
.nav-logo-sub{font-family:var(--font-sans);color:var(--gold);font-size:.7rem;letter-spacing:.15em;line-height:1}
.nav-menu{display:flex;align-items:center;gap:4px}
.nav-link{color:rgba(253,246,227,.85);font-size:.92rem;font-family:var(--font-serif);padding:8px 14px;border-radius:4px;position:relative;transition:var(--transition)}
.nav-link::after{content:'';position:absolute;bottom:4px;left:50%;width:0;height:1px;background:var(--gold);transform:translateX(-50%);transition:width .3s}
.nav-link:hover,.nav-link.active{color:var(--gold)}
.nav-link:hover::after,.nav-link.active::after{width:60%}
.nav-admin-btn{background:linear-gradient(135deg,var(--red),var(--red-dark));border:1px solid var(--gold);color:var(--gold)!important;border-radius:4px;font-size:.85rem;padding:7px 14px;margin-left:8px}
.nav-admin-btn::after{display:none}
.nav-admin-btn:hover{background:var(--red-light);box-shadow:0 0 15px rgba(139,26,26,.5)}
.nav-toggle{display:none;flex-direction:column;gap:5px;width:30px;padding:4px}
.nav-toggle span{display:block;height:2px;width:100%;background:var(--cream);border-radius:2px;transition:var(--transition)}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav-overlay{display:none;position:fixed;inset:0;z-index:998;background:rgba(0,0,0,.6);backdrop-filter:blur(4px)}
.nav-overlay.active{display:block}

/* ===== HERO ===== */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden}
.hero-bg-layer{position:absolute;inset:0;background:radial-gradient(ellipse at 20% 50%,#3D0A0A 0%,#1C0A00 40%,#0A0500 100%);z-index:0}
.hero-pattern-layer{position:absolute;inset:0;background-image:radial-gradient(circle,rgba(201,168,76,.08) 1px,transparent 1px);background-size:48px 48px;z-index:1;animation:patternDrift 60s linear infinite}
@keyframes patternDrift{0%{background-position:0 0}100%{background-position:96px 96px}}
.hero-canvas{position:absolute;inset:0;z-index:2;pointer-events:none}
.deco-frame{position:absolute;inset:20px;z-index:3;pointer-events:none}
.deco-corner{position:absolute;width:50px;height:50px;border-color:rgba(201,168,76,.5);border-style:solid;animation:cornerPulse 3s ease-in-out infinite}
.deco-tl{top:0;left:0;border-width:2px 0 0 2px}
.deco-tr{top:0;right:0;border-width:2px 2px 0 0}
.deco-bl{bottom:0;left:0;border-width:0 0 2px 2px}
.deco-br{bottom:0;right:0;border-width:0 2px 2px 0}
@keyframes cornerPulse{0%,100%{opacity:.4}50%{opacity:1}}
.hero-content{position:relative;z-index:10;text-align:center;padding:80px 20px 40px}
.hero-eyebrow{display:flex;align-items:center;gap:16px;color:var(--gold);font-size:.85rem;letter-spacing:.25em;font-family:var(--font-serif);margin-bottom:28px;justify-content:center;opacity:.9}
.eyebrow-line{display:inline-block;width:48px;height:1px;background:linear-gradient(90deg,transparent,var(--gold))}
.eyebrow-line:last-child{background:linear-gradient(270deg,transparent,var(--gold))}
.hero-title{font-family:var(--font-calligraphy);color:var(--cream);margin-bottom:20px;display:flex;flex-direction:column;align-items:center;line-height:1.1}
.hero-title-small{font-size:clamp(1.2rem,3vw,1.8rem);color:var(--gold);letter-spacing:.4em;margin-bottom:8px;opacity:.9}
.hero-title-main{font-size:clamp(3rem,8vw,7rem);background:linear-gradient(135deg,#FFF8DC,var(--gold-light),var(--gold),#B8860B);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(0 0 30px rgba(201,168,76,.4));letter-spacing:.2em}
.hero-ornament{display:flex;align-items:center;gap:16px;justify-content:center;margin:20px 0}
.orn-line{flex:1;max-width:80px;height:1px;background:linear-gradient(90deg,transparent,var(--gold))}
.orn-line:last-child{background:linear-gradient(270deg,transparent,var(--gold))}
.orn-diamond{color:var(--gold);font-size:.8rem}
.hero-motto{color:rgba(253,246,227,.85);font-family:var(--font-serif);font-size:clamp(.9rem,2vw,1.1rem);letter-spacing:.3em;margin-bottom:12px}
.hero-quote{color:rgba(201,168,76,.7);font-family:var(--font-serif);font-size:.9rem;letter-spacing:.15em;margin-bottom:36px;font-style:italic}
.hero-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.hero-btn{padding:13px 32px;font-family:var(--font-serif);font-size:.95rem;letter-spacing:.1em;border-radius:4px;display:inline-flex;align-items:center;gap:8px;transition:var(--transition);position:relative;overflow:hidden}
.hero-btn::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.15),transparent);opacity:0;transition:opacity .3s}
.hero-btn:hover::before{opacity:1}
.hero-btn-primary{background:linear-gradient(135deg,var(--red),var(--red-dark));color:var(--cream);border:1px solid rgba(201,168,76,.4);box-shadow:0 4px 20px rgba(139,26,26,.5)}
.hero-btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(139,26,26,.7);border-color:var(--gold)}
.hero-btn-ghost{background:transparent;color:var(--gold);border:1px solid rgba(201,168,76,.5)}
.hero-btn-ghost:hover{background:rgba(201,168,76,.1);border-color:var(--gold);transform:translateY(-2px);box-shadow:0 4px 20px rgba(201,168,76,.2)}
.hero-scroll-hint{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:10;display:flex;flex-direction:column;align-items:center;gap:8px;color:rgba(253,246,227,.5);font-size:.75rem;letter-spacing:.1em;animation:scrollHintBob 2s ease-in-out infinite}
.scroll-mouse{width:22px;height:34px;border:1.5px solid rgba(253,246,227,.4);border-radius:11px;position:relative;display:flex;justify-content:center;padding-top:6px}
.scroll-wheel{width:3px;height:6px;background:rgba(201,168,76,.8);border-radius:2px;animation:scrollWheel 2s ease-in-out infinite}
@keyframes scrollHintBob{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(6px)}}
@keyframes scrollWheel{0%,100%{opacity:1;transform:translateY(0)}50%{opacity:0;transform:translateY(8px)}}

/* ===== NOTICE BAR ===== */
.notice-bar{background:var(--red-dark);border-top:1px solid rgba(201,168,76,.3);border-bottom:1px solid rgba(201,168,76,.3);display:flex;align-items:center;overflow:hidden;height:42px}
.notice-icon{flex-shrink:0;background:var(--red);color:var(--gold);padding:0 20px;height:100%;display:flex;align-items:center;gap:8px;font-family:var(--font-serif);font-size:.85rem;letter-spacing:.1em;border-right:1px solid rgba(201,168,76,.3);white-space:nowrap}
.notice-track-wrap{flex:1;overflow:hidden;padding:0 16px}
.notice-marquee{display:flex;gap:60px;white-space:nowrap;animation:marqueeScroll 30s linear infinite;color:rgba(253,246,227,.85);font-size:.85rem}
.notice-marquee:hover{animation-play-state:paused}
@keyframes marqueeScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ===== SECTIONS ===== */
.section{padding:90px 0;position:relative}
.section-header{text-align:center;margin-bottom:56px}
.sec-tag{display:inline-block;color:var(--gold);font-size:.8rem;letter-spacing:.3em;font-family:var(--font-sans);margin-bottom:12px;background:linear-gradient(135deg,var(--gold-pale),rgba(201,168,76,.05));border:1px solid rgba(201,168,76,.25);padding:4px 16px;border-radius:20px}
.sec-title{font-family:var(--font-calligraphy);font-size:clamp(1.8rem,4vw,2.8rem);color:var(--dark);margin-bottom:20px;letter-spacing:.1em}
.sec-divider{display:flex;align-items:center;gap:16px;justify-content:center;color:var(--gold)}
.sec-divider span{display:block;width:60px;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}
.sec-divider i{font-size:.9rem}
.spin-slow{animation:spinSlow 8s linear infinite}
@keyframes spinSlow{to{transform:rotate(360deg)}}

/* ===== ABOUT ===== */
.about-section{background:var(--cream)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.about-badge{display:inline-flex;background:var(--red);color:var(--gold);font-size:.78rem;letter-spacing:.15em;padding:4px 14px;border-radius:3px;margin-bottom:20px;font-family:var(--font-serif)}
.about-lead{font-family:var(--font-serif);font-size:1.1rem;color:var(--red);font-weight:600;margin-bottom:16px;line-height:1.7}
.about-text-col p{color:var(--text);margin-bottom:14px;font-size:.95rem}
.about-quote{margin-top:24px;padding:16px 20px;background:linear-gradient(135deg,rgba(139,26,26,.06),transparent);border-left:3px solid var(--gold);border-radius:0 8px 8px 0;display:flex;gap:12px;align-items:flex-start;color:var(--text-light);font-family:var(--font-serif);font-size:.9rem;font-style:italic}
.about-quote i{color:var(--gold);margin-top:2px;flex-shrink:0}
.about-frame{aspect-ratio:1;max-width:360px;margin:0 auto;position:relative;border:1px solid rgba(201,168,76,.25);border-radius:4px;padding:24px;background:linear-gradient(135deg,rgba(139,26,26,.04),rgba(201,168,76,.04))}
.about-frame-inner{width:100%;height:100%;min-height:280px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#3D1A0A 0%,#2C1206 100%);border-radius:2px;position:relative;overflow:hidden}
.clan-emblem{position:relative;display:flex;align-items:center;justify-content:center}
.emblem-char{font-family:var(--font-calligraphy);font-size:5rem;color:var(--gold);position:relative;z-index:2;animation:emblemGlow 3s ease-in-out infinite}
@keyframes emblemGlow{0%,100%{text-shadow:0 0 20px rgba(201,168,76,.4)}50%{text-shadow:0 0 50px rgba(201,168,76,.8),0 0 80px rgba(201,168,76,.3)}}
.emblem-ring{position:absolute;border-radius:50%;border:1px solid rgba(201,168,76,.3)}
.emblem-ring-1{width:120px;height:120px;animation:ringPulse 3s ease-in-out infinite}
.emblem-ring-2{width:180px;height:180px;animation:ringPulse 3s ease-in-out infinite .5s}
@keyframes ringPulse{0%,100%{opacity:.2;transform:scale(1)}50%{opacity:.6;transform:scale(1.05)}}
.frame-ornament{position:absolute;width:20px;height:20px;border-color:var(--gold);border-style:solid}
.fo-tl{top:8px;left:8px;border-width:2px 0 0 2px}
.fo-tr{top:8px;right:8px;border-width:2px 2px 0 0}
.fo-bl{bottom:8px;left:8px;border-width:0 0 2px 2px}
.fo-br{bottom:8px;right:8px;border-width:0 2px 2px 0}
.about-stats-row{display:flex;gap:16px;margin-top:24px;justify-content:center}
.stat-box{flex:1;text-align:center;background:var(--cream-dim);border:1px solid rgba(201,168,76,.2);border-radius:8px;padding:16px 8px;position:relative;overflow:hidden;transition:var(--transition)}
.stat-box::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--red),var(--gold))}
.stat-box:hover{transform:translateY(-4px);box-shadow:var(--shadow-sm)}
.stat-num{font-family:var(--font-serif);font-size:1.8rem;font-weight:700;color:var(--red);line-height:1}
.stat-unit{font-size:.75rem;color:var(--gold);margin:2px 0}
.stat-label{font-size:.78rem;color:var(--text-light);font-family:var(--font-sans)}

/* ===== NEWS ===== */
.news-section{background:var(--dark-2)}
.news-section .sec-title{color:var(--cream)}
.news-section .sec-tag{background:rgba(201,168,76,.1)}
.section-bg-pattern{position:absolute;inset:0;background-image:radial-gradient(circle,rgba(201,168,76,.04) 1px,transparent 1px);background-size:36px 36px;pointer-events:none}
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:40px}
.news-card{background:rgba(60,26,8,.6);border:1px solid rgba(201,168,76,.12);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:var(--transition);position:relative}
.news-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--red),var(--gold));transform:scaleX(0);transition:transform .35s;transform-origin:left}
.news-card:hover{transform:translateY(-6px);box-shadow:0 12px 40px rgba(0,0,0,.4);border-color:rgba(201,168,76,.3)}
.news-card:hover::after{transform:scaleX(1)}
.news-card-img{width:100%;height:180px;background:var(--dark-3);overflow:hidden}
.news-card-img img{width:100%;height:180px;object-fit:cover;transition:transform .5s}
.news-card:hover .news-card-img img{transform:scale(1.08)}
.news-card-img-placeholder{width:100%;height:180px;background:linear-gradient(135deg,var(--dark-3),var(--dark-2));display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:rgba(201,168,76,.4)}
.news-card-img-placeholder i{font-size:2rem}
.news-card-img-placeholder span{font-size:.8rem}
.news-card-body{padding:20px}
.news-card-meta{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.news-cat{background:var(--red);color:var(--gold);font-size:.7rem;padding:2px 8px;border-radius:2px;font-family:var(--font-serif);letter-spacing:.05em}
.news-date{color:rgba(253,246,227,.4);font-size:.75rem;margin-left:auto;display:flex;align-items:center;gap:4px}
.news-date i{font-size:.65rem}
.news-card-title{color:var(--cream);font-family:var(--font-serif);font-size:1rem;font-weight:600;margin-bottom:10px;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.news-card-summary{color:rgba(253,246,227,.55);font-size:.82rem;line-height:1.7;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.news-card-footer{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-top:1px solid rgba(201,168,76,.08)}
.news-read-more{color:var(--gold);font-size:.8rem;display:flex;align-items:center;gap:6px;transition:gap .2s}
.news-card:hover .news-read-more{gap:10px}
.news-views{color:rgba(253,246,227,.3);font-size:.75rem;display:flex;align-items:center;gap:4px}
.section-more{text-align:center}
.btn-more{display:inline-flex;align-items:center;gap:10px;padding:12px 36px;background:transparent;border:1px solid rgba(201,168,76,.35);color:var(--gold);font-family:var(--font-serif);font-size:.95rem;letter-spacing:.1em;border-radius:4px;transition:var(--transition);cursor:pointer}
.btn-more:hover{background:rgba(201,168,76,.1);border-color:var(--gold);transform:translateY(-2px);box-shadow:0 4px 20px rgba(201,168,76,.15)}

/* News Modal */
.modal-wrap{position:fixed;inset:0;z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s}
.modal-wrap.open{opacity:1;visibility:visible}
.modal-overlay{position:absolute;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(6px)}
.modal-box{position:relative;z-index:1;background:var(--dark-2);border:1px solid rgba(201,168,76,.2);border-radius:var(--radius-lg);max-width:750px;width:100%;max-height:85vh;overflow-y:auto;transform:scale(.9) translateY(20px);transition:transform .35s cubic-bezier(.34,1.56,.64,1)}
.modal-wrap.open .modal-box{transform:scale(1) translateY(0)}
.modal-close{position:sticky;top:0;float:right;margin:16px 16px 0 0;width:34px;height:34px;background:rgba(139,26,26,.8);border-radius:50%;color:var(--cream);display:flex;align-items:center;justify-content:center;font-size:.9rem;cursor:pointer;transition:var(--transition);z-index:10}
.modal-close:hover{background:var(--red);transform:rotate(90deg)}
.news-modal-content{padding:0 30px 30px}
.news-modal-content img{width:100%;border-radius:8px;margin-bottom:20px}
.news-modal-content h2{font-family:var(--font-calligraphy);color:var(--cream);font-size:1.5rem;margin-bottom:12px;line-height:1.4}
.news-modal-meta{display:flex;gap:16px;margin-bottom:20px;flex-wrap:wrap}
.news-modal-meta span{color:var(--gold);font-size:.82rem;display:flex;align-items:center;gap:6px}
.news-modal-body{color:rgba(253,246,227,.75);font-size:.92rem;line-height:1.9}

/* ===== GALLERY ===== */
.gallery-section{background:var(--cream)}
.gallery-filter-bar{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:40px}
.gf-btn{padding:8px 20px;border-radius:30px;border:1px solid rgba(139,26,26,.3);color:var(--text-light);font-family:var(--font-serif);font-size:.88rem;cursor:pointer;transition:var(--transition);background:transparent;display:flex;align-items:center;gap:6px}
.gf-btn:hover,.gf-btn.active{background:var(--red);color:var(--cream);border-color:var(--red);box-shadow:0 4px 16px rgba(139,26,26,.3)}
.activity-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.activity-card{border-radius:var(--radius);overflow:hidden;cursor:pointer;position:relative;box-shadow:var(--shadow-sm);transition:var(--transition);background:var(--dark);aspect-ratio:4/3}
.activity-card:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.activity-card-cover{width:100%;height:100%;object-fit:cover;transition:transform .6s;display:block}
.activity-card-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:linear-gradient(135deg,#3D1A0A,#5C2A10);color:rgba(201,168,76,.6)}
.activity-card-placeholder i{font-size:2.5rem}
.activity-card:hover .activity-card-cover{transform:scale(1.08)}
.activity-card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(28,10,0,.9) 0%,rgba(28,10,0,.1) 60%,transparent 100%);display:flex;flex-direction:column;justify-content:flex-end;padding:20px;transition:var(--transition)}
.activity-card:hover .activity-card-overlay{background:linear-gradient(to top,rgba(28,10,0,.95) 0%,rgba(28,10,0,.4) 60%,transparent 100%)}
.activity-card-name{color:var(--cream);font-family:var(--font-serif);font-size:1rem;font-weight:600;margin-bottom:6px;line-height:1.3}
.activity-card-meta{display:flex;align-items:center;justify-content:space-between}
.activity-card-date{color:var(--gold);font-size:.78rem;display:flex;align-items:center;gap:5px}
.activity-photo-count{background:rgba(201,168,76,.2);border:1px solid rgba(201,168,76,.4);color:var(--gold);font-size:.75rem;padding:2px 8px;border-radius:10px;display:flex;align-items:center;gap:4px}
.activity-card-view-hint{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:rgba(253,246,227,0);font-size:2rem;transition:color .3s}
.activity-card:hover .activity-card-view-hint{color:rgba(253,246,227,.9)}

/* ===== LIGHTBOX ===== */
.lightbox-wrap{position:fixed;inset:0;z-index:3000;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s}
.lightbox-wrap.open{opacity:1;visibility:visible}
.lb-overlay{position:absolute;inset:0;background:rgba(0,0,0,.92);backdrop-filter:blur(8px)}
.lb-box{position:relative;z-index:1;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center}
.lb-close{position:fixed;top:20px;right:20px;width:44px;height:44px;background:rgba(139,26,26,.8);border-radius:50%;color:white;font-size:1.1rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition);z-index:10}
.lb-close:hover{background:var(--red);transform:rotate(90deg) scale(1.1)}
.lb-nav{position:fixed;top:50%;transform:translateY(-50%);width:50px;height:50px;background:rgba(28,10,0,.7);border:1px solid rgba(201,168,76,.3);color:var(--gold);font-size:1.2rem;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition);z-index:10}
.lb-nav:hover{background:var(--red);border-color:var(--red);color:white}
.lb-prev{left:20px}
.lb-next{right:20px}
.lb-img-wrap{max-width:88vw;max-height:78vh;display:flex;align-items:center;justify-content:center}
.lb-img-wrap img{max-width:100%;max-height:78vh;border-radius:4px;box-shadow:0 20px 60px rgba(0,0,0,.7);object-fit:contain;animation:lbImgIn .3s ease}
@keyframes lbImgIn{from{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}
.lb-footer{display:flex;align-items:center;justify-content:space-between;width:100%;padding:12px 0;color:rgba(253,246,227,.7);font-size:.85rem;gap:16px}
.lb-caption{font-family:var(--font-serif)}
.lb-counter{color:var(--gold);font-size:.8rem;flex-shrink:0}

/* ===== FOOTER ===== */
.site-footer{background:var(--dark);position:relative}
.footer-wave{margin-bottom:-2px;display:block}
.footer-wave svg{display:block}
.footer-body{padding:60px 0 40px}
.footer-cols{display:grid;grid-template-columns:1.5fr 1fr 1.2fr;gap:48px}
.footer-logo{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.fl-icon{width:48px;height:48px;background:linear-gradient(135deg,var(--red),var(--red-dark));border:1px solid var(--gold);border-radius:6px;font-family:var(--font-calligraphy);color:var(--gold);font-size:1.5rem;display:flex;align-items:center;justify-content:center}
.fl-text{display:flex;flex-direction:column}
.fl-text b{color:var(--cream);font-family:var(--font-serif);font-size:1.1rem}
.fl-text span{color:var(--gold);font-size:.7rem;letter-spacing:.2em}
.footer-tagline{color:rgba(253,246,227,.55);font-size:.88rem;line-height:1.8;margin-bottom:20px}
.footer-socials{display:flex;gap:10px}
.social-icon{width:36px;height:36px;background:rgba(255,255,255,.06);border:1px solid rgba(201,168,76,.2);border-radius:50%;color:rgba(253,246,227,.6);display:flex;align-items:center;justify-content:center;font-size:.9rem;transition:var(--transition)}
.social-icon:hover{background:var(--red);border-color:var(--red);color:white;transform:translateY(-3px)}
.footer-col-title{color:var(--cream);font-family:var(--font-serif);font-size:.95rem;margin-bottom:20px;padding-bottom:10px;border-bottom:1px solid rgba(201,168,76,.15);position:relative}
.footer-col-title::after{content:'';position:absolute;bottom:-1px;left:0;width:30px;height:1px;background:var(--gold)}
.footer-nav{display:flex;flex-direction:column;gap:10px}
.footer-nav a{color:rgba(253,246,227,.55);font-size:.88rem;display:flex;align-items:center;gap:8px;transition:var(--transition)}
.footer-nav a i{font-size:.6rem;color:var(--gold);transition:transform .2s}
.footer-nav a:hover{color:var(--gold);padding-left:4px}
.footer-nav a:hover i{transform:translateX(3px)}
.footer-contact-list{display:flex;flex-direction:column;gap:12px}
.fc-item{display:flex;align-items:flex-start;gap:12px;color:rgba(253,246,227,.55);font-size:.88rem}
.fc-item i{color:var(--gold);margin-top:2px;width:14px;text-align:center;flex-shrink:0}
.footer-bottom{border-top:1px solid rgba(201,168,76,.1);padding:20px;display:flex;align-items:center;justify-content:center;gap:16px;color:rgba(253,246,227,.35);font-size:.8rem;flex-wrap:wrap;text-align:center}
.footer-divider{opacity:.3}
.footer-bottom a{color:rgba(201,168,76,.5)}
.footer-bottom a:hover{color:var(--gold)}

/* Back to Top */
.back-top{position:fixed;bottom:28px;right:28px;width:46px;height:46px;background:linear-gradient(135deg,var(--red),var(--red-dark));border:1px solid rgba(201,168,76,.4);border-radius:50%;color:var(--gold);font-size:1.1rem;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:500;opacity:0;visibility:hidden;transition:var(--transition);box-shadow:0 4px 20px rgba(139,26,26,.4)}
.back-top.show{opacity:1;visibility:visible}
.back-top:hover{transform:translateY(-4px);box-shadow:0 8px 30px rgba(139,26,26,.6)}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
    .news-grid{grid-template-columns:repeat(2,1fr)}
    .activity-cards{grid-template-columns:repeat(2,1fr)}
    .about-grid{gap:40px}
    .footer-cols{grid-template-columns:1fr 1fr;gap:36px}
    .footer-brand-col{grid-column:1/-1}
}
@media(max-width:768px){
    .nav-menu{position:fixed;top:0;right:-100%;bottom:0;width:min(320px,85vw);background:var(--dark);flex-direction:column;align-items:flex-start;padding:80px 24px 40px;gap:0;z-index:999;transition:right .4s cubic-bezier(.4,0,.2,1);border-left:1px solid rgba(201,168,76,.15);box-shadow:-10px 0 40px rgba(0,0,0,.4)}
    .nav-menu.open{right:0}
    .nav-link{width:100%;padding:14px 0;border-bottom:1px solid rgba(201,168,76,.08);font-size:1rem}
    .nav-admin-btn{margin-left:0;margin-top:16px;width:100%;justify-content:center}
    .nav-toggle{display:flex;z-index:1000}
    .nav-link::after{display:none}
    .about-grid{grid-template-columns:1fr;gap:32px}
    .about-visual-col{order:-1}
    .about-frame{max-width:280px}
    .news-grid{grid-template-columns:1fr}
    .activity-cards{grid-template-columns:repeat(2,1fr);gap:14px}
    .footer-cols{grid-template-columns:1fr;gap:32px}
    .footer-brand-col{grid-column:auto}
    .deco-frame{inset:10px}
    .deco-corner{width:30px;height:30px}
    .lb-nav{width:40px;height:40px;font-size:1rem}
    .lb-prev{left:8px}
    .lb-next{right:8px}
}
@media(max-width:480px){
    .activity-cards{grid-template-columns:1fr}
    .hero-btns{flex-direction:column;align-items:center}
    .hero-btn{width:100%;max-width:260px;justify-content:center}
    .section{padding:60px 0}
    .about-stats-row{flex-wrap:wrap}
    .stat-box{min-width:calc(50% - 8px)}
}
