/**
 * Graphic Design Page Template Styles
 * Prefixed with .gd- to avoid collisions
 */

/* === CUSTOM CURSOR (data URI — 32x40px for browser compatibility) === */
.gd-hero-wrapper,
.gd-hero-wrapper *,
.gd-scroll-content,
.gd-scroll-content * {
  cursor: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='40' viewBox='0 0 77 97' fill='none'%3E%3Cpath d='M5.31 0.01C4.58-0.04 3.85 0.08 3.16 0.35C2.48 0.62 1.87 1.04 1.36 1.57C0.86 2.1 0.48 2.74 0.25 3.44C0.02 4.14-0.05 4.88 0.04 5.61L7.59 86.69C8.08 90.63 12.73 92.47 15.77 89.92L31.72 76.98L38.87 89.37C42.98 96.49 49.5 98.24 56.62 94.13C63.75 90.02 65.49 83.49 61.38 76.37L54.26 64.03L73.15 56.78C76.88 55.43 77.62 50.48 74.45 48.09L8.01 1C7.23 0.42 6.29 0.07 5.31 0.01Z' fill='%23F3CE34'/%3E%3C/svg%3E") 2 2, auto;
}
.gd-scroll-content a,
.gd-scroll-content button,
.gd-scroll-content [role="button"],
.gd-hero a,
.gd-hero button {
  cursor: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='40' viewBox='0 0 77 97' fill='none'%3E%3Cpath d='M5.31 0.01C4.58-0.04 3.85 0.08 3.16 0.35C2.48 0.62 1.87 1.04 1.36 1.57C0.86 2.1 0.48 2.74 0.25 3.44C0.02 4.14-0.05 4.88 0.04 5.61L7.59 86.69C8.08 90.63 12.73 92.47 15.77 89.92L31.72 76.98L38.87 89.37C42.98 96.49 49.5 98.24 56.62 94.13C63.75 90.02 65.49 83.49 61.38 76.37L54.26 64.03L73.15 56.78C76.88 55.43 77.62 50.48 74.45 48.09L8.01 1C7.23 0.42 6.29 0.07 5.31 0.01Z' fill='%23F3CE34'/%3E%3C/svg%3E") 2 2, pointer;
}

/* === HERO (fixed — other sections scroll over it) === */
.gd-hero-wrapper {
  height: 100vh;
  position: relative;
}
.gd-hero {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  padding: 200px 90px 120px;
  min-height: 100vh;
  overflow: visible;
  background: #151515;
  z-index: 1;
}
/* Content after hero scrolls on top */
.gd-scroll-content {
  position: relative;
  z-index: 2;
      margin-top: -210px;
}

