* {
  box-sizing: border-box;
  margin: 0;
  padding: 0
}

html {
  scroll-behavior: smooth;
  font-size: 16px
}

body {
  color: var(--color-text);
  background-color: var(--color-bg);
  font-family: Inter, sans-serif;
  font-weight: 400;
  line-height: 1.6;
  overflow-x: hidden
}

:root {
  --color-primary: #da9100;
  --color-secondary: #000;
  --color-accent: #d4af37;
  --color-bg: #f9f7f2;
  --color-text: #333;
  --color-text-light: #777;
  --color-white: #fff;
  --color-black: #1a1a1a;
  --color-overlay: #171717b3;
  --spacing-xs: .5rem;
  --spacing-sm: 1rem;
  --spacing-md: 2rem;
  --spacing-lg: 4rem;
  --spacing-xl: 8rem;
  --font-serif: "Cormorant Garamond", serif;
  --font-sans: "Inter", sans-serif;
  --transition-fast: .3s ease;
  --transition-medium: .5s ease;
  --transition-slow: .8s ease;
  --shadow-light: 0 5px 15px #0000000d;
  --shadow-medium: 0 10px 30px #0000001a;
  --shadow-heavy: 0 20px 50px #0003;
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 16px;
  --radius-full: 50%
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: var(--font-serif);
  margin-bottom: var(--spacing-md);
  font-weight: 600;
  line-height: 1.2
}

h1 {
  font-size: clamp(2.5rem, 5vw, 4.5rem)
}

h2 {
  font-size: clamp(2rem, 4vw, 3.5rem)
}

h3 {
  font-size: clamp(1.75rem, 3.5vw, 2.5rem)
}

h4 {
  font-size: clamp(1.25rem, 2.5vw, 1.75rem)
}

p {
  margin-bottom: var(--spacing-md);
  font-size: clamp(1rem, 2vw, 1.125rem)
}

.highlight {
  color: var(--color-accent);
  display: inline-block;
  position: relative
}

.highlight:after {
  content: "";
  background-color: var(--color-accent);
  opacity: .3;
  width: 100%;
  height: 3px;
  position: absolute;
  bottom: 5px;
  left: 0
}

.scrollytelling-container {
  width: 100%;
  margin-left: 0;
  padding-top: 0
}

.chapter {
  border-top: 1px solid #ffffff26;
  border-top-left-radius: 50px;
  border-top-right-radius: 50px;
  justify-content: center;
  align-items: center;
  min-height: 100vh;
  display: flex;
  position: relative;
  overflow: hidden;
  box-shadow: 0 -25px 50px #0003
}

.chapter:first-child {
  box-shadow: none;
  border-top: none;
  border-radius: 0
}

.chapter+.chapter {
  margin-top: -50px
}

.chapter-background {
  z-index: -1;
  background-color: var(--color-black);
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0
}

.hero-video,
.lifestyle-video {
  object-fit: cover;
  will-change: transform;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0
}

.video-overlay {
  background: linear-gradient(#0000004d, #000000b3);
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0
}

.video-overlay.dark {
  background: #0009
}

.chapter-content {
  width: 100%;
  max-width: 1200px;
  padding: var(--spacing-xl) var(--spacing-lg);
  z-index: 1;
  position: relative
}

.content-wrapper {
  max-width: 800px
}

.content-wrapper.centered {
  text-align: center;
  max-width: 1000px;
  margin: 0 auto
}

.chapter-subtitle {
  font-family: var(--font-sans);
  letter-spacing: 3px;
  text-transform: uppercase;
  color: #000;
  margin-bottom: var(--spacing-sm);
  font-size: .9rem;
  font-weight: 500
}

.chapter-title.large {
  margin-bottom: var(--spacing-md);
  font-size: clamp(3rem, 6vw, 5.5rem)
}

#chapter-2 {
  z-index: 5;
  border-top-left-radius: 50px;
  border-top-right-radius: 50px;
  height: 100vh;
  margin-top: -50px;
  padding: 0;
  display: block
}

.about-mask-container {
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  display: flex;
  position: relative;
  overflow: hidden
}

.about-bg {
  object-fit: cover;
  z-index: 1;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0
}

.about-mask-layer {
  z-index: 2;
  transform-origin: 50%;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0
}

.about-svg-mask {
  width: 100%;
  height: 100%
}

.about-content-reveal {
  z-index: 4;
  opacity: 0;
  text-shadow: 0 2px 20px #000c;
  background: linear-gradient(#0000004d, #000c);
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  display: flex;
  position: absolute;
  top: 0;
  left: 0
}

.about-values-grid {
  text-align: left;
  border-top: 1px solid #fff3;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  margin-top: 40px;
  padding-top: 30px;
  display: grid
}

.value-item h4 {
  color: var(--color-accent);
  font-family: var(--font-serif);
  margin-bottom: 10px;
  font-size: 1.5rem
}

.value-item p {
  color: #ffffffe6;
  margin-bottom: 0;
  font-size: .95rem;
  line-height: 1.6
}

#chapter-3 {
  z-index: 6;
  -webkit-backdrop-filter: blur(20px);
  background-color: #efe4d8c7;
  border-top: 1px solid #fff9;
  border-top-left-radius: 50px;
  border-top-right-radius: 50px;
  box-shadow: 0 -25px 50px #0000001a
}

#chapter-3 .chapter-content {
  max-width: 100%;
  padding-left: var(--spacing-sm);
  padding-right: var(--spacing-sm);
  padding-bottom: 0
}

#chapter-3 .category-title {
  color: var(--color-secondary);
  text-shadow: 0 2px 4px #0000001a;
  font-weight: 700
}

#chapter-3 .chapter-background {
  background-color: #0000;
  border-top-left-radius: 50px;
  border-top-right-radius: 50px;
  overflow: hidden
}

.residential-bg-pattern {
  opacity: .05;
  background-image: radial-gradient(#d4af37 1px, #0000 1px);
  background-size: 30px 30px;
  width: 100%;
  height: 100%
}

.gradient-orb {
  filter: blur(80px);
  z-index: -1;
  pointer-events: none;
  will-change: transform, filter;
  border-radius: 50%;
  position: absolute
}

.orb-1 {
  background: radial-gradient(circle, #b76e7940 0%, #0000 70%);
  width: 500px;
  height: 500px;
  animation: 20s infinite alternate orbColorShift1, 18s ease-in-out infinite alternate orbFloat1;
  top: -10%;
  left: -5%
}

.orb-2 {
  background: radial-gradient(circle, #d4af3733 0%, #0000 70%);
  width: 600px;
  height: 600px;
  animation: 25s infinite alternate orbColorShift2, 22s ease-in-out infinite alternate orbFloat2;
  bottom: -10%;
  right: -5%
}

@keyframes orbColorShift1 {
  0% {
    filter: blur(80px)hue-rotate()
  }

  to {
    filter: blur(80px)hue-rotate(45deg)
  }
}

@keyframes orbColorShift2 {
  0% {
    filter: blur(80px)hue-rotate()
  }

  to {
    filter: blur(80px)hue-rotate(-45deg)
  }
}

@keyframes orbFloat1 {
  0% {
    top: -10%;
    left: -5%
  }

  to {
    top: -15%;
    left: 2%
  }
}

@keyframes orbFloat2 {
  0% {
    bottom: -10%;
    right: -5%
  }

  to {
    bottom: -15%;
    right: 2%
  }
}

.project-filters {
  z-index: 20;
  flex-wrap: wrap;
  justify-content: center;
  gap: 20px;
  margin-bottom: 40px;
  display: flex;
  position: relative
}

.filter-select {
  background-color: var(--color-white);
  color: var(--color-primary);
  font-family: var(--font-sans);
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23DA9100' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");
  background-position: right 15px center;
  background-repeat: no-repeat;
  background-size: 16px;
  border: 1px solid #b76e794d;
  border-radius: 50px;
  outline: none;
  min-width: 160px;
  padding: 12px 45px 12px 25px;
  font-size: .95rem;
  font-weight: 600;
  transition: all .3s;
  box-shadow: 0 4px 10px #0000000d
}

.filter-select:hover,
.filter-select:focus {
  border-color: var(--color-primary);
  transform: translateY(-2px);
  box-shadow: 0 8px 20px #b76e7926
}

.filter-reset-btn {
  border: 1px dashed var(--color-primary);
  color: var(--color-primary);
  font-family: var(--font-sans);
  cursor: pointer;
  background-color: #0000;
  border-radius: 30px;
  align-items: center;
  gap: 8px;
  padding: 10px 20px;
  font-size: .9rem;
  font-weight: 600;
  transition: all .3s;
  display: none
}

.filter-reset-btn:hover {
  background-color: #b76e791a
}

.project-category-section {
  margin-bottom: var(--spacing-xl)
}

.category-title {
  font-family: var(--font-serif);
  color: var(--color-primary);
  margin-bottom: var(--spacing-md);
  border-left: 3px solid var(--color-accent);
  padding-left: 20px;
  font-size: 1.8rem
}

.grid-scroll-wrapper {
  display: block;
  position: relative
}

.scroll-arrow {
  background: var(--color-white);
  width: 40px;
  height: 40px;
  box-shadow: var(--shadow-medium);
  color: var(--color-primary);
  cursor: pointer;
  z-index: 10;
  border: 1px solid #0000001a;
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  transition: all .3s;
  display: flex;
  position: absolute;
  top: -70px;
  transform: none
}

.scroll-arrow:hover {
  background: var(--color-primary);
  color: var(--color-white);
  transform: scale(1.1)
}

.left-arrow {
  left: auto;
  right: 70px
}

.right-arrow {
  right: 20px
}

.residential-grid {
  scroll-snap-type: x mandatory;
  scrollbar-width: thin;
  scrollbar-color: var(--color-primary) #0000000d;
  -webkit-overflow-scrolling: touch;
  cursor: grab;
  gap: 30px;
  padding: 20px 20px 40px;
  display: flex;
  overflow-x: auto
}

.residential-grid.active {
  cursor: grabbing;
  cursor: -webkit-grabbing;
  scroll-snap-type: none
}

.residential-grid::-webkit-scrollbar {
  height: 6px
}

.residential-grid::-webkit-scrollbar-track {
  background: #0000000d;
  border-radius: 10px
}

.residential-grid::-webkit-scrollbar-thumb {
  background-color: var(--color-primary);
  border-radius: 10px
}

.res-project-card {
  background: var(--color-white);
  border-radius: var(--radius-lg);
  will-change: transform;
  scroll-snap-align: center;
  border: 1px solid #fffc;
  flex: none;
  width: 340px;
  min-width: 340px;
  transition: transform .4s, box-shadow .4s;
  overflow: hidden;
  box-shadow: 0 15px 35px #0000001a
}

.res-project-card:hover {
  transform: translateY(-10px);
  box-shadow: 0 25px 50px #00000026
}

.res-card-image {
  height: 250px;
  position: relative;
  overflow: hidden
}

.res-card-image img {
  object-fit: cover;
  will-change: transform;
  width: 100%;
  height: 100%;
  transition: transform .8s cubic-bezier(.25, .46, .45, .94), filter .6s
}

.res-project-card:hover .res-card-image img {
  filter: brightness(1.05);
  transform: scale(1.12)
}

.res-card-badge {
  background-color: var(--color-accent);
  color: var(--color-white);
  text-transform: uppercase;
  border-radius: 20px;
  padding: 5px 12px;
  font-size: .75rem;
  font-weight: 600;
  position: absolute;
  top: 15px;
  right: 15px
}

.res-card-badge.completed {
  background-color: var(--color-secondary)
}

.res-card-content {
  background-color: var(--color-white);
  z-index: 2;
  padding: 25px;
  transition: transform .4s;
  position: relative
}

.res-project-card:hover .res-card-content {
  transform: translateY(-8px)
}

.res-card-content h4 {
  color: var(--color-text);
  margin-bottom: 5px;
  font-size: 1.4rem;
  transition: color .3s
}

.res-project-card:hover .res-card-content h4 {
  color: var(--color-primary)
}

.res-location {
  color: var(--color-text-light);
  margin-bottom: 20px;
  font-size: .9rem
}

.res-card-footer {
  border-top: 1px solid #0000000d;
  justify-content: space-between;
  align-items: center;
  padding-top: 15px;
  display: flex
}

.res-card-footer span {
  color: var(--color-primary);
  font-size: .85rem;
  font-weight: 600
}

.res-link {
  color: var(--color-text);
  font-size: .9rem;
  font-weight: 500;
  text-decoration: none;
  transition: color .3s
}

.res-link:hover {
  color: var(--color-accent)
}

.view-all-container {
  text-align: center;
  margin-top: var(--spacing-lg);
  justify-content: center;
  display: flex
}

#chapter-4 {
  z-index: 6;
  -webkit-backdrop-filter: blur(20px);
  background-color: #bfeaf1bf;
  border-top: 1px solid #fffc;
  border-top-left-radius: 50px;
  border-top-right-radius: 50px;
  box-shadow: 0 -25px 50px #0000001a
}

#chapter-4 .chapter-background {
  background-color: #0000;
  border-top-left-radius: 50px;
  border-top-right-radius: 50px;
  overflow: hidden
}

#chapter-4 .chapter-content {
  max-width: 100%;
  padding-left: var(--spacing-sm);
  padding-right: var(--spacing-sm);
  padding-bottom: 0
}

#chapter-4 .chapter-subtitle {
  color: var(--color-secondary);
  font-weight: 700
}

#chapter-4 .chapter-title,
#chapter-4 p {
  color: var(--color-black)
}

#chapter-4 .category-title {
  color: var(--color-secondary);
  text-shadow: 0 2px 4px #0000001a;
  font-weight: 700
}

.commercial-bg-pattern {
  display: none
}

#chapter-5 {
  z-index: 6;
  -webkit-backdrop-filter: blur(20px);
  background-color: #dfffd6cb;
  border-top: 1px solid #fff9;
  border-top-left-radius: 50px;
  border-top-right-radius: 50px;
  box-shadow: 0 -25px 50px #0000001a
}

#chapter-5 .chapter-background {
  background-color: #0000;
  border-top-left-radius: 50px;
  border-top-right-radius: 50px;
  overflow: hidden
}

#chapter-5 .chapter-content {
  max-width: 100%;
  padding-left: var(--spacing-sm);
  padding-right: var(--spacing-sm);
  padding-bottom: 0
}

#chapter-5 .category-title {
  color: #000;
  text-shadow: 0 2px 4px #0000001a;
  font-weight: 700
}

.lifestyle-text-block {
  max-width: 800px;
  margin: 0 auto var(--spacing-xl)
}

.lifestyle-tagline {
  color: var(--color-white);
  font-size: 1.5rem;
  line-height: 1.6
}

