@import url('https://fonts.googleapis.com/css2?family=Cinzel+Decorative:wght@400;700;900&family=Josefin+Sans:wght@100;300;400;600&family=Courier+Prime:ital,wght@0,400;0,700;1,400&display=swap');

:root {
  --black: #030303;
  --deep: #0a0a0f;
  --void: #06060a;
  --silver: #c8c8d4;
  --silver-dim: #7a7a8a;
  --violet: #6b2fa0;
  --violet-bright: #9b4fd4;
  --violet-glow: #c084fc;
  --crimson: #8b1a2a;
  --white: #f0eef5;
  --gold: #b8860b;
  --font-display: 'Cinzel Decorative', serif;
  --font-body: 'Josefin Sans', sans-serif;
  --font-lyric: 'Courier Prime', monospace;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { background: var(--black); color: var(--silver); font-family: var(--font-body); font-weight: 300; letter-spacing: 0.05em; overflow-x: hidden; }

nav { position: fixed; top: 0; left: 0; right: 0; z-index: 1000; padding: 1.2rem 3rem; display: flex; align-items: center; justify-content: space-between; background: linear-gradient(to bottom, rgba(3,3,3,0.95), transparent); }
.nav-logo { font-family: var(--font-display); font-size: 0.85rem; color: var(--violet-glow); text-decoration: none; letter-spacing: 0.2em; }
.nav-links { display: flex; gap: 2.5rem; list-style: none; }
.nav-links a { color: var(--silver-dim); text-decoration: none; font-size: 0.65rem; letter-spacing: 0.25em; text-transform: uppercase; transition: color 0.3s; }
.nav-links a:hover { color: var(--violet-glow); }
.hamburger { display: none; flex-direction: column; gap: 5px; cursor: pointer; background: none; border: none; padding: 0.5rem; }
.hamburger span { display: block; width: 24px; height: 1px; background: var(--silver); }
.mobile-menu { display: none; position: fixed; inset: 0; background: rgba(3,3,3,0.97); z-index: 999; flex-direction: column; align-items: center; justify-content: center; gap: 2.5rem; }
.mobile-menu.open { display: flex; }
.mobile-menu a { font-family: var(--font-display); font-size: 1.4rem; color: var(--silver); text-decoration: none; letter-spacing: 0.2em; transition: color 0.3s; }
.mobile-menu a:hover { color: var(--violet-glow); }
.mobile-close { position: absolute; top: 1.5rem; right: 2rem; background: none; border: none; color: var(--silver); font-size: 2rem; cursor: pointer; }

.hero { position: relative; height: 100vh; min-height: 700px; display: flex; align-items: center; justify-content: center; overflow: hidden; }
.hero-bg { position: absolute; inset: 0; background-image: url('../images/hero-veil.jpg'); background-size: cover; background-position: center top; filter: brightness(0.4) saturate(0.6); }
.hero-overlay { position: absolute; inset: 0; background: linear-gradient(135deg, rgba(3,3,3,0.75) 0%, rgba(107,47,160,0.12) 50%, rgba(3,3,3,0.88) 100%); }
.hero-content { position: relative; z-index: 2; text-align: center; padding: 2rem; animation: fadeUp 1.4s ease both; }
.hero-logo { width: 160px; margin-bottom: 2rem; filter: drop-shadow(0 0 30px rgba(155,79,212,0.6)); animation: logoGlow 4s ease-in-out infinite alternate; }
@keyframes logoGlow { from { filter: drop-shadow(0 0 20px rgba(155,79,212,0.4)); } to { filter: drop-shadow(0 0 50px rgba(192,132,252,0.9)); } }
.hero-title { font-family: var(--font-display); font-size: clamp(2.5rem, 8vw, 6rem); font-weight: 900; color: var(--white); letter-spacing: 0.15em; text-shadow: 0 0 60px rgba(155,79,212,0.5); line-height: 1.1; margin-bottom: 0.5rem; }
.hero-subtitle { font-size: clamp(0.6rem, 2vw, 0.8rem); font-weight: 100; letter-spacing: 0.5em; text-transform: uppercase; color: var(--violet-glow); margin-bottom: 0.75rem; }
.hero-tagline { font-size: clamp(0.5rem, 1.5vw, 0.65rem); letter-spacing: 0.4em; text-transform: uppercase; color: var(--silver-dim); margin-bottom: 3rem; }
.hero-ctas { display: flex; gap: 1.5rem; justify-content: center; flex-wrap: wrap; }
@keyframes fadeUp { from { opacity: 0; transform: translateY(30px); } to { opacity: 1; transform: translateY(0); } }
.scroll-indicator { position: absolute; bottom: 2rem; left: 50%; transform: translateX(-50%); display: flex; flex-direction: column; align-items: center; gap: 0.5rem; color: var(--silver-dim); font-size: 0.5rem; letter-spacing: 0.3em; text-transform: uppercase; animation: scrollBounce 2s infinite; }
.scroll-indicator::after { content: ''; width: 1px; height: 40px; background: linear-gradient(to bottom, var(--violet-glow), transparent); }
@keyframes scrollBounce { 0%, 100% { transform: translateX(-50%) translateY(0); } 50% { transform: translateX(-50%) translateY(8px); } }

.btn { display: inline-block; padding: 0.8rem 2.2rem; font-family: var(--font-body); font-size: 0.62rem; font-weight: 600; letter-spacing: 0.35em; text-transform: uppercase; text-decoration: none; border: 1px solid; transition: all 0.3s; }
.btn-primary { color: var(--violet-glow); border-color: var(--violet-bright); box-shadow: 0 0 20px rgba(107,47,160,0.25); }
.btn-primary:hover { color: var(--white); border-color: var(--violet-glow); box-shadow: 0 0 40px rgba(155,79,212,0.5); background: rgba(107,47,160,0.1); }
.btn-secondary { color: var(--silver-dim); border-color: rgba(200,200,212,0.25); }
.btn-secondary:hover { color: var(--white); border-color: var(--silver); background: rgba(200,200,212,0.05); }
.btn-book { color: var(--crimson); border-color: var(--crimson); }
.btn-book:hover { color: var(--white); border-color: #cc2a3e; box-shadow: 0 0 30px rgba(139,26,42,0.4); background: rgba(139,26,42,0.1); }
.btn-gold { color: var(--gold); border-color: var(--gold); }
.btn-gold:hover { color: var(--white); box-shadow: 0 0 30px rgba(184,134,11,0.4); background: rgba(184,134,11,0.1); }

section { padding: 7rem 0; position: relative; }
.container { max-width: 1100px; margin: 0 auto; padding: 0 2rem; }
.section-header { margin-bottom: 3.5rem; }
.section-title { font-family: var(--font-display); font-size: clamp(1rem, 3vw, 1.6rem); font-weight: 400; letter-spacing: 0.25em; text-transform: uppercase; color: var(--white); margin-bottom: 0.75rem; }
.section-rule { width: 50px; height: 1px; background: linear-gradient(to right, var(--violet-bright), transparent); margin-top: 0.5rem; }
.section-rule-gold { background: linear-gradient(to right, var(--gold), transparent); }

.about-grid { display: grid; grid-template-columns: 1fr 1.5fr; gap: 5rem; align-items: center; }
.about-images { position: relative; height: 580px; }
.about-img-main { position: absolute; width: 72%; height: 460px; object-fit: cover; object-position: center top; left: 0; top: 0; border: 1px solid rgba(107,47,160,0.25); filter: saturate(0.65); transition: filter 0.5s; }
.about-img-main:hover { filter: saturate(1); }
.about-img-secondary { position: absolute; width: 52%; height: 300px; object-fit: cover; object-position: center top; right: 0; bottom: 0; border: 1px solid rgba(200,200,212,0.12); filter: saturate(0.4); transition: filter 0.5s; }
.about-img-secondary:hover { filter: saturate(0.85); }
.genre-tag { display: inline-block; font-size: 0.58rem; letter-spacing: 0.4em; text-transform: uppercase; color: var(--violet-glow); border: 1px solid rgba(192,132,252,0.3); padding: 0.35rem 1rem; margin-bottom: 1.5rem; }
.about-text p { font-size: 0.9rem; line-height: 1.95; color: var(--silver); margin-bottom: 1.5rem; }
.about-text p.lead { font-size: 1rem; color: var(--white); }
.platform-links { display: flex; gap: 1rem; flex-wrap: wrap; margin-top: 2.5rem; }

.music-section { background: linear-gradient(to bottom, var(--black), var(--deep) 50%, var(--black)); }
.soundcloud-wrap { border: 1px solid rgba(107,47,160,0.2); margin-bottom: 5rem; overflow: hidden; }

.discography { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 2rem; margin-bottom: 5rem; }
.album-card { position: relative; overflow: hidden; border: 1px solid rgba(107,47,160,0.15); transition: border-color 0.3s; }
.album-card:hover { border-color: rgba(155,79,212,0.5); }
.album-card img { width: 100%; aspect-ratio: 1; object-fit: cover; display: block; filter: saturate(0.75) brightness(0.8); transition: filter 0.5s, transform 0.5s; }
.album-card:hover img { filter: saturate(1) brightness(1); transform: scale(1.04); }
.album-info { position: absolute; bottom: 0; left: 0; right: 0; padding: 2rem 1.5rem 1.5rem; background: linear-gradient(to top, rgba(3,3,3,0.95), transparent); }
.album-title { font-family: var(--font-display); font-size: 0.8rem; letter-spacing: 0.15em; color: var(--white); margin-bottom: 0.25rem; }
.album-label { font-size: 0.55rem; letter-spacing: 0.3em; color: var(--violet-glow); text-transform: uppercase; }

.lyrics-intro { font-size: 0.85rem; line-height: 1.8; color: var(--silver-dim); margin-bottom: 3rem; max-width: 600px; }
.lyrics-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(310px, 1fr)); gap: 1.5rem; }
.lyric-card { border: 1px solid rgba(107,47,160,0.12); padding: 1.5rem; cursor: pointer; transition: border-color 0.3s, background 0.3s; }
.lyric-card:hover, .lyric-card.open { border-color: rgba(155,79,212,0.4); background: rgba(107,47,160,0.04); }
.lyric-card-header { display: flex; justify-content: space-between; align-items: flex-start; }
.lyric-card-title { font-family: var(--font-display); font-size: 0.85rem; letter-spacing: 0.15em; color: var(--white); margin-bottom: 0.3rem; }
.lyric-card-subject { font-size: 0.55rem; letter-spacing: 0.25em; text-transform: uppercase; color: var(--violet-glow); }
.lyric-expand { color: var(--violet-glow); font-size: 1.4rem; line-height: 1; transition: transform 0.3s; flex-shrink: 0; margin-left: 1rem; }
.lyric-card.open .lyric-expand { transform: rotate(45deg); }
.lyric-content { display: none; margin-top: 1.5rem; padding-top: 1.5rem; border-top: 1px solid rgba(107,47,160,0.15); }
.lyric-card.open .lyric-content { display: block; }
.lyric-stanza { margin-bottom: 1.2rem; }
.lyric-label { font-size: 0.5rem; letter-spacing: 0.4em; text-transform: uppercase; color: var(--silver-dim); font-family: var(--font-body); margin-bottom: 0.4rem; display: block; }
.lyric-lines { font-family: var(--font-lyric); font-size: 0.82rem; line-height: 1.9; color: var(--silver); }

