*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --white:#FFFFFF;
  --off-white:#F2F0ED;
  --light-gray:#C8C5C0;
  --mid-gray:#888480;
  --dark-gray:#3A3835;
  --charcoal:#1A1918;
  --near-black:#0D0D0C;
  --black:#000000;

  --bg-primary:#0D0D0C;
  --bg-secondary:#111110;
  --bg-card:#161615;
  --bg-card-hover:#1C1C1A;
  --text-primary:#F2F0ED;
  --text-secondary:#9A9590;
  --text-muted:#555250;
  --border-subtle:rgba(255,255,255,0.07);
  --border-white:rgba(255,255,255,0.22);
  --shadow-white:0 0 60px rgba(255,255,255,0.04);

  --font-display:'Playfair Display',Georgia,serif;
  --font-body:'Outfit',Helvetica,sans-serif;
  --font-accent:'Cormorant Garamond',Georgia,serif;

  --max-width:1280px;
  --side-margin:max(48px, calc((100vw - var(--max-width)) / 2 + 48px));
}
html{scroll-behavior:smooth;overflow-x:hidden}
body{background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-body);font-weight:300;line-height:1.7;overflow-x:hidden}
::selection{background:var(--white);color:var(--black)}
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--bg-primary)}
::-webkit-scrollbar-thumb{background:var(--dark-gray);border-radius:3px}

/* === LOADER === */
.loader{position:fixed;inset:0;z-index:9999;background:var(--black);display:flex;align-items:center;justify-content:center;flex-direction:column;transition:opacity .9s,visibility .9s}
.loader.hidden{opacity:0;visibility:hidden;pointer-events:none}
.loader-logo{font-family:var(--font-body);font-size:1rem;letter-spacing:.4em;text-transform:uppercase;color:var(--white);animation:pulse 1.6s ease-in-out infinite}
.loader-line{width:50px;height:1px;background:linear-gradient(90deg,transparent,var(--white),transparent);margin-top:1.8rem;animation:expand 1.6s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.2}50%{opacity:1}}
@keyframes expand{0%,100%{width:50px}50%{width:110px}}

/* === NAV === */
nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:1.6rem var(--side-margin);
  display:flex;align-items:center;justify-content:space-between;
  transition:all .5s;
}
nav.scrolled{
  background:rgba(13,13,12,.94);
  backdrop-filter:blur(24px);
  border-bottom:1px solid var(--border-subtle);
  padding-top:1rem;padding-bottom:1rem;
}
.nav-logo{
  display:flex;align-items:center;gap:10px;
  text-decoration:none;flex-shrink:0;
}
.nav-logo-icon{width:28px;height:28px;flex-shrink:0}
.nav-logo-text{
  font-family:var(--font-body);
  font-size:.82rem;letter-spacing:.22em;
  color:var(--white);font-weight:700;text-transform:uppercase;
  white-space:nowrap;
}
.nav-links{display:flex;gap:2.5rem;align-items:center}
.nav-links a{
  color:var(--text-secondary);text-decoration:none;
  font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;
  font-weight:400;transition:color .3s;position:relative;
}
.nav-links a::after{
  content:'';position:absolute;bottom:-4px;left:0;
  width:0;height:1px;background:var(--white);transition:width .3s;
}
.nav-links a:hover{color:var(--white)}
.nav-links a:hover::after{width:100%}
.nav-cta{
  background:var(--white)!important;color:var(--black)!important;
  padding:.65rem 1.7rem!important;font-size:.72rem!important;
  letter-spacing:.18em!important;text-transform:uppercase;
  cursor:pointer;transition:all .3s!important;
  font-family:var(--font-body)!important;border-radius:12px!important;
}
.nav-cta:hover{background:var(--off-white)!important;transform:translateY(-1px)!important}
.nav-cta::after{display:none!important}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;z-index:1001}
.hamburger span{width:24px;height:1.5px;background:var(--white);transition:all .3s}

/* === BURGER (mobile) === */
.burger{position:relative;width:24px;height:18px;background:transparent;cursor:pointer;display:none;z-index:1001}
.burger input{display:none}
.burger span{display:block;position:absolute;height:2px;width:100%;background:var(--white);border-radius:9px;opacity:1;left:0;transform:rotate(0deg);transition:.25s ease-in-out}
.burger span:nth-of-type(1){top:0px;transform-origin:left center}
.burger span:nth-of-type(2){top:50%;transform:translateY(-50%);transform-origin:left center}
.burger span:nth-of-type(3){top:100%;transform-origin:left center;transform:translateY(-100%)}
.burger input:checked ~ span:nth-of-type(1){transform:rotate(45deg);top:0px;left:3px}
.burger input:checked ~ span:nth-of-type(2){width:0%;opacity:0}
.burger input:checked ~ span:nth-of-type(3){transform:rotate(-45deg);top:17px;left:3px}

