11ty-resume/src/scss/critical.scss

374 lines
6.1 KiB
SCSS

@use './components/colors';
@use './components/variables';
@use './components/reset';
@use './components/superminimal';
@use './components/utilities';
@use './components/focus';
@use './components/button';
@use './components/skip-link';
@use './components/icons';
html {
scroll-padding-top: 2rem;
@media screen and (max-width: 767px) {
scroll-padding-top: 8rem;
}
}
body {
background: rgb(var(--sand-400));
background: var(--bg-gradient);
header, footer {
padding: .5rem clamp(.2rem, 3vw, 2rem);
}
}
header {
background-color: var(--primary);
/* background: inherit;
background-attachment: fixed; */
position: fixed;
z-index: 10;
inset-block-start: 0;
inset-inline: 0;
nav {
ul {
display: flex;
justify-content: flex-end;
padding: 0;
list-style: none;
flex-wrap: wrap;
}
li {
padding: 6px 20px;
padding: 6px clamp(10px, 3vw, 20px);
margin: 0;
text-align: end;
}
a[aria-current="page"] {
color: var(--text-2);
text-decoration: underline;
font-weight: var(--font-weight-semibold)
}
}
}
main {
margin: 0;
padding: 0;
h2 {
margin-block: 2rem 1rem;
font-size: calc(var(--font-size) * 1.6);
}
.list-inline {
--item-gap: 0;
}
ul:not(.list-inline) {
margin: 0;
padding: 0;
list-style-type: none;
}
li {
--item-separator: none;
margin: 0;
padding: 0;
}
}
footer {
/* background-color: var(--secondary); */
background-color: rgb(var(--forest-400));
justify-items: center;
margin-block-start: 1.5rem;
> div {
display: flex;
justify-content: space-between;
width: 100%;
align-content: center;
align-items: center;
}
.list-inline {
a {
text-decoration: underline;
--item-color: var(--text-2);
}
}
.socials-list {
margin: 0;
--item-gap: .2ch;
--item-separator: '';
}
}
i {
vertical-align: text-top;
fill: var(--fill-color, var(--primary-light));
display: inline-block;
svg {
aspect-ratio: 1;
font-size: 1.2rem;
}
}
.hero-section {
height: 90vh;
div {
text-align: center;
display: flex;
flex-direction: column;
align-items: center;
justify-content: end;
}
p {
max-width: 48ch;
}
@media screen and (min-width: 768px) {
div {
text-align: start;
align-items: start;
}
}
}
.hero-title {
font-size: 1.8rem;
@media screen and (min-width: 768px) {
font-size: 4rem;
}
}
.projects-section {
ul {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(15rem, 1fr));
gap: 1rem;
}
li {
border-radius: var(--border-radius);
overflow: hidden;
}
article {
--background: url('https://placehold.co/200x150'); // Default background
position: relative;
height: 100%;
padding: .4rem;
display: flex;
flex-direction: column;
justify-content: space-between;
gap: 2.5rem;
z-index: 1;
background: var(--background);
background-repeat: no-repeat;
background-size: cover;
}
a {
&:hover {
color: #3a3a3a;
transition: color .2s ease-in-out;
}
&:before,
&:after {
--icon-size: 1.2rem;
}
}
.top {
width: 100%;
display: flex;
justify-content: space-between;
}
.links {
display: flex;
gap: .35rem;
align-self: flex-end;
}
.content {
padding: 1rem .4rem 0 .4rem;
}
}
.about-section,
.competences-section,
.projects-section,
.experiences-section,
.download-section {
padding-block: 2rem;
margin-block: 3.5rem;
}
.about {
display: flex;
gap: 2rem;
align-items: center;
& > div:first-child {
inline-size: 30%;
}
& > div:last-child {
inline-size: 60%;
}
img {
margin: 1rem auto;
inline-size: 100%;
inline-size: clamp(200px, 100%, 400px);
aspect-ratio: 1;
border-radius: 100%;
border: 4px solid var(--primary-dark)
}
@media screen and (max-width: 767px) {
flex-direction: column;
& > div:first-child, & > div:last-child {
inline-size: 100%;
}
img {
inline-size: clamp(200px, 50vw, 300px);
margin: 0 auto;
}
}
}
.socials-list {
margin-block-start: 1rem;
gap: .2rem;
a {
&:hover {
--item-color: black;
}
}
&--label {
gap: 1rem;
a {
color: black;
--icon-color: #262626;
text-decoration: underline;
text-underline-offset: .25rem;
text-decoration-color: #262626;
font-weight: 500;
}
}
}
.timeline {
display: flex;
flex-direction: column;
position: relative;
padding: 0;
margin-top: 1.4rem;
&:before {
content: '';
position: absolute;
inline-size: 6px;
background-color: var(--light-1);
inset: 0 0 0 1.5rem;
margin-inline-start: -3px;
}
li {
--size: 3rem;
position: relative;
margin: 1.4rem 0;
padding: 0 0 0 calc(var(--size) + .8rem);
&:last-child {
margin-bottom: 3rem;
}
&:first-child {
margin-top: 0;
margin-top: -20px;
}
&:before {
content: '';
position: absolute;
aspect-ratio: 1;
inline-size: var(--size);
background-color: var(--light-1);
border: 6px solid rgb(var(--forest-500));
/* border: 6px solid var(--secondary-dark); */
inset-inline-start: 0;
// inset-inline-start: .9rem;
inset-block-end: 50%;
transform: translateY(50%);
// inset-block-end: 0;
// inset-block-start: 1.5rem;
border-radius: 50%;
z-index: 1;
transition: all .2s ease-in-out;
}
&:hover {
&:before {
border-color: rgb(var(--forest-600));
}
}
}
}
.experiences-section {
p {
margin: 0;
}
}
.download-section {
text-align: center;
> div {
gap: .8rem;
}
p {
font-size: 1.4rem;
}
}
.btn-download {
color: rgb(var(--forest-200));
}
.competences-section {
margin-left: 4vw;
> div {
display: flex;
flex-direction: column;
justify-content: space-around;
}
.col {
width: 100%;
margin-bottom: 2rem;
}
@media screen and (min-width: 991px) {
> div {
flex-direction: row;
}
.col {
width: 40%;
}
}
}