Skip to content
Snippets Groups Projects
style.scss 8.22 KiB
Newer Older
syuilo's avatar
syuilo committed
@charset "utf-8";

:root {
	--radius: 12px;
syuilo's avatar
syuilo committed
	--marginFull: 16px;
syuilo's avatar
syuilo committed
	--marginHalf: 10px;
syuilo's avatar
syuilo committed

	--margin: var(--marginFull);

	@media (max-width: 500px) {
		--margin: var(--marginHalf);
	}
syuilo's avatar
syuilo committed

	//--ad: rgb(255 169 0 / 10%);
syuilo's avatar
syuilo committed
}

syuilo's avatar
syuilo committed
::selection {
	color: #fff;
	background-color: var(--accent);
} 
syuilo's avatar
syuilo committed

html {
syuilo's avatar
syuilo committed
	touch-action: manipulation;
syuilo's avatar
syuilo committed
	background-color: var(--bg);
	background-attachment: fixed;
	background-size: cover;
	background-position: center;
	color: var(--fg);
syuilo's avatar
syuilo committed
	accent-color: var(--accent);
syuilo's avatar
syuilo committed
	overflow: auto;
syuilo's avatar
syuilo committed
	overflow-wrap: break-word;
syuilo's avatar
syuilo committed
	font-family: 'Hiragino Maru Gothic Pro', "BIZ UDGothic", Roboto, HelveticaNeue, Arial, sans-serif;
syuilo's avatar
syuilo committed
	font-size: 14px;
syuilo's avatar
syuilo committed
	line-height: 1.35;
	text-size-adjust: 100%;
syuilo's avatar
syuilo committed
	tab-size: 2;
syuilo's avatar
syuilo committed

	&, * {
syuilo's avatar
syuilo committed
		scrollbar-color: var(--scrollbarHandle) inherit;
		scrollbar-width: thin;
syuilo's avatar
syuilo committed

		&::-webkit-scrollbar {
			width: 6px;
			height: 6px;
		}

		&::-webkit-scrollbar-track {
syuilo's avatar
syuilo committed
			background: inherit;
syuilo's avatar
syuilo committed
		}

		&::-webkit-scrollbar-thumb {
			background: var(--scrollbarHandle);

			&:hover {
				background: var(--scrollbarHandleHover);
			}

			&:active {
				background: var(--accent);
			}
		}
	}
syuilo's avatar
syuilo committed

syuilo's avatar
syuilo committed
	&.f-1 {
		font-size: 15px;
syuilo's avatar
syuilo committed
	}

syuilo's avatar
syuilo committed
	&.f-2 {
		font-size: 16px;
syuilo's avatar
syuilo committed
	}

syuilo's avatar
syuilo committed
	&.f-3 {
		font-size: 17px;
syuilo's avatar
syuilo committed
	}
syuilo's avatar
syuilo committed

	&.useSystemFont {
syuilo's avatar
syuilo committed
		font-family: 'Hiragino Maru Gothic Pro', sans-serif;
syuilo's avatar
syuilo committed
	}
syuilo's avatar
syuilo committed
}

syuilo's avatar
syuilo committed
html._themeChanging_ {
syuilo's avatar
syuilo committed
	&, * {
syuilo's avatar
syuilo committed
		transition: background 1s ease, border 1s ease !important;
syuilo's avatar
syuilo committed
	}
}

html, body {
	margin: 0;
	padding: 0;
	scroll-behavior: smooth;
}

a {
	text-decoration: none;
	cursor: pointer;
	color: inherit;
syuilo's avatar
syuilo committed
	tap-highlight-color: transparent;
	-webkit-tap-highlight-color: transparent;
syuilo's avatar
syuilo committed

	&:hover {
		text-decoration: underline;
	}
}

syuilo's avatar
syuilo committed
textarea, input {
	tap-highlight-color: transparent;
	-webkit-tap-highlight-color: transparent;
}

syuilo's avatar
syuilo committed
optgroup, option {
	background: var(--panel);
	color: var(--fg);
}

syuilo's avatar
syuilo committed
hr {
	margin: var(--margin) 0 var(--margin) 0;
	border: none;
	height: 1px;
	background: var(--divider);
}

