@import url("https://fonts.googleapis.com/css2?family=Amatic+SC:wght@400;700&family=Barlow+Condensed:wght@300;400;500;700&display=swap");

/* styling resets */
html {
  position: relative;
  box-sizing: border-box;
  scroll-behavior: smooth;
}

*,
*:before,
*:after {
  position: relative;
  box-sizing: inherit;
}

h1,
h2,
h3,
h4,
h5,
p {
  margin-top: 0;
  margin-bottom: 16px;
}

ul {
  list-style-type: none;
}

a {
  text-decoration: none;
}

img {
  display: block;
  max-width: 100%;
  height: auto;
}

textarea:focus,
input:focus {
  outline: 0;
}

input {
  margin: 0;
  padding: 0;
  appearance: none;
}

/* Define css variables */
:root {
  --color-body: #F9F8F4;
  --color-body-dark: #0b090a;
  --color-primary: #ff008c;
  --color-primary-darker: hsl(327, 100%, 43%);
  --color-primary-opacity: #ff008c99;
  --color-secondary: rgb(60, 255, 0);
  --font-body: "Barlow Condensed", sans-serif;
  --font-handwriting: "Amatic SC", cursive;
  --color-neon-yellow: rgb(208, 255, 0);
}

/* general styling */
body {
  margin: 0;
  padding: 0;
  background-color: var(--color-body-dark);
  font-family: var(--font-body);
  font-size: 16px;
  color: var(--color-body);
  max-width: 100vw;
}

h1 {
  font-size: 32px;
}

h2 {
  font-size: 28px;
}

h3 {
  font-size: 24px;
}

h4 {
  font-size: 20px;
}

h5 {
  font-size: 18px;
}

a {
  transition: color 0.33s;
}

main {
  margin-top: 100px;
}

.container {
  padding: 0 5%;
}

.content-container {
  margin-bottom: 75px;
}

.handwriting-font {
  font-family: var(--font-handwriting) !important;
}

.heading {
  text-align: center;
}
.heading--left {
  text-align: left;
}

.subtitle {
  font-size: 22px;
}
.subtitle--centered {
  text-align: center;
}
.subtitle--handwriting {
  font-family: var(--font-handwriting);
}

.btn {
  display: flex;
  flex-flow: row nowrap;
  justify-content: center;
  align-items: center;
  height: 100%;
  width: 100%;
  border: 3px solid var(--color-body);
  border-radius: 10px;
  background-color: transparent;
  color: var(--color-body);
  cursor: pointer;
}
.btn i {
  margin-left: 8px;
}
.btn-dark {
  border-color: var(--color-body-dark);
  color: var(--color-body-dark);
}
.btn-primary {
  box-shadow: 0 0 40px 40px var(--color-primary) inset, 0 0 0 0 var(--color-primary);
  border-color: var(--color-primary);
}

@media (min-width: 768px) {
  .container {
    padding: 0 8%;
  }

  .btn {
    transition: box-shadow 0.2s ease-in-out, color 0.33s;
  }
  .btn i {
    transition: transform 0.33s;
  }
  .btn:hover {
    box-shadow: 0 0 10px 0 var(--color-body) inset, 0 0 10px 4px var(--color-body);
  }
  .btn:hover i {
    transform: translateX(7px);
  }
  .btn-dark {
    transition: box-shadow 0.2s ease-in-out, color 0.33s;
  }
  .btn-dark:hover {
    box-shadow: 0 0 40px 40px var(--color-body-dark) inset, 0 0 0 0 var(--color-body-dark);
    color: var(--color-body);
  }
  .btn-primary:hover {
    color: var(--color-primary);
    box-shadow: 0 0 10px 0 var(--color-primary) inset, 0 0 10px 4px var(--color-primary);
  }
}
@media (min-width: 992px) {
  body {
    font-size: 20px;
  }

  h1 {
    font-size: 52px;
  }

  h2 {
    font-size: 44px;
  }

  h3 {
    font-size: 32px;
  }

  h4 {
    font-size: 26px;
  }

  h5 {
    font-size: 22px;
  }

  main {
    margin-top: 160px;
  }

  .subtitle {
    font-size: 32px;
  }
}
/* about styling */
.heading--welcome {
  color: var(--color-primary);
  margin-bottom: 8px;
}

