* {
    box-sizing: border-box; /* Ensures padding/borders are included in element's total width/height */
    margin: 0; /* Removes all default margins */
    padding: 0; /* Removes all default padding */
}

html, body {
  overflow-x: hidden;
}

.funnel-sans-<uniquifier> {
  font-family: "Funnel Sans", sans-serif;
  font-optical-sizing: auto;
  font-weight: <weight>;
  font-style: normal;
}

.special-gothic-expanded-one-regular {
  font-family: "Special Gothic Expanded One", sans-serif;
  font-weight: 400;
  font-style: normal;
}


.orbitron-<uniquifier> {
  font-family: "Orbitron", sans-serif;
  font-optical-sizing: auto;
  font-weight: <weight>;
  font-style: normal;
}

.nav {
    display: flex;
    width: 85%;
    justify-content: space-between;
    align-items: flex-start;
    margin-top: 2em;
    gap: 5em;
}

nav > :first-child {
  margin-right: auto;
}

.nav a {
    color: #FFF;
    font-family: Orbitron;
    font-size: clamp(0.85rem, 1.2vw, 1rem);
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    text-wrap: nowrap;
    text-decoration: none;
}

.header {
    background-color: black;
    display: flex;
    flex-direction: column;
    align-items: center;     /* centers horizontally */
    height: auto;
}

.portfolio-header {
    margin-top: auto;       /* pushes SVG to the bottom */
    padding-bottom: 2em;
    width: 85%;
}

.video-hero {
  width: 100%;
  height: 500px;          /* or whatever height you want */
  overflow: hidden;
  position: relative;
}

.video-hero video {
  width: 100%;
  height: 100%;
  object-fit: cover;      /* fills container without stretching */
  object-position: center;
}

.video-hero-2 {
  width: 100%;
  height: auto;         
  overflow: hidden;
  position: relative;
}

.video-hero-2 video {
  width: 100%;
  height: 100%;
  object-fit: cover;      /* fills container without stretching */
  object-position: center;
}

#videography {
  background-color: black;
  padding-top: 10em;
}

.p-video {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;     /* center horizontally */
  text-align: center; 
}

.p-video video{
  width: 85%;
  height: 50vw;
  border-radius: 20px;
  margin-top: 5em;
  border-radius: 8px;
  border: 2px solid rgba(0, 0, 0, 0.35);
}

#video1 video {
  border-radius: 12px;
  border: 1px solid rgba(0, 0, 0, 0.35);
  box-shadow:
    0 0 50px rgba(255, 149, 0, 0.35),
    0 0 100px rgba(255, 153, 0, 0.15);
}

#video2 video {
  border-radius: 12px;
  border: 1px solid rgba(0, 0, 0, 0.35);
  box-shadow:
    0 0 50px rgba(255, 232, 57, 0.35),
    0 0 100px rgba(255, 255, 255, 0.15);
}

#video3 video {
  border-radius: 12px;
  border: 1px solid rgba(0, 0, 0, 0.35);
  box-shadow:
    0 0 50px rgba(73, 255, 60, 0.35),
    0 0 100px rgba(0, 0, 0, 0.15);
}

#video4 video {
  border-radius: 12px;
  border: 1px solid rgba(0, 0, 0, 0.35);
  box-shadow:
    0 0 50px rgba(255, 0, 0, 0.35),
    0 0 100px rgba(255, 0, 0, 0.15);
}


.white-text p, .white-text h2, .white-text h3, #photography h3, #videography h3{
  color: white;
}

#videography h3{ 
  margin-top: 0.2em;
}

.title {
  margin-bottom: 5em;
}

.title-1{
    margin: 2em 0 0 6%;
    width: 60%;
}

h1 {
    font-family: Special Gothic Expanded One;
    fill: #000;
    font-size: clamp(32px, 4vw, 64px);
}

h2 {
    font-family: Special Gothic Expanded One;
    fill: #000;
    filter: drop-shadow(0 0 21.6px rgba(0, 0, 0, 0.30)) blur(0.20000000298023224px);
    font-size: clamp(14px, 1.5vw, 22px);
}

.vision {
  margin-left: 7.5%;
}

h3 {
    font-family: Special Gothic Expanded One;
    fill: white;
    font-size: clamp(22px, 4vw, 64px);
    margin-top: 1em;
    margin-bottom: 1em;
}

.social-media {
  display: flex;
  flex-direction: column;
  margin-top: 10em;
  justify-content: center;
  align-items: center;
  text-align: center;
  margin: 10em 7.5% 0 7.5%;
  padding-bottom: 10em;
}


.social-video-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
  width: 100%;
}

.social-video-grid video {
  width: 100%;
  aspect-ratio: 9 / 16;
  object-fit: cover;
  border-radius: 14px;
  background: black;
}


p {
  color: #000;
  font-family: "Funnel Sans";
  font-size: clamp(14px, 1.5vw, 22px);
  font-style: normal;
  font-weight: 400;
  line-height: normal;
  letter-spacing: 0.96px;
  }


.bg-black {
  position: relative;
  width: 100%;
}



.profile {
  width: 50%;
  position: relative;
}


#profile-1 {
  display: block;
  height: 50vw;
  width: 100%;
  object-fit: cover;
}

#profile-2 {
  position: relative;
  width: 100%;
  bottom: 9vw;
}


.about-me {
  display: flex;
  flex-direction: row;
  margin: 0 7.5% 0 7.5%;
  gap: 1em;
}

.about-me h1 {
  margin-left: 0;
}

.about-me-text-section {
  display: flex;
  flex-direction: column;
  margin: 0 7.5% 0 2em;
  width: 50%;
}

