@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%);
}

@keyframes swing-in {
    0% {
        transform: rotateY(100deg);
        transform-origin: left;
        opacity: 0;
    }
    100% {
        transform: rotateY(0);
        transform-origin: left;
        opacity: 1;
    }
}

body {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    margin: 0;
    min-height: 100dvh;
    background-color: var(--color-primary)
}

.wrapper {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    gap: 20px;
    grid-column: span 1;
    width: min(100%, 1000px);
    background: var(--color-secondary);
}

h2 {
    padding: 20px;
    margin: 0;
    font-size: 2rem;
    grid-column: span 12;
    text-align: center;
}

p {
     line-height: 1.6;
     font-size: 1.2rem;
     max-width: 75ch;
}

img {
     width: 100%;
}

a {
     text-decoration: none;
}

header {
    grid-column: 1 / 13;
    background-image: url(../../../website-reviews/css/images/hero.webp);
}
 
header h1 {
     grid-column: span 12;
     margin: 40px auto;
     padding: 20px;
     text-align: center;
     color: var(--color-primary);
     line-height: 48px;
     font-size: 36px;
     letter-spacing: 2px;
}

main {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    grid-column: span 12;
    animation: swing-in 0.5s cubic-bezier(0.175, 0.885, 0.320, 1.275) both;
}

ol li {
    padding: 20px;
    font-size: 24px;
    font-weight: bold;
    list-style-type: "⋆";
    overflow-wrap: break-word;
}

ol li a:link {
     color: var(--color-primary);
}

ol li a:visited {
    color: var(--color-primary);
}

ol li a:hover {
    color: var(--color-cta)
}

.section-wrapper {
    grid-column: 2 / 12;
    background: var(--color-white);
    border: 3px solid var(--color-cta);
    border-radius: 10px;
    margin: 20px;
    padding-left: 20px;
    padding-right: 20px;
}

.demo-box {
    display: grid;
    grid-template-columns: repeat(10, 1fr);
    grid-template-rows: repeat(10, 1fr);
    grid-gap: 20px;
    grid-column: 2 / 12;
    background-color: white;
    border: 3px solid var(--color-cta);
    font-weight: bold;
    height: 320px;
}

.box {
    display: flex;
    background-color: lightblue;
    border: 1px solid black;
    justify-content: center;
    text-align: center;
}

.box-css {
    grid-area: 2 / 2 / span 4 / span 4;
}

.box p {
    flex: 1 1 auto;
    align-self: center;
    justify-content: center;
    font-size: clamp(1.5em, 5vw, 5.5em);
}

.box-is {
    grid-area: 7 / 3 / span 2 / span 2;
}

.box-awesome {
    grid-area: 1 / 7 / span 10 / span 3;
    margin-top: 20px;
    margin-bottom: 20px;
}

.text-rotate {
    transform: rotate(-90deg);
}

footer {
     grid-column: span 12;
     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);
     }

     .demo-box {
       height: 600px;
    }
}