@charset "UTF-8";

/*----------------------------------------------------------------
  Font Awesome
  ----------------------------------------------------------------*/

@font-face {
	font-family: 'Font Awesome 5 Free';
	font-style: normal;
	font-weight: 400;
	src: url("../fonts/fa-solid-900.eot");
	src: url("../fonts/fa-solid-900.eot?#iefix") format("embedded-opentype"), url("../fonts/fa-solid-900.woff2") format("woff2"), url("../fonts/fa-solid-900.woff") format("woff"), url("../fonts/fa-solid-900.ttf") format("truetype"), url("../fonts/fa-solid-900.svg#fontawesome") format("svg");
}

.ff-fa,
.ff-fa-a::after,
.ff-fa-b::before {
	font-family: 'Font Awesome 5 Free';
	font-weight: 400;
}

.fa-home-b::before {
	content: '\f015';
}

.fa-about-b::before {
	content: '\f2bb';
}

.fa-log-b::before {
	content: '\f15c';
}

.fa-project-b::before {
	content: '\f02d';
}

.fa-mail-b::before {
	content: '\f0e0';
}

/*----------------------------------------------------------------
  HTML Elements
  ----------------------------------------------------------------*/

*,
*::after,
*::before {
	box-sizing: border-box;
}

html {
	font: 62.5%/1.5 "Helvetica", "Century Gothic", "Arial", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "平成角ゴシック","HeiseiKakuGothic", "メイリオ", "Meiryo", "Osaka", "MS Pゴシック", "MS PGothic", sans-serif;
	-webkit-text-size-adjust: 100%;
}

body {
	margin: 0;
	padding: 0;
	background-color: #f5f5f5;
	font-size: 1.6rem;
	font-family: inherit;
	color: #231815;
}

img {
	max-width: 100%;
	vertical-align: bottom;
}

h1, h2, h3, h4, h5, h6, p, ul, ol, li, dl, dt, dd, table, figure {
	margin: 0;
	padding: 0;
	font-weight: normal;
}

/*----------------------------------------------------------------
  Common Styles
  ----------------------------------------------------------------*/

.inner {
	width: 96%;
	max-width: 1000px;
	margin: 0 auto;
}

.content-header {
	display: flex;
	justify-content: center;
	align-items: center;
	border-left: 1px solid #000;
	border-right: 1px solid #000;
	background: transparent linear-gradient(to bottom, #111 0%, #111 85%, #f5f5f5 100% ) center repeat;
	text-transform: uppercase;
	font-weight: bold;
	color: #fff;
}

.content {
	border-left: 1px solid #000;
	border-right: 1px solid #000;
}

.section-header {
	margin-bottom: 40px;
	padding-left: 5px;
	border-bottom: 1px solid #000;
	border-left: 5px solid #000;
	font-size: 2.4rem;
}

.section-subheader {
	margin-bottom: 10px;
	padding: 0 10px;
	border-bottom: 1px solid #000;
	font-size: 2rem;
}

.content p,
.content ul,
.content figure {
	margin-bottom: 2.4rem;
}

.content ul,
.content ol {
	padding-left: 2.4rem;
}

.content p:last-child,
.content ul:last-child {
	margin-bottom: 0;
}

.content blockquote {
	position: relative;
	margin: 0 0 2.4rem;
	padding: 2.4rem 2.4rem 2.4rem 6rem;
	border: 1px dotted #000;
	overflow: hidden;
}

.content blockquote::before {
	content: '\201c';
	position: absolute;
	top: -4.8rem;
	left: 0;
	font-size: 14.4rem;
}

.btn-black,
.btn-white {
	border: 1px solid #111;
	border-radius: 5px;
	text-decoration: none;
	text-align: center;
	transition: background-color 0.3s;
}

.btn-black,
.btn-white:hover,
.btn-wihte:active {
	background-color: #111;
	color: #f5f5f5;
}

.btn-white,
.btn-black:hover,
.btn-black:active {
	border: 1px solid #111;
	background-color: #f5f5f5;
	color: #111;
}

/*----------------------------------------------------------------
  Page Header
  ----------------------------------------------------------------*/

.global-nav {
	position: sticky;
	top: 0;
	left: 0;
	z-index: 1;
	display: flex;
	justify-content: center;
	background-color: #111;
	color: #fff;
}

.global-nav a {
	width: min(19.2%, 200px);
	background-color: inherit;
	text-align: center;
	text-decoration: none;
	text-transform: uppercase;
	font-family: 'Encode Sans Semi Expanded', sans-serif;
	color: inherit;
	transition: background-color 0.3s;
}

.global-nav a:hover,
.global-nav a:active,
.global-nav .current {
	background-color: #fff;
	color: #111;
}

.global-nav a::before {
	display: block;
}

/*----------------------------------------------------------------
  Weblog
  ----------------------------------------------------------------*/

.movie iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border: none;
}

.weblog-data {
	display: flex;
	flex-wrap: wrap;
	width: 100%;
	border: 1px solid #000;
}

.weblog-data::before {
	content: "Entry Data";
	display: block;
	width: 100%;
	margin-bottom: 10px;
	text-align: center;
	font-weight: bold;
	font-size: 2rem;
}

.weblog-data dt:last-of-type,
.weblog-data dd:last-of-type {
	border-bottom: 1px solid #000;
}

.content .tag-list {
	display: flex;
	flex-wrap: wrap;
	padding: 0;
	list-style-type: none;
}

.tag-list a {
	display: block;
}

.form-text,
.form-textarea {
	width: 100%;
	padding: 5px;
	border: 1px solid #111;
	border-radius: 5px;
	font-family: inherit;
	outline: none;
}
