mirror of
https://github.com/Sendouc/sendou.ink.git
synced 2026-03-21 18:04:39 -05:00
348 lines
6.7 KiB
CSS
348 lines
6.7 KiB
CSS
.layout__header {
|
|
--item-size: 3rem;
|
|
|
|
position: relative;
|
|
z-index: 501;
|
|
display: grid;
|
|
align-items: center;
|
|
padding: var(--s-4);
|
|
background-color: var(--bg);
|
|
grid-template-columns: 1fr 2fr;
|
|
}
|
|
|
|
.layout__header__logo-container {
|
|
display: grid;
|
|
width: var(--item-size);
|
|
min-width: var(--item-size);
|
|
height: var(--item-size);
|
|
min-height: var(--item-size);
|
|
padding: var(--s-1);
|
|
background-color: var(--bg-lighter);
|
|
background-image: url("/svg/background-pattern.svg");
|
|
border-radius: var(--rounded);
|
|
cursor: pointer;
|
|
justify-self: flex-start;
|
|
place-items: center;
|
|
}
|
|
|
|
.layout__logo {
|
|
max-width: 100%;
|
|
max-height: 100%;
|
|
}
|
|
|
|
.layout__header__search-container {
|
|
display: none;
|
|
}
|
|
|
|
.layout__header__right-container {
|
|
display: flex;
|
|
gap: var(--s-4);
|
|
justify-self: flex-end;
|
|
}
|
|
|
|
.layout__beta__link {
|
|
text-decoration: none;
|
|
}
|
|
|
|
.layout__beta__banner {
|
|
display: flex;
|
|
width: 100%;
|
|
justify-content: center;
|
|
background-color: var(--theme);
|
|
color: var(--button-text-transparent);
|
|
font-size: var(--fonts-xs);
|
|
font-weight: var(--bold);
|
|
gap: var(--s-8);
|
|
overflow-x: hidden;
|
|
white-space: nowrap;
|
|
}
|
|
|
|
.layout__nav {
|
|
display: none;
|
|
justify-content: center;
|
|
background-color: var(--bg-lighter);
|
|
background-image: url("/svg/background-pattern.svg");
|
|
}
|
|
|
|
.layout__nav__items {
|
|
display: inline-flex;
|
|
justify-content: center;
|
|
padding: var(--s-4) var(--s-8);
|
|
background-color: var(--bg-lighter);
|
|
gap: var(--s-12);
|
|
grid-template-columns: repeat(4, 100px);
|
|
}
|
|
|
|
.layout__nav__items__column {
|
|
display: flex;
|
|
flex-direction: column;
|
|
gap: var(--s-2);
|
|
}
|
|
|
|
.layout__nav__link {
|
|
display: flex;
|
|
align-items: center;
|
|
color: var(--text);
|
|
font-size: var(--fonts-sm);
|
|
font-weight: var(--bold);
|
|
gap: var(--s-2);
|
|
text-decoration: none;
|
|
text-transform: capitalize;
|
|
transition: 0.2s transform;
|
|
}
|
|
|
|
.layout__nav__link.disabled {
|
|
filter: grayscale(100%);
|
|
}
|
|
|
|
.layout__nav__link:hover {
|
|
transform: translateX(2px);
|
|
}
|
|
|
|
.layout__nav__column__title {
|
|
color: var(--text-lighter);
|
|
font-size: var(--fonts-xxs);
|
|
font-weight: var(--bold);
|
|
text-transform: uppercase;
|
|
}
|
|
|
|
.layout__nav__link__icon {
|
|
width: 2rem;
|
|
height: 2rem;
|
|
}
|
|
|
|
.layout__main {
|
|
padding-top: var(--s-8);
|
|
}
|
|
|
|
.layout__burger {
|
|
display: flex;
|
|
width: 3rem;
|
|
height: 3rem;
|
|
flex-direction: column;
|
|
align-items: center;
|
|
justify-content: center;
|
|
padding: 0.5rem;
|
|
border: 2px solid;
|
|
border-color: var(--bg-lighter);
|
|
background-color: transparent;
|
|
border-radius: var(--rounded);
|
|
color: inherit;
|
|
cursor: pointer;
|
|
gap: 2px;
|
|
}
|
|
|
|
.layout__burger__top-line {
|
|
transform: none;
|
|
transform-origin: 16px 10px;
|
|
transition-duration: 150ms;
|
|
transition-property: transform;
|
|
transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
|
|
}
|
|
|
|
.layout__burger__top-line.expanded {
|
|
transform: translateY(7px) rotate(45deg);
|
|
}
|
|
|
|
.layout__burger__middle-line {
|
|
opacity: 1;
|
|
transition-duration: 150ms;
|
|
transition-property: opacity;
|
|
transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
|
|
}
|
|
|
|
.layout__burger__middle-line.expanded {
|
|
opacity: 0;
|
|
}
|
|
|
|
.layout__burger__bottom-line {
|
|
transform: none;
|
|
transform-origin: 16px 22px;
|
|
transition-duration: 150ms;
|
|
transition-property: transform;
|
|
transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
|
|
}
|
|
|
|
.layout__burger__bottom-line.expanded {
|
|
transform: translateY(-5px) rotate(-45deg);
|
|
}
|
|
|
|
.layout__mobile-nav {
|
|
position: absolute;
|
|
z-index: 500;
|
|
bottom: 100vh;
|
|
width: 100%;
|
|
height: 100%;
|
|
padding-bottom: var(--s-6);
|
|
background-color: var(--bg-lighter);
|
|
background-image: url("/svg/background-pattern.svg");
|
|
overflow-y: auto;
|
|
|
|
/* TODO: same for Safari */
|
|
overscroll-behavior: contain;
|
|
transition: bottom 0.5s;
|
|
transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
|
|
}
|
|
|
|
.layout__mobile-nav.expanded {
|
|
bottom: 0;
|
|
}
|
|
|
|
.layout__mobile-nav__top-action {
|
|
display: grid;
|
|
padding-top: var(--s-24);
|
|
padding-bottom: var(--s-8);
|
|
background-color: var(--bg);
|
|
gap: var(--s-4);
|
|
place-items: center;
|
|
}
|
|
|
|
.layout__mobile-nav__link__icon {
|
|
width: 2rem;
|
|
height: 2rem;
|
|
}
|
|
|
|
.layout__mobile-nav__link__icon.disabled {
|
|
filter: grayscale(100%);
|
|
}
|
|
|
|
.layout__mobile-nav__links {
|
|
display: grid;
|
|
justify-content: center;
|
|
grid-auto-columns: 1fr;
|
|
grid-auto-rows: 4rem;
|
|
}
|
|
|
|
.layout__mobile-nav__group-title {
|
|
align-self: flex-end;
|
|
padding: var(--s-2) var(--s-3);
|
|
margin-bottom: var(--s-1);
|
|
background-color: var(--bg);
|
|
border-radius: var(--rounded);
|
|
font-weight: var(--bold);
|
|
justify-self: center;
|
|
text-transform: uppercase;
|
|
}
|
|
|
|
.layout__mobile-nav__link {
|
|
display: flex;
|
|
align-items: center;
|
|
padding: 0 var(--s-2);
|
|
border-top: 3px solid var(--bg-lighter);
|
|
margin: 0 var(--s-12);
|
|
background-color: var(--bg);
|
|
color: var(--text);
|
|
font-size: var(--fonts-sm);
|
|
font-weight: var(--bold);
|
|
gap: var(--s-2);
|
|
text-decoration: none;
|
|
text-transform: capitalize;
|
|
}
|
|
|
|
.layout__mobile-nav__link.first {
|
|
border-radius: var(--rounded) var(--rounded) 0 0;
|
|
}
|
|
|
|
.layout__mobile-nav__link.last {
|
|
border-radius: 0 0 var(--rounded) var(--rounded);
|
|
}
|
|
|
|
.layout__search-input__container {
|
|
display: flex;
|
|
height: 1rem;
|
|
align-items: center;
|
|
justify-content: center;
|
|
padding: var(--s-5) var(--s-4);
|
|
background-color: var(--bg-lighter);
|
|
border-radius: var(--rounded);
|
|
}
|
|
|
|
.layout__search-input__container:focus-within {
|
|
outline: 2px solid var(--theme);
|
|
}
|
|
|
|
.layout__search-input {
|
|
width: 12rem;
|
|
height: 2rem;
|
|
flex-grow: 1;
|
|
border: none;
|
|
background-color: var(--bg-lighter);
|
|
color: var(---text);
|
|
font-size: var(--fonts-sm);
|
|
outline: none;
|
|
}
|
|
|
|
.layout__search-input::placeholder {
|
|
color: var(--text-lighter);
|
|
font-weight: var(--semi-bold);
|
|
letter-spacing: 0.5px;
|
|
}
|
|
|
|
.layout__search-input__icon {
|
|
height: 1.25rem;
|
|
color: var(--text);
|
|
}
|
|
|
|
.layout__log-in-button {
|
|
display: flex;
|
|
height: var(--item-size);
|
|
align-items: center;
|
|
justify-content: center;
|
|
padding: 0.5rem;
|
|
border: 2px solid;
|
|
border-color: var(--bg-lighter);
|
|
background-color: transparent;
|
|
border-radius: var(--rounded);
|
|
color: inherit;
|
|
cursor: pointer;
|
|
font-size: var(--fonts-xs);
|
|
font-weight: var(--bold);
|
|
gap: var(--s-2);
|
|
text-decoration: none;
|
|
}
|
|
|
|
.layout__log-in-button > svg {
|
|
width: 1rem;
|
|
}
|
|
|
|
.layout__log-in-button:active {
|
|
transform: translateY(1px);
|
|
}
|
|
|
|
.layout__avatar {
|
|
width: var(--item-size);
|
|
min-width: var(--item-size);
|
|
height: var(--item-size);
|
|
border-radius: var(--rounded);
|
|
}
|
|
|
|
@media screen and (min-width: 640px) {
|
|
.layout__header {
|
|
--item-size: 38px;
|
|
|
|
grid-template-columns: 1fr 1fr 1fr;
|
|
}
|
|
|
|
.layout__header__search-container {
|
|
display: block;
|
|
}
|
|
|
|
.layout__nav {
|
|
display: flex;
|
|
}
|
|
|
|
.layout__burger {
|
|
display: none;
|
|
}
|
|
|
|
.layout__mobile-nav {
|
|
display: none;
|
|
}
|
|
}
|
|
|
|
@media screen and (min-width: 480px) {
|
|
.mobileNavLink {
|
|
margin: 0 var(--s-24);
|
|
}
|
|
}
|