/* === HERO === */
.hero{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
  padding:0 var(--side-margin);
}
.hero-bg{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 80% 60% at 15% 85%, rgba(255,255,255,.025) 0%, transparent 60%),
    radial-gradient(ellipse 50% 50% at 85% 15%, rgba(255,255,255,.015) 0%, transparent 55%);
}
.hero-grain{
  position:absolute;inset:0;opacity:.025;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E")
}
.hero-lines{position:absolute;inset:0;overflow:hidden}
.hero-lines::before,.hero-lines::after{
  content:'';position:absolute;width:1px;height:200vh;
  background:linear-gradient(180deg,transparent,rgba(255,255,255,.06),transparent);
  animation:drift 22s linear infinite;
}
.hero-lines::before{left:18%;top:-50%;animation-delay:0s}
.hero-lines::after{right:22%;top:-80%;animation-delay:-11s}
@keyframes drift{0%{transform:translateY(-10%)}100%{transform:translateY(10%)}}

.hero-content{position:relative;text-align:center;max-width:860px;opacity:0;animation:fadeUp .9s .3s forwards}
.hero-badge{
  display:inline-flex;align-items:center;gap:.9rem;
  border:1px solid var(--border-white);
  padding:.5rem 1.8rem;border-radius:50px;margin-bottom:2.5rem;
}
.hero-badge span{font-size:.68rem;letter-spacing:.3em;text-transform:uppercase;color:var(--light-gray)}
.hero-badge-dot{width:5px;height:5px;border-radius:50%;background:var(--white);animation:glow 2s ease-in-out infinite}
@keyframes glow{0%,100%{box-shadow:0 0 4px rgba(255,255,255,.5)}50%{box-shadow:0 0 14px rgba(255,255,255,.9)}}

.hero-title{
  font-family:var(--font-display);
  font-size:clamp(2.4rem,6.5vw,6rem);
  font-weight:400;line-height:1.06;letter-spacing:-.02em;
  margin-bottom:1.2rem;
  opacity:0;animation:fadeUp .8s .55s forwards;
}
.hero-title em{
  font-style:italic;color:var(--light-gray);
  font-family:var(--font-accent);font-weight:300;
}
.hero-subtitle{
  font-family:var(--font-accent);
  font-size:clamp(1rem,2vw,1.5rem);
  color:var(--text-secondary);font-weight:300;
  letter-spacing:.04em;line-height:1.7;
  max-width:620px;margin:0 auto 3rem;
  opacity:0;animation:fadeUp .8s .75s forwards;
}
.hero-actions{
  display:flex;gap:1.2rem;justify-content:center;flex-wrap:wrap;
  opacity:0;animation:fadeUp .8s .95s forwards;
}
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}

/* === BUTTONS === */
.btn{
  display:inline-flex;align-items:center;gap:.7rem;
  padding:1rem 2.5rem;font-family:var(--font-body);
  font-size:.76rem;letter-spacing:.22em;text-transform:uppercase;
  text-decoration:none;font-weight:400;cursor:pointer;
  transition:all .35s;border:none;border-radius:12px;
}
.btn-white{
  background:var(--white);color:var(--black);
  position:relative;overflow:hidden;
}
.btn-white::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(0,0,0,.08),transparent);
  transform:translateX(-100%);transition:transform .6s;
}
.btn-white:hover::before{transform:translateX(100%)}
.btn-white:hover{box-shadow:0 8px 32px rgba(255,255,255,.18);transform:translateY(-1px)}
.btn-outline{
  border:1px solid var(--border-white);color:var(--off-white);background:transparent;border-radius:12px;
}
.btn-outline:hover{background:rgba(255,255,255,.06);border-color:var(--white)}
.btn-arrow{transition:transform .3s}
.btn:hover .btn-arrow{transform:translateX(5px)}

