@charset "UTF-8";

*,
 *:before,
 *:after {
     box-sizing: border-box;
}

html {
     font-family: sans-serif;
     min-height: 100dvh;
     scroll-behavior: smooth;
}

:root {
    --color-primary: hsl(205, 62%, 18%);
    --color-secondary: hsl(208, 72%, 82%);
    --color-tertiary: hsl(207,68%,75%);
    --color-cta: hsl(267, 61%, 54%);
    --color-white: hsl(0, 0%, 100%);
    --color-gray-light: hsl(0, 0%, 96%);
    --color-gray: hsl(0, 0%, 83%);
    --color-gray-dark: hsl(0, 0%, 40%);
    --color-black: hsl(0, 0%, 0%);

    --header-hero: url(../../images/hero.webp);
}

@keyframes appear-mobile {
    0% {
        transform: translateX(-50px) translateY(-50px);
        opacity: 0;
    }
    100% {
        transform: translateX(20px) translateY(20px);
        opacity: 1;
        
    }
}

@keyframes appear-desktop {
    0% {
        transform: translateX(-50px) translateY(-50px);
        opacity: 0;
    }
    100% {
        transform: translateX(20px) translateY(20px);
        opacity: 1;
    }
}

@keyframes fade-in {
    0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

body {
    margin: 0;
    min-height: 100dvh;
    background-color: var(--color-primary)
}

.wrapper {
     width: min(100%, 1000px);
     background: var(--color-secondary);
}

h2 {
    padding: 10px;
    font-size: 1.6rem;
    margin: 10px;
}

p {
     margin: 0 0 16px;
     line-height: 1.6;
     font-size: 1.2rem;
     max-width: 75ch;
}

img {
     width: 100%;
     border: 6px solid var(--color-secondary);
}

a {
     text-decoration: none;
}

header {
     position: relative;
     background-image: var(--header-hero);
     background-repeat: repeat;
     margin: 0 auto;
     height: 150px;
}
 
header h1 {
     margin: 0;
     padding: 0;
     color: var(--color-primary);
     line-height: 48px;
     font-size: 36px;
     letter-spacing: 2px;
     transform: translateX(5px) translateY(5px);
     animation: appear-mobile 0.6s cubic-bezier(0.390, 0.575, 0.565, 1.000) both;
}

header h2 {
     animation: appear-mobile 0.6s cubic-bezier(0.390, 0.575, 0.565, 1.000) both;
}

main {
      animation: fade-in 1.8s cubic-bezier(0.390, 0.575, 0.565, 1.000) 0.5s both;
}

ul li {
    padding: 10px;
    font-size: 1.2rem;
    list-style-type: "⋆";
    word-wrap: break-word;
}

ul li a:link {
     color: var(--color-primary);
}

ul li a:visited {
    color: var(--color-primary);
}

ul li a:hover {
    color: var(--color-cta)
}

.section-wrapper {
    background: var(--color-white);
    border: 3px solid var(--color-primary);
    border-radius: 10px;
    margin: 20px;
    padding-left: 20px;
    padding-right: 20px;
}

footer {
     display: flex;
     flex-wrap: wrap;
     gap: 20px;
     margin: 0 20px;
     padding-top: 20px;
     padding-bottom: 10px;
}

footer p {
    color: var(--color-primary);
}
 
footer a {
    color: var(--color-primary);
    text-decoration: none;
    font-size: 24px;
    padding: 0 10px;
}

footer a:hover {
    position: relative;
    text-decoration: none;
    color: var(--color-cta)
}
 
footer :nth-child(1) {
     margin-right: auto;
}
 
footer a[href^="javascript"] {
     position: relative;
     color: var(--color-primary);
     padding: 0 10px;
}
 
footer a[href^="javascript"]:hover {
    color: var(--color-cta);
}

@media (min-width: 768px) {
     
     .wrapper {
         margin: 0 auto;
         box-shadow: 2px 0px 5px var(--color-black);
     }

     header {
          height: 300px;
     }

     header h1 {
         transform: var(--header-h1);
         animation: appear-desktop 0.6s cubic-bezier(0.390, 0.575, 0.565, 1.000) both;
     }
}