.subtitle--welcome {
  margin-bottom: 24px;
}

.about-paragraph {
  margin-bottom: 24px;
}

.about-image {
  width: 100%;
  /* aspect-ratio: 1/1; */
}
.about-image-wrapper {
  display: flex;
  flex-flow: column;
  overflow: hidden;
  max-width: 80%;
  margin: 4px auto 20px;
  border-radius: 50%;
  box-shadow: 0 0 10px 0 var(--color-primary) inset, 0 0 10px 4px var(--color-primary);
  /* justify-content: center; */
}
.about-image-layer {
  position: absolute;
  z-index: 1000;
  width: 100%;
  height: 100%;
  background-color: var(--color-primary);
  opacity: 0;
}

.btn-wrapper--contact {
  height: 40px;
  width: 100%;
}

@media (min-width: 768px) {
  .about-wrapper {
    display: flex;
    flex-flow: row nowrap;
    align-items: center;
    gap: 70px;
  }

  .about-image-wrapper {
    flex: 0 0 40%;
    max-width: 40%;
    max-height: 306.48px;
    align-self: center;
    margin: 4px 0 0;
  }
  .about-image-wrapper:hover .about-image-layer {
    opacity: 0;
  }
  .about-image-layer {
    opacity: 0;
    transition: opacity 0.6s;
  }

  .about-text-wrapper {
    flex: 0 0 calc(60% - 70px);
    max-width: calc(60% - 70px);
  }

  .btn-wrapper--contact {
    width: 200px;
  }

  #about {
    margin-bottom: 120px;
  }
}
@media (min-width: 992px) {
  .about-image-wrapper {
    max-height: 100%;
  }

  .btn-wrapper--contact {
    height: 50px;
  }

  #about {
    margin-bottom: 0;
    height: calc(100vh - 160px);
  }
}
/* contact styling */
.contact-container {
  border-radius: 35px;
  background-color: var(--color-primary-darker);
  padding: 35px 5%;
}
.contact-container .heading {
  color: var(--color-body-dark);
}
.contact-wrapper {
  padding-bottom: 60px;
}
.contact-wrapper .text-image-wrapper {
  margin-bottom: 40px;
}
.contact-image-wrapper {
  width: 315px;
  height: 315px;
  margin-bottom: 20px;
  border-radius: 50%;
  overflow: hidden;
}
.contact-image {
  width: 100%;
  height: 100%;
  aspect-ratio: 1/1;
  object-fit: cover;
}
.contact-text {
  font-size: 26px;
  text-align: center;
  color: var(--color-body-dark);
  font-weight: 700;
}
.contact-form .form__send-btn {
  height: 40px;
  margin-bottom: 20px;
}
.contact-form .form__submit-message .error,
.contact-form .form__submit-message .success {
  height: 0;
  font-size: 22px;
  opacity: 0;
  transition: opacity 0.9s;
}
.contact-form .form__submit-message .show-message {
  height: auto;
  opacity: 1;
}
.contact-form .form__submit-message p {
  margin-bottom: 0;
}

