:root {
  /* Brand Colors */
  --clr-primary: #051e2d;
  --clr-secondary: #edad25;

  /* Accent Colors */
  --clr-accent-1: #ffcc1a;
  --clr-accent-2: #f4d89f;

  /* Neutral Colors */
  --clr-white: #ffffff;

  /* Background Col
  ors */
  --clr-bg-primary: #ffffff;
  --clr-bg-secondary: #f6f6f2;

  /* Typography */
  --ff-inter: "Inter", sans-serif;
  --ff-inter-tight: "Inter Tight", sans-serif;
  --ff-roboto-slab: "Roboto Slab", serif;

  /* Font Weights */
  --fw-thin: 100;
  --fw-extra-light: 200;
  --fw-light: 300;
  --fw-regular: 400;
  --fw-medium: 500;
  --fw-semi-bold: 600;
  --fw-bold: 700;
  --fw-extra-bold: 800;
  --fw-black: 900;

  /* Spacing */
  --sp-xxs: 0.25rem;
  --sp-xs: 0.5rem;
  --sp-sm: 0.75rem;
  --sp-md: 1rem;
  --sp-lg: 1.5rem;
  --sp-xl: 2rem;
  --sp-xxl: 3rem;

  /* Breakpoints */
  --bp-mobile: 576px;
  --bp-tablet: 768px;
  --bp-desktop: 992px;
  --bp-large: 1200px;
  --bp-xlarge: 1440px;

  /* Border Radius */
  --border-radius: 1rem;
  --border-radius-full: 500px;

  @media (prefers-color-scheme: dark) {
    /* --clr-bg-primary: #1a1a1a;
    --clr-primary: #ffffff; */
  }
}

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

html:focus-within {
  scroll-behavior: smooth;
}

body {
  font-family: var(--ff-inter);
  font-size: 1rem;
  line-height: 1.5;
  text-wrap: balance;
  background: var(--clr-bg-primary);
  background-image: radial-gradient(circle 700px at top left, var(--clr-accent-2), transparent 100%);
  color: var(--clr-primary);
  background-repeat: no-repeat;

  @media (max-width: 768px) {
    background-image: radial-gradient(circle 400px at top left, var(--clr-accent-2), transparent 100%);
    color: var(--clr-primary);
    background-repeat: no-repeat;
  }
}

img,
picture {
  display: block;
  max-width: 100%;
}

ul[role="list"],
li[role="list"] {
  list-style: none;
}

p {
  margin-block-end: 1rem;
  text-wrap: wrap;
}

a {
  text-decoration: none;
  color: #334557;
}
/* Removes all animations, transitions and smooth scroll for people who opt-out */
@media (prefers-reduced-motion: reduce) {
  html:focus-within {
    scroll-behavior: auto;
  }
}

/* === REUSABLE UI COMPONENTS === */

/* Button */
.button,
.button--white {
  display: inline-block;
  padding-block: 0.8rem;
  padding-inline: 2.5rem;
  border-radius: 500px;
  text-wrap: nowrap;
  transition: 0.3s ease;
  color: var(--clr-white);
  background: var(--clr-primary);
}

.button--white {
  color: var(--clr-primary);
  background: var(--clr-white);
  max-width: 200px;
}

