:root{
  --bg:#070707;
  --text:#f5f2ec;
  --muted:rgba(245,242,236,.68);
  --line:rgba(255,255,255,.12);
  --gold:#b08d57;
  --gold2:#d4af6a;
  --glass:rgba(0,0,0,.48);
  --radius:22px;
  --shadow:0 30px 90px rgba(0,0,0,.65);
}

*{box-sizing:border-box}

html{scroll-behavior:smooth}

body{
  margin:0;
  font-family:ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  color:var(--text);
  background:var(--bg);
}

/* FULL SITE BACKGROUND IMAGE */
.hero-background{
    position:absolute;
  inset:0;
  z-index:0;
	
    background:
        linear-gradient(
            to bottom,
            rgba(0,0,0,.05) 0%,
            rgba(0,0,0,.07) 85%,
            rgba(0,0,0,.40) 90%,
            rgba(0,0,0,.80) 100%,
            #000 100%
        ),
        url("img/bg.png");

    background-size:cover;
    background-position:center;
}

/* HEADER */
.topbar{
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:20;

  display:flex;
  justify-content:space-between;
  align-items:center;

  padding:20px 60px;
  background:rgba(0,0,0,.28);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(255,255,255,.08);
}

.brand{
  display:flex;
  align-items:center;
  text-decoration:none;
  color:var(--text);
  font-weight:900;
  letter-spacing:.14em;
  text-transform:uppercase;
}

.logo{
  height:52px;
  width:auto;
  display:block;
}

.desktop-nav{
  display:flex;
  gap:30px;
  align-items:center;
}

.desktop-nav a{
  color:rgba(255,255,255,.72);
  text-decoration:none;
  font-size:13px;
  font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
}

.desktop-nav a:hover{
  color:var(--gold2);
}

/* HERO */
.hero{
  min-height:100vh;
  display:flex;
  align-items:center;
  padding:120px 70px 60px;
  overflow:hidden;
  position:relative;
}
.hero .btn-primary{
    position:absolute;
    left:145%;
    bottom:45px;
    transform:translateX(-50%);
    z-index:20;

    width:auto !important;
    display:inline-flex !important;
    white-space:nowrap;
}
.hero-grid{
  width:min(1500px, 100%);
  margin:0 auto;
  display:grid;
  grid-template-columns:52% 48%;
  align-items:center;
  gap:20px;
}

.hero-content{
  position:relative;
  z-index:4;
  max-width:760px;
}

.hero-kicker{
  margin:0 0 24px;
  color:var(--gold2);
  font-size:13px;
  font-weight:900;
  letter-spacing:.42em;
  text-transform:uppercase;
}

.hero-title{
  margin:0 0 28px;
  font-size:clamp(58px, 5.6vw, 96px);
  line-height:.96;
  letter-spacing:-.055em;
}

.hero-sub{
  margin:0 0 26px;
  max-width:620px;
  color:var(--gold2);
  font-size:clamp(22px, 2vw, 34px);
  font-weight:900;
  line-height:1.08;
  text-transform:uppercase;
}

.hero-meta{
  margin:0 0 42px;
  color:rgba(255,255,255,.68);
  font-size:18px;
  font-weight:800;
  line-height:1.6;
}

.hero-meta span{
  color:var(--gold2);
  margin:0 12px;
}

.hero-image{
  position:relative;
  z-index:2;
  display:flex;
  justify-content:flex-end;
  align-items:flex-end;
  height:100%;
}

.hero-image img{
  height:min(100vh, 900px);
  width:auto;
  max-width:none;
  margin-right:-100px;
  margin-bottom:-40px;
  object-fit:contain;
}

/* mobile */
@media(max-width:900px){
  .hero{
    padding:120px 24px 70px;
    text-align:center;
  }

  .hero-grid{
    grid-template-columns:1fr;
  }

  .hero-content{
    margin:0 auto;
  }

  .hero-title{
    font-size:clamp(42px, 12vw, 64px);
  }

  .hero-image{
    justify-content:center;
  }

  .hero-image img{
    width:min(420px, 92vw);
    margin:20px auto -20px;
  }
}


/* BUTTONS */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:15px 22px;
  border-radius:999px;
  border:1px solid var(--line);
  text-decoration:none;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
  font-size:12px;
}

.btn-primary{
  color:#111;
  background:linear-gradient(135deg, var(--gold2), var(--gold));
  border-color:rgba(212,175,106,.55);
  box-shadow:0 18px 45px rgba(176,141,87,.22);
}

.btn-primary:hover{
  transform:translateY(-2px);
  filter:brightness(1.06);
}

/* MARQUEE */
.marquee-section{
  position:relative;
  overflow:hidden;
  height:150px;
  margin-top:-70px;
}

.marquee{
  display:flex;
  align-items:center;
  height:100%;
}

.marquee-track{
  display:flex;
  gap:90px;
  white-space:nowrap;
  animation:marquee-scroll 42s linear infinite;
}

.marquee-track span{
  font-size:clamp(70px, 9vw, 140px);
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--gold2);
  opacity:.13;
}