.amenities-grid {
  gap: var(--spacing-md);
  margin-bottom: var(--spacing-xl);
  grid-template-columns: repeat(3, 1fr);
  display: grid
}

.amenity-card {
  -webkit-backdrop-filter: blur(12px);
  border-radius: var(--radius-md);
  transition: var(--transition-medium);
  background-color: #ffffff26;
  border: 1px solid #ffffff4d;
  overflow: hidden;
  box-shadow: 0 8px 32px #0000004d
}

.amenity-card:hover {
  background-color: #ffffff40;
  border-color: #ffffff80;
  transform: translateY(-10px);
  box-shadow: 0 15px 40px #0006
}

.amenity-image {
  background-position: 50%;
  background-size: cover;
  height: 200px
}

.amenity-content {
  padding: var(--spacing-md);
  color: var(--color-white)
}

.lifestyle-cta {
  border: 2px solid var(--color-accent);
  color: var(--color-accent);
  border-radius: var(--radius-md);
  font-family: var(--font-sans);
  cursor: pointer;
  transition: var(--transition-fast);
  background-color: #0000;
  justify-content: center;
  align-items: center;
  gap: 10px;
  margin: 0 auto;
  padding: 15px 30px;
  font-size: 1.1rem;
  font-weight: 600;
  display: flex
}

.lifestyle-cta:hover {
  background-color: var(--color-accent);
  color: var(--color-black)
}

#chapter-6 {
  -webkit-backdrop-filter: blur(20px);
  z-index: 6;
  background-color: #e1e4e6d9;
  border-top: 1px solid #ffffff80;
  box-shadow: 0 -25px 50px #0000001a
}

#chapter-6 .chapter-background {
  z-index: 0;
  background: radial-gradient(circle at 80% 20%, #b76e7914, #0000 40%), radial-gradient(circle at 20% 80%, #d4af3714, #0000 40%)
}

.view-all-container {
  text-align: center;
  width: 100%;
  margin-top: 2.5rem;
  margin-bottom: 1rem
}

.cta-button {
  text-transform: uppercase;
  letter-spacing: .5px;
  color: #fff;
  cursor: pointer;
  background-color: #a98851;
  border: 2px solid #0000;
  border-radius: 50px;
  justify-content: center;
  align-items: center;
  gap: .75rem;
  padding: .8rem 2rem;
  font-size: 1rem;
  font-weight: 600;
  text-decoration: none;
  transition: all .3s ease-in-out;
  display: inline-flex;
  box-shadow: 0 4px 15px #0000001a
}

.cta-button:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 25px #a988514d
}

.cta-button.outline {
  color: #4d453a;
  box-shadow: none;
  background-color: #0000;
  border-color: #4d453a
}

.cta-button.outline:hover {
  color: #fff;
  background-color: #4d453a;
  box-shadow: 0 8px 25px #a988514d
}

.cta-button i {
  transition: transform .3s
}

.cta-button:hover i {
  transform: translate(5px)
}

.legacy-grid-bg {
  background-image: linear-gradient(#00000008 1px, #0000 1px), linear-gradient(90deg, #00000008 1px, #0000 1px);
  background-size: 60px 60px;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  -webkit-mask-image: radial-gradient(circle, #000 40%, #0000 100%);
  mask-image: radial-gradient(circle, #000 40%, #0000 100%)
}

.floating-block {
  -webkit-backdrop-filter: blur(2px);
  backdrop-filter: blur(2px);
  opacity: 0;
  z-index: 0;
  background: linear-gradient(135deg, #fff9, #ffffff1a);
  border: 1px solid #ffffff80;
  border-radius: 16px;
  position: absolute
}

.block-1 {
  width: 100px;
  height: 100px;
  animation: 18s linear infinite floatUp;
  bottom: -100px;
  left: 10%
}

.block-2 {
  width: 140px;
  height: 140px;
  animation: 25s linear 2s infinite floatUp;
  bottom: -150px;
  right: 15%
}

.block-3 {
  width: 60px;
  height: 60px;
  animation: 20s linear 5s infinite floatUp;
  bottom: -80px;
  left: 25%
}

.block-4 {
  width: 90px;
  height: 90px;
  animation: 22s linear 8s infinite floatUp;
  bottom: -120px;
  right: 35%
}

@keyframes floatUp {
  0% {
    transform: translate(var(--mouse-x, 0px), var(--mouse-y, 0px)) translateY(0) rotate(0deg);
    opacity: 0
  }

  10% {
    opacity: .5
  }

  90% {
    opacity: .5
  }

  to {
    transform: translate(var(--mouse-x, 0px), var(--mouse-y, 0px)) translateY(-120vh) rotate(180deg);
    opacity: 0
  }
}

#chapter-6 .chapter-subtitle {
  color: var(--color-secondary);
  font-weight: 700
}

#chapter-6 .chapter-title {
  color: var(--color-black)
}

#chapter-6 .l-label {
  color: var(--color-text);
  font-weight: 600
}

#chapter-6 .l-number {
  white-space: nowrap;
  font-size: clamp(1.5rem, 2.5vw, 2.5rem)
}

#chapter-6 .legacy-stats-row {
  justify-content: center;
  gap: 4rem
}

#chapter-6 .timeline:before {
  display: none
}

#chapter-6 .timeline {
  grid-template-columns: repeat(2, 1fr);
  gap: 1.5rem;
  max-width: 900px;
  margin: 3rem auto;
  display: grid
}

#chapter-6 .timeline-item {
  text-align: center;
  flex-direction: column;
  align-items: center;
  margin-bottom: 0;
  padding-left: 0;
  transition: transform .3s
}

#chapter-6 .timeline-year {
  margin-bottom: .5rem;
  transition: all .3s;
  display: inline-block;
  position: static
}

#chapter-6 .timeline-content {
  -webkit-backdrop-filter: blur(12px);
  background-color: #ffffff59;
  border: 1px solid #fff9;
  flex-direction: column;
  flex: 1;
  justify-content: center;
  width: 100%;
  max-width: 100%;
  padding: 1.5rem;
  transition: all .3s;
  display: flex;
  box-shadow: 0 15px 35px #00000026
}

#chapter-6 .timeline-item:hover {
  transform: translateY(-5px)
}

#chapter-6 .timeline-item:hover .timeline-content {
  background-color: var(--color-white);
  box-shadow: 0 25px 50px #0003
}

#chapter-6 .timeline-item:hover .timeline-year {
  background-color: var(--color-primary);
  transform: scale(1.1)
}

.legacy-stats-row {
  margin-bottom: var(--spacing-lg);
  padding-bottom: var(--spacing-md);
  border-bottom: 1px solid #0000001a;
  justify-content: space-between;
  gap: 20px;
  display: flex
}

.l-stat {
  text-align: center;
  flex: 1
}

.l-number {
  font-family: var(--font-serif);
  color: var(--color-primary);
  margin-bottom: 5px;
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 700;
  line-height: 1
}

.l-label {
  font-family: var(--font-sans);
  color: var(--color-text-light);
  text-transform: uppercase;
  letter-spacing: 1px;
  font-size: .9rem
}

.timeline-carousel {
  width: 100%;
  margin-top: 2rem;
  padding: 3rem 0;
  position: relative;
  overflow: hidden;
  -webkit-mask-image: linear-gradient(90deg, #0000, #000 10% 90%, #0000);
  mask-image: linear-gradient(90deg, #0000, #000 10% 90%, #0000)
}

.timeline-track {
  gap: 3rem;
  width: max-content;
  padding-left: 3rem;
  animation: 30s linear infinite ticker-scroll;
  display: flex
}

.timeline-track:hover {
  animation-play-state: paused
}

@keyframes ticker-scroll {
  0% {
    transform: translate(0)
  }

  to {
    transform: translate(-50%)
  }
}

#chapter-6 .timeline-carousel .timeline-item {
  flex-shrink: 0;
  width: 320px
}

.timeline {
  margin: var(--spacing-xl) 0;
  position: relative
}

.timeline:before {
  content: "";
  background-color: var(--color-accent);
  width: 2px;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0
}

.timeline-item {
  margin-bottom: var(--spacing-lg);
  padding-left: 40px;
  display: flex;
  position: relative
}

.timeline-year {
  background-color: var(--color-accent);
  color: var(--color-white);
  border-radius: var(--radius-md);
  padding: 5px 15px;
  font-size: 1.1rem;
  font-weight: 600;
  animation: 2s infinite pulse-gold;
  position: absolute;
  top: 0;
  left: -50px
}

.timeline-content {
  padding: var(--spacing-md);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-light);
  background-color: #ffffffe6;
  flex: 1
}

.enquiry-bg-img {
  object-fit: cover;
  filter: blur(8px);
  width: 100%;
  height: 100%;
  transform: scale(1.1)
}

.enquiry-overlay {
  background: linear-gradient(135deg, #f9f7f2d9, #ffffffb3);
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0
}

.dynamic-contact-container {
  grid-template-columns: 1fr 1.5fr;
  gap: 30px;
  max-width: 1000px;
  margin: 40px auto 0;
  display: grid
}

.contact-card-glass,
.form-card-glass {
  -webkit-backdrop-filter: blur(20px);
  text-align: left;
  background: #ffffffb3;
  border: 1px solid #ffffff80;
  border-radius: 20px;
  padding: 40px;
  transition: transform .1s ease-out;
  position: relative;
  overflow: hidden;
  box-shadow: 0 15px 35px #0000001a
}

.contact-card-glass {
  color: #fff;
  background: linear-gradient(135deg, #b76e79e6, #b76e79b3);
  flex-direction: column;
  justify-content: space-between;
  display: flex
}

.glass-header h3 {
  font-family: var(--font-serif);
  margin-bottom: 10px;
  font-size: 1.8rem
}

.glass-header p {
  opacity: .9;
  margin-bottom: 30px;
  font-size: .9rem
}

.info-row {
  align-items: flex-start;
  gap: 15px;
  margin-bottom: 25px;
  display: flex
}

.info-row i {
  color: var(--color-accent);
  margin-top: 5px;
  font-size: 1.2rem
}

.info-row span {
  font-size: .95rem;
  line-height: 1.5
}

.glass-social {
  gap: 15px;
  margin-top: 20px;
  display: flex
}

.glass-social a {
  color: #fff;
  background: #fff3;
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  width: 40px;
  height: 40px;
  text-decoration: none;
  transition: all .3s;
  display: flex
}

.glass-social a:hover {
  color: var(--color-primary);
  background: #fff;
  transform: translateY(-3px)
}

.decorative-circle {
  background: #ffffff1a;
  border-radius: 50%;
  width: 150px;
  height: 150px;
  position: absolute;
  bottom: -50px;
  right: -50px
}

#inlineLeadForm {
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  display: grid
}

.input-group {
  margin-bottom: 5px;
  position: relative
}

.input-group.full {
  grid-column: span 2
}

.glass-input {
  width: 100%;
  font-family: var(--font-sans);
  background: #ffffff80;
  border: 1px solid #0000001a;
  border-radius: 10px;
  outline: none;
  padding: 15px;
  font-size: 1rem;
  transition: all .3s
}

.glass-input:focus {
  border-color: var(--color-primary);
  background: #fff;
  box-shadow: 0 5px 15px #0000000d
}

.input-group label {
  color: #777;
  pointer-events: none;
  font-size: .95rem;
  transition: all .3s;
  position: absolute;
  top: 15px;
  left: 15px
}

.glass-input:focus+label,
.glass-input:not(:placeholder-shown)+label {
  background: var(--color-primary);
  color: #fff;
  border-radius: 4px;
  padding: 2px 8px;
  font-size: .75rem;
  top: -10px;
  left: 10px
}

textarea.glass-input {
  resize: vertical;
  min-height: 100px
}

.glass-btn {
  background: var(--color-primary);
  color: #fff;
  cursor: pointer;
  border: none;
  border-radius: 10px;
  grid-column: span 2;
  justify-content: center;
  align-items: center;
  gap: 10px;
  margin-top: 10px;
  padding: 15px;
  font-size: 1rem;
  font-weight: 600;
  transition: all .3s;
  display: flex
}

.glass-btn:hover {
  background: var(--color-secondary);
  transform: translateY(-2px);
  box-shadow: 0 10px 20px #00000026
}

@media (max-width:768px) {

  .dynamic-contact-container,
  #inlineLeadForm {
    grid-template-columns: 1fr
  }

  .input-group.full {
    grid-column: span 1
  }
}

.fade-in {
  opacity: 0;
  transition: opacity .8s, transform .8s;
  transform: translateY(30px)
}

.fade-in.visible,
.slide-in-left.visible,
.slide-in-right.visible {
  opacity: 1;
  transform: translate(0)
}

#loader-overlay {
  background-color: var(--color-bg);
  z-index: 9999;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  transition: opacity .8s, visibility .8s;
  display: flex;
  position: fixed;
  top: 0;
  left: 0
}

#loader-overlay.hidden {
  opacity: 0;
  visibility: hidden
}

.loader-container {
  align-items: center;
  gap: var(--spacing-md);
  flex-direction: column;
  display: flex
}

.loader-logo {
  opacity: 0;
  filter: drop-shadow(0 5px 15px #b76e794d);
  width: 120px;
  height: auto;
  animation: 1.5s cubic-bezier(.16, 1, .3, 1) forwards logoReveal;
  transform: scale(.8)
}

@keyframes logoReveal {
  to {
    opacity: 1;
    transform: scale(1)
  }
}

.loader-brand {
  font-family: var(--font-serif);
  letter-spacing: .3em;
  color: var(--color-primary);
  opacity: 0;
  font-size: 1.5rem;
  animation: .8s 2s forwards fadeUp;
  transform: translateY(10px)
}

.typewriter-effect:after {
  content: "|";
  color: var(--color-accent);
  opacity: 1;
  margin-left: 2px;
  animation: .8s step-end infinite blink;
  display: inline-block
}

@media (max-width:1200px) {
  @keyframes fadeUp {
    to {
      opacity: 1;
      transform: translateY(0)
    }
  }

  @keyframes blink {
    50% {
      opacity: 0
    }
  }

  .sidebar-nav {
    width: 100%
  }

  .nav-title {
    display: none
  }

  .mobile-nav {
    display: block
  }

  .scrollytelling-container {
    width: 100%;
    margin-left: 0
  }

  .craftsmanship-gallery,
  .amenities-grid {
    grid-template-columns: repeat(2, 1fr)
  }
}

@media (max-width:1130px) {
  .sidebar-nav {
    display: none
  }

  .sidebar-nav.search-active {
    display: flex
  }

  .scrollytelling-container {
    width: 100%;
    margin-left: 0
  }

  .mobile-menu-trigger {
    display: flex
  }

  .mobile-menu-overlay {
    display: block
  }
}

@media (max-width:768px) {
  :root {
    --spacing-xl: 5rem;
    --spacing-lg: 3rem
  }

  .legacy-stats-row {
    gap: var(--spacing-md);
    grid-template-columns: 1fr 1fr;
    display: grid
  }

  .timeline-track {
    gap: 1.5rem;
    padding-left: 1rem
  }

  .craftsmanship-gallery,
  .amenities-grid {
    grid-template-columns: 1fr
  }

  .chapter-content {
    padding: var(--spacing-lg) var(--spacing-md)
  }

  .chapter {
    border-top-left-radius: 30px;
    border-top-right-radius: 30px
  }

  .timeline:before {
    left: 15px
  }

  .timeline-item {
    padding-left: 60px
  }

  .timeline-year {
    left: 0
  }

  #chapter-6 .timeline {
    grid-template-columns: 1fr
  }
}

