html, body {
  height: 100%;
}
* {
  -moz-box-sizing: border-box;
}
body {
  background-color: #ededed;
  color: #424242;
  margin: 0;
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 14px;
  line-height: 1.428571429;
}
h1, h2, h3, h4, h5, h6, .h1, .h2, .h3, .h4, .h5, .h6 {
  font-family: "HelveticaNeue-Light", "Helvetica Neue Light", "Helvetica Neue", Helvetica, Arial, "Lucida Grande", sans-serif;
  font-weight: normal;
  line-height: 1.1;
  color: #333
}
h1 small, h2 small, h3 small, h4 small, h5 small, h6 small, .h1 small, .h2 small, .h3 small, .h4 small, .h5 small, .h6 small {
  font-weight: normal;
  line-height: 1
}
h1, .h1 {
  font-size: 45px;
  line-height: 48px
}
h2, .h2 {
  font-size: 36px;
  line-height: 42px
}
h3, .h3 {
  font-size: 28px;
  line-height: 36px
}
h4, .h4 {
  font-size: 24px;
  line-height: 25px
}
h5, .h5 {
  font-size: 20px;
  line-height: 24px
}
h6, .h6 {
  font-size: 18px;
  line-height: 24px
}
a {
  color: #3282e6;
}
a:hover, a:focus {
  color: #165db5;
  text-decoration: underline
}
.text-center {
  text-align: center
}
.logo {
  display: flex;
  align-items: center;
  gap: 0;
}
.logo-img {
  height: 44px; /* adjust to suit */
  width: auto;
  display: block;
}
/* Optional: slightly smaller on mobile */
@media (max-width: 768px) {
  .logo-img {
    height: 38px;
  }
}
.quicksand-<uniquifier > {
  font-family: "Quicksand", sans-serif;
  font-optical-sizing: auto;
  font-weight: <weight>;
  font-style: normal;
}
.montserrat-<uniquifier > {
  font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
  font-weight: <weight>;
  font-style: normal;
}
.lora-<uniquifier > {
  font-family: "Lora", serif;
  font-optical-sizing: auto;
  font-weight: <weight>;
  font-style: normal;
}
.wrap {
  min-height: 100%;
  .display: table;
  .height: 100%;
}
.top-bar {
  height: 20px;
  background: #71a100;
  background: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiA/Pgo8c3ZnIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgd2lkdGg9IjEwMCUiIGhlaWdodD0iMTAwJSIgdmlld0JveD0iMCAwIDEgMSIgcHJlc2VydmVBc3BlY3RSYXRpbz0ibm9uZSI+CiAgPGxpbmVhckdyYWRpZW50IGlkPSJncmFkLXVjZ2ctZ2VuZXJhdGVkIiBncmFkaWVudFVuaXRzPSJ1c2VyU3BhY2VPblVzZSIgeDE9IjAlIiB5MT0iMCUiIHgyPSIwJSIgeTI9IjEwMCUiPgogICAgPHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iIzcxYTEwMCIgc3RvcC1vcGFjaXR5PSIxIi8+CiAgICA8c3RvcCBvZmZzZXQ9IjEwMCUiIHN0b3AtY29sb3I9IiM2ZmExMDAiIHN0b3Atb3BhY2l0eT0iMSIvPgogIDwvbGluZWFyR3JhZGllbnQ+CiAgPHJlY3QgeD0iMCIgeT0iMCIgd2lkdGg9IjEiIGhlaWdodD0iMSIgZmlsbD0idXJsKCNncmFkLXVjZ2ctZ2VuZXJhdGVkKSIgLz4KPC9zdmc+);
  background: -moz-linear-gradient(top, #71a100 0%, #6fa100 100%);
  background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #71a100), color-stop(100%, #6fa100));
  background: -webkit-linear-gradient(top, #71a100 0%, #6fa100 100%);
  background: -o-linear-gradient(top, #71a100 0%, #6fa100 100%);
  background: -ms-linear-gradient(top, #71a100 0%, #6fa100 100%);
  background: linear-gradient(to bottom, #71a100 0%, #6fa100 100%);
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#71a100', endColorstr='#6fa100', GradientType=0);
}
:root .top-bar {
  filter: none \0/IE9;
}
.welcome-container {
  width: 500px;
  margin: 0 auto;
  overflow: auto;
  padding-bottom: 60px;
}
.coming-soon-wrap {
  margin-top: 90px;
}
.frowny-face {
  text-align: center;
  font-size: 130px;
  color: #919191;
  line-height: 1.1;
  margin-top: 90px;
  margin-bottom: 70px;
}
.welcome-container h1 {
  margin-bottom: 1em;
}
.btn-primary {
  background-color: #7FB141;
  border-color: #648C33;
  color: #FFFFFF;
}
input, button, select, textarea {
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
}
button, html input[type="button"], input[type="reset"], input[type="submit"] {
  cursor: pointer;
}
button, select {
  text-transform: none;
}
button, input {
  line-height: normal;
}
button, input, select, textarea {
  font-family: inherit;
  font-size: 100%;
  margin: 0;
}
.btn {
  -moz-border-bottom-colors: none;
  -moz-border-left-colors: none;
  -moz-border-right-colors: none;
  -moz-border-top-colors: none;
  border-color: transparent;
  border-image: none;
  border-radius: 0 0 0 0;
  border-style: solid;
  border-width: 0 0 3px;
  cursor: pointer;
  display: inline-block;
  font-size: 14px;
  font-weight: 300;
  line-height: 1.42857;
  margin-bottom: 0;
  padding: 8px 20px;
  text-align: center;
  vertical-align: middle;
  white-space: nowrap;
  text-decoration: none;
}
.btn-primary {
  background-color: #7FB141;
  border-color: #648C33;
  color: #FFFFFF;
}
.btn-primary:hover, .btn-primary:focus, .btn-primary:active, .btn-primary.active {
  background-color: #729E3A;
  border-color: #496626;
  color: #fff;
}
.btn:hover, .btn:focus {
  text-decoration: none;
}
.login-container {
  text-align: right;
  margin: 20px;
}
.footer {
  position: relative;
  margin-top: -60px; /* negative value of footer height */
  height: 60px;
  clear: both;
  text-align: center;
  font-size: 14px;
}
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box
}
:root {
  --green: #4a7c3f;
  --green-dark: #3a6331;
  --green-light: #6ea55e;
  --lime: #8cbc3d;
  --cream: #f9f7f2;
  --cream-dark: #f0ece3;
  --brown: #3d3529;
  --brown-light: #5a4f40;
  --gray: #6b7280;
  --gray-light: #9ca3af;
  --white: #ffffff;
  --shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
  --shadow-lg: 0 10px 40px rgba(0, 0, 0, 0.12);
  --radius: 10px;
  --transition: all .3s cubic-bezier(.4, 0, .2, 1)
}
html {
  scroll-behavior: smooth
}
body {
  font-family: 'Montserrat', sans-serif;
  color: var(--brown);
  line-height: 1.7;
  overflow-x: hidden;
  background: var(--white)
}
h1, h2, h3, h4 {
  font-family: 'Montserrat', sans-serif;
  line-height: 1.3
}
a {
  text-decoration: none;
  color: inherit
}
img {
  max-width: 100%;
  display: block
}
button {
  cursor: pointer;
  border: none;
  font-family: inherit
}
.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 2rem
}
/* HEADER */
header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  padding: 1rem 0;
  transition: var(--transition);
  background: transparent
}
header.scrolled {
  background: rgba(74, 124, 63, .97);
  backdrop-filter: blur(10px);
  box-shadow: 0 2px 20px rgba(0, 0, 0, .15);
  padding: .7rem 0
}
.nav-inner {
  display: flex;
  justify-content: space-between;
  align-items: center
}
.logo {
  display: flex;
  align-items: center;
  gap: .6rem;
  color: white;
  font-family: 'Montserrat', sans-serif;
  font-size: 1.6rem;
  font-weight: 700;
  letter-spacing: -.5px
}
.logo-leaf {
  font-size: 1.4rem
}
.logo small {
  font-family: 'Montserrat', sans-serif;
  font-size: .6rem;
  font-weight: 400;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  display: block;
  opacity: .8;
  margin-top: -4px
}
.nav-links {
  display: flex;
  list-style: none;
  gap: 2rem;
  align-items: center
}
.nav-links a {
  color: white;
  font-size: .95rem;
  font-weight: 500;
  position: relative;
  padding: 4px 0;
  transition: var(--transition)
}

.nav-links a:hover {
    text-decoration: none;
}

.nav-links a:not(.nav-cta):after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0;
  height: 2px;
  background: var(--lime);
  transition: var(--transition)
}
.nav-links a:not(.nav-cta):hover:after {
  width: 100%
}
.nav-cta {
  background: var(--white);
  color: var(--green) !important;
  padding: .65rem 1.4rem !important;
  border-radius: .2rem;
  font-weight: 600;
  transition: var(--transition)
}
.nav-cta:hover {
  background: var(--lime);
  color: white !important;
  transform: translateY(-2px);
  box-shadow: 0 4px 15px rgba(0, 0, 0, .2)
}
.hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none;
  padding: 5px
}
.hamburger span {
  display: block;
  width: 24px;
  height: 2.5px;
  background: white;
  border-radius: 2px;
  transition: var(--transition)
}
/* 	HERO */
.hero {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: white;
  position: relative;
  overflow: hidden;
  padding: 120px 2rem 80px
}
.hero-bg {
  position: absolute;
  inset: 0;

  /* 1) Photo */
  background-image: url("assets/hero/hero-02.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;

  /* 2) Optional subtle “premium” scale */
  transform: scale(1.03);

  z-index: 1;
}

/* 3) Green overlay ON TOP of the image (keeps text readable) */
.hero-bg::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    135deg,
    rgba(35, 60, 28, 0.85) 0%,
    rgba(45, 75, 38, 0.80) 40%,
    rgba(55, 90, 45, 0.75) 100%
  );
}