/* === SECTION SHARED === */
section{padding:7rem 0}
.section-inner{padding:0 var(--side-margin)}
.section-label{
  font-size:.68rem;letter-spacing:.35em;text-transform:uppercase;
  color:var(--light-gray);margin-bottom:1rem;
  display:flex;align-items:center;gap:1rem;
}
.section-label::before{content:'';width:28px;height:1px;background:var(--white)}
.section-title{
  font-family:var(--font-display);
  font-size:clamp(1.8rem,4vw,3.2rem);
  font-weight:400;line-height:1.15;margin-bottom:.8rem;
}
.section-subtitle{
  font-family:var(--font-accent);font-size:1.15rem;
  color:var(--text-secondary);font-weight:300;
  max-width:540px;line-height:1.7;
}

/* === MARQUEE === */
.marquee-wrap{
  border-top:1px solid var(--border-subtle);
  border-bottom:1px solid var(--border-subtle);
  padding:1.3rem 0;overflow:hidden;
  background:#0a0a0a;
}
.marquee-track{display:flex;gap:3rem;animation:marquee 32s linear infinite;width:max-content}
.marquee-track span{
  font-family:var(--font-body);font-size:.85rem;font-weight:400;
  color:rgba(255,255,255,0.75);letter-spacing:.2em;text-transform:uppercase;
  white-space:nowrap;display:flex;align-items:center;gap:3rem;
}
.marquee-track span::after{content:'◆';color:rgba(255,255,255,0.3);font-size:.4rem;vertical-align:middle}
.marquee-track span::after{content:'◆';color:var(--dark-gray);font-size:.4rem;vertical-align:middle}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* === STATS BAR === */
.stats-bar{
  background:var(--bg-secondary);
  border-bottom:1px solid var(--border-subtle);
  padding:2.5rem var(--side-margin);
  display:flex;gap:0;
}
.stat-item{
  flex:1;text-align:center;padding:0 2rem;
  border-right:1px solid var(--border-subtle);
}
.stat-item:last-child{border-right:none}
.stat-num{
  font-family:var(--font-display);font-size:2.4rem;
  font-weight:400;color:var(--white);letter-spacing:-.02em;
}
.stat-label{
  font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--text-muted);margin-top:.3rem;
}

/* === SERVICES === */
.services{background:var(--bg-secondary);position:relative;padding:7rem 0}
.services-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1px;margin-top:4rem;
  background:var(--border-subtle);
  margin-left:var(--side-margin);margin-right:var(--side-margin);
}
.service-card{
  background:var(--bg-secondary);padding:3rem 2.5rem;
  position:relative;overflow:hidden;transition:all .5s;cursor:default;
}
.service-card::before{
  content:'';position:absolute;top:0;left:0;width:100%;height:1px;
  background:linear-gradient(90deg,transparent,var(--white),transparent);
  transform:scaleX(0);transition:transform .5s;
}
.service-card:hover::before{transform:scaleX(1)}
.service-card:hover{background:var(--bg-card)}
.service-icon{
  width:46px;height:46px;border:1px solid var(--border-white);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  margin-bottom:1.8rem;color:var(--white);font-size:1rem;transition:all .4s;
}
.service-card:hover .service-icon{
  background:rgba(255,255,255,.06);
  box-shadow:0 0 20px rgba(255,255,255,.08);
}
.service-card h3{
  font-family:var(--font-display);font-size:1.15rem;
  font-weight:400;margin-bottom:.8rem;letter-spacing:.02em;
}
.service-card p{color:var(--text-secondary);font-size:.87rem;line-height:1.75}

/* === EVENTS === */
.events{padding:7rem 0}
.events-header{padding:0 var(--side-margin);margin-bottom:3.5rem}
.events-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1rem;
  padding:0 var(--side-margin);
}
.events-grid .event-card.span-2{grid-column:span 2}
.events-grid .event-card.span-3{grid-column:span 3}
.event-card{
  position:relative;border-radius:12px;overflow:hidden;
  cursor:pointer;aspect-ratio:3/4;
}
.event-card.span-2{aspect-ratio:2.4/1}
.event-card.span-3{aspect-ratio:21/9}
.event-card.match-row{aspect-ratio:1.2/1}
.event-img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;transition:transform .7s,filter .7s}
.event-card:hover .event-img{transform:scale(1.06);filter:brightness(.6) grayscale(.3)}
.event-overlay{
  position:absolute;inset:0;
  background:linear-gradient(0deg,rgba(13,13,12,.85) 0%,rgba(13,13,12,.15) 40%,transparent 65%);
  display:flex;flex-direction:column;justify-content:flex-end;padding:2rem;
  transition:background .4s;
}
.event-card:hover .event-overlay{
  background:linear-gradient(0deg,rgba(13,13,12,.95) 0%,rgba(13,13,12,.4) 55%,transparent 75%);
}
.event-tag{display:none}
.event-card h3{
  font-family:var(--font-display);font-size:1.2rem;
  margin-bottom:0;color:var(--white);
  transition:transform .4s;
}
.event-card:hover h3{transform:translateY(-6px)}
.event-card .event-details,
.event-card p{
  color:var(--text-secondary);font-size:.82rem;line-height:1.6;
  margin-top:.4rem;
  opacity:0;max-height:0;overflow:hidden;
  transition:opacity .4s,max-height .4s;
}
.event-card:hover .event-details,
.event-card:hover p{
  opacity:1;max-height:80px;
}