@media (max-width:480px) {
  :root {
    --spacing-xl: 3rem;
    --spacing-lg: 2rem;
    --spacing-md: 1.5rem
  }

  h1 {
    font-size: 2.2rem
  }

  h2 {
    font-size: 1.8rem
  }

  .chapter-title.large {
    font-size: 2.5rem
  }

  .oasis-quote {
    padding: var(--spacing-md);
    font-size: 1.2rem
  }

  .about-values-grid {
    text-align: center;
    grid-template-columns: 1fr
  }

  .legacy-stats-row {
    grid-template-columns: 1fr
  }

  .inline-form-container {
    padding: 1.5rem
  }

  .res-project-card {
    width: 85vw;
    min-width: 85vw
  }

  .scroll-arrow {
    display: none
  }
}

.portfolio-header {
  text-align: center;
  background-color: var(--color-bg);
  padding-top: 150px;
  padding-bottom: 50px
}

.portfolio-filters {
  flex-wrap: wrap;
  justify-content: center;
  gap: 15px;
  margin-bottom: 50px;
  padding: 0 20px;
  display: flex
}

.filter-btn {
  border: 1px solid var(--color-primary);
  color: var(--color-primary);
  cursor: pointer;
  font-family: var(--font-sans);
  background: 0 0;
  border-radius: 30px;
  padding: 10px 25px;
  font-weight: 500;
  transition: all .3s
}

.filter-btn.active,
.filter-btn:hover {
  background: var(--color-primary);
  color: var(--color-white)
}

.portfolio-grid {
  padding: 0 var(--spacing-lg) var(--spacing-xl);
  grid-template-columns: repeat(auto-fill, minmax(350px, 1fr));
  gap: 30px;
  max-width: 1400px;
  margin: 0 auto;
  display: grid
}

.portfolio-card {
  background: var(--color-white);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-light);
  opacity: 1;
  transition: all .4s;
  overflow: hidden;
  transform: scale(1)
}

.portfolio-card:hover {
  box-shadow: var(--shadow-medium);
  transform: translateY(-10px)
}

.p-card-image {
  background-position: 50%;
  background-size: cover;
  height: 250px;
  position: relative
}

.p-card-badge {
  background: var(--color-white);
  color: var(--color-primary);
  text-transform: uppercase;
  border-radius: 20px;
  padding: 5px 12px;
  font-size: .75rem;
  font-weight: 700;
  position: absolute;
  top: 15px;
  right: 15px;
  box-shadow: 0 2px 5px #0000001a
}

.p-card-badge.completed {
  color: var(--color-secondary)
}

.p-card-content {
  padding: 25px
}

.p-card-title {
  color: var(--color-text);
  margin-bottom: 5px;
  font-size: 1.25rem
}

.p-card-loc {
  color: var(--color-text-light);
  margin-bottom: 15px;
  font-size: .9rem;
  display: block
}

.p-card-footer {
  border-top: 1px solid #eee;
  justify-content: space-between;
  align-items: center;
  padding-top: 15px;
  display: flex
}

.p-card-type {
  color: var(--color-text-light);
  font-size: .85rem;
  font-weight: 600
}

.p-card-link {
  color: var(--color-primary);
  font-size: .9rem;
  font-weight: 600;
  text-decoration: none;
  transition: color .3s
}

.p-card-link:hover {
  color: var(--color-secondary)
}

.search-container {
  max-width: 600px;
  margin: 0 auto 30px;
  padding: 0 20px;
  position: relative
}

.search-input {
  width: 100%;
  font-family: var(--font-sans);
  background-color: var(--color-white);
  box-shadow: var(--shadow-light);
  border: 1px solid #b76e794d;
  border-radius: 30px;
  padding: 15px 50px 15px 25px;
  font-size: 1rem;
  transition: all .3s
}

.search-input:focus {
  border-color: var(--color-primary);
  box-shadow: var(--shadow-medium);
  outline: none
}

.search-icon {
  color: var(--color-primary);
  pointer-events: none;
  position: absolute;
  top: 50%;
  right: 40px;
  transform: translateY(-50%)
}

.sticky-chapter-container {
  width: 100%;
  position: relative
}

.avadh-parallax-wrapper {
  z-index: 1;
  background-color: var(--color-black);
  width: 100%;
  height: 100vh;
  position: sticky;
  top: 0;
  overflow: hidden
}

.sticky-bg {
  z-index: 1;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  transform: translate(0, 0)
}

.parallax-img {
  object-fit: cover;
  will-change: transform;
  width: 100%;
  height: 100%;
  transform: scale(1.1)
}