.gallery-grid { display: grid; grid-template-columns: repeat(4, 1fr); grid-auto-rows: 240px; gap: 3px; }
.gallery-grid .wide { grid-column: span 2; }
.gallery-grid .tall { grid-row: span 2; }
.gallery-item { overflow: hidden; }
.gallery-item img { width: 100%; height: 100%; object-fit: cover; filter: saturate(0.5) brightness(0.75); transition: filter 0.5s, transform 0.5s; }
.gallery-item:hover img { filter: saturate(1) brightness(1); transform: scale(1.07); }

.writing-piece { margin-bottom: 6rem; padding-bottom: 6rem; border-bottom: 1px solid rgba(107,47,160,0.12); }
.writing-piece:last-child { border-bottom: none; margin-bottom: 0; }
.writing-title { font-family: var(--font-display); font-size: clamp(1rem, 2.5vw, 1.4rem); letter-spacing: 0.2em; color: var(--white); margin-bottom: 0.4rem; }
.writing-type { font-size: 0.55rem; letter-spacing: 0.4em; text-transform: uppercase; color: var(--violet-glow); margin-bottom: 2.5rem; }
.manifesto-body { max-width: 740px; }
.manifesto-rule { margin-bottom: 1.1rem; padding-left: 1.5rem; border-left: 1px solid rgba(107,47,160,0.25); font-family: var(--font-lyric); font-size: 0.88rem; line-height: 1.75; color: var(--silver); }
.manifesto-num { color: var(--violet-glow); font-weight: 700; margin-right: 0.5rem; }
.poem-body { font-family: var(--font-lyric); font-size: 0.9rem; line-height: 2; color: var(--silver); max-width: 640px; white-space: pre-line; }
.song-body { max-width: 680px; }
.song-stanza { margin-bottom: 1.5rem; }
.song-label { font-size: 0.5rem; letter-spacing: 0.45em; text-transform: uppercase; color: var(--silver-dim); font-family: var(--font-body); display: block; margin-bottom: 0.4rem; }
.song-lines { font-family: var(--font-lyric); font-size: 0.88rem; line-height: 1.9; color: var(--silver); }