.hero-pattern {
  position: absolute;
  inset: 0;
  opacity: .04;
  z-index: 2
}
.hero-content {
  position: relative;
  z-index: 3;
  max-width: 780px;
  animation: fadeUp .8s ease
}
.hero-badge {
  display: inline-block;
  background: rgba(255, 255, 255, .15);
  backdrop-filter: blur(5px);
  padding: .5rem 1.2rem;
  border-radius: 30px;
  font-size: .8rem;
  letter-spacing: 2px;
  text-transform: uppercase;
  margin-bottom: 1.5rem;
  border: 1px solid rgba(255, 255, 255, .2)
}
.hero-badge {
  background: rgba(255, 255, 255, 0.2);
  border: 1px solid rgba(255, 255, 255, 0.35);
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
}
.hero h1 {
  font-size: 3.8rem;
  font-weight: 700;
  margin-bottom: 1.5rem;
  line-height: 1.15
}
.hero h1 {
  color: #ffffff;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.35), 0 1px 3px rgba(0, 0, 0, 0.25);
}
.hero h1 span {
  color: var(--lime)
}
.hero h1 span {
  color: #b8e04e;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.4), 0 1px 3px rgba(0, 0, 0, 0.3);
}

.hero > div > p {
  font-size: 1.15rem;
  opacity: .92;
  margin-bottom: 2.5rem;
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.8
}
.hero > div > p {
  opacity: 0.95;
  text-shadow: 0 1px 4px rgba(0, 0, 0, 0.3);
}
.hero-btns {
  display: flex;
  gap: 1.2rem;
  justify-content: center;
  flex-wrap: wrap
}
.btn {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: 1rem 2rem;
  border-radius: var(--radius);
  font-weight: 600;
  font-size: 1rem;
  transition: var(--transition)
}
.btn-white {
  background: var(--white);
  color: var(--green);
  box-shadow: 0 8px 25px rgba(0, 0, 0, .15)
}
.btn-white:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 35px rgba(0, 0, 0, .2);
  background: var(--lime);
  color: white
}
.btn-outline {
  border: 2px solid white;
  color: white;
  background: transparent
}
.btn-outline:hover {
  background: white;
  color: var(--green)
}
.btn-green {
  background: var(--green);
  color: white
}
.btn-green:hover {
  background: var(--green-dark);
  transform: translateY(-2px);
  box-shadow: var(--shadow-lg)
}
.btn-lime {
  background: var(--lime);
  color: white
}
.btn-lime:hover {
  background: var(--green);
  transform: translateY(-2px);
  box-shadow: var(--shadow-lg)
}
.scroll-hint {
  position: absolute;
  bottom: 2rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: 3;
  color: white;
  opacity: .7;
  animation: bounce 2s infinite;
  font-size: .85rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .5rem
}
@keyframes bounce {
  0%, 100% {
    transform: translate(-50%, 0)
  }
  50% {
    transform: translate(-50%, -10px)
  }
}
/* STATS BAR */
.stats-bar {
  position: relative;
  z-index: 10;
  margin-top: -60px;
  padding: 0 2rem
}
.stats-inner {
  background: var(--white);
  border-radius: var(--radius);
  box-shadow: var(--shadow-lg);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  overflow: hidden
}
.stat {
  text-align: center;
  padding: 2.5rem 1.5rem;
  border-right: 1px solid var(--cream-dark);
  transition: var(--transition)
}
.stat:last-child {
  border-right: none
}
.stat:hover {
  background: var(--cream)
}
.stat-num {
  font-family: "Quicksand", sans-serif;
  font-size: 2.8rem;
  font-weight: 700;
  color: var(--green);
  margin-bottom: .3rem
}
.stat-label {
  font-size: 1rem;
  font-weight: 600;
  color: var(--brown);
  margin-bottom: .3rem
}
.stat-desc {
  font-size: .85rem;
  color: var(--gray)
}
/* SECTION COMMON */
.section {
  padding: 6rem 0
}
.section-header {
  text-align: center;
  margin-bottom: 3.5rem
}
.section-tag {
  display: inline-block;
  color: var(--green);
  font-size: .8rem;
  font-weight: 600;
  letter-spacing: 2px;
  text-transform: uppercase;
  margin-bottom: .5rem
}
.section-title {
  font-size: 2.6rem;
  color: var(--brown);
  margin-bottom: 1rem
}
.section-desc {
  color: var(--gray);
  font-size: 1.1rem;
  max-width: 600px;
  margin: 0 auto
}
.bg-cream {
  background: var(--cream)
}
.bg-green {
  background: var(--green);
  color: white
}
.bg-green .section-tag {
  color: var(--lime)
}
.bg-green .section-title {
  color: white
}
.bg-green .section-desc {
  color: rgba(255, 255, 255, .8)
}
/* SERVICES */
.services-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem
}
.svc-card {
  background: var(--white);
  border: 1px solid #e8e5de;
  border-radius: var(--radius);
  padding: 2.2rem;
  transition: var(--transition);
  position: relative;
  overflow: hidden
}
.svc-card:before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--lime);
  transform: scaleX(0);
  transition: var(--transition);
  transform-origin: left
}
.svc-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-lg);
  border-color: var(--lime)
}
.svc-card:hover:before {
  transform: scaleX(1)
}
.svc-icon {
  width: 56px;
  height: 56px;
  background: linear-gradient(135deg, var(--cream) 0%, var(--cream-dark) 100%);
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.6rem;
  margin-bottom: 1.2rem
}
.svc-card h3 {
  font-size: 1.25rem;
  margin-bottom: .8rem;
  color: var(--brown)
}
.svc-card > p {
  color: var(--gray);
  font-size: .95rem;
  margin-bottom: 1.2rem
}
.svc-features {
  list-style: none;
  margin-bottom: 1.2rem
}
.svc-features li {
  color: var(--gray);
  font-size: .88rem;
  padding: .3rem 0;
  display: flex;
  align-items: center;
  gap: .5rem
}
.svc-features li:before {
  content: '✓';
  color: var(--lime);
  font-weight: 700;
  font-size: .9rem
}
.svc-link {
  color: var(--green);
  font-weight: 600;
  font-size: .9rem;
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  transition: var(--transition)
}
.svc-link:hover {
  color: var(--lime);
  gap: .6rem
}
/* ABOUT */
.about-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: center
}
.about-images {
  position: relative
}
.about-img-main {
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  height: 450px;

  /* ✅ Real Garden Image */
  background-image: url("assets/about/about-garden.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;

  /* Optional premium overlay */
  position: relative;
}
.about-img-float {
  position: absolute;
  bottom: -20px;
  right: -20px;
  width: 180px;
  height: 180px;
  border-radius: var(--radius);
  background: var(--lime);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: white;
  font-size: .9rem;
  text-align: center;
  box-shadow: var(--shadow-lg);
  padding: 1rem
}
.about-img-float strong {
  font-family: "Quicksand", sans-serif;
  ;
  font-size: 2.5rem;
  display: block;
  margin-bottom: .3rem
}
.about-content .section-tag {
  text-align: left
}
.about-content .section-title {
  text-align: left;
  font-size: 2.2rem
}
.about-content > p {
  color: var(--gray);
  margin-bottom: 1.5rem;
  font-size: 1rem
}
.about-features {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin: 2rem 0
}
.about-feat {
  display: flex;
  align-items: flex-start;
  gap: .7rem
}
.about-feat-icon {
  width: 36px;
  height: 36px;
  min-width: 36px;
  background: var(--cream);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  color: var(--green)
}
.about-feat h4 {
  font-family: "Montserrat", sans-serif;
  font-size: .95rem;
  font-weight: 600;
  margin-bottom: .2rem
}
.about-feat p {
  font-size: .82rem;
  color: var(--gray)
}
/* PROCESS */
.process-steps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2rem;
  position: relative
}
.process-steps:before {
  content: '';
  position: absolute;
  top: 35px;
  left: 10%;
  right: 10%;
  height: 2px;
  background: rgba(255, 255, 255, .2)
}
.step-card {
  text-align: center;
  position: relative;
  z-index: 1
}
.step-num {
  width: 70px;
  height: 70px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .15);
  border: 2px solid rgba(255, 255, 255, .3);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1.2rem;
  font-family: "Quicksand", sans-serif;
  font-size: 1.8rem;
  font-weight: 700;
  transition: var(--transition)
}
.step-card:hover .step-num {
  background: var(--lime);
  border-color: var(--lime);
  transform: scale(1.1)
}
.step-card h3 {
  font-size: 1.15rem;
  margin-bottom: .6rem
}
.step-card p {
  font-size: .9rem;
  opacity: .8;
  max-width: 220px;
  margin: 0 auto
}
/* PORTFOLIO */
.portfolio-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem
}
.proj-card {
  border-radius: var(--radius);
  overflow: hidden;
  background: white;
  box-shadow: var(--shadow);
  transition: var(--transition)
}
.proj-card:hover {
  transform: translateY(-8px);
  box-shadow: var(--shadow-lg)
}
.proj-img {
  height: 260px;
  position: relative;
  overflow: hidden
}
.proj-img-inner {
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  transition: transform .5s ease
}