.input-wrapper {
  width: 100%;
  height: 35px;
  margin-bottom: 16px;
  border-radius: 0;
}
.input-wrapper--message {
  height: auto;
}
.input-wrapper input {
  display: block;
  width: 100%;
  height: 100%;
}
.input-wrapper textarea {
  width: 100%;
  min-width: 100%;
  max-width: 100%;
}
.input-wrapper input,
.input-wrapper textarea {
  border: 0;
  border-radius: 10px;
  padding: 8px;
  background-color: var(--color-body-dark);
  color: var(--color-body);
  font-family: var(--font-handwriting);
  font-size: 20px;
  font-weight: 700;
}
.input-wrapper input:focus-visible,
.input-wrapper textarea:focus-visible {
  outline: 0;
}
.input-wrapper input::-webkit-input-placeholder,
.input-wrapper textarea::-webkit-input-placeholder {
  /* Chrome/Opera/Safari */
  color: #adb5bd;
}
.input-wrapper input::-moz-placeholder,
.input-wrapper textarea::-moz-placeholder {
  /* Firefox 19+ */
  color: #adb5bd;
}
.input-wrapper input:-ms-input-placeholder,
.input-wrapper textarea:-ms-input-placeholder {
  /* IE 10+ */
  color: #adb5bd;
}
.input-wrapper input:-moz-placeholder,
.input-wrapper textarea:-moz-placeholder {
  /* Firefox 18- */
  color: #adb5bd;
}

@media (min-width: 768px) {
  .contact-container {
    padding: 35px 8%;
  }
  .contact-wrapper .text-image-wrapper {
    display: flex;
    flex-flow: row nowrap;
  }
  .contact-image-wrapper {
    flex: 0 0 315px;
    max-width: 315px;
  }
  .contact-text-wrapper {
    flex: 0 0 263.61px;
    max-width: 263.61px;
    padding-left: 20px;
  }
  .contact-text {
    font-size: 32px;
  }
  .contact-form {
    display: flex;
    flex-flow: row wrap;
    column-gap: 30px;
  }
  .contact-form .form__send-btn {
    height: 50px;
    width: 180px;
  }
  .contact-form .form__send-btn .btn:hover i {
    transform: translate(5px, -5px);
  }

  .input-wrapper {
    flex: 0 0 calc(50% - 15px);
    max-width: calc(50% - 15px);
  }
  .input-wrapper--message {
    flex: 1 1 100%;
    max-width: 100%;
  }
}
@media (min-width: 992px) {
  .contact-container {
    padding: 75px 10%;
  }
  .contact-wrapper {
    display: flex;
    flex-flow: row nowrap;
  }
  .contact-wrapper .text-image-wrapper {
    flex-flow: column;
    max-height: 500px;
  }
  .contact-image-wrapper, .contact-text-wrapper {
    flex: 0 0 315px;
    max-width: 315px;
    padding-left: 0;
  }
  .contact-form {
    padding-left: 70px;
    max-height: 500px;
    flex: 0 0 calc(100% - 315px);
    max-width: calc(100% - 315px);
  }

  .input-wrapper {
    height: 50px;
  }
  .input-wrapper--message {
    height: auto;
    max-width: 100%;
  }
  .input-wrapper input,
  .input-wrapper textarea {
    padding: 10px;
    font-size: 24px;
  }
}
/* nav styling */
.nav-container {
  position: fixed;
  top: 0;
  z-index: 2000;
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: 70px;
  width: 100vw;
  box-shadow: 0 3px 10px var(--color-primary-opacity);
  background-color: var(--color-body-dark);
}
.nav-container .nav-logo {
  flex: 0 0 35%;
  max-width: 35%;
  max-height: 70px;
  font-size: 26px;
}

.nav-container .nav-logo img {
  max-height: 50px;
}

.nav-container .nav-links {
  flex: 0 0 55%;
  display: flex;
  justify-content: space-between;
}
.nav-container .nav-link {
  color: var(--color-primary);
  font-size: 20px;
}
.nav-container .nav-link:hover {
  color: var(--color-secondary);
}
.nav-container .social-media-icons {
  display: none;
}