.button:hover {
  background-image: linear-gradient(0.25turn, #394a5d 0, var(--clr-primary) 55%);
  transition: 0.3s ease;
}

.button:focus-visible {
  outline: 2px solid var(--clr-accent-2);
  outline-offset: 2px;
}

/* Horizontal Rule */
hr {
  border-top: #b1af9e;
}

/* Card */
.cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  margin-block-end: 5rem;

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

.cards > * {
  flex: 1;
}

.card {
  border: 1px solid #f4d89f;
  border-radius: 1rem;
}

.card__container {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 1rem;
}

/* Transparent Card */
.transparent-cards {
  margin-block-end: 5rem;
}

.transparent-card {
  margin-block-end: 3rem;
  border: 1px solid #e1e1e1;
  border-radius: 1rem;
  background-color: #fcfcfa;
}

.transparent-card__container {
  display: flex;
  flex-flow: row wrap;
  gap: 1rem;
  padding: 3rem 2rem 2rem 2rem;

  @media (max-width: 576px) {
    flex-direction: column;
  }
}

.transparent-card__container > * {
  flex: 1;
}

.transparent-card__eyebrow {
  font-size: 1rem;
  font-weight: var(--fw-light);
  letter-spacing: 0.5rem;
}

.transparent-card__title {
  font-size: 2rem;
  font-weight: var(--fw-medium);
}

.transparent-card__text {
  text-wrap: pretty;
}

/* Content */
.content {
  margin-block-end: 5rem;
}

.content__container {
  max-width: 100%;
}

.content__title,
.content__heading {
  padding-block-end: 1.5rem;
  font-size: 2.375rem;
  font-weight: var(--fw-semi-bold);

  @media (max-width: 1200px) {
    font-size: 2rem;
  }
}

/* Main Content */
.main-content {
  margin-block-end: 5rem;
}

.main-content__container {
  max-width: 80%;

  @media (max-width: 992px) {
    max-width: 100%;
  }
}

.main-content__title,
.main-content__heading,
.main-content__sub-heading {
  padding-block-end: 1.5rem;
  font-size: 2.375rem;
  font-weight: var(--fw-semi-bold);

  @media (max-width: 1200px) {
    font-size: 2rem;
  }
}

.main-content__sub-heading {
  font-size: 2rem;
  font-weight: var(--fw-regular);

  @media (max-width: 1200px) {
    font-size: 1.5rem;
  }
}

.main-content__text {
  text-align: justify;

  @media (max-width: 992px) {
    text-align: revert;
  }
}

/* Lightbox */
#lightbox {
  display: none;
  position: fixed;
  z-index: 999;
  top: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.8);
}

#lightbox.active {
  display: flex;
  justify-content: center;
  align-items: center;

  & img {
    max-width: 90%;
    max-height: 80%;
    border-radius: 1rem;
  }
}

/* === HEADER TEXT === */
h1,
h2,
h3,
h4,
h5 {
  font-family: var(--ff-inter-tight);
}

/* === HEADER === */

.header {
  display: flex;
  justify-content: center;
}

.header__wrapper {
  max-width: 1440px;
  width: 100%;
}

/* === NAV === */
.nav {
  display: grid;
  width: 100%;
  grid-template-rows: 1fr;
  grid-template-columns: 1fr 3fr;
  position: relative;

  margin-block-start: 2rem;
  padding-inline: 1.5rem;

  @media (max-width: 768px) {
    grid-template-rows: 1fr;
    grid-template-columns: 1fr;
    gap: 2.5rem;
  }
}

.nav__logo {
  max-width: 200px;

  @media (max-width: 768px) {
    max-width: 150px;
  }
}

/* Navigation list not displayed within small mobile menu unless toggled */
.nav__list {
  display: grid;
  grid-template-rows: 1fr;
  grid-template-columns: 2fr 1fr;
  align-items: center;

  & .button {
    width: fit-content;
    justify-self: end;

    @media (max-width: 768px) {
      width: 100%;
      text-align: center;
    }
  }

  @media (max-width: 768px) {
    display: none;
  }
}

/* Navigation list activated within small mobile menu with toggle */
.nav__list.active {
  @media (max-width: 768px) {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 100%;
    gap: 1rem;
  }
}