.education {
  margin-bottom: 3em;
}

.decorated {
  position: relative;
  padding-left: 1.25rem; /* space for the line */
}

.decorated::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.2em;
  width: 3px;
  height: 100%;
  background: #ff0000;
}

.skills-and-expertise {
  display: flex;
  flex-direction: row;
}

.container {
  display: flex;
  flex-wrap: wrap;  
}

.full {
  flex: 0 0 100%;
}

.half {
  flex: 0 0 50%;
}

#photography {
  background-color: black;
}

.photography-title {
  display: flex;
  margin: 0 7.5% 0 7.5%;
  padding-top: 5em;
  justify-content: space-between;
  text-wrap: nowrap;
}

.photo-hero {
  margin: 0 7.5% 3em 7.5%;
}

.photo-hero img {
  height: 35em;
  width: 100%;
  object-fit: cover;
}

.photo-svg {
  width: 50%;
}


.full-bg {
  position: relative;      
  width: 100vw;             
    background: linear-gradient(
    to bottom,      
    white 30%,      
    black 30%         
  );
  box-sizing: border-box;    
}

.text {
  margin: 0;
  color: white;
}

.gallery {
  display: grid;
  grid-template-columns: repeat(3, 1fr); /* 3 columns */
  gap: 10px;                             /* spacing between images */
  grid-auto-rows: 15em;                  /* base row height */
}

.landscape-gallery {
  display: grid;
  grid-template-columns: repeat(2, 1fr); /* 2 columns = 50% width each */
  gap: 10px;                             /* spacing between images */
  grid-auto-rows: 20em;                  /* base height, adjust as needed */
}

.landscape-gallery img {
  width: 100%;
  height: 100%;
  object-fit: cover; /* keeps aspect ratio, crops if needed */
  border-radius: 8px;
  display: block;
}

/* Optional: vertical images span 2 rows */
.landscape-gallery img.vertical {
  grid-row: span 2;
}

.gallery img {
  width: 100%;
  height: 100%;
  object-fit: cover;    /* keeps aspect ratio, crops if needed */
  border-radius: 8px;
  display: block;
}

/* Vertical images span 2 rows (taller) */
.gallery img.vertical {
  grid-row: span 2;
}

/* Optional: adjust horizontal images to span 1 row (default) */
.gallery img.horizontal {
  grid-row: span 1;
}





.video-svg {
  position: absolute;        /* overlay on top of the video */
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 85%;
}


.divider {
  border: none;         /* remove default border */
  height: 5px;          /* thickness of the line */
  background-color: black; /* line color */          /* length of the line */
  margin: 2em auto;     /* vertical spacing + center */
  border-radius: 1px;   /* optional rounded edges */
}


.contact-wrapper {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  margin: 5em 7.5% 0 7.5%;
}

.contact {
  display: flex;
  flex-direction: column;
  flex: 0 0 50%;
}

.line-text {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
}

.line-1 {
    margin: 0 7.5% 0 7.5%;
}

footer {
  position: relative;
  margin-top: -10vw;
  background-color: black;
  height: 20em;
  z-index: -5;
}

.work {
  width: 40%;
}


/* ================================
   TABLET (≤ 1024px)
   ================================ */
@media (max-width: 1024px) {
  .gallery {
    grid-template-columns: repeat(2, 1fr);
  }

  .social-video-grid {
    grid-template-columns: repeat(2, 1fr);
  }

    .full-bg {            
    background: linear-gradient(
    to bottom,      
    white 33%,      
    black 33%         
  );
    }


.photo, .video, .video-editing, .color-grading {
  display: none;
}

nav > :first-child {
  margin-left: auto;
    font-size: 20px;
}

nav {
  text-align: center;
  align-items: center;
}

.header {
  gap: 1em;
}

}

/* ================================
   MOBILE (≤ 640px)
   ================================ */
@media (max-width: 775px) {

  .white-text p, .white-text h2,.white-text h3 {
  color: black;
}

  .gallery {
    grid-template-columns: 1fr;
  }

  .social-video-grid {
    grid-template-columns: 1fr;
  }

    .about-me {
    flex-direction: column;
    justify-content: center;
    align-items: center;
    margin: 0 0 0 0;
    gap: 0;
  }

  .about-me-text-section {
  width: 85%;
}


  .full-bg {  
    background: #FFF;
}

.profile {
  width: 85%;
  position: relative;
}

.photography-title {
  display: flex;
  flex-direction: column;
  margin: 0 7.5% 0 7.5%;
  padding-top: 4em;
  padding-bottom: 2em;
  justify-content: center;
  align-items: center;
  text-wrap: wrap;
  text-align: center;
  gap: 1em;
}

.photography-title h3{
  margin-bottom: 0;
}

.photo-svg {
  width: 85%;
}

.contact {
  flex-direction: column;
}

.contact-wrapper {
  flex-direction: column;
  justify-content: center;
  align-items: center;
  margin: 5em 7.5% 0 7.5%;
  gap: 5em;
}

.contact {
  display: flex;
  flex-direction: column;
  width: 100%;
}

.contact-wrapper #profile-1 {
  display: flex;
  align-items: center;
  justify-content: center;
  height: auto;
  width: 100%;
  object-fit: cover;
}

.work {
  width: 75%;
  margin-top: 30vw;
}

footer {
  position: relative;
  margin-top: -20vw;
  background-color: black;
  height: 20em;
  z-index: -5;
}

  .line-text {
    flex-direction: column;
    justify-content: center;
    align-items: center;
  }

  .title {
    margin-bottom: 2em;
  }
}