.s-title{font-family:var(--ff-head);font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:700;line-height:1.1;margin-bottom:0.6rem}
.s-sub{font-size:0.95rem;line-height:1.8;max-width:580px;margin-bottom:2rem}

/* PAGE HERO */
.page-hero{position:relative;height:62vh;min-height:420px;display:flex;align-items:center;overflow:hidden}
.ph-img{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.04);animation:phZoom 10s ease-out forwards}
@keyframes phZoom{to{transform:scale(1)}}
.ph-overlay{position:absolute;inset:0;background:linear-gradient(100deg,rgba(13,8,0,0.82) 0%,rgba(13,8,0,0.38) 60%,transparent 100%)}
.ph-overlay2{position:absolute;inset:0;background:linear-gradient(to top,rgba(13,8,0,0.65) 0%,transparent 50%)}
.ph-content{position:relative;z-index:2;padding:100px 3.5rem 3rem;max-width:760px;animation:phIn 1s 0.2s both}
@keyframes phIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.ph-breadcrumb{display:flex;align-items:center;gap:0.5rem;font-family:var(--ff-mono);font-size:0.68rem;letter-spacing:0.15em;text-transform:uppercase;color:rgba(255,255,255,0.45);margin-bottom:1.2rem}
.ph-breadcrumb a{color:var(--gold);text-decoration:none}.ph-breadcrumb a:hover{color:var(--gold-light)}
.ph-breadcrumb span{color:rgba(255,255,255,0.3)}
.ph-tag{font-family:var(--ff-mono);font-size:0.72rem;letter-spacing:0.22em;text-transform:uppercase;color:var(--gold-light);margin-bottom:0.9rem;display:flex;align-items:center;gap:0.6rem}
.ph-tag::before{content:'';display:block;width:22px;height:1px;background:var(--gold)}
.ph-h1{font-family:var(--ff-head);font-size:clamp(2.4rem,5.5vw,4.4rem);font-weight:700;line-height:1.05;color:#fff;margin-bottom:1rem}
.ph-h1 em{color:var(--gold-light);font-style:italic}
.ph-desc{font-size:1rem;color:rgba(255,255,255,0.72);line-height:1.75;max-width:520px}

/* GALLERY SECTION */
.gallery-section{padding:5rem 3.5rem}
.gallery-header{max-width:1200px;margin:0 auto 2.5rem;display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.gallery-header .s-title{color:var(--text);margin-bottom:0}
.gallery-count{font-family:var(--ff-mono);font-size:0.72rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted)}

/* FILTER TABS */
.filter-tabs{display:flex;gap:0.5rem;flex-wrap:wrap;margin-bottom:2.5rem;max-width:1200px;margin-left:auto;margin-right:auto}
.ft{background:transparent;border:1px solid rgba(201,147,58,0.2);color:var(--muted);padding:0.5rem 1.2rem;font-family:var(--ff-mono);font-size:0.72rem;letter-spacing:0.12em;text-transform:uppercase;cursor:pointer;border-radius:1px;transition:all 0.2s}
.ft:hover{border-color:var(--gold);color:var(--gold)}
.ft.active{background:var(--gold);color:var(--dark);border-color:var(--gold);font-weight:600}

/* MASONRY GRID */
.gal-grid{max-width:1200px;margin:0 auto;columns:3;column-gap:1rem}
.gal-card{break-inside:avoid;margin-bottom:1rem;position:relative;border-radius:3px;overflow:hidden;cursor:pointer;background:var(--dark-mid);border:1px solid rgba(201,147,58,0.08)}
.gal-card img{width:100%;display:block;transition:transform 0.45s}
.gal-card:hover img{transform:scale(1.04)}
.gal-card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(13,8,0,0.85) 0%,rgba(13,8,0,0.2) 50%,transparent 100%);opacity:0;transition:opacity 0.3s;display:flex;flex-direction:column;justify-content:flex-end;padding:1.2rem}
.gal-card:hover .gal-card-overlay{opacity:1}
.gal-card-name{font-family:var(--ff-head);font-size:1.05rem;font-weight:600;color:#fff;line-height:1.2;margin-bottom:0.3rem}
.gal-card-caption{font-size:0.8rem;color:rgba(255,255,255,0.65);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.gal-card-date{font-family:var(--ff-mono);font-size:0.65rem;letter-spacing:0.1em;color:var(--gold-light);margin-top:0.5rem;text-transform:uppercase}
.gal-card-del{position:absolute;top:0.7rem;right:0.7rem;background:rgba(19,12,2,0.75);border:1px solid rgba(201,147,58,0.2);color:rgba(255,255,255,0.5);width:32px;height:32px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:0.9rem;opacity:0;transition:opacity 0.2s,background 0.2s,color 0.2s;backdrop-filter:blur(4px)}
.gal-card:hover .gal-card-del{opacity:1}
.gal-card-del:hover{background:rgba(201,147,58,0.85);color:var(--dark);border-color:var(--gold)}
.gal-card-official{position:absolute;top:0.7rem;left:0.7rem;background:rgba(201,147,58,0.88);color:#130c02;padding:0.2rem 0.55rem;font-family:var(--ff-mono);font-size:0.58rem;letter-spacing:0.12em;text-transform:uppercase;border-radius:1px;font-weight:700;pointer-events:none}

/* EMPTY STATE */
.empty-state{text-align:center;padding:5rem 2rem;max-width:480px;margin:0 auto}
.empty-icon{font-size:4rem;opacity:0.3;display:block;margin-bottom:1.5rem}
.empty-title{font-family:var(--ff-head);font-size:1.8rem;color:var(--muted);margin-bottom:0.6rem}
.empty-sub{font-size:0.9rem;color:var(--muted);line-height:1.7;opacity:0.7}

/* LIGHTBOX */
.lb{position:fixed;inset:0;background:rgba(10,6,0,0.97);z-index:1000;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity 0.3s,visibility 0.3s}
.lb.open{opacity:1;visibility:visible}
.lb-inner{position:relative;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center}
.lb-img{max-width:100%;max-height:75vh;object-fit:contain;border-radius:2px;display:block}
.lb-info{margin-top:1.2rem;text-align:center;max-width:600px}
.lb-name{font-family:var(--ff-head);font-size:1.5rem;color:var(--gold-light);margin-bottom:0.3rem}
.lb-caption{font-size:0.88rem;color:rgba(255,255,255,0.55);line-height:1.7}
.lb-date{font-family:var(--ff-mono);font-size:0.65rem;letter-spacing:0.12em;color:rgba(201,147,58,0.4);text-transform:uppercase;margin-top:0.5rem}
.lb-close{position:fixed;top:1.5rem;right:1.8rem;background:none;border:1px solid rgba(201,147,58,0.25);color:rgba(255,255,255,0.5);width:40px;height:40px;border-radius:50%;cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center;transition:all 0.2s}
.lb-close:hover{border-color:var(--gold);color:var(--gold-light)}
.lb-nav{position:fixed;top:50%;transform:translateY(-50%);background:none;border:1px solid rgba(201,147,58,0.22);color:rgba(255,255,255,0.45);width:44px;height:44px;border-radius:50%;cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center;transition:all 0.2s}
.lb-nav:hover{border-color:var(--gold);color:var(--gold-light)}
.lb-prev{left:1.5rem}.lb-next{right:1.5rem}
.lb-nav.hidden{opacity:0;pointer-events:none}

/* INVITE BAND */
.invite-band{background:var(--dark);padding:4rem 3.5rem;text-align:center;position:relative;overflow:hidden;border-top:1px solid rgba(201,147,58,0.1)}
.invite-band::before{content:'';position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(201,147,58,0.07),transparent 70%);pointer-events:none}
.invite-band .eyebrow{justify-content:center;color:var(--gold-light)}.invite-band .eyebrow::before{background:var(--gold-light)}
.invite-band .s-title{color:var(--gold-light);margin:0 auto 0.8rem;max-width:600px}
.invite-band .s-sub{color:rgba(255,255,255,0.45);margin:0 auto 2rem}
.ib-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.btn-primary{display:inline-block;background:var(--gold);color:var(--dark);border:none;padding:0.9rem 2.2rem;font-family:var(--ff-body);font-size:0.85rem;letter-spacing:0.1em;text-transform:uppercase;font-weight:600;cursor:pointer;border-radius:1px;text-decoration:none;transition:background 0.2s,transform 0.15s}
.btn-primary:hover{background:var(--gold-light);transform:translateY(-2px)}
.btn-ghost{display:inline-block;background:transparent;color:var(--gold-light);border:1px solid rgba(201,147,58,0.4);padding:0.9rem 2.2rem;font-family:var(--ff-body);font-size:0.85rem;letter-spacing:0.1em;text-transform:uppercase;font-weight:500;cursor:pointer;border-radius:1px;text-decoration:none;transition:all 0.2s}
.btn-ghost:hover{background:rgba(201,147,58,0.1);border-color:var(--gold)}

@media(max-width:960px){
  .ph-content{padding:80px 1.5rem 2rem}
  .gallery-section{padding:3rem 1.5rem}
  .gal-grid{columns:2}
  .invite-band{padding:3rem 1.5rem}
  .lb-nav{display:none}
}
@media(max-width:560px){
  .gal-grid{columns:1}
}