.parallax-overlay {
  z-index: 2;
  background: linear-gradient(#0000001a, #0000004d);
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0
}

.sticky-text-content {
  color: #fff;
  text-align: center;
  z-index: 2;
  pointer-events: none;
  width: 90%;
  margin: auto;
  transition: opacity .3s ease-out, transform .3s ease-out;
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  transform: translateY(-50%)
}

.sticky-subtitle {
  letter-spacing: 2px;
  text-transform: uppercase;
  opacity: .8;
  margin-bottom: .5rem;
  font-family: Poppins, sans-serif;
  font-size: 1.2rem;
  font-weight: 300
}

.sticky-title {
  text-shadow: 0 2px 15px #0000004d;
  font-family: Cormorant Garamond, serif;
  font-size: 5rem;
  font-weight: 700;
  line-height: 1.1
}

@media (max-width:768px) {
  .sticky-title {
    font-size: 3rem
  }

  .sticky-subtitle {
    font-size: 1rem
  }
}

.site-footer {
  background-color: var(--color-black);
  color: var(--color-white);
  padding: var(--spacing-xl) 0 0;
  z-index: 10;
  position: relative
}

.footer-content {
  max-width: 1400px;
  padding: 0 var(--spacing-lg);
  gap: var(--spacing-lg);
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  margin: 0 auto;
  display: grid
}

.footer-brand p {
  color: #ffffffb3;
  margin-top: var(--spacing-sm);
  font-size: .9rem;
  line-height: 1.6
}

.footer-logo {
  filter: brightness(0)invert();
  opacity: .9;
  width: auto;
  height: 60px
}

.footer-links h4,
.footer-contact h4,
.footer-social h4 {
  font-family: var(--font-serif);
  margin-bottom: var(--spacing-md);
  color: var(--color-accent);
  letter-spacing: 1px;
  font-size: 1.3rem
}

.footer-links ul {
  padding: 0;
  list-style: none
}

.footer-links li {
  margin-bottom: 12px
}

.footer-links a {
  color: #ffffffb3;
  font-size: .95rem;
  text-decoration: none;
  transition: all .3s;
  display: inline-block
}

.footer-links a:hover {
  color: var(--color-primary);
  transform: translate(5px)
}

.footer-contact p {
  color: #ffffffb3;
  align-items: flex-start;
  gap: 15px;
  margin-bottom: 18px;
  font-size: .95rem;
  display: flex
}

.footer-contact i {
  color: var(--color-primary);
  margin-top: 5px;
  font-size: 1rem
}

.social-icons {
  gap: 15px;
  display: flex
}

.social-icons a {
  width: 45px;
  height: 45px;
  color: var(--color-white);
  background-color: #ffffff0d;
  border: 1px solid #ffffff1a;
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  text-decoration: none;
  transition: all .3s;
  display: flex
}

.social-icons a:hover {
  transform: translateY(-5px)
}

.social-icons a[aria-label=Facebook]:hover {
  background-color: #1877f2;
  border-color: #1877f2
}

.social-icons a[aria-label=Instagram]:hover {
  background: radial-gradient(circle at 30% 107%, #fdf497 0% 5%, #fd5949 45%, #d62976 60%, #285aeb 90%);
  border-color: #0000
}

.social-icons a[aria-label=LinkedIn]:hover {
  background-color: #0077b5;
  border-color: #0077b5
}

.social-icons a[aria-label=YouTube]:hover {
  background-color: red;
  border-color: red
}

.footer-bottom {
  margin-top: var(--spacing-xl);
  text-align: center;
  color: #ffffff80;
  border-top: 1px solid #ffffff1a;
  padding: 25px 0;
  font-size: .85rem
}

.footer-bottom a {
  color: #ffffffb3;
  margin-left: 10px;
  text-decoration: none;
  transition: color .3s
}

.footer-bottom a:hover {
  color: var(--color-primary)
}

@media (max-width:992px) {
  .footer-content {
    gap: var(--spacing-md);
    grid-template-columns: 1fr 1fr
  }

  .site-footer {
    padding-top: var(--spacing-lg)
  }
}

@media (max-width:576px) {
  .footer-content {
    grid-template-columns: 1fr
  }

  .footer-brand {
    text-align: center
  }

  .footer-logo {
    margin: 0 auto;
    display: block
  }

  .social-icons {
    justify-content: center
  }
}

._sidebarNav_1otw1_3 {
  -webkit-backdrop-filter: blur(24px)saturate(160%);
  z-index: 1000;
  width: 95%;
  max-width: 1400px;
  height: 70px;
  padding: 0 var(--spacing-md);
  background-color: #fffc;
  border: 1px solid #ffffff4d;
  border-radius: 24px;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  transition: all .4s cubic-bezier(.16, 1, .3, 1);
  display: grid;
  position: fixed;
  inset: 20px auto auto 50%;
  transform: translate(-50%);
  box-shadow: 0 8px 32px #0000001a
}

._sidebarNav_1otw1_3._loading_1otw1_53 {
  background-color: #ffffffd9
}

._sidebarNav_1otw1_3._scrolled_1otw1_63 {
  -webkit-backdrop-filter: blur(24px)saturate(160%);
  background-color: #fffc;
  width: 90%;
  max-width: 1100px;
  height: 60px;
  padding: 0 1rem;
  top: 10px;
  box-shadow: 0 10px 40px #0000001a
}

._sidebarNav_1otw1_3._scrolled_1otw1_63 ._brandName_1otw1_87 {
  font-size: 1rem
}

._sidebarNav_1otw1_3._scrolled_1otw1_63 ._navLink_1otw1_95 {
  padding: 0 .6rem;
  font-size: .75rem
}

._sidebarNav_1otw1_3._scrolled_1otw1_63 ._navLogo_1otw1_105 {
  width: 30px;
  height: 30px
}

._navBrand_1otw1_115 {
  align-items: center;
  gap: var(--spacing-sm);
  cursor: pointer;
  background: 0 0;
  border: none;
  flex-direction: row;
  grid-column: 1;
  padding: 0;
  transition: opacity .3s, visibility .3s;
  display: flex
}

._navLogo_1otw1_105 {
  object-fit: contain;
  width: 40px;
  height: 40px;
  margin-bottom: 0;
  transition: all .4s cubic-bezier(.16, 1, .3, 1)
}

._brandName_1otw1_87 {
  font-family: var(--font-serif);
  color: var(--color-primary);
  letter-spacing: 2px;
  font-size: 1.2rem;
  font-weight: 700;
  transition: all .4s cubic-bezier(.16, 1, .3, 1)
}

._chapterNav_1otw1_179 {
  flex-direction: row;
  grid-column: 2;
  align-items: center;
  gap: 0;
  height: 100%;
  list-style: none;
  transition: opacity .3s, visibility .3s;
  display: flex
}

._navItem_1otw1_203 {
  height: 100%;
  display: flex;
  position: relative
}

._navLink_1otw1_95 {
  cursor: pointer;
  height: 100%;
  color: var(--color-text);
  font-family: var(--font-sans);
  text-transform: uppercase;
  letter-spacing: 1px;
  white-space: nowrap;
  background: 0 0;
  border: none;
  justify-content: center;
  align-items: center;
  gap: 5px;
  padding: 0 .6rem;
  font-size: .85rem;
  font-weight: 600;
  transition: all .4s cubic-bezier(.16, 1, .3, 1);
  display: flex;
  position: relative
}

._navLink_1otw1_95:hover,
._navItem_1otw1_203:hover ._navLink_1otw1_95 {
  color: var(--color-primary);
  background-color: #b76e790d
}

._navLink_1otw1_95._active_1otw1_271 {
  color: var(--color-primary)
}

._navLink_1otw1_95._active_1otw1_271:after {
  content: "";
  background-color: var(--color-accent);
  width: 100%;
  height: 3px;
  position: absolute;
  bottom: 0;
  left: 0
}

._dropdownIcon_1otw1_301 {
  margin-left: 4px;
  font-size: .7rem;
  transition: transform .3s
}

._navItem_1otw1_203:hover ._dropdownIcon_1otw1_301,
._submenuOpen_1otw1_315 ._dropdownIcon_1otw1_301 {
  transform: rotate(180deg)
}

._hasSubmenu_1otw1_323:hover ._submenu_1otw1_315,
._submenuOpen_1otw1_315 ._submenu_1otw1_315 {
  opacity: 1;
  visibility: visible;
  transform: translateY(0)
}

._submenu_1otw1_315 {
  -webkit-backdrop-filter: blur(24px)saturate(160%);
  min-width: 220px;
  padding: var(--spacing-sm) 0;
  opacity: 0;
  visibility: hidden;
  background-color: #fffc;
  border: 1px solid #ffffff4d;
  border-top: none;
  border-radius: 16px;
  margin-top: 15px;
  list-style: none;
  transition: all .3s;
  position: absolute;
  top: 100%;
  left: 0;
  transform: translateY(10px);
  box-shadow: 0 20px 40px #0000001a
}

._submenu_1otw1_315>li {
  background: 0 0
}

._submenu_1otw1_315>li>a,
._submenu_1otw1_315>li>button {
  color: var(--color-text);
  text-transform: capitalize;
  transition: var(--transition-fast);
  letter-spacing: .5px;
  padding: 12px 20px;
  font-size: .85rem;
  font-weight: 500;
  text-decoration: none;
  display: block
}

._submenu_1otw1_315>li>a:hover,
._submenu_1otw1_315>li>button:hover {
  color: var(--color-primary);
  background-color: #b76e791a;
  padding-left: 25px
}

._hasNestedSubmenu_1otw1_431 {
  position: relative
}

._submenuTitle_1otw1_439 {
  color: var(--color-text);
  cursor: pointer;
  transition: var(--transition-fast);
  justify-content: space-between;
  align-items: center;
  padding: 12px 20px;
  font-size: .9rem;
  font-weight: 500;
  display: flex
}

._submenuTitle_1otw1_439 i {
  opacity: .7;
  font-size: .7rem;
  transition: transform .3s
}

._hasNestedSubmenu_1otw1_431:hover>._submenuTitle_1otw1_439 {
  color: var(--color-primary);
  background-color: #b76e791a;
  padding-left: 25px
}

._hasNestedSubmenu_1otw1_431:hover>._submenuTitle_1otw1_439 i {
  transform: translate(3px)
}

._nestedSubmenu_1otw1_475 {
  -webkit-backdrop-filter: blur(24px)saturate(160%);
  opacity: 0;
  visibility: hidden;
  background-color: #fffc;
  border: 1px solid #ffffff4d;
  border-radius: 16px;
  flex-direction: column;
  min-width: 300px;
  margin-left: 10px;
  padding: 10px;
  transition: all .3s;
  display: flex;
  position: absolute;
  top: 0;
  left: 100%;
  transform: translate(10px);
  box-shadow: 0 10px 30px #0000001a
}

._projectList_1otw1_549 {
  max-height: 380px;
  margin: 0;
  padding: 0;
  list-style: none;
  overflow: hidden auto
}

._projectList_1otw1_549::-webkit-scrollbar {
  width: 4px
}

._projectList_1otw1_549::-webkit-scrollbar-thumb {
  background-color: var(--color-primary);
  border-radius: 4px
}

._hasNestedSubmenu_1otw1_431:hover ._nestedSubmenu_1otw1_475 {
  opacity: 1;
  visibility: visible;
  transform: translate(0)
}

._nestedSubmenu_1otw1_475._openLeft_1otw1_601 {
  margin-left: 0;
  margin-right: 10px;
  left: auto;
  right: 100%;
  transform: translate(-10px)
}

._projectLink_1otw1_617,
._searchResultItem_1otw1_619 {
  color: inherit;
  border-radius: 8px;
  margin: 2px 0;
  text-decoration: none;
  transition: background-color .2s;
  display: block
}

._projectLink_1otw1_617:hover,
._searchResultItem_1otw1_619:hover {
  background-color: #b76e791a
}

._viewAllItem_1otw1_651 {
  text-align: center;
  background-color: #ffffff80;
  border-top: 1px solid #0000000d;
  border-bottom-right-radius: 16px;
  border-bottom-left-radius: 16px;
  flex-shrink: 0;
  margin: 5px -10px -10px;
  padding: 12px 10px
}

._viewAllLink_1otw1_673 {
  color: var(--color-primary);
  font-size: .8rem;
  font-weight: 600;
  text-decoration: none
}

._viewAllLink_1otw1_673 i {
  margin-left: 5px;
  font-size: .7rem
}

._viewAllLinkMobile_1otw1_697 {
  color: var(--color-primary) !important;
  font-weight: 600 !important
}

._projectCardMini_1otw1_707 {
  background-color: #ffffff80;
  border: 1px solid #fff3;
  border-radius: 8px;
  align-items: center;
  gap: 12px;
  padding: 8px;
  display: flex
}

._projectCardMini_1otw1_707 img {
  object-fit: cover;
  background-color: #eee;
  border-radius: 6px;
  width: 50px;
  height: 50px
}

._projectCardMini_1otw1_707 ._info_1otw1_743 {
  flex-direction: column;
  display: flex
}

._projectCardMini_1otw1_707 ._name_1otw1_753 {
  font-family: var(--font-sans);
  color: var(--color-text);
  font-size: .9rem;
  font-weight: 600;
  line-height: 1.2
}

._projectCardMini_1otw1_707 ._loc_1otw1_769 {
  color: var(--color-text-light);
  margin-top: 2px;
  font-size: .75rem
}

._navFooter_1otw1_781 {
  align-items: center;
  gap: var(--spacing-md);
  flex-direction: row;
  grid-column: 3;
  justify-self: end;
  padding: 0;
  transition: opacity .3s, visibility .3s, gap .4s cubic-bezier(.16, 1, .3, 1);
  display: flex
}

._sidebarNav_1otw1_3._scrolled_1otw1_63 ._navFooter_1otw1_781 {
  gap: 1rem
}

._contactIcons_1otw1_811 {
  align-items: center;
  gap: 8px;
  display: flex
}

._iconButton_1otw1_823 {
  border: 1px solid var(--color-primary-light, #ddd);
  width: 38px;
  height: 38px;
  color: var(--color-primary);
  cursor: pointer;
  background-color: #0000;
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  font-size: .9rem;
  text-decoration: none;
  transition: all .3s;
  display: flex
}

._iconButton_1otw1_823:hover {
  background-color: var(--color-primary);
  color: var(--color-white);
  border-color: var(--color-primary);
  transform: translateY(-2px);
  box-shadow: 0 4px 8px #0000001a
}

._socialLinks_1otw1_871 {
  display: none
}

._socialLinks_1otw1_871 a {
  color: var(--color-text-light);
  transition: var(--transition-fast);
  font-size: 1rem
}

._socialLinks_1otw1_871 a:hover {
  color: var(--color-primary)
}

._navSearchTrigger_1otw1_901 {
  color: var(--color-primary);
  cursor: pointer;
  background: 0 0;
  border: none;
  justify-content: center;
  align-items: center;
  padding: 10px;
  font-size: 1.1rem;
  transition: transform .3s;
  display: flex
}

._navSearchTrigger_1otw1_901:hover {
  color: var(--color-secondary);
  transform: scale(1.1)
}

._sidebarNav_1otw1_3._searchActive_1otw1_939 ._navBrand_1otw1_115,
._sidebarNav_1otw1_3._searchActive_1otw1_939 ._chapterNav_1otw1_179,
._sidebarNav_1otw1_3._searchActive_1otw1_939 ._navFooter_1otw1_781 {
  opacity: 0;
  visibility: hidden;
  pointer-events: none
}

._searchOverlay_1otw1_955 {
  -webkit-backdrop-filter: blur(24px)saturate(160%);
  z-index: 10;
  opacity: 0;
  visibility: hidden;
  background-color: #fffc;
  border-radius: 24px;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  padding: 0 40px;
  transition: all .4s cubic-bezier(.16, 1, .3, 1);
  display: flex;
  position: absolute;
  top: 0;
  left: 0;
  transform: scale(.98)
}

._searchOverlay_1otw1_955._active_1otw1_271 {
  opacity: 1;
  visibility: visible;
  transform: scale(1)
}

._searchBarWrapper_1otw1_1013 {
  align-items: center;
  width: 100%;
  max-width: 800px;
  display: flex
}

._searchOverlayInput_1otw1_1027 {
  border: none;
  border-bottom: 2px solid var(--color-primary);
  width: 100%;
  font-family: var(--font-serif);
  color: var(--color-text);
  background: 0 0;
  padding: 10px 0;
  font-size: 1.5rem
}

._searchOverlayInput_1otw1_1027:focus {
  outline: none
}

._searchClose_1otw1_1057 {
  width: 44px;
  height: 44px;
  color: var(--color-text);
  cursor: pointer;
  background-color: #0000000d;
  border: none;
  border-radius: 50%;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  margin-left: 20px;
  font-size: 1.2rem;
  transition: all .3s;
  display: flex
}

._searchClose_1otw1_1057:hover {
  color: var(--color-primary);
  background-color: #0000001a;
  transform: rotate(90deg)
}

._searchResultsContainer_1otw1_1103 {
  -webkit-backdrop-filter: blur(24px)saturate(160%);
  background-color: #fffc;
  border: 1px solid #ffffff4d;
  border-radius: 12px;
  flex-direction: column;
  gap: 8px;
  width: 100%;
  max-width: 800px;
  max-height: calc(80vh - 100px);
  margin-top: 1rem;
  padding: 1rem;
  display: flex;
  position: absolute;
  top: 100%;
  left: 50%;
  overflow-y: auto;
  transform: translate(-50%);
  box-shadow: 0 4px 20px #0000000d
}

._searchResultsContainer_1otw1_1103::-webkit-scrollbar {
  width: 4px
}

._searchResultsContainer_1otw1_1103::-webkit-scrollbar-thumb {
  background-color: var(--color-primary);
  border-radius: 4px
}

._noResults_1otw1_1165 {
  color: var(--color-text);
  text-align: center;
  font-family: var(--font-sans);
  padding: 20px
}

._searchContentWrapper_1otw1_1179 {
  width: 100%;
  max-width: 850px;
  transition: max-width .3s;
  position: relative
}

._searchBarWrapper_1otw1_1013 {
  align-items: center;
  gap: 1rem;
  display: flex
}

._mobileMenuOverlay_1otw1_1213 {
  z-index: 1000;
  opacity: 0;
  visibility: hidden;
  -webkit-backdrop-filter: blur(4px);
  background-color: #00000080;
  width: 100%;
  height: 100%;
  transition: all .4s;
  display: none;
  position: fixed;
  top: 0;
  left: 0
}

._mobileMenuOverlay_1otw1_1213._active_1otw1_271 {
  opacity: 1;
  visibility: visible
}

._mobileNav_1otw1_1255 {
  -webkit-backdrop-filter: blur(24px)saturate(160%);
  z-index: 1001;
  visibility: hidden;
  background-color: #ffffffd9;
  border-top-left-radius: 24px;
  border-top-right-radius: 24px;
  max-height: 85vh;
  padding: 0;
  transition: bottom .6s cubic-bezier(.16, 1, .3, 1), visibility .6s cubic-bezier(.16, 1, .3, 1);
  display: none;
  position: fixed;
  bottom: -100%;
  left: 0;
  right: 0;
  overflow-y: auto;
  box-shadow: 0 -10px 30px #0000001a
}

._mobileNav_1otw1_1255::-webkit-scrollbar {
  width: 4px
}

._mobileNav_1otw1_1255::-webkit-scrollbar-thumb {
  background-color: var(--color-primary);
  border-radius: 4px
}

._mobileNav_1otw1_1255._active_1otw1_271 {
  visibility: visible;
  bottom: 0
}

._mobileNavHeader_1otw1_1325 {
  margin-bottom: var(--spacing-md);
  z-index: 10;
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  padding: var(--spacing-md);
  background-color: #fffffff2;
  border-bottom: 1px solid #0000000d;
  justify-content: space-between;
  align-items: center;
  transition: box-shadow .3s, border-color .3s;
  display: flex;
  position: sticky;
  top: 0
}

._mobileNavHeader_1otw1_1325._scrolled_1otw1_63 {
  border-bottom-color: #0000;
  box-shadow: 0 4px 20px #0000000d
}

._mobileLogo_1otw1_1365 {
  width: 50px;
  height: 50px
}

._closeMenu_1otw1_1375 {
  width: 44px;
  height: 44px;
  color: var(--color-text);
  cursor: pointer;
  background-color: #0000000d;
  border: none;
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  font-size: 1.2rem;
  transition: all .3s;
  display: flex
}

._closeMenu_1otw1_1375:hover {
  color: var(--color-primary);
  background-color: #0000001a;
  transform: rotate(90deg)
}

._mobileChapterNav_1otw1_1417 {
  margin-bottom: var(--spacing-lg);
  padding: 0 var(--spacing-md);
  list-style: none
}

._mobileNavItem_1otw1_1429 {
  font-family: var(--font-sans);
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--color-text);
  cursor: pointer;
  opacity: 0;
  border-bottom: 1px solid #0000000d;
  flex-direction: column;
  padding: 15px 0;
  font-size: 1rem;
  font-weight: 600;
  transition: opacity .5s, transform .5s, color .3s;
  display: flex;
  transform: translateY(20px)
}

._mobileNav_1otw1_1255._active_1otw1_271 ._mobileNavItem_1otw1_1429 {
  opacity: 1;
  transform: translateY(0)
}

._mobileNav_1otw1_1255._active_1otw1_271 ._mobileNavItem_1otw1_1429:first-child {
  transition-delay: .1s
}

._mobileNav_1otw1_1255._active_1otw1_271 ._mobileNavItem_1otw1_1429:nth-child(2) {
  transition-delay: .15s
}

._mobileNav_1otw1_1255._active_1otw1_271 ._mobileNavItem_1otw1_1429:nth-child(3) {
  transition-delay: .2s
}

._mobileNav_1otw1_1255._active_1otw1_271 ._mobileNavItem_1otw1_1429:nth-child(4) {
  transition-delay: .25s
}

._mobileNav_1otw1_1255._active_1otw1_271 ._mobileNavItem_1otw1_1429:nth-child(5) {
  transition-delay: .3s
}

._mobileNav_1otw1_1255._active_1otw1_271 ._mobileNavItem_1otw1_1429:nth-child(6) {
  transition-delay: .35s
}

._mobileNav_1otw1_1255._active_1otw1_271 ._mobileNavItem_1otw1_1429:nth-child(7) {
  transition-delay: .4s
}

._mobileNav_1otw1_1255._active_1otw1_271 ._mobileNavItem_1otw1_1429:nth-child(8) {
  transition-delay: .45s
}

._mobileNavItem_1otw1_1429 a {
  color: inherit;
  text-decoration: none
}

._mobileNavHeaderRow_1otw1_1547 {
  font: inherit;
  color: inherit;
  cursor: pointer;
  text-transform: inherit;
  letter-spacing: inherit;
  background: 0 0;
  border: none;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  margin: 0;
  padding: 0;
  display: flex
}

._mobileDropdownToggle_1otw1_1591 {
  transition: transform .3s
}

._mobileDropdownToggle_1otw1_1591._open_1otw1_601 {
  transform: rotate(180deg)
}

._mobileSubmenu_1otw1_1607 {
  -webkit-backdrop-filter: blur(16px)saturate(160%);
  opacity: 0;
  background-color: #ffffffb3;
  border: 1px solid #fff3;
  border-radius: 12px;
  max-height: 0;
  margin-top: 0;
  padding: 8px;
  list-style: none;
  transition: max-height .5s cubic-bezier(.4, 0, .2, 1), opacity .4s, transform .4s, margin-top .4s, padding-top .4s;
  overflow: hidden;
  transform: translateY(-10px)
}

._mobileProjectList_1otw1_1639 {
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  -ms-overflow-style: none;
  flex-direction: row;
  gap: 15px;
  padding: 10px 0;
  display: flex;
  overflow-x: auto
}

._mobileProjectList_1otw1_1639::-webkit-scrollbar {
  display: none
}

._mobileProjectList_1otw1_1639 li {
  scroll-snap-align: start;
  flex: 0 0 280px
}

._viewAllItemMobile_1otw1_1687 {
  text-align: center;
  border-top: 1px solid #0000000d;
  margin-top: 5px;
  padding: 10px
}

._mobileSubmenu_1otw1_1607._open_1otw1_601 {
  opacity: 1;
  max-height: 2000px;
  margin-top: 15px;
  transform: translateY(0)
}

._mobileSubmenu_1otw1_1607 li a {
  text-transform: none;
  color: var(--color-text-light);
  padding: 12px 15px;
  font-size: .9rem;
  font-weight: 500;
  text-decoration: none;
  display: block
}

._mobileNestedItem_1otw1_1739 {
  border-bottom: 1px solid #00000008;
  padding: 0
}

._mobileNestedItem_1otw1_1739:last-child {
  border-bottom: none
}

._mobileNavHeaderRow_1otw1_1547._nestedHeader_1otw1_1757 {
  color: var(--color-text);
  padding: 12px 15px;
  font-size: .9rem;
  font-weight: 600
}

._mobileSubmenu_1otw1_1607._nested_1otw1_475 {
  background-color: #0000;
  border-top: 1px solid #00000014;
  border-radius: 0;
  margin-top: 10px;
  padding-left: 0
}

._mobileSubmenu_1otw1_1607._nested_1otw1_475 li a {
  padding-left: 30px;
  position: relative
}

._mobileSubmenu_1otw1_1607._nested_1otw1_475 li a:before {
  content: "";
  border: 1px solid var(--color-primary);
  border-radius: 50%;
  width: 5px;
  height: 5px;
  transition: background-color .3s;
  position: absolute;
  top: 50%;
  left: 15px;
  transform: translateY(-50%)
}

._mobileSubmenu_1otw1_1607._nested_1otw1_475 li a:hover:before {
  background-color: var(--color-primary)
}

._mobileNavItem_1otw1_1429._active_1otw1_271 {
  color: var(--color-primary)
}

._mobileNavFooter_1otw1_1847 {
  padding: 0 var(--spacing-md) var(--spacing-lg);
  opacity: 0;
  justify-content: space-around;
  margin-top: auto;
  transition: opacity .5s, transform .5s, background-color .3s;
  display: flex;
  transform: translateY(20px)
}

@media (max-width:1130px) {
  ._sidebarNav_1otw1_3 {
    display: none
  }

  ._mobileNav_1otw1_1255,
  ._mobileMenuOverlay_1otw1_1213 {
    display: block
  }

  ._sidebarNav_1otw1_3._searchActive_1otw1_939 {
    -webkit-backdrop-filter: none;
    width: 100%;
    max-width: 100%;
    height: 100%;
    box-shadow: none;
    background: 0 0;
    border: none;
    border-radius: 0;
    display: flex;
    top: 0;
    left: 0;
    transform: none
  }

  ._sidebarNav_1otw1_3._searchActive_1otw1_939 ._searchOverlay_1otw1_955 {
    border-radius: 0;
    padding: 15vh 20px 20px
  }

  ._sidebarNav_1otw1_3._searchActive_1otw1_939 ._searchOverlayInput_1otw1_1027 {
    font-family: var(--font-sans);
    background-color: var(--color-white);
    border: 1px solid #eee;
    border-radius: 50px;
    padding: 1rem 1.5rem;
    font-size: 1.1rem;
    transition: all .3s;
    box-shadow: 0 5px 20px #00000012
  }

  ._sidebarNav_1otw1_3._searchActive_1otw1_939 ._searchOverlayInput_1otw1_1027:focus {
    border-color: var(--color-primary);
    box-shadow: 0 5px 20px #00000012, 0 0 0 3px #b76e7933
  }
}

._mobileIconButton_1otw1_1973 {
  background-color: var(--color-white);
  width: 54px;
  height: 54px;
  color: var(--color-primary);
  cursor: pointer;
  border: 1px solid #eee;
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  font-size: 1.2rem;
  text-decoration: none;
  transition: all .3s;
  display: flex;
  box-shadow: 0 2px 10px #00000012
}

._mobileIconButton_1otw1_1973:hover {
  background-color: var(--color-primary);
  color: var(--color-white);
  transform: translateY(-3px);
  box-shadow: 0 5px 15px #b76e794d
}

._mobileNav_1otw1_1255._active_1otw1_271 ._mobileNavFooter_1otw1_1847 {
  opacity: 1;
  transition-delay: .5s;
  transform: translateY(0)
}

._projectCardMini_1533s_1 {
  color: inherit;
  border-radius: 6px;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 8px;
  text-decoration: none;
  transition: background-color .2s, box-shadow .2s, transform .2s;
  display: flex
}

._projectCardMini_1533s_1:hover {
  z-index: 10;
  background-color: #0000000a;
  position: relative;
  transform: scale(1.02);
  box-shadow: 0 4px 15px #00000014
}

._projectImage_1533s_33 {
  object-fit: cover;
  border-radius: 4px;
  flex-shrink: 0;
  width: 80px;
  height: 60px
}

._info_1533s_53 {
  flex-direction: column;
  justify-content: center;
  display: flex
}

._name_1533s_63 {
  color: #333;
  font-size: .9rem;
  font-weight: 600;
  line-height: 1.3
}

._loc_1533s_77 {
  color: #777;
  margin-top: 4px;
  font-size: .8rem
}

._mobileHeader_rcdoo_1 {
  z-index: 1000;
  -webkit-backdrop-filter: blur(16px)saturate(180%);
  background-color: #ffffffbf;
  border: 1px solid #fff3;
  border-radius: 50px;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 5px;
  width: 90vw;
  max-width: 400px;
  height: 55px;
  padding: 0 10px;
  transition: all .4s cubic-bezier(.16, 1, .3, 1);
  display: none;
  position: fixed;
  top: 15px;
  left: 50%;
  transform: translate(-50%);
  box-shadow: 0 8px 32px #0000001a
}

._mobileHeader_rcdoo_1._onHero_rcdoo_57 {
  -webkit-backdrop-filter: blur(18px)saturate(180%);
  background-color: #f0f2f5bf;
  border: 1px solid #ffffff4d
}

._logoContainer_rcdoo_75 {
  grid-column: 1;
  justify-content: center;
  align-items: center;
  width: 44px;
  display: flex
}

._logo_rcdoo_75 {
  object-fit: contain;
  width: 35px;
  height: 35px;
  transition: all .4s cubic-bezier(.16, 1, .3, 1)
}

._brandNameContainer_rcdoo_107 {
  grid-column: 2;
  justify-content: center;
  align-items: center;
  display: flex
}

._brandName_rcdoo_107 {
  font-family: var(--font-serif);
  color: #383a37;
  letter-spacing: 5px;
  opacity: 0;
  text-shadow: 0 1px 2px #0000000d;
  white-space: nowrap;
  text-align: center;
  width: 0;
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1;
  display: inline-block;
  overflow: hidden
}

._brandNameContainer_rcdoo_107._loaded_rcdoo_159 ._brandName_rcdoo_107 {
  opacity: 1;
  animation: 1s steps(5, end) forwards _typing_rcdoo_1
}

@keyframes _typing_rcdoo_1 {
  0% {
    width: 0
  }

  to {
    width: 120px
  }
}

._menuContainer_rcdoo_193 {
  grid-column: 3;
  justify-content: center;
  align-items: center;
  width: 44px;
  display: flex
}

._hamburgerButton_rcdoo_211 {
  z-index: 1001;
  cursor: pointer;
  background-color: #0000;
  border: none;
  border-radius: 50%;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 44px;
  height: 44px;
  transition: background-color .3s;
  display: flex
}

._hamburgerButton_rcdoo_211:hover {
  background-color: #0000000d
}

._menuLine_rcdoo_251 {
  background-color: var(--color-text);
  border-radius: 2px;
  width: 22px;
  height: 2px;
  transition: background-color .3s
}

@media (max-width:1130px) {
  ._mobileHeader_rcdoo_1 {
    display: grid
  }
}

._contactUs_1gd43_1 {
  max-width: 100%;
  box-shadow: none;
  background-color: #0000;
  border-radius: 0;
  margin: 1rem 0;
  padding: 0;
  position: relative;
  overflow: visible
}

._bgPattern_1gd43_23 {
  opacity: .03;
  pointer-events: none;
  background-image: radial-gradient(#eab308 1px, #0000 1px);
  background-size: 24px 24px;
  width: 100%;
  height: 100%;
  display: none;
  position: absolute;
  top: 0;
  left: 0
}

._chapterContent_1gd43_49 {
  z-index: 1;
  position: relative
}

._contentWrapper_1gd43_59 {
  width: 100%
}

._accordionHeader_1gd43_67 {
  cursor: pointer;
  background-color: #2d2d2d;
  border: 1px solid #444;
  border-radius: 50px;
  justify-content: center;
  align-items: center;
  padding: 1rem 1.5rem;
  transition: all .3s;
  display: flex;
  position: relative
}

._accordionHeader_1gd43_67:hover {
  background-color: #333;
  border-color: #eab308
}

._accordionTitle_1gd43_103 {
  color: #eab308;
  margin: 0;
  font-size: 1.5rem;
  font-weight: 600
}

._accordionIcon_1gd43_117 {
  color: #eab308;
  font-size: 1.2rem;
  transition: transform .3s;
  position: absolute;
  right: 1.5rem
}

._rotateIcon_1gd43_133 {
  transform: rotate(180deg)
}

._accordionContent_1gd43_141 {
  overflow: hidden
}

._chapterDescription_1gd43_149 {
  color: #000;
  text-align: center;
  margin: 1.5rem 0;
  line-height: 1.6
}

._chapterTitle_1gd43_163 {
  color: #eab308;
  margin-bottom: 1rem;
  font-size: 2rem
}

._inlineForm_1gd43_175 {
  flex-direction: column;
  gap: 1.5rem;
  margin-top: 1rem;
  display: flex
}

._formRow_1gd43_189 {
  gap: 1.5rem;
  display: flex
}

._formGroup_1gd43_199 {
  text-align: left;
  flex-direction: column;
  flex: 1;
  gap: .5rem;
  display: flex
}

._formGroup_1gd43_199 label {
  color: #eab308;
  margin-left: 4px;
  font-size: .9rem;
  font-weight: 500
}

._formGroup_1gd43_199 input,
._formGroup_1gd43_199 textarea {
  color: #fff;
  background-color: #fff;
  border: 1px solid #555;
  border-radius: 6px;
  width: 100%;
  padding: 12px 16px;
  font-size: 1rem;
  transition: all .3s
}

._formGroup_1gd43_199 input:focus,
._formGroup_1gd43_199 textarea:focus {
  background-color: #333;
  border-color: #eab308;
  outline: none;
  box-shadow: 0 0 0 3px #eab30833
}

._formGroup_1gd43_199 input::placeholder,
._formGroup_1gd43_199 textarea::placeholder {
  color: #777
}

._formGroup_1gd43_199 textarea {
  resize: vertical;
  min-height: 120px
}

._error_1gd43_289 {
  border-color: #ef4444 !important
}

._errorMessage_1gd43_297 {
  color: #ef4444;
  margin-top: .25rem;
  font-size: .85rem
}

._ctaButton_1gd43_309 {
  color: #000;
  cursor: pointer;
  background-color: #eab308;
  border: none;
  border-radius: 6px;
  justify-content: center;
  align-self: center;
  align-items: center;
  gap: 10px;
  min-width: 200px;
  padding: 14px 32px;
  font-size: 1.1rem;
  font-weight: 700;
  transition: all .3s;
  display: inline-flex
}

._ctaButton_1gd43_309:hover {
  background-color: #ca8a04;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px #eab3084d
}

._ctaButton_1gd43_309:disabled {
  color: #888;
  cursor: not-allowed;
  box-shadow: none;
  background-color: #555;
  transform: none
}

@media (max-width:768px) {
  ._formRow_1gd43_189 {
    flex-direction: column;
    gap: 1.5rem
  }

  ._contactUs_1gd43_1 {
    padding: 2rem 1rem
  }
}

._errorContainer_kk0c2_1 {
  color: #d46b08;
  box-sizing: border-box;
  background-color: #fffbe6;
  border: 1px solid #ffe58f;
  border-left: 4px solid #faad14;
  border-radius: 4px;
  align-items: center;
  width: 100%;
  margin: 20px 0;
  padding: 16px;
  display: flex
}

._errorIcon_kk0c2_37 {
  flex-shrink: 0;
  margin-right: 16px;
  font-size: 1.5rem
}

._errorContent_kk0c2_49 {
  flex-grow: 1
}

._errorMessage_kk0c2_57 {
  margin: 0;
  font-weight: 500
}

._retryButton_kk0c2_67 {
  color: #d48806;
  cursor: pointer;
  background-color: #0000;
  border: 1px solid #d48806;
  border-radius: 4px;
  margin-top: 12px;
  padding: 6px 12px;
  font-weight: 600;
  transition: background-color .2s, color .2s
}

._retryButton_kk0c2_67:hover {
  color: #fff;
  background-color: #d48806
}

._retryButton_kk0c2_67 i {
  margin-right: 6px
}

.modal-overlay {
  z-index: 10000;
  background-color: #000000b3;
  justify-content: center;
  align-items: center;
  display: flex;
  position: fixed;
  inset: 0
}

.modal-content {
  color: #fff;
  background-color: #1a1814;
  border: 1px solid #cda45e;
  border-radius: 8px;
  width: 90%;
  max-width: 450px;
  padding: 25px;
  animation: .3s ease-out modalFadeIn;
  position: relative;
  box-shadow: 0 10px 30px #00000080
}

.modal-header {
  border-bottom: 1px solid #ffffff1a;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 15px;
  padding-bottom: 10px;
  display: flex
}

.modal-header h3 {
  color: #cda45e;
  margin: 0;
  font-family: Playfair Display, serif
}

.close-button {
  color: #ffffffb3;
  cursor: pointer;
  background: 0 0;
  border: none;
  font-size: 1.5rem;
  transition: color .3s
}

.close-button:hover {
  color: #fff
}

.modal-body {
  color: #ffffffe6;
  margin-bottom: 25px;
  line-height: 1.6
}

.modal-footer {
  justify-content: flex-end;
  display: flex
}

.modal-btn {
  color: #000;
  cursor: pointer;
  background-color: #cda45e;
  border: none;
  border-radius: 4px;
  padding: 10px 25px;
  font-weight: 600;
  transition: background-color .3s
}

.modal-btn:hover {
  background-color: #d9b370
}

@keyframes modalFadeIn {
  0% {
    opacity: 0;
    transform: translateY(-20px)
  }

  to {
    opacity: 1;
    transform: translateY(0)
  }
}

.blog-detail-page {
  background-color: #fff;
  min-height: 100vh;
  padding-top: 100px;
  padding-bottom: 80px
}

.blog-detail-container {
  max-width: 800px;
  margin: 0 auto;
  padding: 0 20px
}

.back-btn {
  cursor: pointer;
  color: #666;
  background: 0 0;
  border: none;
  align-items: center;
  gap: 8px;
  margin-bottom: 40px;
  padding: 0;
  font-size: 1rem;
  transition: color .3s;
  display: flex
}

.back-btn:hover {
  color: #000
}

.article-header {
  text-align: center;
  margin-bottom: 40px
}

.article-category {
  text-transform: uppercase;
  letter-spacing: 2px;
  color: #888;
  margin-bottom: 15px;
  font-size: .85rem;
  display: block
}

.article-header h1 {
  color: #222;
  margin-bottom: 20px;
  font-family: Playfair Display, serif;
  font-size: 2.5rem;
  line-height: 1.2
}

.article-meta {
  color: #666;
  font-size: .9rem
}

.article-meta .separator {
  margin: 0 10px
}

.article-featured-image {
  border-radius: 12px;
  width: 100%;
  height: 400px;
  margin-bottom: 50px;
  overflow: hidden
}

.article-featured-image img {
  object-fit: cover;
  width: 100%;
  height: 100%
}

.article-content {
  color: #333;
  font-size: 1.1rem;
  line-height: 1.8
}

.article-content p {
  margin-bottom: 25px
}

.article-content .lead {
  color: #000;
  font-size: 1.25rem;
  font-weight: 500
}

.article-content h3 {
  margin-top: 40px;
  margin-bottom: 20px;
  font-family: Playfair Display, serif;
  font-size: 1.5rem
}

.article-content blockquote {
  background: #f9f9f9;
  border-left: 4px solid #333;
  margin: 40px 0;
  padding: 10px 30px;
  font-size: 1.2rem;
  font-style: italic
}

.all-posts-grid {
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 30px;
  margin-top: 40px;
  display: grid
}

.post-card {
  cursor: pointer;
  background: #fff;
  border-radius: 12px;
  flex-direction: column;
  transition: transform .3s, box-shadow .3s;
  display: flex;
  overflow: hidden;
  box-shadow: 0 4px 15px #0000000d
}

.post-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 25px #0000001a
}

.post-card-image {
  height: 200px;
  overflow: hidden
}

.post-card-image img {
  object-fit: cover;
  width: 100%;
  height: 100%;
  transition: transform .5s
}

.post-card:hover .post-card-image img {
  transform: scale(1.05)
}

.post-card-content {
  flex-direction: column;
  flex-grow: 1;
  padding: 20px;
  display: flex
}

.post-date {
  color: #888;
  margin-bottom: 10px;
  font-size: .8rem;
  display: block
}

.post-card-content h3 {
  color: #222;
  margin-bottom: 10px;
  font-family: Playfair Display, serif;
  font-size: 1.25rem;
  line-height: 1.3
}

.post-card-content p {
  color: #666;
  flex-grow: 1;
  margin-bottom: 20px;
  font-size: .95rem;
  line-height: 1.6
}

.read-more-link {
  color: #333;
  text-transform: uppercase;
  letter-spacing: .5px;
  font-size: .9rem;
  font-weight: 600
}

._heroSlide_xop15_11 {
  opacity: 0;
  z-index: 0;
  background-color: var(--color-black);
  width: 100%;
  height: 100%;
  transition: opacity 1.5s;
  position: absolute;
  top: 0;
  left: 0
}

._heroSlide_xop15_11._active_xop15_35 {
  opacity: 1;
  z-index: 1
}

._heroVideo_xop15_45 {
  object-fit: cover;
  will-change: transform;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  transform: scale(1)
}

._heroOverlay_xop15_67 {
  background: linear-gradient(#0000004d, #000000b3);
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0
}

._heroContent_xop15_85 {
  z-index: 2;
  color: var(--color-white);
  text-shadow: 0 2px 15px #00000080;
  will-change: opacity;
  max-width: 600px;
  position: absolute;
  top: 50%;
  left: 10%;
  transform: translateY(-50%)
}

._heroTitle_xop15_109 {
  font-family: var(--font-serif);
  margin-bottom: var(--spacing-md);
  text-shadow: 0 2px 15px #00000080;
  font-size: clamp(3rem, 5vw, 5rem);
  line-height: 1.1
}

._word_xop15_135 {
  display: inline-block
}

._textRevealContainer_xop15_145 {
  padding: 2px 0;
  overflow: hidden
}

._char_xop15_159 {
  opacity: 0;
  animation-name: _revealChar_xop15_1;
  animation-duration: .8s;
  animation-timing-function: cubic-bezier(.2, .8, .2, 1);
  animation-fill-mode: forwards;
  display: inline-block;
  transform: translateY(110%)
}

@keyframes _revealChar_xop15_1 {
  to {
    opacity: 1;
    transform: translateY(0)
  }
}

._ctaContainer_xop15_197 {
  margin-top: var(--spacing-lg);
  opacity: 0;
  animation: 1s cubic-bezier(.2, .8, .2, 1) 1.8s forwards _fadeInCta_xop15_1;
  transform: translateY(20px)
}

@keyframes _fadeInCta_xop15_1 {
  to {
    opacity: 1;
    transform: translateY(0)
  }
}

._watchVideoButton_xop15_229 {
  color: var(--color-white);
  font-weight: 600;
  font-family: var(--font-sans);
  -webkit-backdrop-filter: blur(8px);
  background-color: #ffffff26;
  border: 1px solid #fff6;
  border-radius: 50px;
  align-items: center;
  gap: 10px;
  padding: 12px 24px;
  font-size: .9rem;
  text-decoration: none;
  transition: all .3s;
  display: inline-flex
}

._watchVideoButton_xop15_229:hover {
  border-color: var(--color-white);
  background-color: #ffffff4d;
  transform: translateY(-3px)scale(1.02);
  box-shadow: 0 5px 15px #0003
}

._scrollIndicator_xop15_279 {
  color: var(--color-white);
  z-index: 10;
  will-change: opacity;
  flex-direction: column;
  align-items: center;
  display: flex;
  position: absolute;
  bottom: 30px;
  left: 50%;
  transform: translate(-50%)
}

._mouse_xop15_305 {
  border: 2px solid var(--color-white);
  border-radius: 20px;
  justify-content: center;
  width: 30px;
  height: 50px;
  margin-bottom: 10px;
  padding-top: 10px;
  display: flex
}

._wheel_xop15_327 {
  background-color: var(--color-white);
  border-radius: 2px;
  width: 4px;
  height: 10px;
  animation: 2s infinite _scrollWheel_xop15_1
}

@keyframes _scrollWheel_xop15_1 {
  0% {
    opacity: 1;
    transform: translateY(0)
  }

  to {
    opacity: 0;
    transform: translateY(15px)
  }
}

@media (max-width:768px) {
  ._heroContent_xop15_85 {
    text-align: center;
    max-width: none;
    left: 20px;
    right: 20px;
    transform: translateY(-55%)
  }

  ._scrollIndicator_xop15_279 {
    bottom: 20px
  }
}

._aboutSection_1jqwf_5 {
  background-color: var(--color-light);
  border-top-left-radius: var(--section-radius);
  border-top-right-radius: var(--section-radius);
  height: 100vh;
  box-shadow: var(--section-shadow);
  z-index: 2;
  contain: paint;
  position: relative;
  overflow: hidden
}

._aboutMaskContainer_1jqwf_37 {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  overflow: hidden
}

._aboutBg_1jqwf_57 {
  object-fit: cover;
  z-index: 1;
  will-change: transform;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0
}

._aboutMaskLayer_1jqwf_81 {
  background-color: var(--color-light);
  z-index: 2;
  transform-origin: 50%;
  opacity: 1;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  display: flex;
  position: absolute;
  top: 0;
  left: 0;
  transform: scale(1)
}

._aboutSvgMask_1jqwf_121 {
  width: 80%;
  max-width: 800px;
  height: 80%;
  max-height: 800px
}

._aboutContentReveal_1jqwf_137 {
  opacity: 0;
  z-index: 3;
  pointer-events: none;
  text-shadow: 0 4px 25px #000000e6;
  background: linear-gradient(#00000080, #000000bf);
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  display: flex;
  position: absolute;
  top: 0;
  left: 0
}

._aboutValuesGrid_1jqwf_179 {
  text-align: left;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 2rem;
  margin-top: 3rem;
  display: grid
}

._aboutTextContainer_1jqwf_197 {
  width: 100%;
  padding: 0 var(--spacing-lg)
}

._valueItem_1jqwf_209 {
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  background: #ffffff1a;
  border: 1px solid #fff;
  border-radius: 10px;
  padding: 1.5rem
}

._valueItem_1jqwf_209 h4 {
  color: var(--color-primary);
  margin-bottom: .5rem
}

._valueItem_1jqwf_209 p {
  color: #fffc;
  font-size: .9rem;
  line-height: 1.6
}

._textContentWhite_1jqwf_249,
._textContentWhite_1jqwf_249 .chapter-title,
._textContentWhite_1jqwf_249 .section-paragraph {
  color: #fff
}

._textContentWhite_1jqwf_249 .highlight {
  color: var(--color-primary)
}

@media (max-width:768px) {
  ._aboutTextContainer_1jqwf_197 {
    padding: 0 var(--spacing-md)
  }
}

@media (max-width:480px) {
  ._aboutTextContainer_1jqwf_197 {
    padding: 0 var(--spacing-sm)
  }

  ._aboutMaskLayer_1jqwf_81 text {
    font-size: 20vw
  }

  ._aboutValuesGrid_1jqwf_179 {
    gap: 1.5rem
  }
}

@media (min-width:481px) and (max-width:768px) and (orientation:portrait) {
  ._aboutMaskLayer_1jqwf_81 text {
    font-size: 120px
  }
}

#get-in-touch {
  color: #fff;
  background-color: #1a1814;
  min-height: auto;
  padding: 50px 0;
  position: relative;
  overflow: hidden
}

#get-in-touch .chapter-content {
  z-index: 2;
  padding-top: 0;
  padding-bottom: 0;
  position: relative
}

#get-in-touch .content-wrapper.centered {
  max-width: 900px;
  margin: 0 auto;
  padding: 0 20px
}

#get-in-touch .chapter-subtitle {
  color: #ffffffb3
}