.urban-oasis-cover {
  background-image: url("assets/projects/urban-oasis/cover.jpg");
}
.modern-haven-cover {
  background-image: url("assets/projects/modern-haven/cover-2.jpg");
}
.gleb-farm-cover {
  background-image: url("assets/projects/eagles-farm1/cover.png");
}
.willow-rise-cover {
  background-image: url("assets/projects/willow-rise/cover.jpg");	
}
.contemporary-cover {
  background-image: url("assets/projects/contemporary/cover.png");
}
.family-garden-cover{
  background-image: url("assets/projects/eagles-farm/cover.jpg");
}


.proj-card:hover .proj-img-inner {
  transform: scale(1.05)
}
.proj-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0, 0, 0, .6) 0%, transparent 60%);
  display: flex;
  align-items: flex-end;
  padding: 1.2rem
}
.proj-overlay .proj-loc {
  color: white;
  font-size: .8rem;
  display: flex;
  align-items: center;
  gap: .3rem;
  opacity: .9
}
.proj-body {
  padding: 1.5rem
}
.proj-body h3 {
  font-size: 1.2rem;
  margin-bottom: .5rem
}
.proj-body > p {
  color: var(--gray);
  font-size: .9rem;
  margin-bottom: 1rem;
  line-height: 1.6
}
.proj-tags {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
  margin-bottom: 1rem
}
.proj-tag {
  background: var(--cream);
  color: var(--green);
  font-size: .75rem;
  padding: .3rem .7rem;
  border-radius: 20px;
  font-weight: 500
}
.proj-link {
  color: var(--green);
  font-weight: 600;
  font-size: .9rem;
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  transition: var(--transition)
}
.proj-link:hover {
  color: var(--lime);
  gap: .6rem
}
/* TESTIMONIALS */
.test-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem
}
.test-card {
  background: var(--white);
  padding: 2rem;
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  border-left: 4px solid var(--lime);
  transition: var(--transition)
}
.test-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg)
}
.test-stars {
  color: #f59e0b;
  margin-bottom: 1rem;
  font-size: 1rem;
  letter-spacing: 2px
}
.test-text {
  color: var(--gray);
  font-style: italic;
  margin-bottom: 1.5rem;
  line-height: 1.8;
  font-size: .95rem
}
.test-author {
  display: flex;
  align-items: center;
  gap: .8rem
}
.test-avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--green);
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  font-size: .9rem
}
.test-name {
  font-weight: 600;
  color: var(--brown);
  font-size: .95rem
}
.test-role {
  color: var(--gray);
  font-size: .82rem
}
/* FAQ */
.faq-wrap {
  max-width: 720px;
  margin: 0 auto
}
.faq-item {
  background: var(--white);
  border: 1px solid #e8e5de;
  border-radius: var(--radius);
  margin-bottom: .8rem;
  overflow: hidden;
  transition: var(--transition)
}
.faq-item:hover {
  border-color: var(--lime)
}
.faq-q {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.3rem 1.5rem;
  cursor: pointer;
  font-weight: 600;
  font-size: 1.05rem;
  color: var(--brown);
  transition: var(--transition)
}
.faq-q:hover {
  color: var(--green)
}
.faq-icon {
  font-size: 1.3rem;
  transition: transform .3s ease;
  color: var(--green);
  min-width: 24px;
  text-align: center
}
.faq-item.open .faq-icon {
  transform: rotate(45deg)
}
.faq-a {
  padding: 0 1.5rem;
  max-height: 0;
  overflow: hidden;
  transition: max-height .3s ease, padding .3s ease
}
.faq-item.open .faq-a {
  max-height: 300px;
  padding: 0 1.5rem 1.3rem
}
.faq-a p {
  color: var(--gray);
  font-size: .95rem;
  line-height: 1.8
}
/* PRICING */
.pricing-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
  align-items: start
}
.price-card {
  background: var(--white);
  border: 2px solid #e8e5de;
  border-radius: var(--radius);
  padding: 2.5rem;
  text-align: center;
  transition: var(--transition);
  position: relative
}
.price-card.popular {
  border-color: var(--lime);
  transform: scale(1.04);
  box-shadow: var(--shadow-lg)
}
.price-badge {
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--lime);
  color: white;
  font-size: .75rem;
  font-weight: 600;
  padding: .3rem 1rem;
  border-radius: 20px;
  letter-spacing: 1px;
  text-transform: uppercase
}
.price-card:hover {
  box-shadow: var(--shadow-lg);
  transform: translateY(-4px)
}
.price-card.popular:hover {
  transform: scale(1.04) translateY(-4px)
}
.price-name {
  font-family: "Quicksand", sans-serif;
  font-size: 1.4rem;
  margin-bottom: .5rem
}
.price-desc {
  color: var(--gray);
  font-size: .9rem;
  margin-bottom: 1.5rem
}
.price-range {
  font-family: "Quicksand", sans-serif;
  font-size: 2rem;
  color: var(--green);
  font-weight: 700;
  margin-bottom: 1.5rem
}
.price-range small {
  font-size: .9rem;
  font-weight: 400;
  color: var(--gray)
}
.price-features {
  list-style: none;
  text-align: left;
  margin-bottom: 2rem
}
.price-features li {
  padding: .55rem 0;
  border-bottom: 1px solid var(--cream-dark);
  color: var(--gray);
  font-size: .9rem;
  display: flex;
  align-items: center;
  gap: .5rem
}
.price-features li:before {
  content: '✓';
  color: var(--lime);
  font-weight: 700
}
/* TEAM */
.team-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2rem;
  max-width: 600px;
  margin: 0 auto
}
.team-card {
  text-align: center;
  padding: 2rem;
  background: var(--white);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  transition: var(--transition)
}
.team-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-lg)
}
.team-avatar {
  width: 120px;
  height: 120px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--green), var(--lime));
  margin: 0 auto 1.2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  font-size: 2.5rem;
  box-shadow: 0 4px 15px rgba(74, 124, 63, .3)
}
.team-card h3 {
  font-size: 1.2rem;
  margin-bottom: .2rem
}
.team-card .role {
  color: var(--green);
  font-size: .9rem;
  font-weight: 500;
  margin-bottom: .8rem
}
.team-card > p {
  color: var(--gray);
  font-size: .88rem
}
/* CONTACT */
.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: start
}
.contact-info h2 {
  color: white;
  font-size: 2.2rem;
  margin-bottom: 1rem
}
.contact-info > p {
  color: rgba(255, 255, 255, .8);
  margin-bottom: 2rem;
  font-size: 1rem;
  line-height: 1.8
}
.contact-list {
  list-style: none;
  margin-bottom: 2rem
}
.contact-list li {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin: 1rem 0;
  color: rgba(255, 255, 255, .9);
  font-size: .95rem
}
.contact-list .cl-icon {
  width: 40px;
  height: 40px;
  min-width: 40px;
  background: rgba(140, 188, 61, .2);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem
}
.contact-form {
  background: rgba(255, 255, 255, .07);
  border: 1px solid rgba(255, 255, 255, .1);
  border-radius: var(--radius);
  padding: 2.5rem;
  backdrop-filter: blur(5px)
}
.contact-form h3 {
  color: white;
  font-size: 1.4rem;
  margin-bottom: .5rem
}
.contact-form > p {
  color: rgba(255, 255, 255, .7);
  font-size: .9rem;
  margin-bottom: 1.5rem
}
.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem
}
.form-group {
  margin-bottom: 1.2rem
}
.form-group label {
  display: block;
  color: rgba(255, 255, 255, .9);
  font-size: .88rem;
  font-weight: 500;
  margin-bottom: .4rem
}
.form-group input, .form-group textarea, .form-group select {
  width: 100%;
  padding: .8rem 1rem;
  border: 1px solid rgba(255, 255, 255, .15);
  border-radius: 8px;
  background: rgba(255, 255, 255, .08);
  color: white;
  font-family: inherit;
  font-size: .95rem;
  transition: var(--transition)
}
.form-group input::placeholder, .form-group textarea::placeholder {
  color: rgba(255, 255, 255, .4)
}
.form-group input:focus, .form-group textarea:focus, .form-group select:focus {
  outline: none;
  border-color: var(--lime);
  background: rgba(255, 255, 255, .12);
  box-shadow: 0 0 0 3px rgba(140, 188, 61, .2)
}
.form-group textarea {
  resize: vertical;
  min-height: 100px
}
.form-group select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='white' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 1rem center
}
.form-group select option {
  color: var(--brown);
  background: white
}
.form-submit {
  width: 100%;
  padding: 1rem;
  background: var(--lime);
  color: white;
  border: none;
  border-radius: 8px;
  font-size: 1rem;
  font-weight: 600;
  transition: var(--transition);
  font-family: inherit
}
.form-submit:hover {
  background: var(--green-light);
  transform: translateY(-2px);
  box-shadow: 0 8px 25px rgba(0, 0, 0, .2)
}
/* AREA */
.area-tags {
  display: flex;
  flex-wrap: wrap;
  gap: .6rem;
  justify-content: center;
  margin-top: 2rem
}
.area-tag {
  background: var(--cream);
  color: var(--green);
  padding: .5rem 1.2rem;
  border-radius: 30px;
  font-size: .88rem;
  font-weight: 500;
  transition: var(--transition)
}
.area-tag:hover {
  background: var(--green);
  color: white
}
/* FOOTER */
footer {
  background: #2d2820;
  color: var(--gray-light);
  padding: 4rem 0 0
}
.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 2.5rem;
  margin-bottom: 3rem
}
.footer-brand .logo {
  color: white;
  margin-bottom: 1rem
}
.footer-brand > p {
  font-size: .9rem;
  line-height: 1.7;
  margin-bottom: 1.5rem
}
.footer-col h4 {
  color: white;
  font-family: "Montserrat", sans-serif;
  font-size: 1rem;
  font-weight: 600;
  margin-bottom: 1rem
}
.footer-col a {
  display: block;
  margin: .5rem 0;
  font-size: .9rem;
  transition: var(--transition)
}
.footer-col a:hover {
  color: var(--lime);
  padding-left: 4px
}
.social-row {
  display: flex;
  gap: .6rem
}
.social-row a {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: rgba(140, 188, 61, .15);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--lime);
  font-size: .9rem;
  transition: var(--transition)
}
.social-row a:hover {
  background: var(--lime);
  color: white;
  transform: translateY(-3px)
}
.footer-bottom {
  border-top: 1px solid rgba(255, 255, 255, .08);
  padding: 1.5rem 0;
  text-align: center;
  font-size: .85rem
}
/* BACK TO TOP */
.btt {
  position: fixed;
  bottom: 2rem;
  right: 2rem;
  width: 46px;
  height: 46px;
  border-radius: 50%;
  background: var(--green);
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  box-shadow: var(--shadow-lg);
  z-index: 999;
  opacity: 0;
  pointer-events: none;
  transition: var(--transition)
}
.btt.visible {
  opacity: 1;
  pointer-events: auto
}
.btt:hover {
  background: var(--lime);
  transform: translateY(-3px)
}
/* RESPONSIVE */
@media(max-width:1024px) {
  .services-grid, .portfolio-grid, .test-grid, .pricing-grid {
    grid-template-columns: repeat(2, 1fr)
  }
  .process-steps {
    grid-template-columns: repeat(2, 1fr)
  }
  .process-steps:before {
    display: none
  }
  .footer-grid {
    grid-template-columns: repeat(2, 1fr)
  }
}
@media(max-width:768px) {
  .nav-links {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: rgba(74, 124, 63, .98);
    flex-direction: column;
    padding: 1.5rem;
    gap: 1rem;
    box-shadow: 0 10px 30px rgba(0, 0, 0, .2)
  }
  .nav-links.open {
    display: flex
  }
  .hamburger {
    display: flex
  }
  .hero h1 {
    font-size: 2.2rem
  }
  .hero > div > p {
    font-size: 1rem
  }
  .stats-inner {
    grid-template-columns: repeat(2, 1fr)
  }
  .stat {
    border-bottom: 1px solid var(--cream-dark)
  }
  .services-grid, .portfolio-grid, .test-grid, .pricing-grid {
    grid-template-columns: 1fr
  }
  .about-grid, .contact-grid {
    grid-template-columns: 1fr;
    gap: 2rem
  }
  .about-images {
    order: 2
  }
  .about-img-float {
    position: relative;
    bottom: auto;
    right: auto;
    margin-top: 1rem
  }
  .process-steps {
    grid-template-columns: 1fr 1fr
  }
  .section-title {
    font-size: 2rem
  }
  .price-card.popular {
    transform: none
  }
  .price-card.popular:hover {
    transform: translateY(-4px)
  }
  .form-row {
    grid-template-columns: 1fr
  }
  .footer-grid {
    grid-template-columns: 1fr
  }
  .team-grid {
    grid-template-columns: 1fr
  }
  .hero-btns {
    flex-direction: column;
    align-items: center
  }
  .btn {
    width: 100%;
    max-width: 300px;
    justify-content: center
  }
}
@media(max-width:480px) {
  .hero h1 {
    font-size: 1.7rem
  }
  .stats-inner {
    grid-template-columns: 1fr
  }
  .stat-num {
    font-size: 2.2rem
  }
  .section-title {
    font-size: 1.6rem
  }
  .container {
    padding: 0 1rem
  }
  .section {
    padding: 3.5rem 0
  }
}
@keyframes fadeUp {
  from {
    opacity: 0;
    transform: translateY(25px)
  }
  to {
    opacity: 1;
    transform: translateY(0)
  }
}
/* ==================== PROJECT DETAIL MODAL ==================== */
.project-modal {
  position: fixed;
  inset: 0;
  z-index: 2000;
  opacity: 0;
  pointer-events: none;
  transition: opacity .4s ease
}
.project-modal.open {
  opacity: 1;
  pointer-events: auto
}
.project-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, .65);
  backdrop-filter: blur(4px)
}
.project-modal-container {
  position: absolute;
  inset: 0;
  overflow-y: auto;
  overflow-x: hidden
}
.project-modal-content {
  background: var(--white);
  min-height: 100vh;
  position: relative;
  animation: pmSlideUp .5s ease
}
.project-modal.open .project-modal-content {
  animation: pmSlideUp .5s ease forwards
}
@keyframes pmSlideUp {
  from {
    opacity: 0;
    transform: translateY(40px)
  }
  to {
    opacity: 1;
    transform: translateY(0)
  }
}
/* Close Button */
.pm-close {
  position: fixed;
  top: 1.5rem;
  right: 2rem;
  z-index: 2010;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background: rgba(0, 0, 0, .6);
  backdrop-filter: blur(10px);
  color: white;
  border: none;
  font-size: 1.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: var(--transition)
}
.pm-close:hover {
  background: var(--green);
  transform: scale(1.1)
}
/* Back Link */
.pm-back {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  color: var(--green);
  font-weight: 600;
  font-size: .95rem;
  padding: 1.5rem 0;
  cursor: pointer;
  transition: var(--transition);
  border: none;
  background: none;
  font-family: inherit
}
.pm-back:hover {
  color: var(--lime);
  gap: .8rem
}
/* Hero Gallery */
.pm-hero {
  position: relative;
  height: 70vh;
  min-height: 450px;
  max-height: 650px;
  overflow: hidden
}
.pm-hero-slides {
  display: flex;
  height: 100%;
  transition: transform .5s ease
}
.pm-hero-slide {
  min-width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  position: relative
}
.pm-hero-slide::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0, 0, 0, .5) 0%, transparent 50%)
}
.pm-hero-info {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 3rem;
  z-index: 2;
  color: white
}
.pm-hero-location {
  font-size: .9rem;
  display: flex;
  align-items: center;
  gap: .4rem;
  margin-bottom: .5rem;
  opacity: .9
}
.pm-hero-title, .pm-hero-title {
  font-family: "Montserrat", sans-serif;
  font-size: 3rem;
  font-weight: 700;
  margin-bottom: .5rem
}
.pm-hero-tagline {
  font-size: 1.1rem;
  opacity: .9;
  max-width: 600px
}
.pm-gallery-nav {
  position: absolute;
  top: 50%;
  z-index: 3;
  transform: translateY(-50%);
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .2);
  backdrop-filter: blur(10px);
  color: white;
  border: 2px solid rgba(255, 255, 255, .3);
  font-size: 1.2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: var(--transition)
}
.pm-gallery-nav:hover {
  background: rgba(255, 255, 255, .4)
}
.pm-gallery-prev {
  left: 1.5rem
}
.pm-gallery-next {
  right: 1.5rem
}
.pm-gallery-dots {
  position: absolute;
  bottom: 1.5rem;
  right: 3rem;
  display: flex;
  gap: .5rem;
  z-index: 3
}
.pm-gallery-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .4);
  border: none;
  cursor: pointer;
  transition: var(--transition)
}
.pm-gallery-dot.active {
  background: white;
  transform: scale(1.2)
}
/* Content Layout */
.pm-body {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 2rem
}
.pm-grid {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 4rem;
  padding: 2rem 0 4rem
}
.pm-main {}
.pm-sidebar {}
/* Overview */
.pm-section {
  margin-bottom: 3rem
}
.pm-section-tag {
  color: var(--green);
  font-size: .8rem;
  font-weight: 600;
  letter-spacing: 2px;
  text-transform: uppercase;
  margin-bottom: .5rem
}
.pm-section-title {
  font-family: "Quicksand", sans-serif;
  font-size: 1.8rem;
  color: var(--brown);
  margin-bottom: 1rem
}
.pm-section p {
  color: var(--gray);
  line-height: 1.9;
  font-size: 1rem;
  margin-bottom: 1rem
}
/* Specs Card */
.pm-specs-card {
  background: var(--cream);
  border-radius: var(--radius);
  padding: 2rem;
  margin-bottom: 2rem;
  position: sticky;
  top: 5rem
}
.pm-specs-card h3 {
  font-family: "Quicksand", sans-serif;
  font-size: 1.3rem;
  margin-bottom: 1.5rem;
  color: var(--brown)
}
.pm-spec-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: .75rem 0;
  border-bottom: 1px solid rgba(0, 0, 0, .06)
}
.pm-spec-row:last-child {
  border-bottom: none
}
.pm-spec-label {
  color: var(--gray);
  font-size: .9rem;
  display: flex;
  align-items: center;
  gap: .5rem
}
.pm-spec-value {
  font-weight: 600;
  color: var(--brown);
  font-size: .95rem
}
/* Features Grid */
.pm-features-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin-top: 1rem
}
.pm-feature {
  display: flex;
  align-items: flex-start;
  gap: .8rem;
  padding: 1rem;
  background: var(--cream);
  border-radius: 8px;
  transition: var(--transition)
}
.pm-feature:hover {
  background: var(--cream-dark);
  transform: translateX(4px)
}
.pm-feature-icon {
  width: 40px;
  height: 40px;
  min-width: 40px;
  border-radius: 8px;
  background: var(--green);
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem
}
.pm-feature h4 {
  font-family: "Montserrat", sans-serif;
  font-size: .95rem;
  font-weight: 600;
  color: var(--brown);
  margin-bottom: .2rem
}
.pm-feature p {
  font-size: .82rem;
  color: var(--gray);
  line-height: 1.5
}
/* Before/After */
.pm-ba-container {
  position: relative;
  border-radius: var(--radius);
  overflow: hidden;
  height: 400px;
  cursor: ew-resize;
  margin-top: 1rem;
  box-shadow: var(--shadow-lg)
}
.pm-ba-before, .pm-ba-after {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center
}
.pm-ba-before {
  z-index: 2;
  width: 50%
}
.pm-ba-after {
  z-index: 1
}
.pm-ba-line {
  position: absolute;
  top: 0;
  bottom: 0;
  width: 3px;
  background: white;
  z-index: 3;
  left: 50%;
  transform: translateX(-50%);
  pointer-events: none
}
.pm-ba-handle {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 4;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background: white;
  box-shadow: 0 2px 15px rgba(0, 0, 0, .3);
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none
}
.pm-ba-handle::before {
  content: '◀▶';
  font-size: .7rem;
  color: var(--green);
  letter-spacing: 4px
}
.pm-ba-label {
  position: absolute;
  top: 1rem;
  padding: .4rem .8rem;
  border-radius: 5px;
  font-size: .75rem;
  font-weight: 600;
  letter-spacing: 1px;
  text-transform: uppercase;
  z-index: 5
}
.pm-ba-label.before {
  left: 1rem;
  background: rgba(0, 0, 0, .5);
  color: white
}
.pm-ba-label.after {
  right: 1rem;
  background: rgba(255, 255, 255, .9);
  color: var(--brown)
}
/* Timeline */
.pm-timeline {
  position: relative;
  padding-left: 2rem;
  margin-top: 1.5rem
}
.pm-timeline::before {
  content: '';
  position: absolute;
  left: .5rem;
  top: 0;
  bottom: 0;
  width: 2px;
  background: var(--cream-dark)
}
.pm-tl-item {
  position: relative;
  padding-bottom: 1.5rem
}
.pm-tl-item:last-child {
  padding-bottom: 0
}
.pm-tl-dot {
  position: absolute;
  left: -1.75rem;
  top: .25rem;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--lime);
  border: 3px solid var(--cream);
  z-index: 1
}
.pm-tl-item h4 {
  font-family: "Montserrat", sans-serif;
  font-size: .95rem;
  font-weight: 600;
  color: var(--brown);
  margin-bottom: .2rem
}
.pm-tl-item p {
  font-size: .88rem;
  color: var(--gray)
}
.pm-tl-date {
  font-size: .78rem;
  color: var(--lime);
  font-weight: 600;
  margin-bottom: .2rem
}
/* Client Quote */
.pm-quote {
  background: var(--green);
  color: white;
  border-radius: var(--radius);
  padding: 2rem;
  margin-top: 1.5rem;
  position: relative;
  overflow: hidden
}
.pm-quote::before {
  content: '"';
  position: absolute;
  top: -.2rem;
  left: 1rem;
  font-size: 6rem;
  font-family: "Quicksand", sans-serif;
  opacity: .15;
  line-height: 1
}
.pm-quote p {
  font-style: italic;
  font-size: 1rem;
  line-height: 1.8;
  margin-bottom: 1rem;
  position: relative;
  z-index: 1
}
.pm-quote-author {
  font-weight: 600;
  font-size: .95rem
}
.pm-quote-role {
  font-size: .82rem;
  opacity: .8
}
/* Related Projects */
.pm-related {
  background: var(--cream);
  padding: 4rem 0;
  margin-top: 2rem
}
.pm-related .container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 2rem
}
.pm-related h2 {
  font-family: "Quicksand", sans-serif;
  font-size: 1.8rem;
  text-align: center;
  margin-bottom: 2rem;
  color: var(--brown)
}
.pm-related-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem
}
.pm-related-card {
  background: white;
  border-radius: var(--radius);
  overflow: hidden;
  cursor: pointer;
  transition: var(--transition);
  box-shadow: var(--shadow)
}
.pm-related-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-lg)
}
.pm-related-img {
  height: 180px;
  background-size: cover;
  background-position: center;
  position: relative
}
.pm-related-img::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0, 0, 0, .4) 0%, transparent 60%)
}
.pm-related-body {
  padding: 1.2rem
}
.pm-related-body h4 {
  font-size: 1.05rem;
  margin-bottom: .3rem
}
.pm-related-body p {
  font-size: .82rem;
  color: var(--gray)
}
/* CTA Banner */
.pm-cta {
  background: linear-gradient(135deg, var(--green) 0%, var(--green-dark) 100%);
  color: white;
  text-align: center;
  padding: 4rem 2rem;
  border-radius: var(--radius);
  margin: 2rem 0 3rem
}
.pm-cta h2 {
  font-family: 'Montserrat', sans-serif;
  font-size: 2rem;
  margin-bottom: .8rem;
}
.pm-cta p {
  opacity: .9;
  margin-bottom: 1.5rem;
  max-width: 500px;
  margin-left: auto;
  margin-right: auto
}
/* Photo Grid */
.pm-photo-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: .8rem;
  margin-top: 1rem;
  border-radius: var(--radius);
  overflow: hidden
}
.pm-photo {
  height: 200px;
  background-size: cover;
  background-position: center;
  border-radius: 6px;
  cursor: pointer;
  transition: var(--transition);
  position: relative;
  overflow: hidden
}
.pm-photo:hover {
  transform: scale(1.02);
  box-shadow: var(--shadow)
}
.pm-photo:first-child {
  grid-column: 1/3;
  grid-row: 1/3;
  height: 100%
}
.pm-photo::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0);
  transition: var(--transition)
}
.pm-photo:hover::after {
  background: rgba(0, 0, 0, .1)
}
/* Lightbox */
.pm-lightbox {
  position: fixed;
  inset: 0;
  z-index: 3000;
  background: rgba(0, 0, 0, .92);
  display: none;
  align-items: center;
  justify-content: center;
  cursor: zoom-out
}
.pm-lightbox.open {
  display: flex
}
.pm-lightbox img, .pm-lightbox .pm-lb-img {
  max-width: 90%;
  max-height: 85vh;
  object-fit: contain;
  border-radius: var(--radius);
  background-size: cover;
  background-position: center
}
.pm-lb-close {
  position: absolute;
  top: 1.5rem;
  right: 2rem;
  color: white;
  font-size: 2rem;
  cursor: pointer;
  background: none;
  border: none;
  transition: var(--transition)
}
.pm-lb-close:hover {
  transform: scale(1.2)
}
/* Responsive */
@media(max-width:768px) {
  .pm-grid {
    grid-template-columns: 1fr;
    gap: 2rem
  }
  .pm-sidebar {
    order: -1
  }
  .pm-specs-card {
    position: static
  }
  .pm-hero {
    height: 50vh;
    min-height: 300px
  }
  .pm-hero-title {
    font-size: 1.8rem
  }
  .pm-features-grid {
    grid-template-columns: 1fr
  }
  .pm-ba-container {
    height: 280px
  }
  .pm-photo-grid {
    grid-template-columns: 1fr 1fr
  }
  .pm-photo:first-child {
    grid-column: 1/3;
    height: 220px
  }
  .pm-related-grid {
    grid-template-columns: 1fr
  }
  .pm-cta h2 {
    font-size: 1.5rem
  }
}
/* ═══════════════════════════════════════════════════ */
/*  CONTACT SECTION STYLES                             */
/* ═══════════════════════════════════════════════════ */
#contact {
  background-color: rgb(74, 124, 63);
  padding: 96px 0;
}
#contact .container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 24px;
}
.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  align-items: start;
}
/* ── Contact Info (Left) ─────────────────────────── */
.contact-info .section-tag {
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: rgba(255, 255, 255, 0.7);
  margin-bottom: 12px;
}
.contact-info h2 {
  color: #fff;
  font-size: 32px;
  font-weight: 600;
  margin-bottom: 16px;
}
.contact-info p {
  color: rgba(255, 255, 255, 0.75);
  font-size: 15px;
  line-height: 1.7;
  margin-bottom: 32px;
}
.contact-icon {
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.1);
  border-radius: 50%;
  font-size: 16px;
  flex-shrink: 0;
}
.social-links {
  display: flex;
  gap: 10px;
  margin-top: 10px;
}
.social-links a {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.1);
  color: #fff;
  font-size: 12px;
  text-decoration: none;
  transition: background 0.3s;
}
.social-links a:hover {
  background: rgba(255, 255, 255, 0.25);
}
/* ── Contact Form (Right) ────────────────────────── */
.contact-form {
  background: rgba(255, 255, 255, 0.07);
  padding: 40px;
  border-radius: 10px;
}
.contact-form h3 {
  color: #fff;
  font-size: 22.4px;
  font-weight: 400;
  margin-bottom: 8px;
}
.contact-form > p {
  color: rgba(255, 255, 255, 0.7);
  font-size: 14.4px;
  margin-bottom: 24px;
}
/* ── Form Layout ─────────────────────────────────── */
.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.form-group {
  margin-bottom: 19px;
}
.form-group label {
  display: block;
  color: rgba(255, 255, 255, 0.9);
  font-size: 14px;
  font-weight: 500;
  margin-bottom: 6px;
}
.form-group input, .form-group select, .form-group textarea {
  width: 100%;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-radius: 8px;
  padding: 13px 16px;
  color: #fff;
  font-size: 15px;
  font-family: "Montserrat", sans-serif;
  outline: none;
  transition: border-color 0.3s, box-shadow 0.3s;
  box-sizing: border-box;
}
.form-group input::placeholder, .form-group textarea::placeholder {
  color: rgba(255, 255, 255, 0.35);
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus {
  border-color: rgba(140, 188, 61, 0.6);
  box-shadow: 0 0 0 3px rgba(140, 188, 61, 0.15);
}
.form-group select {
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='rgba(255,255,255,0.5)' d='M6 8L0 0h12z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 16px center;
  padding-right: 40px;
  cursor: pointer;
}
.form-group select option {
  background: #3a6a32;
  color: #fff;
}
.form-group textarea {
  min-height: 100px;
  resize: vertical;
}
/* ── Submit Button ───────────────────────────────── */
#contactForm button[type="submit"] {
  width: 100%;
  background: rgb(140, 188, 61);
  color: #fff;
  border: none;
  border-radius: 8px;
  padding: 16px;
  font-size: 16px;
  font-weight: 600;
  font-family: "Montserrat", sans-serif;
  cursor: pointer;
  transition: background 0.3s, transform 0.2s;
}
#contactForm button[type="submit"]:hover {
  background: rgb(120, 168, 45);
  transform: translateY(-1px);
}
#contactForm button[type="submit"]:active {
  transform: translateY(0);
}
#contactForm button[type="submit"]:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none;
}
/* ── Status Messages ─────────────────────────────── */
.form-status {
  margin-top: 16px;
  padding: 14px 18px;
  border-radius: 8px;
  font-size: 14px;
  text-align: center;
}
.form-status.success {
  background: rgba(140, 188, 61, 0.2);
  color: #c5e89e;
  border: 1px solid rgba(140, 188, 61, 0.3);
}
.form-status.error {
  background: rgba(220, 53, 69, 0.2);
  color: #f5a5a5;
  border: 1px solid rgba(220, 53, 69, 0.3);
}
/* ── Responsive ──────────────────────────────────── */
@media (max-width: 768px) {
  .contact-grid {
    grid-template-columns: 1fr;
  }
  .form-row {
    grid-template-columns: 1fr;
  }
  .contact-form {
    padding: 28px 20px;
  }
  #contact {
    padding: 60px 0;
  }
}