.page-hero { min-height: 50vh; display: flex; align-items: flex-end; position: relative; overflow: hidden; padding-bottom: 5rem; }
.page-hero-bg { position: absolute; inset: 0; background-size: cover; background-position: center; filter: brightness(0.28) saturate(0.5); }
.page-hero-overlay { position: absolute; inset: 0; background: linear-gradient(to top, var(--black) 0%, rgba(3,3,3,0.3) 60%, transparent 100%); }
.page-hero-content { position: relative; z-index: 2; }

.g3z-logo-section { text-align: center; padding: 3rem 0; }
.g3z-logo { max-width: 400px; width: 90%; filter: drop-shadow(0 0 40px rgba(184,134,11,0.35)); }
.g3z-sub { font-size: 0.62rem; letter-spacing: 0.5em; text-transform: uppercase; color: var(--gold); margin-top: 1.5rem; }
.members-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 2rem; margin-top: 3rem; }
.member-card { text-align: center; }
.member-card img { width: 100%; aspect-ratio: 3/4; object-fit: cover; object-position: center top; filter: saturate(0.3) brightness(0.75); border: 1px solid rgba(184,134,11,0.2); transition: filter 0.4s; margin-bottom: 1rem; }
.member-card:hover img { filter: saturate(0.7) brightness(1); }
.member-name { font-family: var(--font-display); font-size: 0.72rem; letter-spacing: 0.2em; color: var(--white); margin-bottom: 0.25rem; }
.member-role { font-size: 0.55rem; letter-spacing: 0.3em; text-transform: uppercase; color: var(--gold); }
.playbills-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 2rem; }
.playbill-item img { width: 100%; border: 1px solid rgba(184,134,11,0.2); transition: border-color 0.3s; }
.playbill-item:hover img { border-color: rgba(184,134,11,0.5); }