#get-in-touch .chapter-title {
  color: #fff
}

#get-in-touch .chapter-title .highlight {
  color: #cda45e
}

#get-in-touch .chapter-description {
  color: #fffc;
  max-width: 700px;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.8
}

.form-group input,
.form-group select,
.form-group textarea {
  color: #fff;
  background-color: #ffffff0d;
  border: 1px solid #fff3;
  border-radius: 5px;
  width: 100%;
  padding: 12px 15px;
  font-size: 1rem;
  transition: border-color .3s, box-shadow .3s
}

.form-group textarea {
  resize: vertical
}

.form-group input::placeholder,
.form-group textarea::placeholder {
  color: #fff6
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color: #cda45e;
  outline: none;
  box-shadow: 0 0 0 2px #cda45e4d
}

@media (max-width:768px) {
  .form-row {
    flex-direction: column
  }
}

@keyframes spin {
  0% {
    transform: rotate(0)
  }

  to {
    transform: rotate(360deg)
  }
}

@keyframes fadeIn {
  0% {
    opacity: 0;
    transform: translateY(-10px)
  }

  to {
    opacity: 1;
    transform: translateY(0)
  }
}

.inline-form {
  width: 100%;
  max-width: 900px;
  margin: 2rem auto 0
}

.form-row {
  gap: 1.5rem;
  margin-bottom: 1.5rem;
  display: flex
}