/* =========================================================
   UNIQUE-TO-FIRST (scoped)
   These are ONLY the styles where FIRST differs from / adds to MASTER.
   Everything is wrapped with .portfolio to avoid global overrides.
   ========================================================= */

/* FIRST treated related cards like links */
.portfolio .pm-related-card{
  text-decoration:none;
  color:inherit;
  display:block;
}

/* FIRST typography choices (MASTER uses Quicksand in these spots) */
.portfolio .pm-hero-title{
  font-family: "Montserrat", sans-serif;
}
.portfolio .pm-section-title{
  font-family:"Montserrat",sans-serif;
}
.portfolio .pm-specs-card h3{
  font-family:"Montserrat",sans-serif;
}

/* FIRST before/after handle glyphs + sizing */
.portfolio .pm-ba-handle::before{
  content:"\25C0 \25B6";
  font-size:.65rem;
  color:var(--green);
  letter-spacing:2px;
}

/* FIRST quote mark + font */
.portfolio .pm-quote::before{
  content:"\201C";
  font-family:"Montserrat",sans-serif;
}

/* MASTER adds extra overlays/click-cursor that FIRST did not have.
   These overrides bring behaviour back to FIRST. */
.portfolio .pm-photo{
  cursor:default;
}
.portfolio .pm-photo::after{
  content:none;
}

