@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;1,400;1,700&family=EB+Garamond:ital,wght@0,400;0,500;1,400&family=Space+Grotesk:wght@300;400;500&display=swap');

*{box-sizing:border-box;margin:0;padding:0}
:root{
  --noir:#0a0907;
  --noir2:#111009;
  --noir3:#1a1710;
  --noir4:#252018;
  --or:#c9a84c;
  --or2:#b89a5a;
  --or4:#6b5628;
  --creme:#f5ede0;
  --creme2:#ede0cc;
  --gris:#3a3428;
  --gris2:#4f4737;
  --gris3:#9a8f74;
  --serif:'Playfair Display',Georgia,serif;
  --garamond:'EB Garamond',Georgia,serif;
  --sans:'Space Grotesk',sans-serif;
}
html,body{background:var(--noir)}
.site{background:var(--noir);color:var(--creme);font-family:var(--serif);width:100%;min-height:100vh;display:flex;flex-direction:column}
.site a{color:inherit;text-decoration:none}
.site main{flex:1}

/* NAV */
.nav{background:var(--noir2);border-bottom:1px solid var(--noir4);padding:0 2rem;display:flex;justify-content:space-between;align-items:center;height:56px;flex-wrap:wrap;position:sticky;top:0;z-index:50}
.nav-logo{display:flex;align-items:center;padding:8px 0}
.nav-logo img{height:40px;width:auto;max-height:calc(56px - 16px);display:block}
.nav-links{display:flex;gap:0;align-items:center;flex-wrap:wrap}
.nav-link{font-family:var(--sans);font-size:10.5px;font-weight:300;letter-spacing:0.12em;text-transform:uppercase;color:var(--gris3);padding:0 1.1rem;height:56px;display:flex;align-items:center;cursor:pointer;border-bottom:2px solid transparent;transition:color 0.2s,border-color 0.2s}
.nav-link:hover,.nav-link.active{color:var(--or);border-bottom-color:var(--or)}
.nav-cta{margin-left:1.5rem;padding:7px 18px;border:1px solid var(--or4);font-family:var(--sans);font-size:10px;font-weight:400;letter-spacing:0.15em;text-transform:uppercase;color:var(--or);cursor:pointer;transition:background 0.2s}
.nav-cta:hover{background:rgba(201,168,76,0.08)}
@media (min-width:761px){
  .nav{min-height:68px;height:auto}
  .nav-logo{padding:4px 0}
  .nav-logo img{height:60px;max-height:none}
}

/* HERO */
.hero{background:var(--noir);padding:4rem 2rem 1.75rem;border-bottom:1px solid var(--noir4);position:relative;overflow:hidden}
.hero-kicker{font-family:var(--sans);font-size:9.5px;font-weight:300;letter-spacing:0.28em;text-transform:uppercase;color:var(--or);margin-bottom:1.2rem}
.hero-title{font-size:3.4rem;font-weight:700;line-height:0.98;letter-spacing:-0.01em;color:var(--creme);margin-bottom:0.4rem}
.hero-title em{font-style:italic;font-weight:400;color:var(--or2)}
.hero-rule{display:flex;align-items:center;gap:1rem;margin:1.5rem 0}
.hero-rule-line{flex:0 0 48px;height:1px;background:var(--or)}
.hero-rule-diamond{width:5px;height:5px;background:var(--or);transform:rotate(45deg)}
.hero-sub{font-family:var(--garamond);font-size:1.25rem;font-style:italic;color:var(--or2);margin-bottom:0.75rem}
.hero-desc{font-family:var(--sans);font-size:13px;font-weight:300;color:var(--gris3);line-height:1.8;max-width:720px;margin-bottom:1rem}
.hero-actions{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}
.btn-gold{display:inline-block;padding:11px 28px;background:var(--or);font-family:var(--sans);font-size:10px;font-weight:500;letter-spacing:0.18em;text-transform:uppercase;color:var(--noir);cursor:pointer;transition:background 0.2s;border:none}
.btn-gold:hover{background:var(--or2)}
.btn-outline{display:inline-block;padding:11px 28px;border:1px solid var(--or4);font-family:var(--sans);font-size:10px;font-weight:300;letter-spacing:0.18em;text-transform:uppercase;color:var(--or2);cursor:pointer;transition:all 0.2s;background:none}
.btn-outline:hover{border-color:var(--or);color:var(--or)}

