/* === RESET & BASE === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{
  font-family:'Work Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  background:#fff;
  color:#0a0a0a;
  line-height:1.6;
  -webkit-font-smoothing:antialiased
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
ul{list-style:none}

/* === HEADER / NAV === */
.site-header{
  position:relative;
  width:100%;
  z-index:1000;
  padding:1.55rem 2rem;
  display:flex;
  justify-content:space-between;
  align-items:center;
  background:#fff;
}
.site-logo{font-size:2.1rem;font-weight:700;letter-spacing:.01em;text-transform:none;line-height:1.2}
.nav-links{display:flex;gap:1.35rem;align-items:center}
.nav-links > a{font-size:1.2rem;font-weight:500;letter-spacing:0;text-transform:none;opacity:1;line-height:1.4}
.nav-links > a:hover{opacity:1}
.nav-links > a.active,.nav-links > a[aria-current="page"]{text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:.32em}
.social-links{display:flex;gap:.85rem;margin-left:.25rem}
.social-links a{display:inline-flex;align-items:center;opacity:1}
.social-links svg{width:15px;height:15px;fill:#0a0a0a}

/* === MOBILE NAV TOGGLE === */
.nav-toggle{display:none;background:none;border:none;color:#0a0a0a;font-size:1.5rem;cursor:pointer}

/* === MAIN CONTENT === */
.page-wrap{padding-top:0}

/* === HERO / CAROUSEL === */
.hero{position:relative;overflow:hidden}
.carousel{display:flex;transition:transform .6s ease}
.carousel-slide{min-width:100%;position:relative}
.carousel-slide img{width:100%;height:75vh;object-fit:cover}
.carousel-caption{
  position:absolute;bottom:2rem;left:2rem;
  font-size:.75rem;text-transform:uppercase;letter-spacing:1px;
  background:rgba(0,0,0,.6);padding:.5rem 1rem
}
.carousel-controls{
  position:absolute;bottom:2rem;right:2rem;display:flex;gap:.5rem
}
.carousel-btn{
  background:rgba(0,0,0,.15);border:none;color:#0a0a0a;
  width:40px;height:40px;cursor:pointer;font-size:1.2rem;
  transition:background .2s
}
.carousel-btn:hover{background:rgba(0,0,0,.3)}
.carousel-dots{
  position:absolute;bottom:1rem;left:50%;transform:translateX(-50%);
  display:flex;gap:.5rem
}
.dot{width:8px;height:8px;border-radius:50%;background:rgba(0,0,0,.3);cursor:pointer;transition:background .3s}
.dot.active{background:#0a0a0a}

/* === SECTION COMMON === */
.section{padding:2rem 2rem;max-width:1200px;margin:0 auto}
.section-title{
  font-size:2rem;font-weight:700;text-transform:uppercase;
  letter-spacing:3px;margin-bottom:2rem
}
.section-subtitle{
  font-size:1rem;opacity:.6;text-transform:uppercase;letter-spacing:1px;
  margin-bottom:2rem
}

/* === HOME WHAT WE DO === */
.what-we-do p{font-size:1.1rem;max-width:800px;opacity:.85;margin-bottom:1rem}

/* === RECENT POSTS (HOME) === */
.recent-title{text-transform:none;letter-spacing:0}
.recent-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:2.5rem}
.recent-card{text-align:center;opacity:0;transform:translateY(24px);transition:opacity .5s ease,transform .5s ease}
.recent-card.visible{opacity:1;transform:translateY(0)}
.recent-card img{width:100%;aspect-ratio:1/1;object-fit:cover;margin-bottom:1rem}
.recent-card h3{font-size:1.25rem;margin-bottom:.75rem;line-height:1.25}
.recent-card .excerpt{font-size:.875rem;opacity:1;line-height:1.4;margin-bottom:.75rem}
.recent-card .read-more{display:inline-block;font-size:.95rem;text-transform:none;letter-spacing:0;opacity:1;margin-bottom:.55rem}
.recent-card .date{font-size:.82rem;opacity:.8;text-transform:none;letter-spacing:0}

/* === WORK TOGETHER CTA === */
.cta-section{
  position:relative;padding:6rem 2rem;text-align:center;
  background-size:cover;background-position:center
}
.cta-section .overlay{position:absolute;inset:0;background:rgba(255,255,255,.5)}
.cta-section .content{position:relative;z-index:1}
.cta-section h2{font-size:2.5rem;margin-bottom:1rem}
.cta-section p{font-size:1.1rem;opacity:.8;margin-bottom:2rem;max-width:600px;margin-left:auto;margin-right:auto}
.btn{
  display:inline-block;padding:.8rem 2.5rem;
  border:1px solid #0a0a0a;text-transform:uppercase;
  letter-spacing:2px;font-size:.85rem;transition:all .3s
}
.btn:hover{background:#0a0a0a;color:#fff}

/* === MUSIC LISTING === */
.music-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:2.5rem}
.music-card{opacity:0;transform:translateY(24px);transition:opacity .5s ease,transform .5s ease;border-bottom:1px solid rgba(0,0,0,.08);padding-bottom:2rem}
.music-card.visible{opacity:1;transform:translateY(0)}
.music-card:hover{opacity:.8}
.music-card img{width:100%;height:240px;object-fit:cover;margin-bottom:1rem}
.music-card .meta{font-size:.7rem;opacity:.5;text-transform:uppercase;letter-spacing:1px;margin-bottom:.5rem}
.music-card .meta span{margin-right:1rem}
.music-card h2{font-size:1.2rem;margin-bottom:.5rem}
.music-card p{font-size:.9rem;opacity:.65;margin-bottom:.75rem}

/* === ABOUT PAGE === */
.about-hero-img{width:100%;height:60vh;object-fit:cover;margin-bottom:3rem}
.about-text{max-width:800px;margin:0 auto 4rem;text-align:center}
.about-text p{font-size:1.1rem;opacity:.85}
.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:2rem;margin-top:3rem}
.team-card{text-align:center}
.team-card img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:50%;margin-bottom:1rem}
.team-card h3{font-size:1.2rem;margin-bottom:.25rem}
.team-card .role{font-size:.8rem;opacity:.6;text-transform:uppercase;letter-spacing:1px}

