/* Global variables. */ :root { --breakpoint: 800px; --border-radius: .8rem; --padding-small: 0.5rem; --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-very-reduced: rgba(0, 0, 0, 30%); --outline: 0.2rem solid var(--contrast); 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; } *:focus-visible { outline: var(--outline) } body { margin: 0; background: var(--bg); } 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-visible { background-color: var(--accent); color: var(--accent-contrast); } &[target="_blank"] { &:after { background-color: var(--contrast); content: ""; display: inline-flex; height: 0.7em; margin-left: 4px; -webkit-mask-image: url(/img/icons/external.svg); mask-image: url(/img/icons/external.svg); -webkit-mask-size: cover; mask-size: cover; width: 0.7em; transition: all var(--transition-fast); } &:hover:after, &:focus-visible:after { background-color: var(--accent-contrast); } } &.widget { display: inline-flex; &:hover, &:focus-visible { background: none; } } } } footer { padding-top: var(--padding); margin-top: var(--padding); color: var(--font-reduced); view-transition-name: footer; border-top: 2px solid var(--font-very-reduced); } 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-visible { background-color: var(--accent); transition: all var(--transition-fast); cursor: pointer; } } .flex-row-wrap { display: flex; justify-content: space-between; flex-flow: row wrap; } .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 { display: flex; gap: var(--padding-small); flex-flow: row wrap; a.button { width: calc(88px + var(--a-padding)*4); height: calc(31px + var(--a-padding)*4); padding: calc(var(--a-padding)*2); &:after { display: none; } } } .card { text-decoration: none; padding: 0; margin: var(--a-padding); border-radius: calc(var(--border-radius) *0.5); &:hover, &:focus-visible { border-radius: calc(var(--border-radius)*2); } > div { border-radius: inherit; background: var(--accent); padding-bottom: calc(var(--border-radius)); 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; } } } .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-left: 0px; margin-right: 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/icons/menu.svg); mask-image: url(/img/icons/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/icons/close.svg); mask-image: url(/img/icons/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: all var(--transition-fast) ease-in-out; border-bottom: 2px solid transparent; color: var(--font-reduced); text-decoration: none; font-size: 1.2rem; text-transform: uppercase; cursor: pointer; &.current { color: var(--font); border-bottom: 2px solid var(--font-reduced); } &:hover, &:focus-visible { color: var(--font); border-bottom: 2px solid var(--font-reduced); } } } } } @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-visible { 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; } } body:has(dialog.portfolio:open) { overflow: hidden; } dialog.portfolio { margin: 0px; width: 100vw; height: 100dvh; max-width: 100vw; max-height: 100vh; padding: var(--padding); border: none; background-color: rgba(255, 255, 255, 0.8); backdrop-filter: blur(15px); > div { height: 100%; width: 100%; display: flex; flex-direction: column; gap: var(--padding); justify-content: center; > img { width: auto; height: auto; max-width: 100%; max-height: calc(100% - var(--padding) - var(--padding) - var(--padding) - 1rem); border-radius: var(--border-radius); margin: auto auto; } } aside { background-color: var(--bg); border-radius: var(--border-radius); padding: var(--padding); gap: var(--padding); display: flex; flex-direction: row; justify-content: space-between; button { align-self: end; } dl { display: none; order: 3; width: 100%; > div { padding: var(--padding-small) var(--padding) var(--padding-small) var(--padding); &:not(:last-child) { border-bottom: 0.1em solid var(--font-very-reduced); } } dt { display: flex; align-items: center; color: var(--font-reduced); gap: var(--padding-small); span { width: 1.4em; height: 1.4em; img { max-width: 100%; max-height: 100%; height: 1.2em; } } } dd { margin: 0px; } .iso-icon { height: 1.4em; } } a { align-self: end; } } } .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; width: 100%; transition: all var(--transition-fast); &:hover, &:focus-visible { cursor: zoom-in; border-radius: var(--border-radius); } &:focus-visible { outline: var(--outline); } > img { border-radius: inherit; width: 100%; height: auto; object-fit: cover; display: block; } } } .portfolio-card { img { height: 15rem; object-fit: cover; } } @media screen and (min-width: 800px) { dialog.portfolio { > div { flex-direction: row; } aside { flex-grow: 1; flex-direction: column; max-width: 30rem; overflow: scroll; button { align-self: end; } dl { display: initial; order: initial; align-self: baseline; } a { align-self: end; } } > div > img { max-height: 100%; max-width: calc(100% - min(30%, 30rem)); } } } @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); } }*/ } }