/* SECTION HEADERS */
.section{padding:2rem;border-bottom:1px solid var(--noir4)}
.section-header{display:flex;align-items:baseline;gap:1.5rem;margin-bottom:1.5rem;flex-wrap:wrap}
.section-kicker{font-family:var(--sans);font-size:9.5px;font-weight:300;letter-spacing:0.3em;text-transform:uppercase;color:var(--or)}
.section-title{font-size:1.9rem;font-weight:700;color:var(--creme)}
.section-title em{font-style:italic;font-weight:400}
.section-rule{flex:1;height:1px;background:var(--noir4);min-width:40px}
.section-note{font-family:var(--sans);font-size:12px;font-weight:300;color:var(--gris3);margin-top:1.5rem}

/* CONCERTS */
.concert-list{display:flex;flex-direction:column;gap:0;border:1px solid var(--noir4)}
.concert-item{display:grid;grid-template-columns:100px 1fr auto;align-items:center;gap:0;border-bottom:1px solid var(--noir4)}
.concert-item:last-child{border-bottom:none}
.concert-date{padding:1.2rem 1.25rem;border-right:1px solid var(--noir4);text-align:center}
.concert-day{font-size:1.8rem;font-weight:700;color:var(--or);line-height:1}
.concert-month{font-family:var(--sans);font-size:9px;font-weight:300;letter-spacing:0.2em;text-transform:uppercase;color:var(--or2);margin-top:2px}
.concert-year{font-family:var(--sans);font-size:9px;font-weight:300;letter-spacing:0.15em;color:var(--gris3);margin-top:3px}
.concert-body{padding:1.2rem 1.5rem}
.concert-prog{font-size:1.05rem;font-weight:700;color:var(--creme);margin-bottom:2px}
.concert-detail{font-family:var(--sans);font-size:11.5px;font-weight:300;color:var(--gris3);line-height:1.5}
.concert-venue{font-family:var(--sans);font-size:13.5px;font-weight:400;color:#d3bd93;line-height:1.5;margin-bottom:1px}
.concert-map{display:inline-block;font-family:var(--sans);font-size:11px;font-weight:300;color:var(--or2);text-decoration:underline;text-underline-offset:2px;margin-bottom:3px;transition:color 0.2s}
.concert-map:hover{color:var(--or)}
.concert-action{padding:1.2rem 1.5rem;border-left:1px solid var(--noir4);display:flex;flex-direction:column;gap:8px;align-items:flex-start}
.concert-btn{padding:8px 16px;border:1px solid var(--or4);font-family:var(--sans);font-size:9.5px;font-weight:300;letter-spacing:0.12em;text-transform:uppercase;color:var(--or2);cursor:pointer;white-space:nowrap;transition:all 0.2s;display:inline-block}
.concert-btn:hover{border-color:var(--or);color:var(--or);background:rgba(201,168,76,0.05)}
.concert-tag{font-family:var(--sans);font-size:9px;font-weight:400;letter-spacing:0.12em;text-transform:uppercase;padding:3px 8px;display:inline-block;margin-top:6px}
.concert-tag.gold{background:rgba(201,168,76,0.12);color:var(--or);border:1px solid var(--or4)}
.concert-tag.muted{color:var(--gris3);border:1px solid var(--noir4)}
.concert-item.past{opacity:0.75}
.concert-item.next{grid-template-columns:80px auto 1fr auto}
.concert-cta{align-self:center;justify-self:start;margin:0 1.25rem;padding:9px 17px;background:var(--or);color:var(--noir);font-family:var(--sans);font-size:10px;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;white-space:nowrap;display:inline-block;transition:background 0.2s}
.concert-cta:hover{background:var(--or2)}

/* PHOTOS */
.photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--noir4)}
.photo-item{background:var(--noir3);aspect-ratio:4/3;position:relative;overflow:hidden;display:block}
.photo-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 0.3s,opacity 0.2s}
.photo-item:hover img{transform:scale(1.04);opacity:0.85}