@media (min-width: 768px) {
  .nav-container {
    justify-content: flex-start;
  }
  .nav-container .nav-logo {
    flex: 0 0 40%;
    max-width: 40%;
    color: var(--color-secondary);
  }
  .nav-container .nav-links {
    flex: 0 0 50%;
  }
  .nav-container .nav-link {
    font-size: 24px;
  }
  .nav-container .social-media-icons {
    flex: 0 0 10%;
    display: block;
    text-align: right;
  }
  .nav-container .social-media-icons .social-icon {
    font-size: 40px;
    color: var(--color-secondary);
    cursor: pointer;
  }
  .nav-container .social-media-icons .social-icon i {
    transform: scale(1);
    transition: transform 0.33s;
  }
  .nav-container .social-media-icons .social-icon:hover i {
    transform: scale(1.1);
  }
}
@media (min-width: 992px) {
  .nav-container .nav-logo {
    flex: 0 0 58%;
    max-width: 58%;
  }
  .nav-container .nav-links {
    flex: 0 0 35%;
  }
  .nav-container .nav-link {
    font-size: 24px;
  }
  .nav-container .social-media-icons {
    flex: 0 0 6%;
  }
}
/* project styling */
.heading--work {
  margin-bottom: 8px;
}

.heading--area {
  margin-bottom: 35px;
}

.area-container {
  margin-top: 50px;
}

.image-wrapper {
  text-align: center;
}

.project-text {
  text-align: center;
}

.work-wrapper {
  margin-bottom: 100px;
}
.work-wrapper .image-wrapper,
.work-wrapper .text-wrapper {
  padding: 5% 8%;
  border-radius: 10px;
}
.work-wrapper .image-wrapper {
  margin-bottom: 40px;
  box-shadow: 0 0 10px 0 var(--color-secondary) inset, 0 0 10px 4px var(--color-secondary);
}
.work-wrapper .text-wrapper {
  box-shadow: 0 0 10px 0 var(--color-primary) inset, 0 0 10px 4px var(--color-primary);
}

@media (min-width: 768px) {
  .work-wrapper {
    display: flex;
    flex-flow: row nowrap;
    column-gap: 70px;
    margin-bottom: 60px;
    color: var(--color-body);
  }
  .work-wrapper .image-wrapper,
  .work-wrapper .text-wrapper {
    padding: 3% 4.5%;
  }
  .work-wrapper .image-wrapper {
    flex: 0 0 40%;
    max-width: 40%;
    margin-bottom: 0;
  }
  .work-wrapper .text-wrapper {
    flex: 0 0 calc(60% - 70px);
    max-width: calc(60% - 70px);
  }
  .work-wrapper--b .image-wrapper {
    order: 2;
  }

  .area-container {
    margin-top: 30px;
  }
}
@media (min-width: 992px) {
  .work-wrapper {
    column-gap: 100px;
    margin-bottom: 80px;
  }
  .work-wrapper .image-wrapper,
  .work-wrapper .text-wrapper {
    padding: 2% 3%;
  }
  .work-wrapper .text-wrapper {
    flex: 0 0 calc(60% - 100px);
    max-width: calc(60% - 100px);
  }

  .area-container {
    margin-top: 60px;
  }
}

/* footer styling */
.footer-container {
  width: 100vw;
  min-height: 50px;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: 25px 5%;
  box-shadow: 0 -3px 10px var(--color-primary-opacity);
  background-color: var(--color-body-dark);
}

.footer-left {
  flex: 0 0 50%;
  display: flex;
  flex-direction: column;
  gap: 15px;
}

.footer-right {
  flex: 0 0 50%;
  display: flex;
  flex-flow: row wrap;
  justify-content: flex-end;
}

.footer__link {
  color: var(--color-primary);
}

.footer__link:hover {
  color: var(--color-secondary);
}

.footer__copyright {
  margin-bottom: 0;
}

@media (min-width: 768px) {
  .footer-container {
    min-height: 70px;
    padding: 25px 8%;
    font-size: 24px;
  }
}

@media (min-width: 992px) {
  .footer-left {
    flex-flow: row wrap;
    gap: 25px;
  }
}