/* === PROCESS === */
.process{background:var(--bg-secondary);padding:7rem 0}
.process-inner{padding:0 var(--side-margin)}
.process-steps{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:0;margin-top:4rem;
  border:1px solid var(--border-subtle);
}
.process-step{
  padding:2.5rem 2rem;border-right:1px solid var(--border-subtle);
  position:relative;transition:background .4s;
}
.process-step:last-child{border-right:none}
.process-step:hover{background:rgba(255,255,255,.02)}
.step-num{
  font-family:var(--font-display);font-size:3rem;font-weight:400;
  color:rgba(255,255,255,.08);line-height:1;margin-bottom:1.2rem;
}
.step-title{
  font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--white);margin-bottom:.7rem;font-weight:500;
}
.step-desc{color:var(--text-secondary);font-size:.85rem;line-height:1.7}
.step-arrow{
  position:absolute;top:50%;right:-1px;transform:translateY(-50%);
  width:18px;height:18px;border-top:1px solid var(--border-white);
  border-right:1px solid var(--border-white);
  transform:translateY(-50%) rotate(45deg);
  background:var(--bg-secondary);
  display:none;
}

/* === TESTIMONIALS === */
.testimonials{padding:7rem 0;background:var(--bg-primary);position:relative}
.testimonials::before{
  content:'';position:absolute;top:0;left:50%;
  transform:translateX(-50%);width:1px;height:80px;
  background:linear-gradient(180deg,transparent,rgba(255,255,255,.2));
}
.testimonials-inner{padding:0 var(--side-margin)}
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5px;margin-top:4rem;background:var(--border-subtle)}
.testimonial-card{
  background:var(--bg-primary);border:none;
  padding:2.5rem;position:relative;transition:all .4s;
}
.testimonial-card:hover{background:var(--bg-card)}
.testimonial-quote{
  font-size:2.8rem;font-family:var(--font-display);
  color:rgba(255,255,255,.12);position:absolute;top:1rem;right:1.5rem;line-height:1;
}
.testimonial-text{
  font-family:var(--font-accent);font-size:1.05rem;
  line-height:1.85;color:var(--text-primary);
  font-weight:300;font-style:italic;margin-bottom:2rem;
}
.testimonial-author{
  display:flex;align-items:center;gap:1rem;
  padding-top:1.5rem;border-top:1px solid var(--border-subtle);
}
.testimonial-avatar{
  width:40px;height:40px;border-radius:50%;
  background:linear-gradient(135deg,var(--dark-gray),var(--charcoal));
  border:1px solid var(--border-white);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-size:.78rem;
  color:var(--white);font-weight:700;
}
.testimonial-info strong{display:block;font-size:.86rem;font-weight:500;letter-spacing:.02em}
.testimonial-info span{font-size:.76rem;color:var(--text-muted)}

/* === CTA === */
.cta-section{
  text-align:center;padding:9rem var(--side-margin);
  position:relative;overflow:hidden;
}
.cta-section::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 70% 60% at 50% 50%,rgba(255,255,255,.025),transparent);
}
.cta-title{
  font-family:var(--font-display);
  font-size:clamp(1.8rem,4.5vw,3.8rem);
  font-weight:400;margin-bottom:1rem;position:relative;
}
.cta-title em{color:var(--light-gray);font-family:var(--font-accent);font-style:italic}
.cta-divider{width:50px;height:1px;background:var(--white);margin:2rem auto}
.cta-text{
  font-family:var(--font-accent);color:var(--text-secondary);
  font-size:1.12rem;max-width:480px;
  margin:0 auto 3rem;line-height:1.75;position:relative;
}

