*, *:before, *:after { box-sizing: border-box; } html { overflow-x: hidden; scroll-behavior: smooth; } body { margin: 0; font-family: "Nunito", sans-serif; } body.dark-mode .bg { opacity: 0 !important; } body.dark-mode .main h1 { color: #ddd; } body.dark-mode .main em { color: #ddd; } body.dark-mode .main a { color: #ddd; } body.dark-mode .main a:before, body.dark-mode .main a:after { background: rgba(221, 221, 221, 0.2); } body.dark-mode section:nth-child(even), body.dark-mode footer:nth-child(even) { background: #111 !important; color: white; } body.dark-mode section:nth-child(odd), body.dark-mode footer:nth-child(odd) { background: #000 !important; color: white; } body.dark-mode .works-card .text-container { color: #ddd !important; } body.dark-mode .works-card .text-container a { color: inherit !important; background: rgba(255, 255, 255, 0.1) !important; box-shadow: none !important; } body.dark-mode #contact { color: #ddd !important; } body.dark-mode footer { color: #ddd !important; } .main { min-height: 100vh; position: relative; z-index: 10; display: flex; justify-content: center; align-items: flex-start; flex-direction: column; overflow-y: hidden; } .main > * { position: relative; } .main > canvas#bg { position: absolute; top: 0; left: 0; } .main .text-container { text-align: left; max-width: 50rem; margin: auto auto auto 13vw; } .main h1 { font-size: 4rem; font-weight: 600; margin: 0 0 2rem; color: #333; } .main h3 { margin: 1rem 0 0; font-size: 1.7rem; line-height: 1.4; font-weight: normal; color: #999; } .main em { color: #333; font: inherit; } .main a { color: #333; text-decoration: none; border-bottom: 0.2rem solid transparent; white-space: nowrap; position: relative; } .main a:before, .main a:after { content: ""; bottom: 0.4rem; left: 0; width: 100%; height: 0.1rem; background: rgba(51, 51, 51, 0.2); position: absolute; opacity: 0.2; transition: all 0.2s ease; } .main a:before { transform: scaleX(0); transform-origin: center left; } .main a:after { opacity: 0.5; } .main a:hover:before { transform: scaleX(1); opacity: 1; } .works-card { height: 100vh; display: flex; justify-content: flex-start; align-items: center; max-width: 100%; position: relative; z-index: 10; } .works-card > div { width: 50%; position: relative; height: 100%; } .works-card .image-container img { width: 133%; position: absolute; top: 0; bottom: 0; margin: auto; border-radius: 0.2rem; box-shadow: 0 0 10rem rgba(0, 0, 0, 0.1), 0 0.25rem 1rem rgba(0, 0, 0, 0.33); } .works-card .image-container:nth-child(1) img { right: 0; } .works-card .image-container:nth-child(2) img { left: 0; } .works-card .text-container { display: flex; justify-content: center; align-items: center; flex-direction: column; padding: 0 2rem; transition: all 0.225s ease; } .works-card .text-container > * { max-width: 30rem; width: 100%; } .works-card .text-container h1 { font-size: 3.3rem; margin: 0 0 1rem; } .works-card .text-container p { font-size: 1.15rem; line-height: 1.5; margin: 1rem 0 0; } .works-card .text-container a { color: black; text-decoration: none; position: relative; background: rgba(0, 0, 0, 0.05); display: inline-block; padding: 1rem 2rem 1rem 1.25rem; border-radius: 0.1rem; margin-top: 1rem; box-shadow: 0 0.05rem 0.025rem rgba(0, 0, 0, 0.3); margin-right: 1rem; } .works-card .text-container a:before { position: absolute; bottom: 1.2rem; left: 1.25rem; width: calc(100% - 3.25rem); content: ""; height: 0.115rem; transition: all 0.2s ease; border-top: 0.115rem solid black; opacity: 0.2; box-sizing: border-box; transform: scaleX(0); transform-origin: center left; } .works-card .text-container a:after { content: ""; position: absolute; right: 1.25rem; pointer-events: none; font-size: 0.66rem; top: 0; bottom: 0; height: 0.33rem; width: 0.33rem; transform: rotate(45deg); border: 1px solid; border-bottom: 0; border-left: 0; line-height: 1.2rem; margin: auto; opacity: 0.7; transition: all 0.2s ease; } .works-card .text-container a:hover:before { transform: scaleX(1); } .works-card .text-container a:hover:after { right: 1.15rem; } .works-card .text-container a.dark { color: rgba(255, 255, 255, 0.8); background: rgba(255, 255, 255, 0.9); } .works-card .text-container a.dark:before { border-color: inherit; } .works-card .text-container a.dark:after { border-color: inherit; } #contact { position: relative; z-index: 10; text-align: center; padding: 5rem 2rem 3rem; background: white; } #contact h1 { font-size: 3.3rem; margin: 0 0 2rem; } #contact p { font-size: 1.15rem; line-height: 1.5; margin: 1rem auto 0; } #contact .contact-info-container { max-width: 40rem; margin: 2rem auto; text-align: left; display: flex; flex-direction: column; flex-wrap: wrap; height: 12rem; } #contact .contact-info-container a.contact-method { text-decoration: none; color: inherit; display: block; width: 50%; height: 6rem; position: relative; padding-left: 6rem; display: flex; flex-direction: column; align-items: flex-start; justify-content: center; overflow: hidden; } #contact .contact-info-container a.contact-method h3, #contact .contact-info-container a.contact-method p { font-weight: normal; margin: 0; transition: all 0.2s ease; } #contact .contact-info-container a.contact-method h3 { font-size: 1.5rem; line-height: 1.4; transform: translateY(0.6rem); } #contact .contact-info-container a.contact-method p { line-height: 1.25rem; height: 1.25rem; transform: translateY(1rem); opacity: 0; color: #777; font-size: 0.9rem; } #contact .contact-info-container a.contact-method i { font-size: 2rem; line-height: 6rem; position: absolute; top: 0; left: 0; width: 6rem; height: 6rem; text-align: center; } #contact .contact-info-container a.contact-method i:before { position: relative; z-index: 10; } #contact .contact-info-container a.contact-method i:after { position: absolute; top: 0; left: 0; right: 0; bottom: 0; margin: auto; width: 60%; height: 60%; border-radius: 50%; opacity: 0; transform: scale(0.7); content: ""; transition: all 0.2s ease; background: #333; } #contact .contact-info-container a.contact-method i.email:before { content: "@"; font-style: normal; font-weight: bold; line-height: 5.5rem; top: 0; left: 0; width: 100%; height: 100%; position: absolute; text-align: center; } #contact .contact-info-container a.contact-method:hover h3 { transform: translateY(0); } #contact .contact-info-container a.contact-method:hover p { transform: translateY(0); opacity: 1; } footer { position: relative; z-index: 10; text-align: center; padding: 3rem 0; background: #1f2e3a; color: white; font-size: 1.2rem; } .ticker { padding: 2rem 0 0; font-size: 0.9rem; opacity: 0.7; font-family: monospace; letter-spacing: 1px; } .ticker:after { content: "_"; opacity: 0.4; animation: blink 0.5s infinite; } @keyframes blink { 0% { opacity: 0; } 49% { opacity: 0; } 51% { opacity: 1; } 100% { opacity: 1; } } @media (max-width: 900px), (orientation: portrait) { .main > .text-container { margin: auto; padding: 2rem; } .works-card { flex-direction: column; height: auto; } .works-card > div { height: auto; width: 100%; } .works-card .text-container { order: 2; padding-bottom: 2rem; } .works-card .image-container { order: 1; padding-top: 3rem; min-height: calc(45vw + 5rem); } .works-card .image-container img { width: 80vw; margin: auto; display: block; top: 0; bottom: 0; left: 0; right: 0; margin: auto; box-shadow: 0 0 5rem rgba(0, 0, 0, 0.1), 0 0.25rem 1rem rgba(0, 0, 0, 0.33); } #contact { text-align: left; } #contact .contact-info-container a.contact-method h3 { transform: translateY(0); } #contact .contact-info-container a.contact-method p { transform: translateY(0); opacity: 1; } } @media (max-width: 600px) { #contact .contact-info-container { height: auto; } #contact .contact-info-container a.contact-method { width: 100%; } } @media (max-width: 400px) { .main > .text-container h1 { font-size: 3rem; } .main > .text-container h3 { font-size: 1.5rem; } .works-card > .text-container p { font-size: 1rem; } .works-card > .text-container h1 { font-size: 2.6rem; } } .bg-scroller { z-index: 5; position: fixed; top: 0; left: 0; width: 100%; height: 100vh; } .bg-scroller .bg { position: absolute; top: 0; left: 0; width: 100%; height: 100%; opacity: 0; will-change: opacity; } .clapper { position: fixed; bottom: 0; left: 0; width: 100%; height: 10rem; line-height: 10rem; text-align: center; z-index: 100000; font-size: 5rem; pointer-events: none; transition: none; opacity: 0; } .clapper.clapping { animation: clap 1s ease-in-out; } @keyframes clap { 0% { opacity: 1; } 49% { opacity: 0; } 51% { opacity: 1; } 100% { opacity: 0; } } @media (min-width: 1800px) { html { font-size: 20px; } } @media (min-width: 2400px) { html { font-size: 24px; } } @media (min-width: 2800px) { html { font-size: 32px; } } @media (min-width: 3600px) { html { font-size: 36px; } } /*# sourceMappingURL=style.css.map */