syuilo's avatar
syuilo committed
.ti {
syuilo's avatar
syuilo committed
	vertical-align: -10%;
syuilo's avatar
syuilo committed
	line-height: 0.9em;
syuilo's avatar
syuilo committed

	&:before {
		font-size: 130%;
	}
syuilo's avatar
syuilo committed
}

.ti-fw {
	display: inline-block;
	text-align: center;
}

._indicatorCircle {
	display: inline-block;
	width: 1em;
	height: 1em;
	border-radius: 100%;
	background: currentColor;
}

syuilo's avatar
syuilo committed
._noSelect {
	user-select: none;
	-webkit-user-select: none;
	-webkit-touch-callout: none;
}

._ghost {
	&, * {
		@extend ._noSelect;
		pointer-events: none;
	}
}

._modalBg {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: var(--modalBg);
	-webkit-backdrop-filter: var(--modalBgFilter);
	backdrop-filter: var(--modalBgFilter);
}

syuilo's avatar
syuilo committed
._shadow {
	box-shadow: 0px 4px 32px var(--shadow) !important;
}

syuilo's avatar
syuilo committed
._button {
	appearance: none;
syuilo's avatar
syuilo committed
	padding: 0;
syuilo's avatar
syuilo committed
	margin: 0; // for Safari
syuilo's avatar
syuilo committed
	background: none;
	border: none;
	cursor: pointer;
syuilo's avatar
syuilo committed
	color: inherit;
syuilo's avatar
syuilo committed
	touch-action: manipulation;
syuilo's avatar
syuilo committed
	tap-highlight-color: transparent;
	-webkit-tap-highlight-color: transparent;
syuilo's avatar
syuilo committed
	font-size: 1em;
	font-family: inherit;
	line-height: inherit;
	max-width: 100%;
syuilo's avatar
syuilo committed

	&, * {
syuilo's avatar
syuilo committed
		@extend ._noSelect;
syuilo's avatar
syuilo committed
	}

	* {
		pointer-events: none;
	}

syuilo's avatar
syuilo committed
	&:focus-visible {
syuilo's avatar
syuilo committed
		outline: none;
	}

	&:disabled {
		opacity: 0.5;
		cursor: default;
	}
}

._buttonPrimary {
	@extend ._button;
syuilo's avatar
syuilo committed
	color: var(--fgOnAccent);
syuilo's avatar
syuilo committed
	background: var(--accent);

	&:not(:disabled):hover {
syuilo's avatar
syuilo committed
		background: var(--X8);
syuilo's avatar
syuilo committed
	}

	&:not(:disabled):active {
syuilo's avatar
syuilo committed
		background: var(--X9);
syuilo's avatar
syuilo committed
	}
}

syuilo's avatar
syuilo committed
._buttonGradate {
	@extend ._buttonPrimary;
	color: var(--fgOnAccent);
	background: linear-gradient(90deg, var(--buttonGradateA), var(--buttonGradateB));

	&:not(:disabled):hover {
		background: linear-gradient(90deg, var(--X8), var(--X8));
	}

	&:not(:disabled):active {
		background: linear-gradient(90deg, var(--X8), var(--X8));
	}
}

._help {
	color: var(--accent);
	cursor: help
}

syuilo's avatar
syuilo committed
._textButton {
	@extend ._button;
	color: var(--accent);

	&:not(:disabled):hover {
		text-decoration: underline;
	}
}