/* CAROUSEL */
.carousel{position:relative;border:1px solid var(--noir4);background:var(--noir3);overflow:hidden}
.carousel-track{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;scrollbar-width:none;-ms-overflow-style:none}
.carousel-track::-webkit-scrollbar{display:none}
.carousel-slide{flex:0 0 100%;scroll-snap-align:center;aspect-ratio:16/9;background:var(--noir3)}
.carousel.short{max-width:820px;margin-left:auto;margin-right:auto}
.carousel.short .carousel-slide{aspect-ratio:21/9}
.carousel-slide img{width:100%;height:100%;object-fit:cover;display:block}
.carousel-arrow{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:rgba(10,9,7,0.55);border:1px solid var(--or4);color:var(--or);font-family:var(--serif);font-size:1.6rem;line-height:1;cursor:pointer;transition:background 0.2s,color 0.2s;z-index:2}
.carousel-arrow:hover{background:rgba(10,9,7,0.85);color:var(--creme)}
.carousel-arrow[hidden]{display:none}
.carousel-arrow.prev{left:0.75rem}
.carousel-arrow.next{right:0.75rem}
.carousel-dots{position:absolute;bottom:0.85rem;left:0;right:0;display:flex;justify-content:center;gap:0.55rem;z-index:2}
.carousel-dot{width:7px;height:7px;padding:0;border:1px solid var(--or);background:transparent;cursor:pointer;transform:rotate(45deg);transition:background 0.2s}
.carousel-dot.active{background:var(--or)}
@media (prefers-reduced-motion:reduce){.carousel-track{scroll-behavior:auto}}

/* MEDIA SPLIT (content + side photo) */
.media-split{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:stretch}
.media-split .contact-grid{max-width:none}
.media-photo{overflow:hidden;border:1px solid var(--noir4);min-height:240px}
.media-photo img{width:100%;height:100%;object-fit:cover;display:block}
@media (max-width:760px){.media-split{grid-template-columns:1fr;gap:1.25rem}.media-photo{min-height:200px}}
@media (min-width:761px){.aside-photo{align-self:start;justify-self:center;width:100%;max-width:420px;aspect-ratio:4/5;max-height:520px;position:sticky;top:84px}}
@media (min-width:761px){.aside-raise{margin-top:-7.5rem}}
.concert-aside{display:grid;grid-template-columns:1fr auto;gap:1.25rem;align-items:stretch}
.concert-aside .media-photo{min-height:0;align-self:start;justify-self:end;width:fit-content;max-width:100%}
.concert-aside .media-photo img{width:auto;height:auto;max-width:100%;max-height:150px;object-fit:contain}
@media (max-width:500px){.concert-aside{grid-template-columns:1fr;gap:1.25rem}.concert-aside .media-photo{justify-self:center}}

/* CONTACT */
.contact-grid{display:flex;flex-direction:column;max-width:560px;border:1px solid var(--noir4)}
.contact-block{padding:1.75rem 2rem;border-bottom:1px solid var(--noir4)}
.contact-block:last-child{border-bottom:none}
.contact-block-label{font-family:var(--sans);font-size:9px;font-weight:300;letter-spacing:0.25em;text-transform:uppercase;color:var(--or);margin-bottom:0.5rem}
.contact-block-val{font-family:var(--garamond);font-size:1.1rem;color:var(--creme2);line-height:1.6;font-style:italic;display:inline-flex;align-items:center;gap:8px}
.contact-block-note{font-family:var(--sans);font-size:11.5px;font-weight:300;color:var(--gris3);margin-top:4px;line-height:1.5}