.gd-hero-badge {
  border: 1px solid #f3ce34;
  border-radius: 35px;
  padding: 4px 25px;
  display: inline-block;
  font-size: 14px;
  color: #f3ce34;
  font-weight: 300;
  margin-bottom: 26px;
}
.gd-hero-title {
  font-size: 83px;
  line-height: 96px;
  margin-bottom: 40px;
  max-width: 778px;
  font-weight: 400;
}
.gd-hero-title .bold { font-weight: 700; }
.gd-hero-title .accent { color: #f3ce34; font-weight: 700; }
.gd-hero-desc {
  font-size: 20px;
  line-height: 1.4;
  max-width: 539px;
  margin-bottom: 50px;
  font-weight: 300;
  opacity: 0.9;
}
.gd-hero-btns {
  display: flex;
  gap: 20px;
}
.gd-btn-outline {
  border: 0.5px solid #6d6d6d;
  border-radius: 25px;
  padding: 16px 40px;
  background: transparent;
  color: white;
  font-size: 14px;
  font-family: 'Inter', sans-serif;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.3s;
}
.gd-btn-outline:hover { border-color: #f3ce34; color: #f3ce34; }
.gd-btn-primary {
  background: #f3ce34;
  border: none;
  border-radius: 25px;
  padding: 16px 40px;
  color: #151515;
  font-size: 14px;
  font-family: 'Inter', sans-serif;
  font-weight: 500;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 10px;
  transition: all 0.3s;
 height:50px;
}
.gd-btn-primary:hover { background: #e0bd2f; transform: translateY(-2px); }
.gd-hero-video {
  position: absolute;
  right: 90px;
  top: 184px;
  width: 560px;
  height: 470px;
  border-radius: 20px;
  overflow: hidden;
  background: linear-gradient(135deg, #1a1a1a, #2a2a2a);
}
.gd-hero-video-player {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.gd-video-overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.4);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
  transition: opacity 0.4s ease;
  cursor: pointer;
}
.gd-play-btn {
  width: 80px;
  height: 80px;
  background: rgba(21,21,21,0.8);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: transform 0.3s;
  border: 2px solid rgba(243,206,52,0.3);
}
.matter-left-img{
 position: absolute;
       left: -20px;
    z-index: 11;
    top: 90px;
}
.top-left-image.matter-right-img {
    position: absolute;
    right: 0px;
    top: -250px;
    left: unset;
    z-index: 99;
}
.top-left-image {
    position: absolute;
    /*left: -150px;*/
    top: 90px;
}
.gd-play-btn:hover { transform: scale(1.1); }
.gd-play-btn svg { width: 24px; height: 24px; margin-left: 4px; }
/* Splatter transition — sits between hero and why section */
.gd-splatter {
  position: absolute;
  z-index: 10;
  /* margin-top: -8%;
  margin-bottom: -120px; */
  left: 0;
  bottom:0;
  width: 100%;
  pointer-events: none;
}
.gd-splatter img {
  display: block;
  width: 100%;
  height: auto;
}

/* === WHY IT MATTERS === */
.gd-why {
  background: #f3ce34;
  padding: 200px 90px 140px;
  position: relative;
  z-index: 10;
      padding-top: 70px;
      overflow: visible;
          display: flex;
    align-content: center;
    justify-content: center;
    flex-direction: column;
}
.gd-badge-dark {
  background: rgba(97,97,97,0.15);
  border: 1px solid #151515;
  border-radius: 999px;
  padding: 6px 16px;
  display: inline-block;
  font-size: 14px;
  color: #151515;
  font-weight: 300;
  margin-bottom: 24px;
}
.gd-why-title {
  font-size: 64px;
  line-height: 1.15;
  margin-bottom: 24px;
}
img.matter-image-inner
 {
    position: absolute;
    right: 7%;
    top: 200px;
}
.gd-why-title .normal { font-weight: 400; color: #151515; }
.gd-why-title .bold { font-weight: 600; color: white; }
.gd-why-desc {
  font-size: 20px;
  line-height: 28px;
  color: #151515;
  max-width: 634px;
  margin-bottom: 64px;
}
.gd-features-grid {
 display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
    max-width: 1080px;
    justify-content: center;
    align-content: center;
    margin: 0 auto;
}
.gd-feature-card {
border-radius: 16px;
background:#1a1a1a;
  border: 1px solid #252525;
  padding: 32px;
  transition: transform 0.3s;
  cursor: pointer;
}
.gd-feature-card:hover { transform: translateY(-10px); background: #584d1f; }
.gd-feature-icon {
  width: 56px;
  height: 56px;
border-radius: 16px;
background: #292929;
  border: 0.667px solid #252525;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 24px;
}
.gd-feature-icon svg { width: 28px; height: 28px; }
.gd-feature-card h3 {
  font-size: 24px;
  font-weight: 700;
  line-height: 32px;
  margin-bottom: 12px;
  color: #fff;
}
.gd-feature-card p {
  font-size: 16px;
  line-height: 26px;
  color: rgba(255,255,255,0.6);
}

/* === SERVICES / ARSENAL === */
.gd-services {
  background: #0a0a0a;
  padding: 140px 90px;
      display: flex;
    align-content: center;
    justify-content: center;
    flex-direction: column;
}
.gd-badge-light {
  background: rgba(97,97,97,0.15);
  border-radius: 999px;
  padding: 6px 16px;
  display: block;
  width: fit-content;
  margin: 0 auto 24px;
  font-size: 12px;
  color: rgba(255,255,255,0.6);
  text-align: center;
}
.gd-services-title {
  font-size: 60px;
  text-align: center;
  margin-bottom: 16px;
  font-weight: 400;
}

.gd-services-title .bold { color: #f3ce34; font-weight: 600; }
.gd-services-subtitle {
  text-align: center;
  font-size: 20px;
  color: rgba(255,255,255,0.7);
  margin-bottom: 80px;
}
.gd-services-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  max-width: 1080px;
  margin: 0 auto;
}
.gd-service-card {
  background: #1a1a1a;
  border-radius: 24px;
  padding: 32px;
  position: relative;
  overflow: hidden;
  transition: all 0.4s;
  cursor: pointer;
  border: 1px solid transparent;
}
.gd-service-card:hover { transform: translateY(-10px); border-color: rgba(243,206,52,0.3); }
.gd-service-card.gd-highlight { border: 0.5px solid #f3ce34; }
.gd-service-card.gd-highlight:hover .gd-service-card-title { color: #f3ce34; }
.gd-service-icon {
  width: 56px;
  height: 56px;
  background: rgba(97,97,97,0.3);
  border: 0.667px solid #252525;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 24px;
}
.gd-highlight .gd-service-icon { background: rgba(243,206,52,0.15); }
.gd-service-icon svg { width: 28px; height: 28px; }
.gd-service-card-title {
  font-size: 28px;
  font-weight: 700;
  line-height: 36px;
  margin-bottom: 12px;
  transition: color 0.3s;
}
.gd-highlight .gd-service-card-title { color: #f3ce34; }
.gd-service-card-desc {
  font-size: 16px;
  line-height: 26px;
  color: rgba(255,255,255,0.7);
  margin-bottom: 24px;
}
.gd-service-features {
  list-style: none;
  margin: 0 0 32px;
  padding: 0;
}
.gd-service-features li {
  font-size: 14px;
  color: rgba(255,255,255,0.4);
  line-height: 28px;
  padding-left: 17px;
  position: relative;
}
.gd-service-features li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 11px;
  width: 6px;
  height: 6px;
  background: rgba(243,206,52,0.6);
  border-radius: 50%;
}
.gd-learn-more {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 18px;
  font-weight: 600;
  color: #f3ce34;
  text-decoration: none;
  transition: opacity 0.3s;
}
.gd-learn-more:hover { opacity: 0.7; }
.service-rigth-img{
  position: absolute;
    right: 0% !important;
    bottom: 200px !important;
    top:unset !important;
}
/* === BALL DIVIDER === */
.gd-ball-divider {
margin-top: -10px;
  background: #010101;
  padding: 80px 0 0;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 2;
  margin-bottom: -140px;
  overflow: hidden;
}
.gd-ball-spin {
  width: 300px;
  height: 300px;
  position: relative;
  z-index: 5;
}
.gd-ball-spin model-viewer {
  width: 100%;
  height: 100%;
  --poster-color: transparent;
}
.gd-ball-spin img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  animation: gdSpinBall 6s linear infinite;
}
@keyframes gdSpinBall {
  0% { transform: rotateY(0deg); }
  100% { transform: rotateY(360deg); }
}

/* === CTA === */
.gd-cta {
background: #f3ce34;
    padding: 180px 90px 50px;
    text-align: center;
    position: relative;
    overflow: visible;
    padding-top: 50px;
    z-index: 2;
     /*margin-bottom: 90px; */
}

.gd-cta-title {
  font-size: 64px;
  font-weight: 500;
  color: #151515;
  margin-bottom: 20px;
}
.gd-cta-desc {
  font-size: 20px;
  font-weight: 300;
  color: #151515;
  max-width: 539px;
  margin: 0 auto 40px;
}
.gd-cta-btns {
  display: flex;
  gap: 20px;
  justify-content: center;
}
.gd-btn-dark {
  background: #151515;
  border: none;
  border-radius: 25px;
  padding: 16px 45px;
  color: white;
  font-size: 14px;
  font-family: 'Inter', sans-serif;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.3s;
}
.gd-btn-dark:hover { background: #2a2a2a; }
.gd-btn-dark-outline {
  background: transparent;
  border: 1px solid #151515;
  border-radius: 25px;
  padding: 16px 45px;
  color: #151515;
  font-size: 14px;
  font-family: 'Inter', sans-serif;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.3s;
}
.gd-btn-dark-outline:hover { background: rgba(21,21,21,0.1); }

/* === SCROLL ANIMATION === */
.gd-fade-up {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 0.8s ease, transform 0.8s ease;
}
.gd-fade-up.gd-visible {
  opacity: 1;
  transform: translateY(0);
      position: relative;
    z-index: 1;
}
.gd-delay-1 { transition-delay: 0.1s; }
.gd-delay-2 { transition-delay: 0.2s; }
.gd-delay-3 { transition-delay: 0.3s; }

/* === RESPONSIVE === */
@media (min-width: 1690px) {
.gd-scroll-content {
    margin-top: -310px;
}
}
@media (max-width: 1200px) {
  .gd-hero-video {
    position: relative;
    right: 0;
    top: 50px;
    width: 100%;
    height: auto;
    margin-bottom: 50px;}
  .gd-hero-title { font-size: 60px; line-height: 70px; }
  .gd-why-title { font-size: 48px; }
  .gd-services-title { font-size: 48px; }
  .gd-cta-title { font-size: 48px; }
}
@media (max-width: 1024px) {
  .gd-hero { padding: 140px 40px 0; }
  .gd-splatter { margin-left: 0px; margin-right: 0px; }
  .gd-why { padding: 80px 40px; }
  .gd-services { padding: 80px 40px; }
  .gd-cta { padding: 60px 40px 80px; }
  .gd-features-grid { grid-template-columns: 1fr 1fr; max-width: 100%; }
  .gd-services-grid { grid-template-columns: 1fr 1fr; max-width: 100%; margin: 0 auto; }
  .gd-hero-title { font-size: 50px; line-height: 60px; }
  .gd-why-title { font-size: 40px; }
  .gd-services-title { font-size: 40px; }
  .gd-cta-title { font-size: 40px; }
  .gd-splatter {
    display: none;
}
}
@media (max-width: 990px) {
  .gd-services,.gd-why 
 {
    display: block;
}
}
@media (max-width: 768px) {
    .gd-features-grid {
        grid-template-columns: 1fr;
        max-width: 100%;
    }
        .gd-services-grid {
        grid-template-columns: 1fr;
    }
  .gd-hero { padding: 120px 24px 0; }
  .gd-splatter { margin-left: 0px; margin-right: 0px;margin-bottom:0px;bottom:0; }
  .gd-why, .gd-services, .gd-cta { padding: 60px 24px; }
  .gd-hero-title { font-size: 40px; line-height: 48px; }
  .gd-hero-desc { font-size: 16px; }
  .gd-hero-btns { flex-direction: column; }
  .gd-hero-btns button { width: 100%; justify-content: center; }
  .gd-why-title { font-size: 32px; }
  .gd-why-desc { font-size: 16px; }
  .gd-services-title { font-size: 32px; }
  .gd-cta-title { font-size: 32px; }
  .gd-ball-spin { width: 200px; height: 200px; }
  .gd-ball-divider { margin-bottom: -100px; }
  .gd-cta { padding-top: 40px; }
  .gd-cta-btns { flex-direction: column; align-items: center; }
  .gd-cta-btns button { width: 100%; max-width: 300px; }
}
@media (max-width: 480px) {
  .gd-hero-title { font-size: 32px; line-height: 40px; }
  .top-left-image.matter-right-img { display: none; }
  .gd-why-title { font-size: 28px; }
  .gd-services-title { font-size: 28px; }
  .gd-cta-title { font-size: 28px; }
  .gd-ball-spin { width: 160px; height: 160px; }
  .gd-ball-divider { margin-bottom: -80px; }
     .gd-cta
 {
        padding-top: 50px;
        margin-top: 50px;
    }
    .gd-ball-spin model-viewer {
    width:100% !important ;
    height: 100% !important;
    }
  .gd-cta-ball { width: 140px; height: 140px; }
  .gd-feature-card, .gd-service-card { padding: 24px; }
}