.portfolio .pm-related{
  margin-top:0; /* MASTER adds margin-top:2rem; FIRST didn’t */
}
.portfolio .pm-related-img::after{
  content:none; /* MASTER adds gradient overlay; FIRST didn’t */
}
.portfolio .pm-cta h2 { color: #fff; }



/* ====== LIGHTBOX ====== */
.lightbox {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: none;
}

.lightbox.open { display: block; }

.lightbox-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.75);
}

.lightbox-dialog {
  position: relative;
  max-width: min(1100px, 92vw);
  max-height: 88vh;
  margin: 6vh auto 0;
  background: #0b0b0b;
  border-radius: 16px;
  box-shadow: 0 20px 80px rgba(0,0,0,.5);
  overflow: hidden;
  outline: none;
}

.lightbox-figure {
  margin: 0;
  display: grid;
  place-items: center;
  padding: 18px;
  gap: 10px;
}

.lightbox-img {
  max-width: 100%;
  max-height: calc(88vh - 90px);
  object-fit: contain;
  display: block;
  border-radius: 12px;
  background: #111;
}

.lightbox-cap {
  color: rgba(255,255,255,.8);
  font-size: 14px;
  text-align: center;
  min-height: 18px;
}

.lightbox-close {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.15);
  background: rgba(0,0,0,.45);
  color: #fff;
  cursor: pointer;
}

