/* Global variables. */ :root { --breakpoint: 800px; --border-radius: .8rem; --padding: 1rem; --a-padding: 2px; --margin: calc(var(--padding) + var(--border-radius)); /* Animation Speeds*/ --transition-fast: 200ms; --transition-slow: 400ms; /* Default (light) theme*/ --bg: #ebd5c7; --accent: #4E604E; --accent-contrast: #F1E6DF; --contrast: #3C3CFF; --contrast-light: #8585FF; --warn: red; --success: green; --font: #000; --font-reduced: rgba(0, 0, 0, 70%); font-family: sans-serif; font-size: medium; } @view-transition { navigation: auto; } ::view-transition-group(*) { animation-duration: var(--transition-fast); } *, *::before, *::after { box-sizing: border-box; } body { margin: 0; background: var(--bg); } footer { padding-top: var(--padding); color: var(--font-reduced); view-transition-name: footer; } main, footer { margin: 0px calc(var(--padding) / 2); a { color: var(--contrast); transition: all var(--transition-fast); padding: var(--a-padding); border-radius: 5px; cursor: pointer; &:hover, &:focus { background-color: var(--accent); color: var(--accent-contrast); transition: all var(--transition-fast); } &[target="_blank"] { &:after { background-color: var(--contrast); content: ""; display: inline-flex; height: 0.7em; margin-left: 4px; -webkit-mask-image: url(/img/external.svg); mask-image: url(/img/external.svg); -webkit-mask-size: cover; mask-size: cover; width: 0.7em; } &:hover:after, &:focus:after { background-color: var(--accent-contrast); } } &.widget { display: inline-flex; &:hover, &:focus { background: none; } } } } h1 { margin: 0 0 2rem 0; } code { font-size: large; } button { border: none; border-radius: .2rem; background-color: var(--contrast); color: var(--accent-contrast); padding: .4rem; &:hover, &:focus { background-color: var(--accent); transition: all var(--transition-fast); cursor: pointer; } } .grid { display: grid; grid-gap: var(--padding); &.auto-fill { grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)); } &.auto-fit { grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); } &.button-wall { grid-template-columns: repeat(auto-fit, 88px); } } .button { width: calc(88px + var(--a-padding)*2); height: calc(31px + var(--a-padding)*2); } .card { text-decoration: none; padding: 0; margin: var(--a-padding); &:not(:hover) { border-radius: calc(var(--border-radius)*2); } > div { border-radius: inherit; background: var(--accent); padding-bottom: calc(var(--border-radius)*2); color: var(--accent-contrast); cursor: pointer; height: 100%; overflow: hidden; img { /*border-radius: calc(var(--border-radius)*2) calc(var(--border-radius)*2) 0px 0px;*/ width: 100%; max-width: 100%; height: auto; } div { margin: calc(var(--padding)/2); } h2 { margin-top: 0; } } &.card-image-radius-large > div { border-radius: calc(var(--border-radius)*3); } } .error { color: var(--warn); } .success { color: var(--success); } .hero-img { max-width: 100%; width: 100%; height: auto; border-radius: calc(var(--border-radius)*2); background-size: contain; background-repeat: no-repeat; } @media prefers-reduced-motion { :root { --transition-fast: 0.01ms; --transition-slow: 0.01ms; } @view-transition { navigation: none; } } @media screen and (min-width: 800px) { body { display: grid; grid-template-columns: 1fr minmax(var(--breakpoint), 2.5fr) 1fr; } main, footer { grid-column: 2 / span 1; margin: 0px; } } header { position: sticky; top: 0; z-index: 900; background: var(--bg); display: flex; h1 { margin: 0px 10px; width: fit-content; align-self: center; } .logo { height: 4rem; max-height: 4rem; width: auto; cursor: pointer; } & > nav { display: none; } details { margin: auto 10px auto auto; text-align: right; & > summary { cursor: pointer; list-style: none; display: inline-flex; &::marker, &::-webkit-details-marker { display: none; } &::after { background-color: var(--font); content: ""; height: 2em; -webkit-mask-image: url(/img/menu.svg); mask-image: url(/img/menu.svg); -webkit-mask-size: cover; mask-size: cover; width: 2em; transition: transform 0.3s ease, opacity 0.15s ease; } } } details[open] { & > summary::after { -webkit-mask-image: url(/img/close.svg); mask-image: url(/img/close.svg); transform: rotate(90deg); } } nav { position: absolute; text-align: right; top: 100%; left: 0; width: 100%; box-shadow: 0px var(--border-radius) calc(var(--border-radius) / 2) rgba(0, 0, 0, 0.4); background: var(--bg); ul { margin: 0; padding: 0; list-style: none; } li { margin-bottom: 1em; margin-right: 1em; a { transition: color var(--transition-fast) ease-in-out; color: var(--font-reduced); text-decoration: none; font-size: 1.2rem; text-transform: uppercase; cursor: pointer; &.current { color: var(--font); } &:hover, &:focus { color: var(--font); } } } } } @media prefers-reduced-motion { nav > li > a{ transition: none; } header { details > summary::after { transition: none; } details[open] > summary::after { transform: none; } } } @media screen and (min-width: 800px) { header { grid-column: 2 / span 1; padding: var(--padding) 0px; display: grid; grid-template-columns: auto auto minmax(400px, 3fr); .logo { grid-column: 1 / span 1; border-radius: calc(var(--border-radius) - .1rem); } & > details { display: none; } & > nav { all: unset; grid-column: 3 / span 1; display: flex; justify-content: flex-end; align-items: center; ul { display: flex; justify-content: flex-end; } li { margin-bottom: 0; } } } } form { width: 100%; > *:not(:last-child) { display: block; margin-bottom: .7rem; input, textarea { padding: .2rem .4rem; margin-top: .3rem; width: 100%; border-radius: .2rem; border: none; } } input[type=submit] { border: none; border-radius: .2rem; background-color: var(--contrast); color: var(--accent-contrast); padding: .4rem; &:hover, &:focus { background-color: var(--accent); transition: all var(--transition-fast); cursor: pointer; } } input[type=checkbox], input[type=submit] { width: unset; margin-top: unset; } .mandatory:before { content: "*"; color: var(--warn); margin-right: 0.2rem; } } dialog.portfolio { width: 100%; height: 100%; padding: var(--padding); border: none; background-color: rgba(255, 255, 255, 0.8); backdrop-filter: blur(15px); div { height: 100%; width: 100%; display: flex; justify-content: center; align-items: center; } button.portfolio-close { position: fixed; top: var(--padding); right: var(--padding); z-index: 999; } a.portfolio-open-full-quality { position: fixed; bottom: var(--padding); right: var(--padding); z-index: 999; } img { width: 100%; height: 100%; object-fit: contain; } } .portfolio-section { > div { width: fit-content; > button { display: contents; } } } .gallery { display: flex; flex-direction: column; gap: 5px; } .gallery-row { display: flex; width: 100%; gap: 5px; > div > button { all: unset; background-color: var(--bg); display: block; transition: all var(--transition-fast); &:hover, &:focus { cursor: zoom-in; border-radius: 1rem; } > img { border-radius: inherit; width: 100%; height: auto; object-fit: cover; display: block; } } } .portfolio-card { img { height: 15rem; object-fit: cover; } } @media (prefers-color-scheme: dark) { dialog.portfolio { background-color: rgba(0, 0, 0, 0.9); a.portfolio-open-full-quality { color: var(--contrast-light); &[target="_blank"]:after { background-color: var(--contrast-light); } } a.portfolio-open-full-quality:hover { color: var(--accent-contrast); &[target="_blank"]:after { background-color: var(--accent-contrast); } } } }