/* === FOOTER === */
footer{
  border-top:1px solid var(--border-subtle);
  padding:4.5rem var(--side-margin) 2rem;
  background:var(--bg-secondary);
}
.footer-top{
  display:flex;justify-content:space-between;
  align-items:flex-start;gap:3rem;flex-wrap:wrap;margin-bottom:3rem;
}
.footer-brand{max-width:300px}
.footer-brand-name{
  font-family:var(--font-display);font-size:1.2rem;
  letter-spacing:.4em;color:var(--white);margin-bottom:.8rem;
}
.footer-brand p{color:var(--text-muted);font-size:.83rem;line-height:1.75}
.footer-col h4{
  font-size:.65rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--text-secondary);margin-bottom:1.2rem;
}
.footer-col a{
  display:block;color:var(--text-muted);text-decoration:none;
  font-size:.85rem;margin-bottom:.6rem;transition:color .3s;
}
.footer-col a:hover{color:var(--white)}
.footer-bottom{
  border-top:1px solid var(--border-subtle);padding-top:1.5rem;
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:1rem;
}
.footer-bottom p{color:var(--text-muted);font-size:.76rem;letter-spacing:.05em}
.footer-socials{display:flex;gap:1rem}
.footer-socials a{
  width:36px;height:36px;border:1px solid var(--border-subtle);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  color:var(--text-muted);text-decoration:none;font-size:.8rem;transition:all .3s;
}
.footer-socials a:hover{border-color:var(--white);color:var(--white)}

/* === LANG SWITCHER === */
.lang{
  display:flex;background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);border-radius:6px;
  overflow:hidden;margin-left:1.5rem;
}
.lang button{
  background:none;border:none;color:var(--text-secondary);
  font-family:var(--font-body);font-size:.68rem;font-weight:600;
  padding:6px 13px;cursor:pointer;transition:all .25s;letter-spacing:.5px;text-transform:uppercase;
}
.lang button.active{background:var(--white);color:var(--black);border-radius:4px}
.lang button:hover:not(.active){color:var(--white)}

/* === SCROLL REVEAL === */
.reveal{opacity:0;transform:translateY(36px);transition:opacity .75s,transform .75s}
.reveal.visible{opacity:1;transform:translateY(0)}

/* === RESPONSIVE === */
@media(max-width:1100px){
  :root{--side-margin:40px}
  .events-grid{grid-template-columns:repeat(2,1fr)}
  .events-grid .event-card.span-3{grid-column:span 2}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .testimonials-grid{grid-template-columns:repeat(2,1fr)}
  .process-steps{grid-template-columns:repeat(2,1fr)}
  .process-step:nth-child(2){border-right:none}
  .process-step:nth-child(1),.process-step:nth-child(2){border-bottom:1px solid var(--border-subtle)}
  .stats-bar{flex-wrap:wrap}
  .stat-item{flex:1 0 45%;border-bottom:1px solid var(--border-subtle);border-right:none;padding:1.5rem 1rem}
  .stat-item:nth-child(odd){border-right:1px solid var(--border-subtle)}
}
@media(max-width:768px){
  :root{--side-margin:24px}
  .nav-links{display:none}
  .burger{display:block}
  .nav-links.open{
    display:flex;position:fixed;top:70px;left:0;right:0;
    background:rgba(13,13,12,.98);flex-direction:column;
    align-items:center;justify-content:flex-start;gap:1.2rem;
    padding:2rem 1.5rem;z-index:1000;
    border-bottom:1px solid var(--border-subtle);
    backdrop-filter:blur(24px);
  }
  .nav-links.open .lang{display:flex}
  .events-grid{grid-template-columns:1fr}
  .events-grid .event-card.span-2,.events-grid .event-card.span-3{grid-column:span 1}
  .event-card{aspect-ratio:16/10}
  .event-card.span-2,.event-card.span-3{aspect-ratio:16/10}
  .services-grid{grid-template-columns:1fr;margin-left:var(--side-margin);margin-right:var(--side-margin)}
  .testimonials-grid{grid-template-columns:1fr}
  .process-steps{grid-template-columns:1fr}
  .process-step{border-right:none;border-bottom:1px solid var(--border-subtle)}
  .process-step:last-child{border-bottom:none}
  section{padding:5rem 0}
  .hero-actions{flex-direction:column;align-items:center}
  .lang{display:none}
}