.form-group {
  text-align: left;
  flex-direction: column;
  flex: 1;
  display: flex
}

.form-group label {
  color: #fff;
  margin-bottom: .5rem;
  font-size: .95rem;
  font-weight: 500
}

.form-group input,
.form-group select,
.form-group textarea {
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  background: #fffc;
  border: 1px solid #0000001a;
  border-radius: 8px;
  width: 100%;
  padding: 1rem;
  font-size: 1rem;
  transition: all .3s
}

.form-group input::placeholder,
.form-group textarea::placeholder {
  color: #333;
  opacity: .7
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color: var(--color-primary, #da9100);
  background: #fff;
  outline: none;
  box-shadow: 0 5px 15px #0000000d
}

@media (max-width:992px) {
  .form-row {
    gap: 1rem
  }

  .form-group input,
  .form-group select,
  .form-group textarea {
    padding: .85rem
  }
}

@media (max-width:768px) {
  .form-row {
    flex-direction: column;
    gap: 1rem;
    margin-bottom: 1rem
  }

  .cta-button {
    justify-content: center;
    width: 100%
  }
}

#book-visit {
  color: #fff;
  background-color: #1a1814;
  min-height: auto;
  padding: 80px 0;
  position: relative;
  overflow: hidden
}

.get-in-touch-bg-pattern {
  opacity: .05;
  z-index: 1;
  background-image: url(../static/01-arena-q09nw4gK.webp);
  background-repeat: repeat;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0
}

#book-visit .chapter-content {
  z-index: 2;
  padding-top: 0;
  padding-bottom: 0;
  position: relative
}

#book-visit .content-wrapper.centered {
  max-width: 900px;
  margin: 0 auto;
  padding: 0 20px
}

#book-visit .chapter-subtitle,
#book-visit .chapter-title {
  color: #fff
}

#book-visit .chapter-title .highlight {
  color: #cda45e
}

#book-visit .chapter-description {
  color: #fffc;
  max-width: 700px;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.8
}

.inline-form {
  flex-direction: column;
  gap: 20px;
  width: 100%;
  margin-top: 40px;
  display: flex
}

.form-row {
  gap: 20px;
  width: 100%;
  display: flex
}

.form-group {
  flex-direction: column;
  flex: 1;
  display: flex
}

.form-group label {
  color: #ffffffa9;
  text-align: left;
  margin-bottom: 8px;
  font-size: .9rem
}

.form-group input,
.form-group select {
  color: #fff;
  background-color: #ffffff0d;
  border: 1px solid #fff3;
  border-radius: 5px;
  width: 100%;
  padding: 12px 15px;
  font-size: 1rem;
  transition: border-color .3s, box-shadow .3s
}

.form-group input::placeholder {
  color: #fff6
}