._panel {
	background: var(--panel);
syuilo's avatar
syuilo committed
	border-radius: var(--radius);
syuilo's avatar
syuilo committed
	overflow: clip;
syuilo's avatar
syuilo committed
// TODO: 廃止
syuilo's avatar
syuilo committed
._block {
	@extend ._panel;
syuilo's avatar
syuilo committed

	& + ._block {
		margin-top: var(--margin);
	}
syuilo's avatar
syuilo committed
}

syuilo's avatar
syuilo committed
._margin {
syuilo's avatar
syuilo committed
	margin: var(--margin) 0;
syuilo's avatar
syuilo committed
}

syuilo's avatar
syuilo committed
._autoGap {
	display: flex;
	flex-direction: column;
	gap: 1.5em;
}

._autoGap_half {
	display: flex;
	flex-direction: column;
	gap: 0.75em;
}

syuilo's avatar
syuilo committed
// TODO: 廃止
syuilo's avatar
syuilo committed
._card {
syuilo's avatar
syuilo committed
	@extend ._panel;

syuilo's avatar
syuilo committed
	// TODO: _cardTitle に
syuilo's avatar
syuilo committed
	> ._title {
		margin: 0;
		padding: 22px 32px;
syuilo's avatar
syuilo committed
		font-size: 1em;
syuilo's avatar
syuilo committed
		border-bottom: solid 1px var(--panelHeaderDivider);
syuilo's avatar
syuilo committed
		font-weight: bold;
syuilo's avatar
syuilo committed
		background: var(--panelHeaderBg);
		color: var(--panelHeaderFg);
syuilo's avatar
syuilo committed

		@media (max-width: 500px) {
			padding: 16px;
			font-size: 1em;
		}
	}

syuilo's avatar
syuilo committed
	// TODO: _cardContent に
syuilo's avatar
syuilo committed
	> ._content {
		padding: 32px;

		@media (max-width: 500px) {
			padding: 16px;
		}

syuilo's avatar
syuilo committed
		&._noPad {
			padding: 0 !important;
		}

syuilo's avatar
syuilo committed
		& + ._content {
syuilo's avatar
syuilo committed
			border-top: solid 0.5px var(--divider);
syuilo's avatar
syuilo committed
		}
	}

syuilo's avatar
syuilo committed
	// TODO: _cardFooter に
syuilo's avatar
syuilo committed
	> ._footer {
syuilo's avatar
syuilo committed
		border-top: solid 0.5px var(--divider);
syuilo's avatar
syuilo committed
		padding: 24px 32px;

		@media (max-width: 500px) {
			padding: 16px;
		}
	}
}

syuilo's avatar
syuilo committed
._borderButton {
	@extend ._button;
	display: block;
	width: 100%;
	padding: 10px;
	box-sizing: border-box;
	text-align: center;
syuilo's avatar
syuilo committed
	border: solid 0.5px var(--divider);
syuilo's avatar
syuilo committed
	border-radius: var(--radius);

	&:active {
		border-color: var(--accent);
	}
}

syuilo's avatar
syuilo committed
._popup {
syuilo's avatar
syuilo committed
	background: var(--popup);
syuilo's avatar
syuilo committed
	border-radius: var(--radius);
syuilo's avatar
syuilo committed
	contain: content;
syuilo's avatar
syuilo committed
// TODO: 廃止
syuilo's avatar
syuilo committed
._monolithic_ {
syuilo's avatar
syuilo committed
	._section:not(:empty) {
syuilo's avatar
syuilo committed
		box-sizing: border-box;
		padding: var(--root-margin, 32px);
	
		@media (max-width: 500px) {
			--root-margin: 10px;
		}
	
		& + ._section:not(:empty) {
syuilo's avatar
syuilo committed
			border-top: solid 0.5px var(--divider);
		}
	}
syuilo's avatar
syuilo committed
}
syuilo's avatar
syuilo committed

syuilo's avatar
syuilo committed
._narrow_ ._card {
	> ._title {
		padding: 16px;
		font-size: 1em;
	}

	> ._content {
		padding: 16px;
	}

	> ._footer {
		padding: 16px;
	}
}

syuilo's avatar
syuilo committed
._acrylic {
	background: var(--acrylicPanel);
	-webkit-backdrop-filter: var(--blur, blur(15px));
	backdrop-filter: var(--blur, blur(15px));
syuilo's avatar
syuilo committed
._formLinksGrid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
	grid-gap: 12px;
}

._formLinks {
	> *:not(:last-child) {
		margin-bottom: 8px;
	}
}

._beta {
	margin-left: 0.7em;
	font-size: 65%;
	padding: 2px 3px;
	color: var(--accent);
	border: solid 1px var(--accent);
	border-radius: 4px;
	vertical-align: top;
}

syuilo's avatar
syuilo committed
._table {
	> ._row {
		display: flex;

		&:not(:last-child) {
			margin-bottom: 16px;

			@media (max-width: 500px) {
				margin-bottom: 8px;
			}
		}

		> ._cell {
			flex: 1;

			> ._label {
				font-size: 80%;
				opacity: 0.7;

				> ._icon {
					margin-right: 4px;
					display: none;
				}
			}
		}
	}
}

syuilo's avatar
syuilo committed
	padding: 64px 32px;
	text-align: center;

	> img {
		vertical-align: bottom;
		height: 128px;
		margin-bottom: 16px;
		border-radius: 16px;
	}
}

syuilo's avatar
syuilo committed
._link {
	color: var(--link);
}

syuilo's avatar
syuilo committed
._monospace {
	font-family: Fira code, Fira Mono, Consolas, Menlo, Courier, monospace !important;
syuilo's avatar
syuilo committed
}

syuilo's avatar
syuilo committed
._code {
syuilo's avatar
syuilo committed
	@extend ._monospace;
syuilo's avatar
syuilo committed
	background: #2d2d2d;
	color: #ccc;
	font-size: 14px;
	line-height: 1.5;
	padding: 5px;
}

syuilo's avatar
syuilo committed
.prism-editor__textarea:focus {
syuilo's avatar
syuilo committed
	outline: none;
}

syuilo's avatar
syuilo committed
._zoom {
	transition-duration: 0.5s, 0.5s;
	transition-property: opacity, transform;
	transition-timing-function: cubic-bezier(0,.5,.5,1);
}

syuilo's avatar
syuilo committed
._transition_zoom-enter-active, ._transition_zoom-leave-active {
syuilo's avatar
syuilo committed
	transition: opacity 0.5s, transform 0.5s !important;
}
syuilo's avatar
syuilo committed
._transition_zoom-enter-from, ._transition_zoom-leave-to {
syuilo's avatar
syuilo committed
	opacity: 0;
	transform: scale(0.9);
}

syuilo's avatar
syuilo committed
@keyframes blink {
	0% { opacity: 1; transform: scale(1); }
	30% { opacity: 1; transform: scale(1); }
	90% { opacity: 0; transform: scale(0.5); }
syuilo's avatar
syuilo committed
}
syuilo's avatar
syuilo committed

syuilo's avatar
syuilo committed
@keyframes tada {
syuilo's avatar
syuilo committed
	from {
		transform: scale3d(1, 1, 1);
	}

	10%,
	20% {
		transform: scale3d(0.9, 0.9, 0.9) rotate3d(0, 0, 1, -3deg);
	}

	30%,
	50%,
	70%,
	90% {
		transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg);
	}

	40%,
	60%,
	80% {
		transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg);
	}

	to {
		transform: scale3d(1, 1, 1);
	}
}
syuilo's avatar
syuilo committed

._anime_bounce {
syuilo's avatar
syuilo committed
	will-change: transform;
syuilo's avatar
syuilo committed
  animation: bounce ease 0.7s;
syuilo's avatar
syuilo committed
  animation-iteration-count: 1;
  transform-origin: 50% 50%;
}
._anime_bounce_ready {
syuilo's avatar
syuilo committed
	will-change: transform;
syuilo's avatar
syuilo committed
	transform:  scaleX(0.90) scaleY(0.90) ;
}
syuilo's avatar
syuilo committed
._anime_bounce_standBy {
	transition: transform 0.1s ease;
}
syuilo's avatar
syuilo committed

syuilo's avatar
syuilo committed
@keyframes bounce {
syuilo's avatar
syuilo committed
  0% {
    transform:  scaleX(0.90) scaleY(0.90) ;
  }
syuilo's avatar
syuilo committed
  19% {
syuilo's avatar
syuilo committed
    transform:  scaleX(1.10) scaleY(1.10) ;
  }
syuilo's avatar
syuilo committed
  48% {
syuilo's avatar
syuilo committed
    transform:  scaleX(0.95) scaleY(0.95) ;
  }
  100% {
    transform:  scaleX(1.00) scaleY(1.00) ;
  }
}