.nav__links {
  display: flex;
  flex-flow: row nowrap;
  justify-content: center;
  gap: 4rem;

  & a {
    font-weight: var(--fw-semi-bold);
    color: var(--clr-primary);
    transition: 0.3s ease;
  }

  & a:hover {
    color: #334557;
    transition: 0.3s ease;
  }

  & a:focus-visible {
    outline: 2px solid var(--clr-accent-2);
    outline-offset: 2px;
  }

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

.nav__toggle-button {
  display: none;
  position: absolute;
  top: 0.25rem;
  right: 1.5rem;
  flex-direction: column;
  justify-content: space-between;
  width: 2rem;
  aspect-ratio: 1;
  border: 0;
  background-color: transparent;
  z-index: 9999;

  & .bar {
    width: 100%;
    height: 3px;
    margin: 3px;
    border-radius: 8px;
    background-color: var(--clr-primary);
  }

  @media (max-width: 768px) {
    display: flex;
  }
}

/* === MAIN === */

.main {
  display: flex;
  flex-direction: column;
  align-items: center;

  & > *:not(:last-child) {
    padding-inline: 1.5rem;
  }
}

.main__wrapper {
  max-width: 1440px;
  width: 100%;
}

.main__wrapper--full-width {
  max-width: 100%;
}

/* === HERO === */

.hero {
  margin-block: 8rem;

  @media (max-width: 992px) {
    margin-block: 3rem;
  }
}

.hero__container {
  /* padding-inline: 1.5rem; */
  text-align: center;
}

.hero__eyebrow {
  display: inline-block;
  padding-inline: 1rem;
  padding-block: 0.5rem;
  margin-block-end: 0.75rem;
  border-radius: 500px;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.3rem;
  background-color: #e6e6e6;
}

.hero__title {
  padding-inline: 5rem;
  padding-block-end: 1rem;
  font-size: 5rem;
  font-weight: var(--fw-extra-bold);
  line-height: 1.1;

  @media (max-width: 1440px) {
    font-size: 4.5rem;
    padding-inline: 1rem;
  }

  @media (max-width: 1200px) {
    font-size: 4rem;
  }

  @media (max-width: 992px) {
    font-size: 3rem;
  }

  @media (max-width: 576px) {
    font-size: 2.6rem;
  }
}

.hero__text {
  padding-block-end: 8rem;
  font-size: 1.5rem;
  font-size: clamp(1rem, 0.9rem + 0.5vw, 1.5rem);
  line-height: 1.5;

  @media (max-width: 1500px) {
    padding-inline: 0;
  }

  @media (max-width: 992px) {
    padding-block-end: 3rem;
    font-size: 1.25rem;
  }
}

.hero__text--interior {
  padding-inline: 10rem;
  padding-block-end: 8rem;
  font-size: 1.5rem;
  font-size: clamp(1rem, 0.9rem + 0.5vw, 1.5rem);
  line-height: 1.5;

  @media (max-width: 1500px) {
    padding-inline: 0;
  }

  @media (max-width: 992px) {
    padding-block-end: 3rem;
    font-size: 1rem;
  }
}

.hero__image {
  background: var(--clr-bg-secondary);
  background-size: cover;
  object-fit: cover;
  object-position: 50% 50%;

  width: 100%;
  max-height: 800px;
  margin-inline: auto;
  border-radius: 1rem;
}

/* === INTRO === */
.intro__container {
  padding-inline: 1.5rem;
  text-align: center;

  @media (max-width: 768px) {
    text-wrap: wrap;
    text-align: left;
    padding-inline: 0;
  }
}

.intro__title {
  padding-block-end: 1rem;
  font-size: 3rem;
  font-weight: var(--fw-bold);
  line-height: 1.2;

  @media (max-width: 768px) {
    font-size: 2rem;
  }
}

.intro__subtitle {
  font-size: 1.5rem;
  font-size: clamp(1.25rem, 0.9rem + 0.5vw, 1.5rem);
}

/* === FEATURED CONTENT === */
.featured-content {
  margin-block: 8rem;

  @media (max-width: 768px) {
    margin-block: 5rem;
  }
}

.featured-content__wrapper {
  display: grid;
  grid-template-columns: 1fr 1fr;
  row-gap: 8rem;
  column-gap: 2rem;

  @media (max-width: 768px) {
    grid-template-columns: 1fr;
    row-gap: 3rem;
  }
}

.featured-content__title {
  padding-block-end: 1.5rem;
  font-size: 3.8rem;
  font-weight: var(--fw-bold);

  @media (max-width: 1200px) {
    font-size: 2.8rem;
  }

  @media (max-width: 768px) {
    font-size: 2rem;
  }
}

.featured-content__image {
  width: 100%;
  border-radius: 1rem;
  cursor: pointer;
}

.featured-content__content {
  display: flex;
  justify-content: space-between;
  padding-block: 1.5rem;
  padding-inline: 1rem;

  @media (max-width: 992px) {
    padding-inline: 0;
  }
}

.featured-content__name {
  font-size: 1.2rem;
  font-weight: var(--fw-semi-bold);

  @media (max-width: 768px) {
    font-size: 1rem;
  }
}

.featured-content__category {
  font-family: var(--ff-roboto-slab);
  font-size: 1.2rem;
  font-weight: var(--fw-light);
  text-align: end;

  @media (max-width: 768px) {
    font-size: 1rem;
  }
}

/* === WORK === */

.work {
  margin-block-end: 5rem;
}

.work__container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;

  @media (max-width: 992px) {
    grid-template-columns: 1fr;
  }
}