/* === CONTACT PAGE === */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;max-width:900px;margin:3rem auto 0}
.contact-group{margin-bottom:2rem}
.contact-group h3{font-size:.85rem;text-transform:uppercase;letter-spacing:1.5px;opacity:.5;margin-bottom:.75rem}
.contact-group p{font-size:1.05rem;margin-bottom:.25rem}
.contact-group a{opacity:.75;transition:opacity .2s}
.contact-group a:hover{opacity:1;text-decoration:underline}
.contact-social{display:flex;gap:1rem;margin-top:2rem}
.contact-social a{opacity:.6;transition:opacity .2s}
.contact-social a:hover{opacity:1}
.contact-social svg{width:24px;height:24px;fill:#0a0a0a}

/* === FOOTER === */
.site-footer{
  padding:3.5rem 2rem;text-align:center;
  border-top:none;
  font-size:1rem;opacity:1
}
.site-footer a{opacity:1}
.site-footer a:hover{text-decoration:underline}
.site-footer .brand{font-size:2.1rem;font-weight:700;text-transform:none;letter-spacing:.01em;opacity:1;margin-bottom:.75rem;line-height:1.2}
.site-footer .info{margin-bottom:.55rem}
.footer-links{display:block;margin-top:.6rem}
.footer-links a{font-size:1rem;text-transform:none;letter-spacing:0}

/* === RESPONSIVE === */
@media(max-width:768px){
  .site-header{padding:.95rem 1rem}
  .site-logo{font-size:1.75rem}
  .nav-links{display:none}
  .nav-links.open{display:flex;flex-direction:column;position:absolute;top:100%;left:0;width:100%;background:rgba(255,255,255,.98);padding:1.5rem;gap:1.25rem;align-items:flex-start;border-bottom:1px solid rgba(0,0,0,.08)}
  .nav-links > a{font-size:1rem}
  .nav-toggle{display:block}
  .carousel-slide img{height:50vh}
  .section{padding:3rem 1rem}
  .recent-grid,.music-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr;gap:2rem}
  .carousel-caption{bottom:1rem;left:1rem;font-size:.65rem}
  .carousel-controls{bottom:1rem;right:1rem}
  .team-grid{grid-template-columns:1fr 1fr}
  .cta-section h2{font-size:1.8rem}
}
@media(max-width:480px){
  .team-grid{grid-template-columns:1fr}
}