@keyframes marquee-scroll{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* SECTIONS */
.section{
  width:min(1180px, 92%);
  margin:0 auto;
  padding:90px 0;
  position:relative;
  z-index:2;
}

.section-head{
  text-align:center;
  margin-bottom:42px;
}

.section-head .accent{
  display:block;
  margin-bottom:12px;
  color:var(--gold2);
  font-size:12px;
  font-weight:900;
  letter-spacing:.35em;
  text-transform:uppercase;
}

.section-head h2{
  margin:0 0 16px;
  font-size:clamp(38px, 5vw, 72px);
  line-height:.95;
  letter-spacing:-.035em;
}

.section-head p{
  margin:0 auto;
  max-width:760px;
  color:var(--muted);
  line-height:1.75;
  font-size:17px;
}

.impact-break{
    display:flex;
    justify-content:center;
}

.impact-break img{
    width:min(950px, 70vw);
}


/* ABOUT */
.about-section{
  padding-top:60px;
}

.about-copy{
  max-width:920px;
  margin:0 auto;
  padding:34px;
  border-radius:var(--radius);
  background:var(--glass);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  backdrop-filter:blur(14px);
}

.about-copy p{
  margin:0 0 18px;
  color:rgba(255,255,255,.78);
  font-size:18px;
  line-height:1.85;
}

.about-copy p:last-child{
  margin-bottom:0;
}

/* SERVICES */
.service-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:18px;
}

.service-card,
.media-card{
  padding:26px;
  border-radius:var(--radius);
  background:rgba(0,0,0,.52);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  backdrop-filter:blur(12px);
  transition:transform .25s ease, border-color .25s ease;
}

.service-card:hover,
.media-card:hover{
  transform:translateY(-6px);
  border-color:rgba(212,175,106,.42);
}

.service-card h3,
.media-card h3{
  margin:0 0 10px;
  color:var(--gold2);
  font-size:20px;
  line-height:1.2;
}

.service-card p,
.media-card p{
  margin:0;
  color:var(--muted);
  line-height:1.65;
}

/* MEDIA */
.media-grid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:22px;
}

.media-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 30px;
}

.image-card {
    overflow: hidden;
    border-radius: 25px;
    background: #0a0a0a;
    padding: 15px;
}

.image-card img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: contain;
}


.media-card span{
  display:inline-block;
  margin-top:22px;
  color:var(--gold2);
  font-weight:900;
  letter-spacing:.14em;
  text-transform:uppercase;
  font-size:12px;
}

/* CULTURE */
.culture-section{
  padding:110px 20px;
  text-align:center;
  background:rgba(0,0,0,.42);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}

.culture-inner{
  width:min(980px, 92%);
  margin:0 auto;
}

.culture-inner h2{
  margin:0 0 20px;
  font-size:clamp(38px, 6vw, 86px);
  line-height:.95;
  letter-spacing:-.04em;
}

.culture-inner p{
  margin:0 auto;
  max-width:640px;
  color:var(--muted);
  font-size:18px;
  line-height:1.7;
}

/* CONTACT */
.contact-card{
  width:min(760px, 100%);
  margin:0 auto;
  padding:34px;
  border-radius:var(--radius);
  background:rgba(0,0,0,.55);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  backdrop-filter:blur(12px);
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:22px;
}

.social-links{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  justify-content:center;
}

.social-links a{
  color:rgba(255,255,255,.78);
  text-decoration:none;
  border:1px solid var(--line);
  padding:12px 16px;
  border-radius:999px;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
  font-size:12px;
}

.social-links a:hover{
  color:var(--gold2);
  border-color:rgba(212,175,106,.45);
}

/* FOOTER */
.footer{
  padding:30px 20px;
  text-align:center;
  color:rgba(255,255,255,.45);
  font-size:13px;
  border-top:1px solid rgba(255,255,255,.08);
}

/* MOBILE */
@media (max-width:900px){
  .topbar{
    padding:16px 22px;
  }

  .desktop-nav{
    display:none;
  }

  .hero{
    padding:130px 24px 90px;
    text-align:center;
  }

  .hero-background{
    background:
      linear-gradient(rgba(0,0,0,.78), rgba(0,0,0,.86)),
      url("assets/dion-bg.jpg");
    background-size:cover;
    background-position:center top;
  }

  .hero-content{
    margin:0 auto;
  }

  .hero-kicker{
    letter-spacing:.24em;
    font-size:11px;
  }

  .hero-meta{
    font-size:13px;
  }

  @media (max-width:900px){

  .marquee-section{
    display:block !important;
    height:90px;
    margin-top:-100px;
    overflow:hidden;
  }

  .marquee-track{
    gap:40px;
    animation:marquee-scroll 28s linear infinite;
  }

  .marquee-track span{
    font-size:54px;
    letter-spacing:.08em;
    opacity:.18;
  }

}

  .section{
    padding:70px 0;
  }

  .service-grid,
  .media-grid{
    grid-template-columns:1fr;
  }

  .about-copy,
  .contact-card{
    padding:24px;
  }
}

@media(max-width:900px){

  .hero-image{
    justify-content:center;
    height:auto;
    overflow:visible;
  }

  .hero-image img{
    width:min(520px, 95vw) !important;
    height:auto !important;
    max-height:none !important;
    max-width:95vw !important;

    margin:30px auto -90px !important;
    object-fit:contain !important;
    display:block;
  }

}

@media (max-width: 900px) {

    .hero-grid{
        display:flex;
        flex-direction:column;
    }

    .hero-image{
        order:-1;
        width:100%;
        margin:0 auto 30px;
        justify-content:center;
    }

    .hero-image img{
        width:min(450px, 95vw);
        height:auto;
        display:block;
    }

}@media (max-width: 900px) {

    .hero-image{
        margin-top: -60px !important;
    }

}