
html {
  scroll-behavior: smooth;
}
body {
  overflow-x: hidden;
}
a {
  text-decoration: none;
}
.nav-link {
  cursor: pointer;
}
.project-card {
  cursor: pointer;
  transition: transform .28s ease, box-shadow .28s ease;
}
.project-card:hover,
.project-card:focus-visible {
  transform: translateY(-10px);
  box-shadow: 0 20px 30px rgba(30, 90, 200, 0.16);
}
.hero-anim .group_2,
.hero-anim .text-group_1,
.hero-anim .image_2 {
  opacity: 0;
}
.hero-anim.is-ready .group_2 {
  animation: fadeDown .7s ease forwards;
}
.hero-anim::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(255,255,255,.38), rgba(160,214,255,.22));
  opacity: 0;
  pointer-events: none;
}
.hero-anim.is-ready::before {
  animation: bgFade 1s ease forwards;
}
.hero-anim.is-ready .text-group_1 {
  animation: slideInLeft .8s ease .15s forwards;
}
.hero-anim.is-ready .image_2 {
  animation: slideInRight .9s ease .2s forwards;
}
.group_1 {
  position: relative;
}
.project-modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: none;
}
.project-modal.is-open {
  display: block;
}
.project-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.72);
}
.project-modal__close {
  position: absolute;
  top: 24px;
  right: 28px;
  width: 48px;
  height: 48px;
  border: 0;
  border-radius: 999px;
  background: rgba(255,255,255,.14);
  color: #fff;
  font-size: 30px;
  line-height: 1;
  cursor: pointer;
  z-index: 2;
}
.project-modal__panel {
  position: absolute;
  left: 50%;
  top: 32px;
  transform: translateX(-50%);
  width: min(86vw, 1200px);
  max-height: calc(100vh - 64px);
  overflow-y: auto;
  background: transparent;
  z-index: 1;
  padding: 0;
}
.project-modal__panel img {
  display: block;
  width: 100%;
  height: auto;
  margin: 0;
  border: 0;
}
body.modal-open {
  overflow: hidden;
}
@keyframes bgFade {
  from { opacity: 0; }
  to { opacity: 1; }
}
@keyframes fadeDown {
  from { opacity: 0; transform: translateY(-14px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes slideInLeft {
  from { opacity: 0; transform: translateX(-42px); }
  to { opacity: 1; transform: translateX(0); }
}
@keyframes slideInRight {
  from { opacity: 0; transform: translateX(42px); }
  to { opacity: 1; transform: translateX(0); }
}


/* ===== About section: keep original adaptive layout, fix only typography/buttons ===== */
.section-about .group_9{
  width: 41.52vw !important;
  height: 30.68vw !important;
}

.section-about .paragraph_3{
  width: 41.52vw !important;
  height: auto !important;
  margin-top: 8.70vw !important; /* about +12px */
  font-size: 1.67vw !important;  /* 32px */
  line-height: 3.85vw !important; /* 74px */
  white-space: normal !important;
  overflow-wrap: normal !important;
  display: block !important;
}

.section-about .box_10{
  width: 32.77vw !important;
  height: 3.34vw !important;
  margin: 2.20vw 0 0 2.81vw !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
}

.section-about .box_11{
  width: 22.56vw !important;
  height: 3.34vw !important;
  margin: 1.10vw 0 0 3.85vw !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
}

.section-about .text-wrapper_3,
.section-about .text-wrapper_4,
.section-about .text-wrapper_5,
.section-about .text-wrapper_6,
.section-about .text-wrapper_7{
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
  background-size: 100% 100% !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  transform: none !important;
}

.section-about .text_13,
.section-about .text_14,
.section-about .text_15,
.section-about .text_16,
.section-about .text_17{
  margin: 0 !important;
  width: auto !important;
  height: auto !important;
  font-size: 1.46vw !important;  /* 28px */
  line-height: 1 !important;
  white-space: nowrap !important;
  text-align: center !important;
  display: block !important;
  transform: none !important;
}

@media (max-width: 1200px){
  .section-about .paragraph_3{
    font-size: 1.66vw !important;
    line-height: 3.82vw !important;
    margin-top: 8.72vw !important;
  }
  .section-about .text_13,
  .section-about .text_14,
  .section-about .text_15,
  .section-about .text_16,
  .section-about .text_17{
    font-size: 1.44vw !important;
  }
}


/* ===== User-requested patch: pure-color about buttons + responsive project card radius ===== */

/* About small blue buttons: no image, no shadow, no squeeze */
.section-about .text-wrapper_3,
.section-about .text-wrapper_4,
.section-about .text-wrapper_5,
.section-about .text-wrapper_6,
.section-about .text-wrapper_7{
  background-image: none !important;
  background: #1f78ff !important;
  box-shadow: none !important;
  border-radius: 999px !important;
  overflow: hidden !important;
}

.section-about .box_10,
.section-about .box_11{
  align-items: center !important;
}

.section-about .text-wrapper_3,
.section-about .text-wrapper_4,
.section-about .text-wrapper_5,
.section-about .text-wrapper_6{
  width: clamp(88px, 10.11vw, 194px) !important;
  height: clamp(28px, 3.34vw, 64px) !important;
}

.section-about .text-wrapper_7{
  width: clamp(100px, 11.25vw, 216px) !important;
  height: clamp(28px, 3.34vw, 64px) !important;
}

.section-about .text_13,
.section-about .text_14,
.section-about .text_15,
.section-about .text_16,
.section-about .text_17{
  color: #fff !important;
  font-size: clamp(12px, 1.46vw, 28px) !important;
  line-height: 1 !important;
}

/* Project white cards: responsive radius */
.section-projects .box_2,
.section-projects .box_3,
.section-projects .box_5,
.section-projects .box_6,
.section-projects .box_8{
  border-radius: clamp(16px, 2.08vw, 40px) !important;
  overflow: hidden !important;
}

.section-projects .image_3,
.section-projects .image_4,
.section-projects .image_5,
.section-projects .image_6,
.section-projects .image_7{
  border-top-left-radius: clamp(16px, 2.08vw, 40px) !important;
  border-top-right-radius: clamp(16px, 2.08vw, 40px) !important;
}


/* ===== About buttons spacing/size refinement ===== */
.section-about .box_10,
.section-about .box_11{
  width: max-content !important;
  height: auto !important;
  justify-content: flex-start !important;
  gap: clamp(10px, 0.8vw, 14px) !important;
}

.section-about .box_10{
  margin: 2.45vw 0 0 2.82vw !important;
}

.section-about .box_11{
  margin: 0.95vw 0 0 3.86vw !important;
}

.section-about .text-wrapper_3,
.section-about .text-wrapper_4,
.section-about .text-wrapper_5,
.section-about .text-wrapper_6{
  width: clamp(84px, 7.2vw, 138px) !important;
  height: clamp(26px, 1.95vw, 38px) !important;
  min-width: 0 !important;
}

.section-about .text-wrapper_7{
  width: clamp(98px, 8.4vw, 160px) !important;
  height: clamp(26px, 1.95vw, 38px) !important;
  min-width: 0 !important;
}

.section-about .text_13,
.section-about .text_14,
.section-about .text_15,
.section-about .text_16,
.section-about .text_17{
  font-size: clamp(11px, 0.95vw, 18px) !important;
}

@media (max-width: 900px){
  .section-about .box_10,
  .section-about .box_11{
    gap: 8px !important;
  }
  .section-about .text-wrapper_3,
  .section-about .text-wrapper_4,
  .section-about .text-wrapper_5,
  .section-about .text-wrapper_6{
    width: 86px !important;
    height: 28px !important;
  }
  .section-about .text-wrapper_7{
    width: 102px !important;
    height: 28px !important;
  }
  .section-about .text_13,
  .section-about .text_14,
  .section-about .text_15,
  .section-about .text_16,
  .section-about .text_17{
    font-size: 12px !important;
  }
}


/* ===== About buttons: keep row proportions stable across page scaling ===== */
.section-about .box_10{
  width: 32.77vw !important;
  max-width: 629px !important;
  height: auto !important;
  margin: 2.45vw 0 0 2.82vw !important;
  display: flex !important;
  justify-content: flex-start !important;
  gap: 3.6% !important;
}
.section-about .box_11{
  width: 22.56vw !important;
  max-width: 433px !important;
  height: auto !important;
  margin: 0.95vw 0 0 3.86vw !important;
  display: flex !important;
  justify-content: flex-start !important;
  gap: 5.5% !important;
}
.section-about .text-wrapper_3,
.section-about .text-wrapper_4,
.section-about .text-wrapper_5{
  width: 30.9% !important;
  height: auto !important;
  aspect-ratio: 194 / 64 !important;
}
.section-about .text-wrapper_6{
  width: 44.8% !important;
  height: auto !important;
  aspect-ratio: 194 / 64 !important;
}
.section-about .text-wrapper_7{
  width: 49.9% !important;
  height: auto !important;
  aspect-ratio: 216 / 64 !important;
}
.section-about .text_13,
.section-about .text_14,
.section-about .text_15,
.section-about .text_16,
.section-about .text_17{
  font-size: clamp(11px, 1.1vw, 20px) !important;
}

@media (max-width: 900px){
  .section-about .box_10{ gap: 3.2% !important; }
  .section-about .box_11{ gap: 5% !important; }
  .section-about .text_13,
  .section-about .text_14,
  .section-about .text_15,
  .section-about .text_16,
  .section-about .text_17{
    font-size: clamp(11px, 1.3vw, 16px) !important;
  }
}

/* ===== Final tweak: button text larger on full screen, smaller on reduced page ===== */
.section-about .text_13,
.section-about .text_14,
.section-about .text_15,
.section-about .text_16,
.section-about .text_17{
  font-size: clamp(10px, calc(0.62vw + 8px), 22px) !important;
}

@media (max-width: 900px){
  .section-about .text_13,
  .section-about .text_14,
  .section-about .text_15,
  .section-about .text_16,
  .section-about .text_17{
    font-size: clamp(9px, calc(0.4vw + 7px), 12px) !important;
  }
}


/* ===== Projects carousel upgrade ===== */
.projects-carousel{
  position: relative;
  width: 100%;
}
.projects-carousel__viewport{
  overflow: hidden;
  width: 100%;
}
.projects-carousel__track{
  display: flex;
  width: 100%;
  transition: transform .38s ease;
  will-change: transform;
}
.projects-slide{
  flex: 0 0 100%;
}
.projects-carousel__arrow{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 52px;
  height: 52px;
  border: 0;
  border-radius: 999px;
  background: rgba(17, 111, 255, .92);
  color: #fff;
  font-size: 34px;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 3;
}
.projects-carousel__arrow--prev{ left: -26px; }
.projects-carousel__arrow--next{ right: -26px; }
.projects-carousel__arrow.is-disabled{
  opacity: .35;
  cursor: default;
}
.projects-placeholder{
  opacity: 0;
  pointer-events: none;
}
.projects-placeholder--large{
  width: 44.01vw;
  height: 26.04vw;
  max-width: 845px;
  max-height: 500px;
}
.projects-placeholder--vertical{
  width: 21.41vw;
  height: 26.04vw;
  max-width: 411px;
  max-height: 500px;
}
.projects-placeholder--small{
  width: 21.41vw;
  height: 16.46vw;
  max-width: 411px;
  max-height: 316px;
}


/* ===== Auto cover-fit project thumbnails ===== */
.section-projects .box_2,
.section-projects .box_3,
.section-projects .box_5,
.section-projects .box_6,
.section-projects .box_8{
  overflow: hidden !important;
  border-radius: clamp(16px, 2.08vw, 40px) !important;
}

.section-projects .image_3,
.section-projects .image_4,
.section-projects .image_5,
.section-projects .image_6,
.section-projects .image_7{
  display: block !important;
  width: 100% !important;
  margin: 0 !important;
  object-fit: cover !important;
  object-position: center center !important;
  border-top-left-radius: inherit !important;
  border-top-right-radius: inherit !important;
}

.section-projects .image_3,
.section-projects .image_4{
  height: 83.6% !important;
}

.section-projects .image_5,
.section-projects .image_6,
.section-projects .image_7{
  height: 74.4% !important;
}


/* ===== Final repair: stable carousel width + arrows outside content ===== */
.section-projects .projects-carousel{
  position: relative !important;
  width: 34.134rem !important;
  max-width: calc(100% - 1.4rem) !important;
  margin: 0 auto !important;
  padding: 0 !important;
  box-sizing: border-box !important;
  overflow: visible !important;
}

.section-projects .projects-carousel__viewport{
  width: 100% !important;
  overflow: hidden !important;
}

.section-projects .projects-carousel__track{
  display: flex !important;
  transition: transform .38s ease !important;
  will-change: transform !important;
}

.section-projects .projects-slide{
  box-sizing: border-box !important;
}

.section-projects .projects-slide .block_1,
.section-projects .projects-slide .block_2{
  width: 100% !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

.section-projects .projects-slide .block_1{
  margin-top: 2.48rem !important;
}

.section-projects .projects-slide .block_2{
  margin-top: 0.64rem !important;
  margin-bottom: 3.12rem !important;
}

.section-projects .projects-carousel__arrow{
  position: absolute !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 0.86rem !important;
  height: 0.86rem !important;
  font-size: 0.42rem !important;
  z-index: 8 !important;
  background: rgba(17,111,255,.32) !important;
  color: #fff !important;
  border-radius: 999px !important;
  transition: background .2s ease, opacity .2s ease !important;
}

.section-projects .projects-carousel__arrow:hover{
  background: rgba(17,111,255,.92) !important;
}

.section-projects .projects-carousel__arrow--prev{
  left: -1.55rem !important;
}

.section-projects .projects-carousel__arrow--next{
  right: -1.55rem !important;
}

.section-projects .projects-carousel__arrow.is-disabled{
  opacity: .22 !important;
}

.section-projects .box_2,
.section-projects .box_3,
.section-projects .box_5,
.section-projects .box_6,
.section-projects .box_8{
  overflow: hidden !important;
  border-radius: 0.9rem !important;
}

.section-projects .image_3,
.section-projects .image_4,
.section-projects .image_5,
.section-projects .image_6,
.section-projects .image_7{
  display: block !important;
  width: 100% !important;
  margin: 0 !important;
  object-fit: cover !important;
  object-position: center center !important;
  border-top-left-radius: inherit !important;
  border-top-right-radius: inherit !important;
}

.section-projects .image_3,
.section-projects .image_4{
  height: 83.6% !important;
}

.section-projects .image_5,
.section-projects .image_6,
.section-projects .image_7{
  height: 74.4% !important;
}

.section-projects .projects-placeholder--large{
  width: 22.534rem !important;
  height: 13.334rem !important;
}
.section-projects .projects-placeholder--vertical{
  width: 10.96rem !important;
  height: 13.334rem !important;
}
.section-projects .projects-placeholder--small{
  width: 10.96rem !important;
  height: 8.427rem !important;
}

@media (max-width: 900px){
  .section-projects .projects-carousel{
    max-width: calc(100% - 0.9rem) !important;
  }
  .section-projects .projects-carousel__arrow{
    width: 0.72rem !important;
    height: 0.72rem !important;
    font-size: 0.36rem !important;
  }
  .section-projects .projects-carousel__arrow--prev{
    left: -0.95rem !important;
  }
  .section-projects .projects-carousel__arrow--next{
    right: -0.95rem !important;
  }
}


/* ===== Projects spacing / crop / arrows fine tune ===== */
.section-projects .projects-slide .block_1{
  display: grid !important;
  grid-template-columns: 22.534rem 10.96rem !important;
  column-gap: 0.88rem !important;
  justify-content: center !important;
  align-items: start !important;
}

.section-projects .projects-slide .block_2{
  display: grid !important;
  grid-template-columns: 10.96rem 10.96rem 10.96rem !important;
  column-gap: 0.64rem !important;
  justify-content: center !important;
  align-items: start !important;
}

.section-projects .box_6,
.section-projects .box_8{
  margin-left: 0 !important;
}

.section-projects .projects-carousel__arrow--prev{
  left: -2.1rem !important;
}

.section-projects .projects-carousel__arrow--next{
  right: -2.1rem !important;
}

/* desktop: reduce crop a bit */
.section-projects .image_3,
.section-projects .image_4,
.section-projects .image_5,
.section-projects .image_6,
.section-projects .image_7{
  object-position: center center !important;
}

/* smaller screens: prioritize showing whole image */
@media (max-width: 1200px){
  .section-projects .image_3,
  .section-projects .image_4,
  .section-projects .image_5,
  .section-projects .image_6,
  .section-projects .image_7{
    object-fit: contain !important;
    background: #f4f4f4 !important;
  }
}

@media (max-width: 900px){
  .section-projects .projects-slide .block_1{
    grid-template-columns: 22.534rem 10.96rem !important;
    column-gap: 0.52rem !important;
  }

  .section-projects .projects-slide .block_2{
    grid-template-columns: 10.96rem 10.96rem 10.96rem !important;
    column-gap: 0.36rem !important;
  }

  .section-projects .projects-carousel__arrow--prev{
    left: -1.22rem !important;
  }

  .section-projects .projects-carousel__arrow--next{
    right: -1.22rem !important;
  }
}


/* ===== Final patch: keep cover on small screens + enlarge arrows ===== */
@media (max-width: 1200px){
  .section-projects .image_3,
  .section-projects .image_4,
  .section-projects .image_5,
  .section-projects .image_6,
  .section-projects .image_7{
    object-fit: cover !important;
    background: transparent !important;
  }
}

.section-projects .projects-carousel__arrow{
  width: 1.08rem !important;
  height: 1.08rem !important;
  font-size: 0.56rem !important;
}

@media (max-width: 900px){
  .section-projects .projects-carousel__arrow{
    width: 0.86rem !important;
    height: 0.86rem !important;
    font-size: 0.42rem !important;
  }
}


/* ===== Arrow size enlarged one more step ===== */
.section-projects .projects-carousel__arrow{
  width: 1.22rem !important;
  height: 1.22rem !important;
  font-size: 0.62rem !important;
}

@media (max-width: 900px){
  .section-projects .projects-carousel__arrow{
    width: 0.96rem !important;
    height: 0.96rem !important;
    font-size: 0.48rem !important;
  }
}