.form-group input:focus,
.form-group select:focus {
  border-color: #cda45e;
  outline: none;
  box-shadow: 0 0 0 2px #cda45e4d
}

.form-group input.error {
  border-color: #ff6b6b;
  box-shadow: 0 0 0 2px #ff6b6b33
}

.error-message {
  color: #ff6b6b;
  margin-top: 5px;
  font-size: .8rem;
  display: block
}

.form-group select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1.41 0.58L6 5.17L10.59 0.58L12 2L6 8L0 2L1.41 0.58Z' fill='%23cda45e'/%3E%3C/svg%3E");
  background-position: right 15px center;
  background-repeat: no-repeat;
  background-size: 12px
}

.form-group select option {
  color: #fff;
  background-color: #1a1814
}

.inline-form .cta-button {
  color: #1a1814;
  text-transform: uppercase;
  letter-spacing: 1px;
  cursor: pointer;
  background-color: #cda45e;
  border: none;
  border-radius: 5px;
  align-self: center;
  margin-top: 20px;
  padding: 15px 30px;
  font-size: 1rem;
  font-weight: 600;
  transition: background-color .3s, transform .2s
}

.inline-form .cta-button:hover {
  background-color: #d9b370;
  transform: translateY(-2px)
}

@media (max-width:768px) {
  .form-row {
    flex-direction: column
  }
}

._portfolioContainer_1kb4s_1 {
  width: 100%;
  max-width: 1400px;
  margin: 2rem auto;
  padding: 0 2rem
}

._portfolioFilters_1kb4s_15 {
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  margin-bottom: 2rem;
  display: flex
}

._filterButtons_1kb4s_33 {
  background-color: #f3f4f6;
  border-radius: 50px;
  gap: .5rem;
  padding: .5rem;
  display: flex
}

._filterBtn_1kb4s_49 {
  color: #555;
  cursor: pointer;
  background-color: #0000;
  border: none;
  border-radius: 50px;
  padding: .5rem 1.5rem;
  font-weight: 600;
  transition: all .3s
}