.work__container > * {
  flex: 1;
}

.work__article {
  display: block;
}

.work__image {
  object-fit: cover;
  aspect-ratio: 1/1;
  width: 100%;
  max-height: 500px;
  border-radius: 1rem;
  cursor: pointer;

  @media (max-width: 992px) {
    aspect-ratio: auto;
  }
}

.work__image--inactive {
  display: none;
}

.work__video {
  display: none;
}

.work__video--active {
  display: block;
  object-fit: cover;
  aspect-ratio: 1/1;
  width: 100%;
  max-height: 500px;
  border-radius: 1rem;
  outline: 3px solid #f7f7f4;
}

.work-content__content {
  display: flex;
  justify-content: space-between;
  padding-block: 1.5rem;
  padding-inline: 1rem;

  @media (max-width: 992px) {
    padding-inline: 0;
  }
}

.work-content__name {
  font-size: 1.2rem;
  font-weight: var(--fw-semi-bold);

  @media (max-width: 768px) {
    font-size: 1rem;
  }
}

.work-content__category {
  font-family: var(--ff-roboto-slab);
  font-size: 1.2rem;
  font-weight: var(--fw-light);
  text-align: end;

  @media (max-width: 768px) {
    font-size: 1rem;
  }
}

/* === SERVICES === */
.services {
  margin-block-end: 8rem;

  @media (max-width: 768px) {
    margin-block-end: 5rem;
  }
}

.services hr {
  margin-block-start: 2rem;
  margin-block-end: 2rem;
}

.services__container {
  display: flex;

  @media (max-width: 768px) {
    flex-direction: column;
  }
}

.services__container > * {
  flex: 1;
}

.services__title {
  padding-block-end: 1.5rem;
  font-size: 3.8rem;
  font-weight: var(--fw-bold);

  @media (max-width: 1200px) {
    font-size: 2.8rem;
  }

  @media (max-width: 768px) {
    font-size: 2rem;
  }
}

.services__text {
  font-size: 1.5rem;

  @media (max-width: 768px) {
    font-size: 1.25rem;
  }
}

.services__category {
  font-size: 2rem;
  font-family: var(--ff-roboto-slab);
  font-weight: var(--fw-light);
}

/* === WHY US === */

.why-us {
  /* margin-block-start: 4rem; */
  margin-block-end: 4rem;
}
.why-us hr {
  margin-block-start: 2rem;
  margin-block-end: 2rem;
}

.why-us__container {
  display: flex;
  flex-flow: row wrap;

  @media (max-width: 768px) {
    flex-direction: column;
  }
}

.why-us__container > * {
  flex: 1;
}

.why-us__title {
  padding-block-end: 1.5rem;
  font-size: 3.8rem;
  font-weight: var(--fw-bold);

  @media (max-width: 1200px) {
    font-size: 2.8rem;
  }
  @media (max-width: 768px) {
    font-size: 2rem;
  }
}

.why-us__text {
  font-size: 1.5rem;
  margin-block-end: 1.5rem;

  @media (max-width: 768px) {
    font-size: 1.25rem;
  }
}

/* === TESTIMONIAL === */
.testimonial {
  margin-block-end: 6rem;
}