.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; }
.contact-block h3 { font-family: var(--font-display); font-size: 0.9rem; letter-spacing: 0.2em; color: var(--white); margin-bottom: 0.75rem; }
.contact-block p { font-size: 0.82rem; color: var(--silver-dim); line-height: 1.7; margin-bottom: 1.5rem; }
.contact-email { font-family: var(--font-lyric); font-size: 0.82rem; color: var(--violet-glow); text-decoration: none; border-bottom: 1px solid rgba(192,132,252,0.3); padding-bottom: 2px; transition: color 0.3s; display: inline-block; margin-bottom: 1.5rem; }
.contact-email:hover { color: var(--white); }

.glitter-divider { text-align: center; padding: 2rem 0; color: var(--violet-glow); font-size: 0.5rem; letter-spacing: 1em; text-transform: uppercase; opacity: 0.4; }

footer { background: var(--void); border-top: 1px solid rgba(107,47,160,0.12); padding: 4rem 0 2rem; text-align: center; }
.footer-logo { font-family: var(--font-display); font-size: 1.1rem; color: var(--violet-glow); letter-spacing: 0.25em; margin-bottom: 0.4rem; }
.footer-tagline { font-size: 0.55rem; letter-spacing: 0.45em; text-transform: uppercase; color: var(--silver-dim); margin-bottom: 2.5rem; }
.footer-nav { display: flex; gap: 2rem; justify-content: center; flex-wrap: wrap; margin-bottom: 2.5rem; list-style: none; }
.footer-nav a { color: var(--silver-dim); text-decoration: none; font-size: 0.6rem; letter-spacing: 0.2em; text-transform: uppercase; transition: color 0.3s; }
.footer-nav a:hover { color: var(--violet-glow); }
.footer-copy { font-size: 0.55rem; color: rgba(122,122,138,0.35); letter-spacing: 0.15em; }

@media (max-width: 900px) {
  nav { padding: 1rem 1.5rem; }
  .nav-links { display: none; }
  .hamburger { display: flex; }
  .about-grid { grid-template-columns: 1fr; gap: 3rem; }
  .about-images { height: 380px; }
  .gallery-grid { grid-template-columns: repeat(2, 1fr); }
  .gallery-grid .wide { grid-column: span 1; }
  .contact-grid { grid-template-columns: 1fr; gap: 3rem; }
}
@media (max-width: 480px) {
  .hero-ctas { flex-direction: column; align-items: center; }
  .gallery-grid { grid-template-columns: 1fr; }
  .gallery-grid .tall { grid-row: span 1; }
  section { padding: 4rem 0; }
  .platform-links { flex-direction: column; align-items: flex-start; }
}