._filterBtn_1kb4s_49._active_1kb4s_71 {
  background-color: var(--color-primary, #da9100);
  color: #fff;
  box-shadow: 0 2px 10px #da91004d
}

._searchWrapper_1kb4s_83 {
  position: relative
}

._searchInput_1kb4s_91 {
  border: 1px solid #ddd;
  border-radius: 50px;
  width: 250px;
  padding: .75rem 1rem;
  transition: all .3s
}

._searchInput_1kb4s_91:focus {
  border-color: var(--color-primary, #da9100);
  outline: none;
  box-shadow: 0 0 0 3px #da910033
}

._portfolioGrid_1kb4s_119 {
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 2rem;
  display: grid
}

._portfolioCard_1kb4s_131 {
  cursor: pointer;
  background: #fff;
  border: 1px solid #eee;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 4px 20px #0000000f
}

._pCardImage_1kb4s_149 {
  object-fit: cover;
  width: 100%;
  height: 220px;
  display: block
}

._pCardContent_1kb4s_163 {
  padding: 1.25rem
}

._pCardTitle_1kb4s_171 {
  color: #333;
  margin: 0 0 .25rem;
  font-size: 1.2rem;
  font-weight: 600
}

._pCardLoc_1kb4s_185 {
  color: #777;
  margin: 0;
  font-size: .9rem
}

._noResults_1kb4s_197 {
  text-align: center;
  color: #555;
  grid-column: 1/-1;
  padding: 4rem 0;
  font-size: 1.1rem
}

._skeleton_1kb4s_215 ._pCardImage_1kb4s_149,
._skeleton_1kb4s_215 ._skeletonText_1kb4s_217 {
  background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%) 0 0/200% 100%;
  animation: 1.5s ease-in-out infinite _pulse_1kb4s_1
}

._skeleton_1kb4s_215 ._pCardTitle_1kb4s_171 {
  border-radius: 4px;
  width: 80%;
  height: 1.2rem;
  margin-bottom: .75rem
}

._skeleton_1kb4s_215 ._pCardLoc_1kb4s_185 {
  border-radius: 4px;
  width: 50%;
  height: .9rem
}

@keyframes _pulse_1kb4s_1 {
  0% {
    background-position: 200% 0
  }

  to {
    background-position: -200% 0
  }
}

._dropdownContainer_1awx0_1 {
  min-width: 180px;
  font-family: var(--font-sans, "Inter", sans-serif);
  -webkit-user-select: none;
  user-select: none;
  position: relative
}

._dropdownContainer_1awx0_1._active_1awx0_15 {
  z-index: 100
}

._dropdownTrigger_1awx0_23 {
  background-color: var(--color-white, #fff);
  cursor: pointer;
  color: var(--color-primary, #da9100);
  border: 1px solid #b76e794d;
  border-radius: 50px;
  justify-content: space-between;
  align-items: center;
  padding: 12px 25px;
  font-size: .95rem;
  font-weight: 600;
  transition: all .3s;
  display: flex;
  box-shadow: 0 4px 10px #0000000d
}

._dropdownTrigger_1awx0_23:hover,
._dropdownTrigger_1awx0_23._open_1awx0_59 {
  border-color: var(--color-primary, #da9100);
  transform: translateY(-2px);
  box-shadow: 0 8px 20px #da910026
}

._arrow_1awx0_71 {
  align-items: center;
  margin-left: 10px;
  transition: transform .3s;
  display: flex
}

._dropdownTrigger_1awx0_23._open_1awx0_59 ._arrow_1awx0_71 {
  transform: rotate(180deg)
}

._dropdownMenu_1awx0_93 {
  background-color: var(--color-white, #fff);
  z-index: 1000;
  border: 1px solid #b76e7933;
  border-radius: 16px;
  width: 100%;
  max-height: 250px;
  animation: .2s ease-out forwards _fadeIn_1awx0_1;
  position: absolute;
  top: calc(100% + 10px);
  left: 0;
  overflow: hidden auto;
  box-shadow: 0 10px 30px #0000001a
}

._dropdownMenu_1awx0_93::-webkit-scrollbar {
  width: 6px
}

._dropdownMenu_1awx0_93::-webkit-scrollbar-track {
  background: #00000005
}

._dropdownMenu_1awx0_93::-webkit-scrollbar-thumb {
  background-color: #b76e794d;
  border-radius: 10px
}

._dropdownItem_1awx0_153 {
  cursor: pointer;
  color: var(--color-text, #333);
  border-bottom: 1px solid #00000008;
  align-items: center;
  padding: 12px 20px;
  font-size: .9rem;
  transition: background-color .2s, color .2s;
  display: flex
}

._dropdownItem_1awx0_153:last-child {
  border-bottom: none
}

._dropdownItem_1awx0_153:hover {
  color: var(--color-primary, #da9100);
  background-color: #da910014
}

._dropdownItem_1awx0_153._selected_1awx0_193 {
  color: var(--color-primary, #da9100);
  background-color: #da910026;
  font-weight: 600
}

._checkbox_1awx0_205 {
  background-color: var(--color-white, #fff);
  border: 1px solid #b76e7980;
  border-radius: 4px;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  width: 18px;
  height: 18px;
  margin-right: 12px;
  transition: all .2s;
  display: flex
}

._checked_1awx0_233 {
  background-color: var(--color-primary, #da9100);
  border-color: var(--color-primary, #da9100)
}

._checkbox_1awx0_205 i {
  color: #fff;
  font-size: 10px
}

@keyframes _fadeIn_1awx0_1 {
  0% {
    opacity: 0;
    transform: translateY(-10px)
  }

  to {
    opacity: 1;
    transform: translateY(0)
  }
}

@media (max-width:768px) {
  ._clubChapterContent_68l4a_17 {
    padding-top: 2rem !important;
    padding-bottom: 2rem !important
  }
}

.sustainability-csr-section {
  background-color: #f8f9fa;
  padding: 4rem 2rem
}

.cascading-container {
  max-width: 1200px;
  margin: 0 auto;
  position: relative
}

.cascade-card {
  background: #fff;
  border-radius: 24px;
  flex-direction: column;
  justify-content: center;
  min-height: 60vh;
  margin-bottom: 4rem;
  padding: 3rem;
  transition: transform .3s;
  display: flex;
  position: sticky;
  top: 100px;
  overflow: hidden;
  box-shadow: 0 10px 40px #00000014
}

.cascade-card.green-card {
  z-index: 1;
  background: linear-gradient(135deg, #e8f5e9 0%, #fff 100%)
}

.cascade-card.csr-card {
  z-index: 2;
  background: linear-gradient(135deg, #e3f2fd 0%, #fff 100%);
  top: 120px
}

.card-bg-parallax {
  z-index: 0;
  pointer-events: none;
  width: 100%;
  height: 150%;
  position: absolute;
  top: -20%;
  left: 0
}

.card-bg-doodle {
  opacity: .08;
  filter: grayscale()sepia()hue-rotate(70deg)saturate(200%);
  background-image: url(https://images.unsplash.com/photo-1550989460-0adf9ea622e2?ixlib=rb-1.2.1&auto=format&fit=crop&w=1950&q=80);
  background-position: 50%;
  background-size: cover;
  width: 100%;
  height: 100%;
  animation: 40s ease-in-out infinite alternate doodle-drift
}

@keyframes doodle-drift {
  0% {
    transform: scale(1.1)rotate(-2deg)
  }

  to {
    transform: scale(1.2)rotate(2deg)
  }
}

.card-content {
  z-index: 1;
  position: relative
}

.card-content h2 {
  color: #1a1a1a;
  margin-bottom: 1.5rem;
  font-size: 2.5rem
}

.card-content p {
  color: #4a4a4a;
  max-width: 800px;
  font-size: 1.125rem;
  line-height: 1.7
}

.env-bg {
  will-change: transform;
  transition: transform .8s cubic-bezier(.25, .46, .45, .94)
}

.cascade-card:hover .env-bg {
  transform: scale(1.05)
}

.env-content {
  z-index: 1;
  color: #fff;
  flex-direction: column;
  justify-content: center;
  height: 100%;
  padding: 4rem;
  display: flex;
  position: relative
}

.env-content h2 {
  color: #fff;
  text-shadow: 0 4px 20px #0000004d;
  letter-spacing: -.02em;
  margin-bottom: 1.5rem;
  font-size: 3.5rem;
  font-weight: 700
}

.env-separator {
  background-color: #fff;
  border-radius: 2px;
  width: 80px;
  height: 4px;
  margin-bottom: 2rem;
  box-shadow: 0 2px 10px #0003
}

.env-content p {
  color: #fffffff2;
  text-shadow: 0 2px 10px #0000004d;
  max-width: 800px;
  font-size: 1.25rem;
  font-weight: 400;
  line-height: 1.8
}

@media (max-width:768px) {
  .env-content {
    padding: 2rem
  }

  .env-content h2 {
    font-size: 2.5rem
  }
}

.slide-in-left {
  opacity: 0;
  transition: all .8s ease-out;
  transform: translate(-50px)
}

.slide-in-right {
  opacity: 0;
  transition: all .8s ease-out;
  transform: translate(50px)
}

.slide-in-left.visible,
.slide-in-right.visible {
  opacity: 1;
  transform: translate(0)
}

.slide-in-left[data-delay="0.2"],
.slide-in-right[data-delay="0.2"] {
  transition-delay: .2s
}

.slide-in-left[data-delay="0.4"],
.slide-in-right[data-delay="0.4"] {
  transition-delay: .4s
}

.csr-content-wrapper {
  width: 100%
}

.csr-header {
  justify-content: space-between;
  align-items: center;
  margin-bottom: 2rem;
  display: flex
}

.csr-nav-buttons {
  gap: 1rem;
  display: flex
}

.csr-nav-btn {
  cursor: pointer;
  color: #333;
  background: 0 0;
  border: 1px solid #333;
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  width: 40px;
  height: 40px;
  transition: all .3s;
  display: flex
}

.csr-nav-btn:hover {
  color: #fff;
  background-color: #333
}

.csr-carousel-content {
  flex-wrap: wrap;
  align-items: center;
  gap: 2rem;
  display: flex
}

.csr-image-container {
  border-radius: 12px;
  flex: 300px;
  height: 350px;
  overflow: hidden;
  box-shadow: 0 10px 30px #0000001a
}

.csr-image {
  object-fit: cover;
  width: 100%;
  height: 100%;
  transition: opacity .3s ease-in-out
}

.csr-text-container {
  flex: 300px
}

.csr-title {
  color: #333;
  margin-bottom: 1rem;
  font-size: 1.5rem
}

.csr-description {
  color: #555;
  margin-bottom: 1.5rem;
  font-size: 1rem;
  line-height: 1.6
}

.csr-dots {
  gap: .5rem;
  display: flex
}

.csr-dot {
  cursor: pointer;
  background-color: #ccc;
  border-radius: 4px;
  width: 8px;
  height: 8px;
  transition: all .3s
}

.csr-dot.active {
  background-color: #333;
  width: 20px
}

@media (max-width:1024px) {
  .sustainability-csr-section {
    padding: 3rem 1.5rem
  }

  .cascade-card {
    min-height: auto;
    padding: 2rem
  }

  .csr-image-container {
    height: 300px
  }
}

@media (max-width:768px) {
  .csr-carousel-content {
    flex-direction: column;
    gap: 1.5rem
  }

  .csr-image-container,
  .csr-text-container {
    flex: 100%;
    width: 100%
  }

  .csr-image-container {
    height: 250px
  }

  .csr-header h2 {
    font-size: 1.5rem
  }
}

.media-blog-split-section {
  background: #f8f9fa;
  flex-wrap: wrap;
  width: 100%;
  padding: 0;
  display: flex
}

.split-half {
  box-sizing: border-box;
  width: 50%;
  padding: 60px 40px
}

.split-half h3 {
  color: #333;
  margin-bottom: 30px;
  font-family: Playfair Display, serif;
  font-size: 2rem
}

.section-header {
  justify-content: space-between;
  align-items: center;
  margin-bottom: 30px;
  display: flex
}

.section-header h3 {
  margin-bottom: 0
}

.load-more-btn {
  cursor: pointer;
  text-transform: uppercase;
  letter-spacing: .5px;
  background: 0 0;
  border: 1px solid #333;
  border-radius: 24px;
  padding: 8px 20px;
  font-size: .85rem;
  font-weight: 500;
  transition: all .3s
}

.load-more-btn:hover {
  color: #fff;
  background: #333;
  transform: translateY(-2px);
  box-shadow: 0 5px 15px #0000001a
}

.load-more-btn:active {
  transform: translateY(0);
  box-shadow: 0 2px 5px #0000001a
}

.bento-grid {
  grid-template-columns: repeat(3, 1fr);
  grid-auto-rows: 140px;
  gap: 15px;
  display: grid
}

.bento-item {
  background: #fff;
  border-radius: 12px;
  flex-direction: column;
  justify-content: space-between;
  padding: 20px;
  transition: transform .3s, box-shadow .3s;
  animation: .6s cubic-bezier(.25, .46, .45, .94) backwards fadeInUp;
  display: flex;
  position: relative;
  overflow: hidden;
  box-shadow: 0 4px 15px #0000000d
}

.bento-item:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 25px #0000001a
}

.bento-item.large {
  grid-area: span 2/span 2
}

.bento-item.tall {
  grid-area: span 2/span 1
}

.bento-item.wide {
  grid-area: span 1/span 2
}

.bento-item.small {
  grid-area: span 1/span 1
}

.bento-tag {
  text-transform: uppercase;
  letter-spacing: 1px;
  color: #888;
  margin-bottom: 10px;
  font-size: .75rem;
  display: block
}

.bento-title {
  color: #222;
  font-size: 1.1rem;
  font-weight: 600;
  line-height: 1.3
}

.bento-item.large .bento-title {
  font-size: 1.5rem
}

.horizontal-masonry {
  flex-wrap: wrap;
  gap: 15px;
  display: flex
}

.masonry-item {
  cursor: pointer;
  border-radius: 12px;
  flex-grow: 1;
  min-width: 200px;
  height: 240px;
  position: relative;
  overflow: hidden
}

.masonry-item img {
  object-fit: cover;
  width: 100%;
  height: 100%;
  transition: transform .6s cubic-bezier(.25, .46, .45, .94), filter .3s
}

.masonry-item:hover img {
  filter: brightness(.8);
  transform: scale(1.1)
}

.blog-overlay {
  box-sizing: border-box;
  color: #fff;
  background: linear-gradient(#0000, #000c);
  width: 100%;
  padding: 20px;
  font-weight: 500;
  transition: transform .3s;
  position: absolute;
  bottom: 0;
  left: 0
}

.masonry-item:hover .blog-overlay {
  transform: translateY(-5px)
}

@keyframes fadeInUp {
  0% {
    opacity: 0;
    transform: translateY(30px)
  }

  to {
    opacity: 1;
    transform: translateY(0)
  }
}

@media (max-width:1024px) {
  .media-blog-split-section {
    flex-direction: column
  }

  .split-half {
    width: 100%;
    padding: 40px 24px
  }

  .split-half h3 {
    margin-bottom: 24px;
    font-size: 1.5rem
  }

  .bento-grid {
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    scrollbar-color: #0003 #f8f9fa;
    gap: 15px;
    padding-bottom: 10px;
    display: flex;
    overflow-x: auto
  }

  .bento-grid::-webkit-scrollbar {
    height: 6px
  }

  .bento-grid::-webkit-scrollbar-track {
    background: #f8f9fa
  }

  .bento-grid::-webkit-scrollbar-thumb {
    background: #0003;
    border-radius: 3px
  }

  .bento-grid::-webkit-scrollbar-thumb:hover {
    background: #0006
  }

  .bento-item {
    scroll-snap-align: start;
    flex: 0 0 calc(50% - 8px);
    min-width: 200px;
    max-width: 280px;
    height: auto;
    grid-area: auto !important
  }

  .bento-item.large,
  .bento-item.tall,
  .bento-item.wide {
    flex: 0 0 calc(50% - 8px)
  }

  .horizontal-masonry {
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    scrollbar-color: #0003 #f8f9fa;
    flex-wrap: nowrap;
    gap: 15px;
    padding-bottom: 10px;
    overflow-x: auto
  }

  .horizontal-masonry::-webkit-scrollbar {
    height: 6px
  }

  .horizontal-masonry::-webkit-scrollbar-track {
    background: #f8f9fa
  }

  .horizontal-masonry::-webkit-scrollbar-thumb {
    background: #0003;
    border-radius: 3px
  }

  .horizontal-masonry::-webkit-scrollbar-thumb:hover {
    background: #0006
  }

  .masonry-item {
    scroll-snap-align: start;
    min-width: 200px;
    max-width: 280px;
    height: 180px;
    flex: 0 0 calc(50% - 8px) !important
  }
}

@media (max-width:768px) {
  .media-blog-split-section {
    flex-direction: column;
    padding: 0
  }

  .split-half {
    width: 100%;
    padding: 32px 16px
  }

  .split-half h3 {
    margin-bottom: 20px;
    font-size: 1.3rem
  }

  .section-header {
    gap: 12px
  }

  .section-header h3 {
    font-size: 1.1rem
  }

  .load-more-btn {
    padding: 6px 16px;
    font-size: .75rem
  }

  .bento-grid {
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    scrollbar-color: #00000026 transparent;
    gap: 12px;
    padding-bottom: 8px;
    display: flex;
    overflow-x: auto
  }

  .bento-grid::-webkit-scrollbar {
    height: 4px
  }

  .bento-grid::-webkit-scrollbar-track {
    background: 0 0
  }

  .bento-grid::-webkit-scrollbar-thumb {
    background: #00000026;
    border-radius: 2px
  }

  .bento-grid::-webkit-scrollbar-thumb:hover {
    background: #00000040
  }

  .bento-item {
    scroll-snap-align: start;
    scroll-snap-stop: always;
    flex: 0 0 calc(100% - 12px);
    min-width: 280px;
    height: auto;
    padding: 16px;
    grid-area: auto !important
  }

  .bento-item.large,
  .bento-item.tall,
  .bento-item.wide {
    flex: 0 0 calc(100% - 12px)
  }

  .bento-tag {
    margin-bottom: 8px;
    font-size: .65rem
  }

  .bento-title {
    font-size: .95rem
  }

  .bento-item.large .bento-title {
    font-size: 1.1rem
  }

  .horizontal-masonry {
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    scrollbar-color: #00000026 transparent;
    flex-wrap: nowrap;
    gap: 12px;
    padding-bottom: 8px;
    overflow-x: auto
  }

  .horizontal-masonry::-webkit-scrollbar {
    height: 4px
  }

  .horizontal-masonry::-webkit-scrollbar-track {
    background: 0 0
  }

  .horizontal-masonry::-webkit-scrollbar-thumb {
    background: #00000026;
    border-radius: 2px
  }

  .horizontal-masonry::-webkit-scrollbar-thumb:hover {
    background: #00000040
  }

  .masonry-item {
    scroll-snap-align: start;
    scroll-snap-stop: always;
    min-width: 280px;
    height: 160px;
    flex: 0 0 calc(100% - 12px) !important
  }
}

@media (max-width:480px) {
  .split-half {
    padding: 24px 14px
  }

  .split-half h3 {
    margin-bottom: 18px;
    font-size: 1.15rem
  }

  .section-header h3 {
    font-size: 1rem
  }

  .load-more-btn {
    padding: 5px 12px;
    font-size: .7rem
  }

  .bento-item {
    flex: 0 0 85vw;
    min-width: auto;
    padding: 14px
  }

  .bento-item.large,
  .bento-item.tall,
  .bento-item.wide {
    flex: 0 0 85vw
  }

  .masonry-item {
    min-width: auto;
    height: 140px;
    flex: 0 0 85vw !important
  }
}

._pageContainer_1mrak_1 {
  background-color: #f8f9fa;
  min-height: 100vh;
  padding-top: 80px;
  font-family: Arial, sans-serif
}

._hero_1mrak_17 {
  color: #fff;
  text-align: center;
  background-color: #000;
  margin-bottom: 3rem;
  padding: 4rem 2rem
}

._hero_1mrak_17 h1 {
  color: #eab308;
  margin-bottom: 1rem;
  font-size: 3rem
}

._hero_1mrak_17 p {
  color: #ccc;
  max-width: 600px;
  margin: 0 auto;
  font-size: 1.2rem
}

._searchContainer_1mrak_61 {
  z-index: 10;
  background: #fff;
  border-radius: 8px;
  flex-wrap: wrap;
  gap: 1rem;
  max-width: 1000px;
  margin: -2.5rem auto 3rem;
  padding: 1.5rem;
  display: flex;
  position: relative;
  box-shadow: 0 10px 30px #0000001a
}

._searchInput_1mrak_89 {
  border: 1px solid #ddd;
  border-radius: 5px;
  flex: 2;
  padding: 12px 15px;
  font-size: 1rem
}

._searchSelect_1mrak_105 {
  background-color: #fff;
  border: 1px solid #ddd;
  border-radius: 5px;
  flex: 1;
  min-width: 150px;
  padding: 12px 15px;
  font-size: 1rem
}

._jobsContainer_1mrak_125 {
  max-width: 1000px;
  margin: 0 auto;
  padding: 0 1rem 4rem
}

._jobCard_1mrak_137 {
  background: #fff;
  border-radius: 10px;
  margin-bottom: 2rem;
  transition: transform .2s;
  overflow: hidden;
  box-shadow: 0 4px 15px #0000000d
}

._jobHeader_1mrak_155 {
  cursor: pointer;
  border-bottom: 1px solid #0000;
  justify-content: space-between;
  align-items: center;
  padding: 2rem;
  display: flex
}

._jobHeader_1mrak_155:hover {
  background-color: #fafafa
}

._jobTitle_1mrak_181 h2 {
  color: #333;
  margin: 0 0 .5rem;
  font-size: 1.5rem
}

._jobMeta_1mrak_193 {
  color: #666;
  gap: 15px;
  font-size: .9rem;
  display: flex
}

._jobMeta_1mrak_193 span {
  align-items: center;
  gap: 5px;
  display: flex
}

._expandIcon_1mrak_219 {
  color: #eab308;
  font-size: 1.5rem;
  transition: transform .3s
}

._expanded_1mrak_231 ._expandIcon_1mrak_219 {
  transform: rotate(180deg)
}

._expanded_1mrak_231 ._jobHeader_1mrak_155 {
  border-bottom: 1px solid #eee
}

._jobBody_1mrak_247 {
  padding: 0 2rem 2rem;
  animation: .3s ease-out _slideDown_1mrak_1
}

._description_1mrak_257 {
  color: #444;
  border-bottom: 1px solid #eee;
  margin-bottom: 2rem;
  padding: 2rem 0;
  line-height: 1.6
}

._description_1mrak_257 ul {
  margin-bottom: 1rem;
  padding-left: 1.5rem
}

._description_1mrak_257 p {
  margin-bottom: 1rem
}

._formSection_1mrak_293 {
  background-color: #fcfcfc;
  border: 1px solid #eee;
  border-radius: 8px;
  padding: 2rem
}

._formTitle_1mrak_307 {
  color: #333;
  border-left: 4px solid #eab308;
  margin-bottom: 1.5rem;
  padding-left: 10px;
  font-size: 1.2rem;
  font-weight: 700
}

._formGroup_1mrak_327 {
  margin-bottom: 1.2rem
}

._formGroup_1mrak_327 label {
  color: #555;
  margin-bottom: .5rem;
  font-weight: 500;
  display: block
}

._formGroup_1mrak_327 input,
._formGroup_1mrak_327 textarea {
  border: 1px solid #ddd;
  border-radius: 5px;
  width: 100%;
  padding: 12px;
  font-size: 1rem
}

._formGroup_1mrak_327 input:focus,
._formGroup_1mrak_327 textarea:focus {
  border-color: #eab308;
  outline: none
}

._fileInputWrapper_1mrak_379 {
  text-align: center;
  cursor: pointer;
  background-color: #fafafa;
  border: 2px dashed #ddd;
  border-radius: 5px;
  padding: 1.5rem;
  transition: border-color .3s;
  position: relative
}

._fileInputWrapper_1mrak_379:hover {
  background-color: #fff;
  border-color: #eab308
}

._dragging_1mrak_411 {
  background-color: #fffbeb;
  border-color: #eab308
}

._hiddenInput_1mrak_421 {
  display: none
}

._fileInputLabel_1mrak_429 {
  cursor: pointer;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  display: flex
}

._fileInputLabel_1mrak_429 i {
  color: #ccc;
  margin-bottom: .5rem;
  font-size: 2rem;
  transition: color .3s
}

._fileInputWrapper_1mrak_379:hover ._fileInputLabel_1mrak_429 i {
  color: #eab308
}

._submitBtn_1mrak_469 {
  color: #000;
  cursor: pointer;
  background-color: #eab308;
  border: none;
  border-radius: 5px;
  padding: 12px 30px;
  font-size: 1rem;
  font-weight: 700;
  transition: background-color .3s
}

._submitBtn_1mrak_469:hover {
  background-color: #d9a406
}

._submitBtn_1mrak_469:disabled {
  cursor: not-allowed;
  background-color: #ccc
}

._message_1mrak_511 {
  text-align: center;
  border-radius: 5px;
  margin-top: 1rem;
  padding: 1rem
}

._success_1mrak_525 {
  color: #155724;
  background-color: #d4edda
}

._error_1mrak_535 {
  color: #721c24;
  background-color: #f8d7da
}

._progressBarContainer_1mrak_545 {
  background-color: #e9ecef;
  border-radius: 5px;
  width: 100%;
  height: 20px;
  margin-top: 1rem;
  position: relative;
  overflow: hidden
}

._progressBar_1mrak_545 {
  background-color: #eab308;
  height: 100%;
  transition: width .3s
}

._progressText_1mrak_577 {
  color: #333;
  font-size: .75rem;
  font-weight: 700;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%)
}

._loadMoreContainer_1mrak_597 {
  text-align: center;
  margin-top: 2rem
}

._loadMoreBtn_1mrak_607 {
  color: #333;
  cursor: pointer;
  background-color: #0000;
  border: 1px solid #eab308;
  border-radius: 5px;
  padding: 10px 30px;
  font-size: 1rem;
  transition: all .3s
}

._loadMoreBtn_1mrak_607:hover {
  color: #fff;
  background-color: #eab308
}

._errorText_1mrak_639 {
  color: #dc3545;
  margin-top: .25rem;
  font-size: .85rem;
  display: block
}

@keyframes _slideDown_1mrak_1 {
  0% {
    opacity: 0;
    transform: translateY(-10px)
  }

  to {
    opacity: 1;
    transform: translateY(0)
  }
}

@media (max-width:768px) {
  ._jobHeader_1mrak_155 {
    flex-direction: column;
    align-items: flex-start;
    gap: 1rem
  }

  ._expandIcon_1mrak_219 {
    position: absolute;
    top: 2.5rem;
    right: 2rem
  }

  ._jobMeta_1mrak_193 {
    flex-wrap: wrap
  }

  ._searchContainer_1mrak_61 {
    flex-direction: column;
    margin-top: 0;
    margin-bottom: 2rem
  }

  ._searchInput_1mrak_89,
  ._searchSelect_1mrak_105 {
    width: 100%
  }
}