.testimonial__container {
  display: flex;
  flex-flow: row wrap;
  gap: 1.5rem;
}

.testimonial__container > * {
  flex: 1;
}

.testimonial__item {
  display: grid;
  grid-template-rows: 1fr 0.1fr;
  gap: 1rem;
  justify-items: stretch;

  padding-inline: 1.5rem;
  padding-block: 2rem;
  border-radius: 1rem;
  background: #fcf6e9;

  @media (max-width: 768px) {
    justify-content: flex-start;
    gap: 1rem;
  }
}

.testimonial__content {
  flex-basis: 500px;
}

.testimonial__quote {
  font-size: 1.3rem;
  font-weight: var(--fw-medium);
  line-height: 1.5;
}

.testimonial__author {
  display: flex;
  gap: 1rem;
}

/* === CTA === */
.cta {
  margin-block-start: 5rem;
  background-image: radial-gradient(ellipse at bottom, var(--clr-accent-2), #f7f7f4 30%);

  @media (max-width: 576px) {
    background-image: radial-gradient(ellipse at 50% 150%, var(--clr-accent-2), #f7f7f4 50%);
  }
}

.cta__container {
  padding-block-start: 5rem;
  padding-block-end: 7rem;
  padding-inline: 1.5rem;
  text-align: center;
}

.cta__title {
  padding-block-start: 3rem;
  padding-block-end: 1rem;
  padding-inline: 18rem;
  font-size: 4rem;
  font-weight: var(--fw-bold);
  line-height: 1.1;

  @media (max-width: 1440px) {
    font-size: 4.5rem;
    padding-inline: 0;
  }

  @media (max-width: 992px) {
    font-size: 4rem;
  }

  @media (max-width: 992px) {
    font-size: 3rem;
  }

  @media (max-width: 576px) {
    font-size: 2.6rem;
  }
}

.cta__text {
  padding-block-end: 3rem;
  font-size: 1.5rem;
  font-size: clamp(1rem, 0.9rem + 0.5vw, 1.5rem);
}

/* === FOOTER === */
.footer {
  display: flex;
  justify-content: center;
  padding-block: 5rem;
  background: var(--clr-primary);
}

.footer__wrapper {
  max-width: 1440px;
  width: 100%;
}

.footer__container {
  display: flex;
  flex-flow: row wrap;
  justify-content: space-between;

  padding-inline: 1.5rem;
}

.footer__content {
  display: flex;
  flex-flow: row wrap;
  gap: 16rem;

  @media (max-width: 1500px) {
    gap: 12rem;
  }

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

.footer__section {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  color: var(--clr-white);
}

.footer__logo {
  max-width: 200px;
  filter: brightness(0) invert(1);
}

.footer__title {
  font-weight: var(--fw-bold);
}

.footer__text {
  color: var(--clr-white);
}

.footer__text--small {
  font-size: 10px;
}

.footer__social-icons {
  padding-block-end: 1rem;
}

.footer__social-icon {
  display: inline-block;
  max-width: 30px;
}

.footer__nav-list,
.footer__nav-link {
  color: white;

  & a {
    color: white;
  }

  & a:hover {
    color: #334557;
  }
}

/* === BLOG INDEX === */
.blog-index {
  display: flex;
  justify-content: center;
}

.blog-index__wrapper {
  max-width: 1024px;
  width: 100%;
}

.blog-index-heading {
  margin-block-start: 7rem;
  margin-block-end: 4rem;
  border-bottom: 1px solid lightgray;
  padding-block-end: 2rem;
  width: fit-content;

  @media (max-width: 768px) {
    margin-block-end: 3rem;
  }
}

.blog-index-heading__eyebrow {
  display: inline-block;
  padding-inline: 1rem;
  padding-block: 0.5rem;
  margin-block-end: 0.75rem;
  border-radius: 500px;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.3rem;
  background-color: #e6e6e6;
}

.blog-index-heading__title {
  font-size: 4.3rem;
  font-weight: var(--fw-extra-bold);
  line-height: 1.1;

  @media (max-width: 1200px) {
    font-size: 4rem;
  }
}

/* === BLOG INDEX HERO === */
.blog-index-hero {
  padding-block: 1rem;
  border-bottom: 1px solid #ededed;
}
.blog-index-hero__title {
  font-size: 2.5rem;
  font-weight: var(--fw-semi-bold);
  margin-block-start: 0.5rem;
  margin-block-end: 1rem;

  & a:hover {
    color: #de4f16;
  }

  @media (max-width: 768px) {
    font-size: 2rem;
  }
}

.blog-index-hero__date {
  text-transform: uppercase;
  color: var(--clr-secondary);
}

.blog-index-hero__image {
  border-radius: 1rem;
}

.blog-index-hero__content {
  margin-block: 1rem;
}

.blog-index-hero__category {
  display: inline-block;
  padding-inline: 1rem;
  padding-block-start: 0.5rem;
  padding-block-end: 0.4rem;
  margin-block-start: 0.5rem;
  border: 1px solid #1c7781;
  border-radius: 500px;
  font-size: 0.75rem;
  text-transform: uppercase;
  background-color: transparent;
  color: #1c7781;
}

.blog-index-hero__excerpt {
  font-size: 1.2rem;
}

/* === BLOG INDEX POST GRID === */
.blog-index-post-grid {
  margin-block-start: 2rem;
}

.blog-index-post-grid__container {
  display: flex;
  gap: 3.5rem;
  flex-direction: column;
  padding-block: 1.25rem;

  @media (max-width: 768px) {
    gap: 1rem;
  }
}

.blog-post-card {
  display: grid;
  gap: 2rem;
  grid-template-columns: 1fr 2fr;
  grid-template-rows: 1fr;
  padding-block: 1rem;

  @media (max-width: 768px) {
    grid-template-columns: 1fr;
    /* gap: 1rem; */
  }
}

.blog-post-card__image {
  object-fit: cover;
  width: 100%;
  height: 100%;
  border-radius: 1rem;
}

.blog-post-card__date {
  text-transform: uppercase;
  color: var(--clr-secondary);
}

.blog-post-card__title {
  font-size: 2rem;
  font-weight: var(--fw-bold);

  & a:hover {
    color: #de4f16;
  }
}

.blog-post-card__excerpt {
  font-size: 1.1rem;
}

/* === BLOG POST === */
.blog-post {
  width: 100%;
  display: flex;
  justify-content: center;
}

.blog-post__wrapper {
  width: 100%;
}
/* === BLOG POST HERO === */
.blog-post-hero {
  margin-block-start: 5rem;
}

.blog-post-hero__container {
  display: grid;
  grid-template-rows: 1fr;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  max-width: 1200px;
  margin: 0 auto;
  padding-block: 3rem;
  padding-inline: 0.5rem;
  border-radius: 1rem;
  background: radial-gradient(circle 500px at top right, #e0e9e9, transparent 100%);

  @media (max-width: 768px) {
    grid-template-columns: 1fr;
    gap: 1rem;
    padding-inline: 0;
  }
}

.blog-post-hero__title {
  font-size: 3.2rem;
  font-size: clamp(1.5rem, 1.0143rem + 2.4286vw, 3.2rem);

  font-weight: var(--fw-bold);
  line-height: 1.1;
  text-wrap: auto;
  margin-block-start: 0.5rem;
  margin-block-end: 1rem;

  & a:hover {
    color: #de4f16;
  }
}

.blog-post-hero__date {
  text-transform: uppercase;
  color: var(--clr-secondary);
}

.blog-post-hero__image {
  border-radius: 1rem;
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.blog-post-hero__content {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.blog-post-hero__category {
  display: inline-block;
  width: fit-content;
  font-size: 0.75rem;
  text-transform: uppercase;
  padding-inline: 1rem;
  padding-block-start: 0.5rem;
  padding-block-end: 0.4rem;
  border: 1px solid #1c7781;
  border-radius: 500px;

  background-color: transparent;
  color: #1c7781;
}

.blog-post-hero__excerpt {
  font-size: 1.1rem;
  margin: 0 auto;
  max-width: 1024px;
}