/* ORCHESTRE */
.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--noir4)}
.info-col{padding:2rem;border-right:1px solid var(--noir4)}
.info-col:last-child{border-right:none}
.info-label{font-family:var(--sans);font-size:9.5px;font-weight:300;letter-spacing:0.25em;text-transform:uppercase;color:var(--or);margin-bottom:0.75rem}
.info-lead{font-family:var(--garamond);font-size:1.4rem;font-style:italic;color:var(--creme);line-height:1.3;margin-bottom:1rem}
.info-body{font-family:var(--sans);font-size:12.5px;font-weight:300;color:var(--gris3);line-height:1.8;margin-bottom:.5rem}
.info-sub{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--noir4)}
.info-name{font-size:1.1rem;font-weight:700;color:var(--creme)}
.info-role{font-family:var(--garamond);font-size:0.95rem;font-style:italic;color:var(--or2);margin-top:2px}
.formation-list{display:flex;flex-direction:column;border:1px solid var(--noir4)}
.formation-row{display:flex;justify-content:space-between;align-items:center;padding:0.7rem 1rem;border-bottom:1px solid var(--noir4)}
.formation-row:last-child{border-bottom:none}
.formation-instr{font-family:var(--sans);font-size:12px;font-weight:300;color:var(--creme2)}
.formation-tag{font-family:var(--sans);font-size:10px;font-weight:400;letter-spacing:0.08em;text-transform:uppercase;color:var(--or);border:1px solid var(--or4);padding:2px 8px}

/* FOOTER */
.footer{background:var(--noir2);border-top:1px solid var(--noir4);padding:2rem;display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:2rem}
.footer-brand-name{font-family:var(--sans);font-size:10px;font-weight:300;letter-spacing:0.22em;text-transform:uppercase;color:var(--or);margin-bottom:0.5rem}
.footer-brand-desc{font-family:var(--sans);font-size:11.5px;font-weight:300;color:var(--gris3);line-height:1.6}
.footer-col-title{font-family:var(--sans);font-size:9px;font-weight:400;letter-spacing:0.2em;text-transform:uppercase;color:var(--or4);margin-bottom:0.75rem}
.footer-link{font-family:var(--sans);font-size:12px;font-weight:300;color:var(--gris3);display:block;margin-bottom:0.4rem;cursor:pointer}
.footer-link:hover{color:var(--or2)}
.footer-bottom{background:var(--noir2);border-top:1px solid var(--noir4);padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:0.5rem}
.footer-copy{font-family:var(--sans);font-size:10.5px;font-weight:300;color:var(--gris3);letter-spacing:0.05em}
.footer-or{width:40px;height:1px;background:var(--or4)}
.icon{width:1em;height:1em;vertical-align:middle}

@media (max-width:760px){
  .nav{padding:0 1rem;height:auto;flex-direction:column;align-items:flex-start}
  .nav-links{gap:0;width:100%;overflow-x:auto}
  .nav-link{padding:0 0.65rem}
  .nav-link-interne{display:none}
  .nav-cta{position:absolute;top:14px;right:1rem;margin-left:0}
  .hero{padding:2.5rem 1.25rem 1.25rem}
  .hero-title{font-size:2.3rem}
  .section{padding:2rem 1.25rem}
  .concert-item{grid-template-columns:1fr;grid-template-areas:"date" "body" "action"}
  .concert-item.next{grid-template-columns:1fr;grid-template-areas:"date" "cta" "body" "action"}
  .concert-date{grid-area:date;display:flex;align-items:baseline;gap:0.5rem;text-align:left;border-right:none;border-bottom:1px solid var(--noir4);padding:1rem 1.25rem}
  .concert-day{font-size:1.5rem}
  .concert-month,.concert-year{margin-top:0}
  .concert-body{grid-area:body}
  .concert-action{grid-area:action;border-left:none;border-top:1px solid var(--noir4);flex-direction:row}
  .concert-cta{grid-area:cta;justify-self:start;align-self:center;margin:0 0 0 1.25rem}
  .photo-grid{grid-template-columns:repeat(2,1fr)}
  .info-grid{grid-template-columns:1fr}
  .info-col{border-right:none;border-bottom:1px solid var(--noir4)}
  .info-col:last-child{border-bottom:none}
  .footer{grid-template-columns:1fr;padding:2rem 1.25rem}
  .footer-bottom{padding:1rem 1.25rem}
}
