/* Gabriel Music Company – Angel Metal Theme v2.0 */
/* Fonts loaded via <link> in header.php */
:root{
--bg:#030308;--bg0:#030308;--bg1:#080810;--bg2:#0d0d18;--bgc:#0d0d18;--bgch:#111120;
--heaven:#c8d4e8;--heaven-l:#f0f4ff;--heaven-d:#bac4d5;
--hell:#c41c1c;--hell-l:#e83030;--hell-d:#090606;--ember:#e8500a;
--gold:#d4af37;--gold-l:#f0cc60;--gold-d:#8a6d1a;
--red:#b01a1a;--red-l:#d42020;--red-d:#6b0000;
--text:#f0f0f8;--text2:#a0a0b8;--text3:#606078;--text-muted:#707088;--border:#1e1e30;
--glow-heaven:0 0 28px rgba(200,212,232,.4);--glow-hell:0 0 28px rgba(196,28,28,.55);
--glow-gold:0 0 28px rgba(212,175,55,.5);--glow-red:0 0 28px rgba(176,26,26,.5);
--navh:76px;--ease:cubic-bezier(.25,.46,.45,.94)}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px}
body{background:var(--bg);color:var(--text);font-family:'Barlow','Segoe UI',sans-serif;font-size:17px;line-height:1.85;overflow-x:hidden}
body::before{content:'';position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.04;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='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:200px}
.smoke-layer{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.smoke-layer::before{content:'';position:absolute;width:80vw;height:80vh;top:-20vh;left:-20vw;background:radial-gradient(ellipse at center,rgba(200,212,232,.05),transparent 60%);animation:smokeA 25s ease-in-out infinite alternate}
.smoke-layer::after{content:'';position:absolute;width:70vw;height:70vh;bottom:-20vh;right:-20vw;background:radial-gradient(ellipse at center,rgba(196,28,28,.05),transparent 60%);animation:smokeB 35s ease-in-out infinite alternate}
@keyframes smokeA{0%{transform:translate(0,0) scale(1)}100%{transform:translate(15vw,10vh) scale(1.3)}}
@keyframes smokeB{0%{transform:translate(0,0) scale(1)}100%{transform:translate(-15vw,-10vh) scale(1.2)}}
@media(prefers-reduced-motion:reduce){.smoke-layer::before,.smoke-layer::after{animation:none}body::before{display:none}}
img{max-width:100%;height:auto;display:block}
a{color:var(--heaven);text-decoration:none;transition:all .3s var(--ease)}
a:hover{color:var(--heaven-l)}
ul{list-style:none}
h1,h2,h3,h4,h5{font-family:'Cinzel',serif;font-weight:700;line-height:1.2;letter-spacing:.05em}
.display{font-family:'Metal Mania',cursive;font-weight:400;letter-spacing:.04em}
.metal-text{background:linear-gradient(180deg,#fff 0%,#c8d4e8 25%,#7a8fa8 60%,#c8d4e8 85%,#fff 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hell-text{background:linear-gradient(180deg,#ff8080 0%,#e83030 35%,#6b0000 65%,#e83030 85%,#ff8080 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.gold-text{background:linear-gradient(180deg,#ffe066 0%,#d4af37 40%,#8a6d1a 70%,#d4af37 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.section-eyebrow{font-family:'Rajdhani',sans-serif;font-size:.78rem;letter-spacing:.4em;text-transform:uppercase;color:var(--heaven-d);margin-bottom:.4rem}
.ornament{display:flex;align-items:center;justify-content:center;gap:.8rem;margin:0 auto .5rem}
.ornament::before,.ornament::after{content:'';flex:1;max-width:100px;height:1px;background:linear-gradient(90deg,transparent,var(--heaven-d),var(--heaven),var(--heaven-d),transparent)}
.ornament-gem{width:7px;height:7px;background:var(--gold);transform:rotate(45deg);flex-shrink:0;box-shadow:var(--glow-gold)}
.wing-l,.wing-r{display:none;position:absolute;top:50%;width:90px;height:55px;background:linear-gradient(135deg,rgba(212,175,55,.55),rgba(212,175,55,.2),transparent);clip-path:polygon(100% 0%,35% 8%,0% 50%,35% 92%,100% 100%,72% 50%)}
.wing-l{right:calc(100% + 1.5rem);transform:translateY(-50%) scaleX(-1)}
.wing-r{left:calc(100% + 1.5rem);transform:translateY(-50%)}
@media(min-width:700px){.wing-l,.wing-r{display:block}}
.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}
.section{padding:5rem 0;position:relative}
.section-dark{background:var(--bg1)}
.section-header{text-align:center;margin-bottom:3rem}

/* HEADER */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--navh);background:rgba(5,5,11,.82);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(200,212,232,.08);transition:all .3s var(--ease)}
.site-header.scrolled{background:rgba(5,5,11,.97);border-bottom-color:rgba(200,212,232,.18);box-shadow:0 2px 40px rgba(0,0,0,.5)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:100%;padding:0 1.5rem;max-width:1440px;margin:0 auto;gap:.75rem}
.site-logo{display:flex;align-items:center;gap:.6rem;text-decoration:none;flex-shrink:0}
.logo-img{height:76px;width:auto;transition:opacity .3s}
.site-logo:hover .logo-img{opacity:.85}
.logo-text{font-family:'Cinzel Decorative',serif;font-size:clamp(.68rem,1.3vw,.9rem);font-weight:900;letter-spacing:.04em;text-transform:uppercase;line-height:1.15;background:linear-gradient(180deg,#fff 0%,#ccc 45%,#888 70%,var(--gold) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.main-nav{display:flex;align-items:center;gap:.1rem}
.nav-link{font-family:'Cinzel',serif;font-size:.68rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--text2);padding:.42rem .65rem;position:relative;transition:all .3s}
.nav-link::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:0;height:1px;background:var(--hell);box-shadow:0 0 6px var(--hell);transition:width .3s}
.nav-link:hover,.nav-link.active{color:var(--text)}
.nav-link:hover::after,.nav-link.active::after{width:80%}
.social-nav{display:flex;align-items:center;gap:.32rem;flex-shrink:0}
.social-icon{width:31px;height:31px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:rgba(255,255,255,.04);border:1px solid var(--border);color:var(--text2);font-size:.75rem;transition:all .3s}
.social-icon:hover{transform:translateY(-2px);color:#fff}
.social-icon.youtube:hover{background:#ff0000;border-color:#ff0000;box-shadow:0 0 14px rgba(255,0,0,.45)}
.social-icon.spotify:hover{background:#1db954;border-color:#1db954;box-shadow:0 0 14px rgba(29,185,84,.45)}
.social-icon.apple:hover{background:#fc3c44;border-color:#fc3c44;box-shadow:0 0 14px rgba(252,60,68,.45)}
.social-icon.facebook:hover{background:#1877f2;border-color:#1877f2;box-shadow:0 0 14px rgba(24,119,242,.45)}
.social-icon.instagram:hover{background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#bc1888);border-color:#dc2743;box-shadow:0 0 14px rgba(220,39,67,.45)}
.social-icon.tiktok:hover{background:#010101;border-color:#ff0050;box-shadow:0 0 14px rgba(255,0,80,.45)}
.social-icon.ytmusic:hover{background:#ff0000;border-color:#ff0000;box-shadow:0 0 14px rgba(255,0,0,.45)}
.social-icon.ytmusic svg{width:1em;height:1em;fill:currentColor}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:.4rem;background:none;border:none}
.hamburger span{width:24px;height:2px;background:var(--text);transition:all .3s;transform-origin:left center}
.hamburger.active span:nth-child(1){transform:rotate(43deg)}
.hamburger.active span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.active span:nth-child(3){transform:rotate(-43deg)}
.mobile-menu{display:flex;flex-direction:column;visibility:hidden;position:fixed;top:var(--navh);left:0;right:0;background:rgba(5,5,11,.98);padding:1.5rem;border-bottom:2px solid var(--hell-d);z-index:999;transform:translateY(-110%);transition:transform .35s ease,visibility 0s .35s}
.mobile-menu.open{transform:translateY(0);visibility:visible;transition:transform .35s ease,visibility 0s 0s}
.mobile-nav-link{display:block;font-family:'Cinzel',serif;font-size:.88rem;letter-spacing:.1em;color:var(--text2);padding:.72rem 0;border-bottom:1px solid var(--border);transition:all .3s}
.mobile-nav-link:hover,.mobile-nav-link.active{color:var(--hell-l);padding-left:.5rem}
.mobile-social{display:flex;gap:.6rem;margin-top:1.25rem}

/* ===== HERO ===== */
.hero{position:relative;height:58vw;min-height:280px;overflow:hidden;margin-top:var(--navh)}
.hero-photo{position:absolute;top:-2%;left:0;right:0;bottom:0;background-image:url('../images/band/GMC_1.jpg');background-size:cover;background-position:center top;filter:brightness(.38) saturate(.6)}
.hero-rays{position:absolute;inset:0;background:radial-gradient(ellipse 65% 70% at 0% 0%,rgba(200,212,232,.18) 0%,transparent 60%),radial-gradient(ellipse 65% 70% at 100% 100%,rgba(196,28,28,.22) 0%,transparent 60%);pointer-events:none}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(3,3,8,.35) 0%,rgba(3,3,8,.15) 40%,rgba(3,3,8,.9) 85%,var(--bg) 100%);box-shadow:inset 4px 0 40px rgba(200,212,232,.06),inset -4px 0 40px rgba(196,28,28,.06);pointer-events:none}
.hero-content{position:absolute;z-index:3;top:5%;left:50%;transform:translateX(-50%);width:40%;text-align:center;padding:0}
.hero-logo-img{position:absolute;z-index:3;width:45%;height:auto;left:50%;top:70%;transform:translate(-50%,-50%);filter:drop-shadow(0 0 20px rgba(0,0,0,.6))}
.hero-title{font-family:'Metal Mania',cursive;font-size:clamp(2.5rem,8vw,6rem);font-weight:400;line-height:1.0;letter-spacing:.03em;background:linear-gradient(180deg,#fff 0%,#c8d4e8 25%,#7a8fa8 60%,#c8d4e8 85%,#fff 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem}
.hero-title span{display:block;font-size:.55em;color:var(--hell-l);background:none;-webkit-text-fill-color:var(--hell-l)}
.hero-sub{font-family:'Cinzel',serif;font-size:clamp(1rem,2.4vw,1.4rem);letter-spacing:.35em;color:var(--heaven-d);text-transform:uppercase;font-variant:small-caps;margin:0;white-space:nowrap}
.hero-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.hero-scroll{position:absolute;bottom:2.2rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.4rem;color:var(--heaven-d);font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;animation:scrollBounce 2.2s ease-in-out infinite;cursor:pointer;z-index:2}
.hero-scroll i{font-size:1rem;color:var(--heaven);opacity:.7}
@keyframes scrollBounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(6px)}}
/* Logo intro */
#hero-logo-intro{position:absolute;inset:0;z-index:10;display:flex;align-items:center;justify-content:center;pointer-events:none;transition:opacity 1.4s ease}
#hero-logo-intro img{width:clamp(160px,30vw,320px);filter:drop-shadow(0 0 40px rgba(200,212,232,.6)) drop-shadow(0 0 80px rgba(200,212,232,.3));animation:logoPulse 1.2s ease-in-out}
#hero-logo-intro.fade-out{opacity:0}
@keyframes logoPulse{0%{filter:drop-shadow(0 0 20px rgba(200,212,232,.3))}50%{filter:drop-shadow(0 0 70px rgba(200,212,232,.9)) drop-shadow(0 0 120px rgba(200,212,232,.5))}100%{filter:drop-shadow(0 0 40px rgba(200,212,232,.6))}}
@media(prefers-reduced-motion:reduce){#hero-logo-intro{display:none}}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;gap:.55rem;padding:.75rem 1.8rem;border-radius:3px;font-family:'Rajdhani',sans-serif;font-size:.82rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;text-decoration:none;cursor:pointer;border:2px solid transparent;transition:all .3s;white-space:nowrap;position:relative;overflow:hidden}
.btn-hell{background:transparent;color:var(--hell-l);border-color:var(--hell)}
.btn-hell:hover{background:var(--hell);color:#fff;box-shadow:var(--glow-hell);transform:translateY(-2px)}
.btn-heaven{background:transparent;color:var(--heaven);border-color:var(--heaven-d)}
.btn-heaven:hover{background:var(--heaven-d);color:var(--bg);box-shadow:var(--glow-heaven);transform:translateY(-2px)}
.btn-primary{background:var(--hell);color:#fff;border-color:var(--hell)}
.btn-primary:hover{background:var(--hell-l);border-color:var(--hell-l);box-shadow:var(--glow-hell);transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--heaven);border-color:var(--heaven-d)}
.btn-outline:hover{background:var(--heaven-d);color:var(--bg);box-shadow:var(--glow-heaven);transform:translateY(-2px)}
.btn-ghost{background:rgba(255,255,255,.06);color:var(--text);border-color:var(--border)}
.btn-ghost:hover{background:rgba(255,255,255,.1);border-color:var(--heaven-d)}
.btn-danger{background:var(--hell-d);color:#fff;border-color:var(--hell-d)}
.btn-danger:hover{background:var(--hell);border-color:var(--hell)}
.btn-sm{padding:.45rem 1.1rem;font-size:.76rem}
/* Spark element (spawned by JS) */
.spark{position:fixed;width:3px;height:3px;border-radius:50%;pointer-events:none;z-index:9999;animation:sparkFly .4s ease-out forwards}
@keyframes sparkFly{0%{opacity:1;transform:translate(0,0) scale(1)}100%{opacity:0;transform:translate(var(--tx),var(--ty)) scale(0)}}

/* ===== CARDS ===== */
.card{background:var(--bg2);border:1px solid var(--border);border-radius:6px;overflow:hidden;transition:all .35s}
.card:hover{border-top-color:var(--heaven-d);border-left-color:var(--heaven-d);border-bottom-color:var(--hell);border-right-color:var(--hell);transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,.5)}
.card-img{width:100%;aspect-ratio:16/9;object-fit:cover}
.card-body{padding:1.5rem}
.card-tag{display:inline-block;font-size:.65rem;letter-spacing:.15em;text-transform:uppercase;color:var(--heaven-d);font-family:'Cinzel',serif;margin-bottom:.6rem}
.card-title{font-family:'Cinzel',serif;font-size:1.05rem;font-weight:700;margin-bottom:.5rem;color:var(--text)}
.card-text{font-size:.88rem;color:var(--text2);line-height:1.7}

/* ===== SECTION COMMON ===== */
.section{padding:5rem 0}
.section-dark{background:var(--bg1)}
.section-header{text-align:center;margin-bottom:3.5rem}
.section-subtitle{font-family:'Cinzel',serif;font-size:.72rem;letter-spacing:.3em;color:var(--heaven-d);text-transform:uppercase;margin-bottom:.6rem;display:block}
.section-title{font-family:'Metal Mania',cursive;font-size:clamp(2rem,4vw,2.8rem);margin-bottom:.6rem;background:linear-gradient(180deg,#fff 0%,#c8d4e8 25%,#7a8fa8 60%,#c8d4e8 85%,#fff 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.section-title.centered{text-align:center}
.lightning-divider{display:block;width:100%;margin:.8rem 0;line-height:0}
.lightning-divider svg{display:block;width:100%}
.ld-l{filter:drop-shadow(0 0 3px rgba(200,212,232,.6))}
.ld-r{filter:drop-shadow(0 0 3px rgba(196,28,28,.6))}
/* Keep ornament class for any missed instances */
.ornament{display:flex;align-items:center;justify-content:center;gap:.8rem;margin:0 auto .5rem}
.ornament::before{content:'';flex:1;max-width:120px;height:1px;background:linear-gradient(to right,transparent,var(--heaven-d))}
.ornament::after{content:'';flex:1;max-width:120px;height:1px;background:linear-gradient(to left,transparent,var(--hell-d))}
.ornament span{color:var(--heaven);font-size:.7rem}
.no-results{text-align:center;padding:4rem 1rem;color:var(--text-muted)}
.no-results i{font-size:3rem;color:var(--border);display:block;margin-bottom:1rem}

/* ===== PAGE HERO (inner pages) ===== */
.page-hero{padding:calc(var(--navh) + 3.5rem) 0 3.5rem;position:relative;text-align:center;background:linear-gradient(to bottom,rgba(212,175,55,.04) 0%,transparent 100%);border-bottom:1px solid var(--border)}
.page-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 100% at 50% 0%,rgba(200,212,232,.06),transparent 70%);pointer-events:none}
.page-hero-content{position:relative}
.page-hero-eyebrow{font-family:'Cinzel',serif;font-size:.68rem;letter-spacing:.3em;color:var(--heaven-d);text-transform:uppercase;margin-bottom:.6rem}
.page-hero-title{font-family:'Cinzel Decorative',cursive;font-size:clamp(1.8rem,5vw,3.2rem);font-weight:900;margin-bottom:1rem}
.breadcrumb{display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:.78rem;color:var(--text-muted);margin-top:.5rem}
.breadcrumb a{color:var(--text2);transition:color .3s}.breadcrumb a:hover{color:var(--heaven)}
.breadcrumb-sep{color:var(--border)}

/* ===== ABOUT / STORY ===== */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.about-photo{position:relative}
.about-photo img{width:100%;border-radius:6px;border:1px solid var(--border);display:block}
.about-photo::before{content:'';position:absolute;inset:-8px;border:1px solid var(--gold-d);border-radius:8px;opacity:.4;pointer-events:none}
.about-text p{color:var(--text2);line-height:1.85;font-size:.97rem;margin-bottom:1.1rem}

/* ===== CONCERT BANNER (homepage) ===== */
.concert-banner{background:var(--bg2);border:1px solid var(--border);border-left:4px solid var(--hell);border-radius:6px;padding:1.5rem 2rem;display:flex;align-items:center;gap:2rem;text-decoration:none;transition:all .35s;margin-bottom:1.2rem}
.concert-banner:hover{background:rgba(196,28,28,.05);border-color:var(--hell-d);transform:translateX(4px)}
.concert-date-block{text-align:center;flex-shrink:0;min-width:60px}
.concert-date-day{font-family:'Cinzel Decorative',cursive;font-size:2rem;font-weight:900;color:var(--hell-l);line-height:1}
.concert-date-month{font-family:'Cinzel',serif;font-size:.68rem;letter-spacing:.15em;color:var(--text-muted);text-transform:uppercase;margin-top:.2rem}
.concert-date-year{font-family:'Rajdhani',sans-serif;font-size:.78rem;color:var(--text-muted)}
.concert-sep{width:1px;height:50px;background:var(--border);flex-shrink:0}
.concert-info{flex:1;min-width:0}
.concert-time-line{font-family:'Rajdhani',sans-serif;font-size:.78rem;letter-spacing:.1em;color:var(--heaven-d);text-transform:uppercase;margin-bottom:.25rem}
.concert-title-main{font-family:'Cinzel',serif;font-size:1.1rem;font-weight:700;color:var(--text);margin-bottom:.2rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.concert-venue{font-size:.85rem;color:var(--text2);display:flex;align-items:center;gap:.4rem}
.concert-venue i{color:var(--heaven-d)}
.concert-links{display:flex;gap:.6rem;flex-shrink:0;flex-wrap:wrap}

/* ===== CONCERTS GRID (concerts page) ===== */
.concerts-grid{display:flex;flex-direction:column;gap:1.5rem}
.concert-card{background:var(--bg2);border:1px solid var(--border);border-radius:6px;padding:2rem;display:grid;grid-template-columns:80px 1px 1fr auto;gap:1.5rem;align-items:center;transition:all .35s}
.concert-card-poster{grid-column:1/-1;margin:-2rem -2rem 0;border-radius:6px 6px 0 0;overflow:hidden;max-height:260px}
.concert-card-poster img{width:100%;height:260px;object-fit:cover;object-position:top center;display:block}
.concert-card:hover{border-color:var(--hell-d);box-shadow:0 8px 32px rgba(0,0,0,.4)}
.concert-card .cdate{text-align:center;background:var(--hell);border-radius:4px;padding:.5rem .7rem}
.concert-card .cdate-day{font-family:'Cinzel Decorative',cursive;font-size:2.5rem;font-weight:900;color:#fff;line-height:1}
.concert-card .cdate-mon{font-family:'Cinzel',serif;font-size:.875rem;letter-spacing:.12em;color:rgba(255,255,255,.75);text-transform:uppercase}
.concert-card .cdate-yr{font-size:.94rem;color:rgba(255,255,255,.6)}
.concert-card .cdivider{width:1px;height:100%;background:var(--border)}
.concert-card .cinfo h3{font-family:'Cinzel',serif;font-size:1.2rem;font-weight:700;margin-bottom:.4rem}
.concert-card .cmeta{display:flex;flex-wrap:wrap;gap:.6rem 1.2rem;font-size:.83rem;color:var(--text2);margin-top:.5rem}
.concert-card .cmeta i{color:var(--heaven-d);margin-right:.3rem}
.venue-link{color:inherit;text-decoration:none;border-bottom:1px dotted var(--heaven-d);transition:color .2s,border-color .2s}.venue-link:hover{color:var(--heaven);border-bottom-color:var(--heaven)}
.concert-desc-wrap{margin-top:.6rem}
.concert-desc{font-size:.85rem;color:var(--text2);line-height:1.7;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.concert-desc.expanded{display:block}
.concert-desc-toggle{display:none;background:none;border:none;padding:0;font-size:.8rem;color:var(--hell-l);cursor:pointer;margin-top:.25rem;font-family:inherit;letter-spacing:.03em}
.concert-desc-toggle:hover{color:var(--hell);text-decoration:underline}
.concert-desc-toggle.visible{display:inline}
.concert-card .cactions{display:flex;flex-direction:column;gap:.6rem;align-items:flex-end;min-width:9rem}
.concert-card .cactions .btn{width:100%;text-align:center;justify-content:center}
.past-concerts .concert-card{opacity:.55;filter:grayscale(.3)}
.past-concerts .concert-card:hover{opacity:.8}
.concerts-section-title{font-family:'Cinzel',serif;font-size:.85rem;letter-spacing:.2em;text-transform:uppercase;color:var(--text-muted);padding:.6rem 0;border-bottom:1px solid var(--border);margin-bottom:1.5rem;margin-top:3rem}

/* ===== MEMBERS ===== */
.members-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:2rem}
.member-card{flex:0 0 calc((100% - 4rem) / 3);text-align:center;padding:2rem 1.5rem}
.member-photo{width:160px;height:160px;border-radius:50%;overflow:hidden;margin:0 auto 1.2rem;border:3px solid var(--heaven-d);position:relative;transition:border-color .3s}
.member-card:hover .member-photo{border-color:var(--heaven)}
.member-photo img{width:100%;height:100%;object-fit:cover;object-position:top}
.member-photo-placeholder{width:100%;height:100%;background:var(--bg2);display:flex;align-items:center;justify-content:center;font-family:'Cinzel Decorative',cursive;font-size:2.5rem;color:var(--gold);border-radius:50%}
.member-name{font-family:'Cinzel',serif;font-size:1.1rem;font-weight:700;margin-bottom:.2rem}
.member-role{font-family:'Rajdhani',sans-serif;font-size:.8rem;letter-spacing:.2em;text-transform:uppercase;color:var(--hell-l);margin-bottom:.8rem}
.member-bio{font-size:.85rem;color:var(--text2);line-height:1.7;text-align:left}

/* ===== VIDEOS ===== */
.videos-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}
.video-card .card-body{padding:1.2rem 1.4rem}
.video-thumb{position:relative;cursor:pointer;overflow:hidden;aspect-ratio:16/9;background:#000}
.video-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s,filter .4s;display:block}
.video-thumb:hover img{transform:scale(1.05);filter:brightness(.7)}
.play-button{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;transition:all .3s}
.play-button i{width:60px;height:60px;background:rgba(196,28,28,.9);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.3rem;color:#fff;transition:all .3s;box-shadow:0 0 30px rgba(196,28,28,.4)}
.video-thumb:hover .play-button i{background:var(--hell-l);transform:scale(1.1);box-shadow:0 0 40px rgba(196,28,28,.6)}
.video-title{font-family:'Cinzel',serif;font-size:.95rem;font-weight:700;margin-bottom:.4rem}
.video-desc{font-size:.83rem;color:var(--text2);line-height:1.6}
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:9000;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:all .3s;backdrop-filter:blur(4px)}
.modal-overlay.open{opacity:1;visibility:visible}
.modal-content{position:relative;width:min(900px,92vw)}
.modal-close{position:absolute;top:-44px;right:0;background:none;border:none;color:var(--text2);font-size:1.4rem;cursor:pointer;padding:.4rem;transition:color .3s}
.modal-close:hover{color:var(--heaven)}
.modal-video{position:relative;padding-top:56.25%}
.modal-video iframe{position:absolute;inset:0;width:100%;height:100%;border:none}
.yt-subscribe-banner{display:flex;align-items:center;justify-content:space-between;gap:2rem;background:linear-gradient(135deg,rgba(255,0,0,.12),rgba(212,175,55,.06));border:1px solid rgba(255,0,0,.2);border-radius:6px;padding:2rem 2.5rem;margin-top:3rem;flex-wrap:wrap}
.yt-banner-text h3{font-family:'Cinzel',serif;font-size:1.3rem;margin-bottom:.35rem}
.yt-banner-text p{font-size:.88rem;color:var(--text2)}
.yt-banner-btn{background:#ff0000;color:#fff;border-color:#ff0000;flex-shrink:0}
.yt-banner-btn:hover{background:#cc0000;border-color:#cc0000;box-shadow:0 0 20px rgba(255,0,0,.4)}

/* ===== FEATURED VIDEO (homepage) ===== */
.featured-video-wrap{max-width:800px;margin:0 auto}
.featured-video-frame{position:relative;padding-top:56.25%;border-radius:6px;overflow:hidden;border:1px solid var(--border)}
.featured-video-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:none}

/* ===== GALLERY CAROUSEL ===== */
.gallery-filters{display:flex;gap:.6rem;flex-wrap:wrap;justify-content:center;margin-bottom:2.5rem}
.filter-btn{background:rgba(255,255,255,.04);border:1px solid var(--border);color:var(--text2);padding:.45rem 1.2rem;border-radius:3px;font-family:'Cinzel',serif;font-size:.72rem;letter-spacing:.1em;cursor:pointer;transition:all .3s}
.filter-btn:hover,.filter-btn.active{background:var(--hell);color:#fff;border-color:var(--hell)}
.carousel-wrapper{max-width:960px;margin:0 auto}
.carousel-main{position:relative;border-radius:6px;overflow:hidden;background:#000;aspect-ratio:16/9}
.carousel-slide{display:none;width:100%;height:100%;position:absolute;inset:0}
.carousel-slide.active{display:block}
.carousel-slide img{width:100%;height:100%;object-fit:contain;display:block}
.photo-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.8rem;color:var(--text-muted)}
.photo-placeholder i{font-size:3rem;color:var(--border)}
.carousel-caption{position:absolute;bottom:0;left:0;right:0;padding:.8rem 1.2rem;background:linear-gradient(to top,rgba(0,0,0,.85),transparent);font-size:.85rem;color:var(--text2)}
.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;background:rgba(5,5,11,.7);border:1px solid var(--border);border-radius:50%;color:var(--text);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;z-index:10;font-size:.9rem}
.carousel-btn:hover{background:var(--hell);border-color:var(--hell);color:#fff}
.carousel-btn-prev{left:.8rem}
.carousel-btn-next{right:.8rem}
.carousel-dots{display:flex;gap:.5rem;justify-content:center;margin-top:1rem;flex-wrap:wrap}
.carousel-dot{width:8px;height:8px;border-radius:50%;background:var(--border);border:none;cursor:pointer;padding:0;transition:all .3s}
.carousel-dot.active{background:var(--heaven);width:24px;border-radius:4px}
.carousel-thumbnails{display:flex;gap:.6rem;margin-top:1rem;overflow-x:auto;padding-bottom:.4rem;scrollbar-width:thin;scrollbar-color:var(--border) transparent}
.carousel-thumb{width:90px;height:60px;border-radius:4px;overflow:hidden;flex-shrink:0;cursor:pointer;border:2px solid transparent;transition:border-color .3s}
.carousel-thumb.active,.carousel-thumb:hover{border-color:var(--heaven)}
.carousel-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.thumb-placeholder{width:100%;height:100%;background:var(--bg2);display:flex;align-items:center;justify-content:center;color:var(--text-muted)}

/* ===== NEWSLETTER ===== */
.newsletter-section{padding:4rem 0;background:linear-gradient(135deg,rgba(200,212,232,.05) 0%,rgba(196,28,28,.05) 100%);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.newsletter-inner{max-width:560px;margin:0 auto;text-align:center}
.newsletter-form{display:flex;gap:.6rem;margin-top:1.5rem;flex-wrap:wrap;justify-content:center}
.newsletter-form input[type=email]{flex:1;min-width:220px;background:var(--bg2);border:1px solid var(--border);border-radius:3px;padding:.75rem 1rem;color:var(--text);font-size:.9rem;font-family:'Rajdhani',sans-serif;transition:border-color .3s}
.newsletter-form input:focus{outline:none;border-color:var(--heaven)}
.newsletter-consent{font-size:.75rem;color:var(--text-muted);margin-top:.8rem;line-height:1.6}

/* ===== CONTACT ===== */
.contact-wrapper{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}
.contact-info{display:flex;flex-direction:column;gap:1.8rem}
.contact-item{display:flex;gap:1rem;align-items:flex-start}
.contact-icon{width:42px;height:42px;background:rgba(196,28,28,.1);border:1px solid var(--hell-d);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--hell-l);flex-shrink:0;font-size:.9rem}
.contact-text-label{font-family:'Cinzel',serif;font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;color:var(--text-muted);margin-bottom:.2rem}
.contact-text-value{color:var(--text);font-size:.92rem;transition:color .3s}.contact-text-value:hover{color:var(--gold)}
.contact-social-title{font-family:'Cinzel',serif;font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;color:var(--text-muted);margin-bottom:.8rem}
.contact-social-icons{display:flex;gap:.6rem}
.contact-downloads{display:flex;flex-direction:column;gap:.6rem;padding:1.2rem;background:rgba(212,175,55,.04);border:1px solid var(--border);border-radius:6px}
.contact-downloads p{font-family:'Cinzel',serif;font-size:.68rem;letter-spacing:.15em;color:var(--text-muted);text-transform:uppercase;margin-bottom:.4rem}
.contact-form-box{background:var(--bg2);border:1px solid var(--border);border-radius:6px;padding:2.5rem}
.form-group{margin-bottom:1.25rem}
.form-label{display:block;font-family:'Cinzel',serif;font-size:.7rem;letter-spacing:.12em;color:var(--text2);text-transform:uppercase;margin-bottom:.5rem}
.form-control{width:100%;background:var(--bg1);border:1px solid var(--border);border-radius:3px;padding:.72rem 1rem;color:var(--text);font-size:.92rem;font-family:'Rajdhani',sans-serif;transition:border-color .3s;box-sizing:border-box}
.form-control:focus{outline:none;border-color:var(--gold);background:rgba(212,175,55,.03)}
textarea.form-control{min-height:140px;resize:vertical}
.form-message{padding:.9rem 1.1rem;border-radius:4px;margin-bottom:1.2rem;font-size:.9rem;display:flex;align-items:flex-start;gap:.6rem;line-height:1.6}
.form-message.success{background:rgba(39,174,96,.1);border:1px solid rgba(39,174,96,.3);color:#2ecc71}
.form-message.error{background:rgba(176,26,26,.1);border:1px solid rgba(176,26,26,.3);color:#e74c3c}

/* ===== FOOTER ===== */
.site-footer{background:var(--bg1);border-top:1px solid rgba(200,212,232,.08);padding:1.2rem 0 1rem}
.footer-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:2.5rem;margin-bottom:1rem;align-items:center}
.footer-social-col{text-align:center}
.footer-social-col .footer-social{justify-content:center}
.footer-logo-large{height:220px;width:auto;max-width:100%;display:block;margin:0;transition:opacity .3s}
.footer-logo-large:hover{opacity:.85}
.footer-brand p{font-size:.85rem;color:var(--text2);line-height:1.75;max-width:300px}
.footer-social{display:flex;gap:.5rem;margin-top:1.2rem;flex-wrap:wrap}
.footer-heading{font-family:'Cinzel',serif;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--heaven-d);margin-bottom:1rem}
.footer-links{display:flex;flex-direction:column;gap:.55rem}
.footer-links a{font-size:.85rem;color:var(--text2);transition:color .3s}
.footer-links a:hover{color:var(--heaven)}
.footer-newsletter form{display:flex;flex-direction:column;gap:.6rem}
.footer-newsletter input{background:var(--bg2);border:1px solid var(--border);border-radius:3px;padding:.6rem .9rem;color:var(--text);font-size:.85rem;font-family:'Rajdhani',sans-serif}
.footer-newsletter input:focus{outline:none;border-color:var(--gold)}
.footer-bottom{border-top:1px solid var(--border);padding-top:1.5rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.footer-copy{font-size:.78rem;color:var(--text-muted)}
.footer-copy span{color:var(--heaven)}

/* ===== LANDING PAGE ===== */
.landing-page{min-height:100vh;background:var(--bg0);display:flex;flex-direction:column}
.landing-header{text-align:center;padding:2.2rem 1rem 1rem}
.landing-circle-img{width:180px;height:180px;border-radius:50%;object-fit:cover;object-position:center top;border:3px solid var(--heaven-d);box-shadow:0 0 24px rgba(200,212,232,.2);display:block;margin:0 auto}
.landing-band-name{font-family:'Metal Mania',cursive;font-size:clamp(1.2rem,4vw,1.8rem);font-weight:400;color:var(--heaven);margin-top:.7rem;text-shadow:0 0 30px rgba(200,212,232,.2)}
.landing-tagline{font-family:'Cinzel',serif;letter-spacing:.25em;color:var(--heaven-d);font-size:.82rem;text-transform:uppercase;margin-top:.3rem}
.landing-song-cover-wrap{position:relative;display:block;max-width:400px;margin:0 auto 1.8rem}
.landing-cover-img{width:100%;aspect-ratio:1;height:auto;object-fit:cover;border-radius:8px;border:2px solid var(--hell-d);box-shadow:0 0 30px rgba(196,28,28,.2);display:block}
.landing-circle-img--small{width:72px;height:72px;border-radius:50%;object-fit:cover;object-position:center top;border:3px solid var(--heaven-d);box-shadow:0 0 14px rgba(200,212,232,.2);position:absolute;bottom:-36px;left:50%;transform:translateX(-50%)}
.landing-song-title{font-family:'Cinzel',serif;font-size:1.05rem;color:var(--heaven);letter-spacing:.14em;margin-top:.4rem;text-shadow:0 0 20px rgba(200,212,232,.2)}
.landing-body{flex:1;padding:1.4rem 1rem}
.landing-section-title{font-family:'Cinzel',serif;font-size:.68rem;letter-spacing:.3em;text-transform:uppercase;color:var(--heaven-d);text-align:center;margin-bottom:1rem}
.landing-streaming{display:flex;flex-direction:column;gap:.6rem;max-width:400px;margin:0 auto 1.8rem}
.landing-stream-link{display:flex;align-items:center;gap:1rem;padding:.8rem 1.2rem;background:#131325;border:1px solid rgba(200,212,232,.2);border-radius:6px;text-decoration:none;color:var(--text);transition:all .3s;font-family:'Barlow','Rajdhani',sans-serif;font-size:1rem;letter-spacing:.05em}
.landing-stream-link:hover{background:rgba(200,212,232,.06);border-color:var(--heaven);transform:translateX(4px)}
.landing-stream-link i{font-size:1.3rem;width:28px;text-align:center}
.landing-stream-link .ls-yt{color:#ff0000}
.landing-stream-link .ls-sp{color:#1db954}
.landing-stream-link .ls-am{color:#fc3c44}
.landing-stream-link .ls-ytm{color:#ff0000}
.landing-concerts{display:flex;flex-direction:column;gap:.6rem;max-width:500px;margin:0 auto 1.5rem}
.landing-concert-item{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:#131325;border:1px solid rgba(200,212,232,.2);border-radius:4px}
.landing-concert-date{font-family:'Cinzel',serif;font-size:.82rem;color:var(--heaven-d);min-width:86px}
.landing-concert-info{flex:1}
.landing-concert-title{font-size:.88rem;font-weight:600;color:var(--text);margin-bottom:.1rem}
.landing-concert-venue{font-size:.76rem;color:var(--text2)}
.landing-footer{text-align:center;padding:1.4rem 1rem;border-top:1px solid var(--border)}
.landing-social{display:flex;justify-content:center;gap:.8rem;margin-bottom:.8rem;flex-wrap:wrap}

/* ===== ANIMATIONS ===== */
.animate-on-scroll{opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease}
.animate-on-scroll.visible{opacity:1;transform:translateY(0)}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .about-grid{grid-template-columns:1fr;gap:2.5rem}
  .contact-wrapper{grid-template-columns:1fr;gap:2.5rem}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .footer-grid .footer-brand{grid-column:1/-1;text-align:center}
  .footer-grid .footer-brand .footer-logo-large{margin:0 auto}
  .footer-social-col{text-align:center}
  .concert-card{grid-template-columns:70px 1px 1fr;grid-template-rows:auto auto}
  .concert-card .cactions{grid-column:1/-1;flex-direction:row;justify-content:flex-start;flex-wrap:wrap}
}
@media(max-width:768px){
  .hamburger{display:flex}
  .main-nav,.social-nav{display:none}
  .header-inner{padding:0 1rem}
  .hero-photo{filter:brightness(.55) saturate(.75)}
  .hero-rays,.hero-overlay,.hero-scroll{display:none}
  .hero-sub{font-size:.65rem;letter-spacing:.2em}
  .member-card{flex:0 0 calc((100% - 2rem) / 2)}
  .videos-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .yt-subscribe-banner{flex-direction:column;text-align:center}
  .concert-card{grid-template-columns:60px 1fr;gap:1rem}
  .concert-card .cdivider{display:none}
  .concert-banner{padding:1rem 1.2rem;gap:1rem}
  .concert-date-day{font-size:1.5rem}
  .concert-title-main{white-space:normal}
}
@media(max-width:480px) and (max-height:900px){
  .footer-logo-large{width:85vw;height:auto}
}
@media(max-width:480px){
  .section{padding:3.5rem 0}
  .member-card{flex:0 0 100%}
  .hero-actions{flex-direction:column;align-items:center}
  .carousel-thumbnails{display:none}
  .concert-card{grid-template-columns:1fr}
  .concert-card .cdate{text-align:left;display:flex;gap:.5rem;align-items:baseline}
  .concert-card .cactions{justify-content:flex-start}
  .concert-banner{flex-wrap:wrap;padding:.9rem 1rem;gap:.6rem}
  .concert-sep{display:none}
  .concert-date-block{display:flex;gap:.4rem;align-items:baseline;min-width:0;width:100%}
  .concert-date-day{font-size:1.1rem}
  .concert-date-month{margin-top:0}
  .concert-info{min-width:0;width:100%}
  .concert-links{width:100%}
}