.lightbox-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 46px;
  height: 56px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.15);
  background: rgba(0,0,0,.45);
  color: #fff;
  cursor: pointer;
  font-size: 28px;
  line-height: 1;
}

.lightbox-prev { left: 10px; }
.lightbox-next { right: 10px; }

@media (max-width: 600px) {
  .lightbox-nav { width: 44px; height: 52px; }
}


/* Service Card Image Layout */
.svc-card-with-img {
  padding: 0 !important;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.svc-img {
  width: 100%;
  height: 200px;
  position: relative;
  overflow: hidden;
  border-radius: var(--radius) var(--radius) 0 0;
}
.svc-img-inner {
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center center;
  transition: transform 0.5s;
}
.svc-card-with-img:hover .svc-img-inner {
  transform: scale(1.05);
}
.svc-card-content {
  padding: 1.8rem 2.2rem 2.2rem;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.svc-card-content h3 { margin-top: 0; }
.svc-card-content .svc-link { margin-top: auto; }
/* Placeholder gradients (replace with real images later) */
.svc-img-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 3rem;
}
.svc-img-placeholder.garden-design    { background: linear-gradient(135deg, #4a7c59, #8fbc8f); }
.svc-img-placeholder.patios-paving    { background: linear-gradient(135deg, #8b7355, #c4a882); }
.svc-img-placeholder.decking-pergolas { background: linear-gradient(135deg, #6b4226, #a0785a); }
.svc-img-placeholder.outdoor-kitchens { background: linear-gradient(135deg, #c45c26, #e89b6b); }
.svc-img-placeholder.garden-lighting  { background: linear-gradient(135deg, #4a5568, #a0aec0); }
.svc-img-placeholder.planting-turfing { background: linear-gradient(135deg, #2d6a4f, #74c69d); }

.svc-img-inner.garden-design {
  background-image: url('assets/services/garden-design.jpg'); background-size: cover; background-repeat: no-repeat;
}
.svc-img-inner.patios-paving {
  background-image: url('assets/services/patios-paving.jpg'); background-size: cover; background-repeat: no-repeat;
}
.svc-img-inner.decking-pergolas {
  background-image: url('assets/services/decking-pergolas.jpg'); background-size: cover; background-repeat: no-repeat;
}
.svc-img-inner.outdoor-kitchens {
  background-image: url('assets/services/outdoor-kitchens.jpg'); background-size: cover; background-repeat: no-repeat;
}
.svc-img-inner.garden-lighting {
  background-image: url('assets/services/garden-lighting.jpg'); background-size: cover; background-repeat: no-repeat;
}
.svc-img-inner.planting-turfing {
  background-image: url('assets/services/planting-turfing.jpg'); background-size: cover; background-repeat: no-repeat;
}


/* ── Remove the old image background ── */
/* DELETE or comment out the existing .hero-bg and .hero-bg::after rules */

.hero-video-bg {
  position: absolute;
  inset: 0;
  z-index: 1;
  overflow: hidden;
  pointer-events: none;
}

.hero-video-bg iframe {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100vw;
  height: 100vh;
  min-width: 177.78vh;       /* 16:9 cover */
  min-height: 56.25vw;       /* 16:9 cover */
  transform: translate(-50%, -50%);
  border: 0;
  opacity: 0;                /* hidden until playing */
  transition: opacity 0.8s ease;
}

.hero-video-bg iframe.playing {
  opacity: 1;
}

/* ── Green brand overlay (replaces .hero-bg::after) ── */
.hero-overlay {
  position: absolute;
  inset: 0;
  z-index: 2;
  background: linear-gradient(
    135deg,
    rgba(35, 60, 28, 0.85) 0%,
    rgba(45, 75, 38, 0.80) 40%,
    rgba(55, 90, 45, 0.75) 100%
  );
}

/* ── All other hero rules stay the same ── */
/*  .hero              – unchanged  */
/*  .hero-pattern      – unchanged  */
/*  .hero-content      – unchanged  */
/*  .hero-badge        – unchanged  */
/*  .hero h1, h1 span  – unchanged  */
/*  .hero-btns         – unchanged  */
/*  .scroll-hint       – unchanged  */


/* ==============================================
   COOKIE CONSENT BANNER — TJ Rose Landscapes
   ============================================== */
/* Banner container */
.tj-cookie-banner {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 10000;
  font-family: 'Montserrat', sans-serif;
}
.tj-cookie-banner__main {
  background: #1a1a1a;
  color: #f5f5f0;
  padding: 20px 24px;
  box-shadow: 0 -4px 20px rgba(0,0,0,0.3);
}
.tj-cookie-banner__content {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  margin-bottom: 16px;
}
.tj-cookie-banner__icon {
  font-size: 28px;
  flex-shrink: 0;
  line-height: 1;
}
.tj-cookie-banner__title {
  font-weight: 700;
  font-size: 16px;
  margin: 0 0 6px 0;
  color: #fff;
}
.tj-cookie-banner__desc {
  font-size: 13px;
  line-height: 1.5;
  margin: 0;
  color: #ccc;
}
.tj-cookie-banner__link {
  color: #8cbc3d;
  text-decoration: underline;
  text-underline-offset: 2px;
}
.tj-cookie-banner__link:hover {
  color: #a6d94f;
}
/* Action buttons */
.tj-cookie-banner__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.tj-cookie-btn {
  padding: 10px 20px;
  border: none;
  border-radius: 6px;
  font-family: 'Montserrat', sans-serif;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.2s, transform 0.1s;
  white-space: nowrap;
}
.tj-cookie-btn:hover {
  transform: translateY(-1px);
}
.tj-cookie-btn:active {
  transform: translateY(0);
}
.tj-cookie-btn--accept {
  background: #4a7c3f;
  color: #fff;
}
.tj-cookie-btn--accept:hover {
  background: #3a6a32;
}
.tj-cookie-btn--reject {
  background: transparent;
  color: #f5f5f0;
  border: 1px solid #555;
}
.tj-cookie-btn--reject:hover {
  background: rgba(255,255,255,0.08);
  border-color: #888;
}
.tj-cookie-btn--settings {
  background: transparent;
  color: #8cbc3d;
  border: 1px solid #8cbc3d;
}
.tj-cookie-btn--settings:hover {
  background: rgba(140,188,61,0.1);
}
/* Preferences panel */
.tj-cookie-prefs {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: #fff;
  color: #3d3529;
  border-radius: 16px 16px 0 0;
  box-shadow: 0 -8px 40px rgba(0,0,0,0.25);
  max-height: 80vh;
  overflow-y: auto;
  z-index: 10001;
}
.tj-cookie-prefs__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 24px 12px;
  border-bottom: 1px solid #eee;
}
.tj-cookie-prefs__title {
  font-weight: 700;
  font-size: 18px;
  margin: 0;
}
.tj-cookie-prefs__close {
  background: none;
  border: none;
  font-size: 28px;
  color: #999;
  cursor: pointer;
  padding: 0 4px;
  line-height: 1;
}
.tj-cookie-prefs__close:hover {
  color: #333;
}
.tj-cookie-prefs__body {
  padding: 8px 24px;
}
.tj-cookie-prefs__category {
  padding: 16px 0;
  border-bottom: 1px solid #f0f0f0;
}
.tj-cookie-prefs__category:last-child {
  border-bottom: none;
}
.tj-cookie-prefs__row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
}
.tj-cookie-prefs__cat-title {
  font-weight: 600;
  font-size: 14px;
  margin: 0 0 4px 0;
}
.tj-cookie-prefs__cat-desc {
  font-size: 12px;
  line-height: 1.5;
  color: #777;
  margin: 0;
  max-width: 400px;
}
.tj-cookie-prefs__footer {
  padding: 16px 24px 20px;
  border-top: 1px solid #eee;
  text-align: right;
}
/* Toggle switch */
.tj-cookie-toggle {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  flex-shrink: 0;
}
.tj-cookie-toggle input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}
.tj-cookie-toggle__slider {
  width: 44px;
  height: 24px;
  background: #ccc;
  border-radius: 24px;
  position: relative;
  transition: background 0.3s;
  flex-shrink: 0;
}
.tj-cookie-toggle__slider::after {
  content: '';
  position: absolute;
  top: 3px;
  left: 3px;
  width: 18px;
  height: 18px;
  background: #fff;
  border-radius: 50%;
  transition: transform 0.3s;
  box-shadow: 0 1px 3px rgba(0,0,0,0.2);
}
.tj-cookie-toggle input:checked + .tj-cookie-toggle__slider {
  background: #4a7c3f;
}
.tj-cookie-toggle input:checked + .tj-cookie-toggle__slider::after {
  transform: translateX(20px);
}
.tj-cookie-toggle--disabled {
  cursor: default;
  opacity: 0.6;
}
.tj-cookie-toggle__label {
  font-size: 11px;
  color: #999;
  white-space: nowrap;
}
/* Reopen button */
.tj-cookie-reopen {
  position: fixed;
  bottom: 20px;
  left: 20px;
  z-index: 9999;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: none;
  background: #1a1a1a;
  color: #fff;
  font-size: 20px;
  cursor: pointer;
  box-shadow: 0 2px 10px rgba(0,0,0,0.3);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.2s, background 0.2s;
}
.tj-cookie-reopen:hover {
  transform: scale(1.1);
  background: #4a7c3f;
}
/* Focus visible for keyboard accessibility */
.tj-cookie-btn:focus-visible,
.tj-cookie-toggle input:focus-visible + .tj-cookie-toggle__slider,
.tj-cookie-prefs__close:focus-visible,
.tj-cookie-reopen:focus-visible {
  outline: 2px solid #8cbc3d;
  outline-offset: 2px;
}
/* Desktop: side-by-side layout */
@media (min-width: 768px) {
  .tj-cookie-banner__main {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    padding: 18px 32px;
  }
  .tj-cookie-banner__content {
    margin-bottom: 0;
    flex: 1;
  }
  .tj-cookie-banner__actions {
    flex-shrink: 0;
  }
  .tj-cookie-prefs {
    max-width: 560px;
    left: auto;
    right: 24px;
    bottom: 24px;
    border-radius: 16px;
  }
}
/* === Gallery Lightbox Overlay === */
.lightbox-overlay {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(0, 0, 0, 0.92);
  display: none;
  align-items: center;
  justify-content: center;
  cursor: zoom-out;
}

.lightbox-overlay.active {
  display: flex;
}

.lightbox-overlay .lightbox-content {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  max-width: min(1100px, 92vw);
  max-height: 88vh;
  padding: 18px;
}

.lightbox-overlay .lightbox-caption {
  color: rgba(255, 255, 255, 0.8);
  font-size: 14px;
  text-align: center;
  min-height: 18px;
  margin: 0;
}

.lightbox-overlay .lightbox-counter {
  color: rgba(255, 255, 255, 0.5);
  font-size: 13px;
  text-align: center;
  margin: 0;
}

.lightbox-overlay .lightbox-prev,
.lightbox-overlay .lightbox-next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 46px;
  height: 56px;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.15);
  background: rgba(0, 0, 0, 0.45);
  color: #fff;
  cursor: pointer;
  font-size: 28px;
  line-height: 1;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: center;
}

.lightbox-overlay .lightbox-prev { left: 16px; }
.lightbox-overlay .lightbox-next { right: 16px; }

.lightbox-overlay .lightbox-close:hover,
.lightbox-overlay .lightbox-prev:hover,
.lightbox-overlay .lightbox-next:hover {
  background: rgba(0, 0, 0, 0.7);
  border-color: rgba(255, 255, 255, 0.3);
}

.hero {
  position: relative;
  width: 100%;
  height: 100vh; /* full screen height */
  overflow: hidden;
}

.hero-video-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  overflow: hidden;
}
.hero-video-bg iframe {
  position: absolute;
  top: 50%;
  left: 50%;
  
  /* This creates "cover" behaviour like CSS background */
  width: 177.78vh;   /* 16:9 ratio */
  height: 100vh;

  min-height: 100%;

  transform: translate(-50%, -50%);
  
  pointer-events: none; /* prevents clicking video */
}

.hero-overlay,
.hero-pattern {
  position: absolute;
  inset: 0;
  z-index: 1;
}

.hero-content,
.scroll-hint {
  position: relative;
  z-index: 2;
}

.hero-content,
.scroll-hint {
  position: relative;
  z-index: 2;
}

