미디어위키:Common.css: 두 판 사이의 차이
외관
잔글편집 요약 없음 |
잔글편집 요약 없음 |
||
| 1번째 줄: | 1번째 줄: | ||
/******************************* | /******************************* | ||
* Module: | * Module:Deck | ||
*******************************/ | *******************************/ | ||
:root { | :root { | ||
-- | --kawa-deck-text: currentColor; | ||
-- | --kawa-deck-icon: currentColor; | ||
-- | --kawa-deck-border: rgba(0, 0, 0, 0.5); | ||
-- | --kawa-deck-border-hover: rgba(0, 0, 0, 0.4); | ||
-- | --kawa-deck-hover-bg: rgba(0, 0, 0, 0.04); | ||
-- | --kawa-deck-speed: 0.3s; | ||
-- | --kawa-deck-timing: cubic-bezier(0.16, 1, 0.3, 1); | ||
} | } | ||
. | .kawa-deck-grid, | ||
. | .kawa-deck-grid * { | ||
box-sizing: border-box; | box-sizing: border-box; | ||
margin: 0; | margin: 0; | ||
| 19번째 줄: | 19번째 줄: | ||
} | } | ||
. | .kawa-deck-grid { | ||
display: flex; | display: flex; | ||
flex-wrap: wrap; | flex-wrap: wrap; | ||
| 27번째 줄: | 27번째 줄: | ||
container-type: inline-size; | container-type: inline-size; | ||
. | .kawa-deck-item { | ||
position: relative; | position: relative; | ||
flex: 0 0 100%; | flex: 0 0 100%; | ||
| 33번째 줄: | 33번째 줄: | ||
aspect-ratio: 1 / 1; | aspect-ratio: 1 / 1; | ||
background-color: transparent; | background-color: transparent; | ||
border: 1px solid var(-- | border: 1px solid var(--kawa-deck-border); | ||
text-decoration: none; | text-decoration: none; | ||
overflow: hidden; | overflow: hidden; | ||
| 40번째 줄: | 40번째 줄: | ||
border-radius: 12px; | border-radius: 12px; | ||
transition: | transition: | ||
background-color var(-- | background-color var(--kawa-deck-speed) var(--kawa-deck-timing), | ||
border-color var(-- | border-color var(--kawa-deck-speed) var(--kawa-deck-timing); | ||
&:last-child { | &:last-child { | ||
| 51번째 줄: | 51번째 줄: | ||
&:hover, | &:hover, | ||
&:focus-visible { | &:focus-visible { | ||
background-color: var(-- | background-color: var(--kawa-deck-hover-bg); | ||
border-color: var(-- | border-color: var(--kawa-deck-border-hover); | ||
. | .kawa-deck-icon { | ||
opacity: 0; | opacity: 0; | ||
transform: translate(-50%, -50%) scale(0.7); | transform: translate(-50%, -50%) scale(0.7); | ||
} | } | ||
. | .kawa-deck-content { | ||
opacity: 1; | opacity: 1; | ||
transform: translate(-50%, -50%) scale(1); | transform: translate(-50%, -50%) scale(1); | ||
| 66번째 줄: | 66번째 줄: | ||
&:focus-visible { | &:focus-visible { | ||
outline: 2px solid var(-- | outline: 2px solid var(--kawa-deck-text); | ||
outline-offset: -3px; | outline-offset: -3px; | ||
} | } | ||
. | .kawa-deck-icon { | ||
position: absolute; | position: absolute; | ||
top: 50%; | top: 50%; | ||
left: 50%; | left: 50%; | ||
transform: translate(-50%, -50%) scale(1); | transform: translate(-50%, -50%) scale(1); | ||
color: var(-- | color: var(--kawa-deck-icon); | ||
display: flex; | display: flex; | ||
align-items: center; | align-items: center; | ||
| 81번째 줄: | 81번째 줄: | ||
opacity: 1; | opacity: 1; | ||
transition: | transition: | ||
transform var(-- | transform var(--kawa-deck-speed) var(--kawa-deck-timing), | ||
opacity var(-- | opacity var(--kawa-deck-speed) var(--kawa-deck-timing); | ||
&>i, | &>i, | ||
| 92번째 줄: | 92번째 줄: | ||
} | } | ||
. | .kawa-deck-content { | ||
position: absolute; | position: absolute; | ||
top: 50%; | top: 50%; | ||
| 103번째 줄: | 103번째 줄: | ||
pointer-events: none; | pointer-events: none; | ||
transition: | transition: | ||
transform var(-- | transform var(--kawa-deck-speed) var(--kawa-deck-timing), | ||
opacity var(-- | opacity var(--kawa-deck-speed) var(--kawa-deck-timing); | ||
. | .kawa-deck-title { | ||
display: block; | display: block; | ||
font-size: 1.1rem; | font-size: 1.1rem; | ||
font-weight: 700; | font-weight: 700; | ||
color: var(-- | color: var(--kawa-deck-text); | ||
line-height: 1.2; | line-height: 1.2; | ||
word-break: keep-all; | word-break: keep-all; | ||
| 118번째 줄: | 118번째 줄: | ||
@container (min-width: 300px) { | @container (min-width: 300px) { | ||
. | .kawa-deck-item { | ||
flex: 0 0 calc((100% - 1.25rem) / 2); | flex: 0 0 calc((100% - 1.25rem) / 2); | ||
max-width: calc((100% - 1.25rem) / 2); | max-width: calc((100% - 1.25rem) / 2); | ||
| 130번째 줄: | 130번째 줄: | ||
@container (min-width: 460px) { | @container (min-width: 460px) { | ||
. | .kawa-deck-item { | ||
flex: 0 0 calc((100% - 2.5rem) / 3); | flex: 0 0 calc((100% - 2.5rem) / 3); | ||
max-width: calc((100% - 2.5rem) / 3); | max-width: calc((100% - 2.5rem) / 3); | ||
| 142번째 줄: | 142번째 줄: | ||
@container (min-width: 620px) { | @container (min-width: 620px) { | ||
. | .kawa-deck-item { | ||
flex: 0 0 calc((100% - 3.75rem) / 4); | flex: 0 0 calc((100% - 3.75rem) / 4); | ||
max-width: calc((100% - 3.75rem) / 4); | max-width: calc((100% - 3.75rem) / 4); | ||
| 154번째 줄: | 154번째 줄: | ||
@container (min-width: 780px) { | @container (min-width: 780px) { | ||
. | .kawa-deck-item { | ||
flex: 0 0 calc((100% - 5rem) / 5); | flex: 0 0 calc((100% - 5rem) / 5); | ||
max-width: calc((100% - 5rem) / 5); | max-width: calc((100% - 5rem) / 5); | ||
2026년 5월 26일 (화) 18:53 판
/*******************************
* Module:Deck
*******************************/
:root {
--kawa-deck-text: currentColor;
--kawa-deck-icon: currentColor;
--kawa-deck-border: rgba(0, 0, 0, 0.5);
--kawa-deck-border-hover: rgba(0, 0, 0, 0.4);
--kawa-deck-hover-bg: rgba(0, 0, 0, 0.04);
--kawa-deck-speed: 0.3s;
--kawa-deck-timing: cubic-bezier(0.16, 1, 0.3, 1);
}
.kawa-deck-grid,
.kawa-deck-grid * {
box-sizing: border-box;
margin: 0;
padding: 0;
}
.kawa-deck-grid {
display: flex;
flex-wrap: wrap;
width: 100%;
max-width: 900px;
gap: 1.25rem;
container-type: inline-size;
.kawa-deck-item {
position: relative;
flex: 0 0 100%;
max-width: 100%;
aspect-ratio: 1 / 1;
background-color: transparent;
border: 1px solid var(--kawa-deck-border);
text-decoration: none;
overflow: hidden;
cursor: pointer;
outline: none;
border-radius: 12px;
transition:
background-color var(--kawa-deck-speed) var(--kawa-deck-timing),
border-color var(--kawa-deck-speed) var(--kawa-deck-timing);
&:last-child {
flex-grow: 1;
aspect-ratio: auto;
min-height: 140px;
}
&:hover,
&:focus-visible {
background-color: var(--kawa-deck-hover-bg);
border-color: var(--kawa-deck-border-hover);
.kawa-deck-icon {
opacity: 0;
transform: translate(-50%, -50%) scale(0.7);
}
.kawa-deck-content {
opacity: 1;
transform: translate(-50%, -50%) scale(1);
}
}
&:focus-visible {
outline: 2px solid var(--kawa-deck-text);
outline-offset: -3px;
}
.kawa-deck-icon {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%) scale(1);
color: var(--kawa-deck-icon);
display: flex;
align-items: center;
justify-content: center;
opacity: 1;
transition:
transform var(--kawa-deck-speed) var(--kawa-deck-timing),
opacity var(--kawa-deck-speed) var(--kawa-deck-timing);
&>i,
&>img {
max-width: 40px;
max-height: 40px;
object-fit: contain;
}
}
.kawa-deck-content {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%) scale(1.15);
width: 100%;
padding: 0 12px;
text-align: center;
opacity: 0;
pointer-events: none;
transition:
transform var(--kawa-deck-speed) var(--kawa-deck-timing),
opacity var(--kawa-deck-speed) var(--kawa-deck-timing);
.kawa-deck-title {
display: block;
font-size: 1.1rem;
font-weight: 700;
color: var(--kawa-deck-text);
line-height: 1.2;
word-break: keep-all;
}
}
}
@container (min-width: 300px) {
.kawa-deck-item {
flex: 0 0 calc((100% - 1.25rem) / 2);
max-width: calc((100% - 1.25rem) / 2);
&:last-child {
max-width: 100%;
min-height: calc((100cqw - 1.25rem) / 2);
}
}
}
@container (min-width: 460px) {
.kawa-deck-item {
flex: 0 0 calc((100% - 2.5rem) / 3);
max-width: calc((100% - 2.5rem) / 3);
&:last-child {
max-width: 100%;
min-height: calc((100cqw - 2.5rem) / 3);
}
}
}
@container (min-width: 620px) {
.kawa-deck-item {
flex: 0 0 calc((100% - 3.75rem) / 4);
max-width: calc((100% - 3.75rem) / 4);
&:last-child {
max-width: 100%;
min-height: calc((100cqw - 3.75rem) / 4);
}
}
}
@container (min-width: 780px) {
.kawa-deck-item {
flex: 0 0 calc((100% - 5rem) / 5);
max-width: calc((100% - 5rem) / 5);
&:last-child {
max-width: 100%;
min-height: calc((100cqw - 5rem) / 5);
}
}
}
}