@charset "utf-8";

@font-face {
	font-family: 'FontAwesome';
	src: url('https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/fonts/fontawesome-webfont.eot');
	src: url('https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/fonts/fontawesome-webfont.eot') format('embedded-opentype'),
		url('https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/fonts/fontawesome-webfont.woff2') format('woff2'),
		url('https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/fonts/fontawesome-webfont.woff') format('woff'),
		url('https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/fonts/fontawesome-webfont.ttf') format('truetype'),
		url('https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/fonts/fontawesome-webfont.svg') format('svg');
	font-weight: normal;
	font-style: normal;
	font-display: swap;
}


body {
	font-family: -apple-system, BlinkMacSystemFont, 'Noto Sans JP', "Helvetica Neue", "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Arial, Meiryo, sans-serif;
	font-size: 16px;
	line-height: 1.5em;
	background-color: #000000;
	color: #E9E9E9;
}

/* リンク装飾 */
a {
	-webkit-transition: 0.5s;
	-moz-transition: 0.5s;
	-o-transition: 0.5s;
	-ms-transition: 0.5s;
	transition: 0.5s;
}

a {
	color: #FF0066;
	text-decoration: none;
}

a:hover {
	color: #33F;
}

a:hover img {
	opacity: 0.8;
	filter: alpha(opacity=80);
	-ms-filter: "alpha( opacity=80 )";
}

.ad {
	border: 1px solid #999;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 10px;
}

@media only screen and (min-width:1170px) {
	.ad.small {
		display: block;
	}

	.ad.large {
		display: none;
	}
}

@media only screen and (min-width:421px) and (max-width:1169px) {
	.ad.small {
		display: none;
	}

	.ad.large {
		display: block;
	}
}

@media only screen and (max-width:420px) {
	.ad.small {
		display: block;
	}

	.ad.large {
		display: none;
	}
}

.asp {
	width: 100%;
	height: 0;
	position: relative;
	overflow: hidden;
}

.asp img {
	width: 100%;
	height: 100%;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	object-fit: cover;
	object-position: center;
	position: absolute;
	box-sizing: border-box;
}

/*レイアウト
----------------------------------------------------------*/
#layout {
	max-width: 1140px;
	min-width: 280px;
	margin: 0 auto;
}

header {
	margin-bottom: 20px;
}

#contents {
	margin-bottom: 30px;
	overflow: hidden;
}

#main {
	float: left;
	width: 820px;
}

#sidemenu {
	float: right;
	width: 300px;
}

@media only screen and (max-width: 1169px) {
	header {
		margin-bottom: 20px;
	}

	#contents {
		width: 820px;
		margin: 0 auto;
	}

	#main, #sidemenu {
		float: none;
		width: 100%;
	}
}

@media only screen and (max-width: 859px) {
	#contents {
		width: auto;
		padding: 0 5px;
	}
}

footer {
	clear: both;
}

/* header
------------------------------------------------------*/
#top {
	height: 200px;
	position: relative;
	background-image: url(https://www.kigyou-sapporo.com/img/top_bg2.png), url(https://www.kigyou-sapporo.com/img/top_bg1.jpg);
	background-repeat: no-repeat, no-repeat;
	background-position: 95% 100%, 0% 20%;
}

#top h1 {
	position: absolute;
	bottom: 0px;
	right: 10px;
}

@media screen and (max-width:1060px) {
	#top {
		background-position: 100% 100%, 0% 20%;
		background-size: auto 180px, 80% auto;
	}
}


@media screen and (min-width:681px) {
	#top h1 {
		width: 571px;
		height: 60px;
	}
}

@media screen and (max-width:680px) {
	#top {
		background-position: 100% 100%, -20% 20%;
		background-size: auto 140px, 80% auto;
	}

	#top h1 {
		left: 0;
		right: 0;
		margin: auto;
		text-align: center;
	}
}

@media screen and (max-width:480px) {
	#top {
		background-position: 110% 100%, -20px 20%;
		background-size: auto 130px, 100% auto;
	}
}

@media screen and (max-width:380px) {
	#top {
		background-position: 120% 100%, -20px 20%;
		background-size: auto 120px, 110% auto;
	}
}

header nav ul {
	overflow: hidden;
	border-top: 1px solid #333;
	border-left: 1px solid #333;
}

header nav li {
	float: left;
	width: 14.2857%;
}

header nav li.top {
	display: none;
}

header nav li a {
	color: #FFFFFF;
	display: block;
	text-align: center;
	background-color: #333;
	padding: 5px 2px;
	border-right: 1px solid #333;
	border-bottom: 1px solid #333;
	font-weight: bold;
	background: rgb(255, 48, 25);
	background: -moz-linear-gradient(top, rgba(255, 48, 25, 1) 0%, rgba(207, 4, 4, 1) 100%);
	background: -webkit-linear-gradient(top, rgba(255, 48, 25, 1) 0%, rgba(207, 4, 4, 1) 100%);
	background: linear-gradient(to bottom, rgba(255, 48, 25, 1) 0%, rgba(207, 4, 4, 1) 100%);
	filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff3019', endColorstr='#cf0404', GradientType=0);
}

header nav li a:hover {
	color: #FFFF00;
}

@media screen and (max-width:760px) {
	header nav li a {
		font-size: 14px;
	}
}

@media screen and (max-width:640px) {
	header nav li.top {
		display: block;
	}

	header nav li {
		width: 25%;
	}
}

@media screen and (max-width:419px) {
	header nav li a {
		font-size: 12px;
	}
}

@media screen and (max-width:329px) {
	header nav li a {
		font-size: 11px;
		white-space: nowrap;
	}
}

/* sidemenu
----------------------------------------------------------*/
#sidemenu h3 {
	font-size: 14px;
	font-weight: bold;
	color: #FFFFFF;
	margin-bottom: 10px;
	line-height: 25px;
	background-image: url(https://www.kigyou-sapporo.com/img/bar_icon.gif), url(https://www.kigyou-sapporo.com/img/bar_icon.gif);
	background-repeat: no-repeat, no-repeat;
	background-position: left top, right top;
	border-top: 2px solid #f0e763;
	border-bottom: 2px solid #f0e763;
	text-align: center;
}

@media only screen and (max-width:1139px) {
	#sidemenu h3 {
		background-image: url(https://www.kigyou-sapporo.com/img/bar_icon.gif);
		padding-left: 20px;
		text-align: left;
	}
}

#sidemenu .links li:before {
	font-family: "FontAwesome";
	content: "\f105";
	margin-right: 5px;
}

#sidemenu .links li {
	padding: 3px 0;
}


.ad_banner_side {
	margin-bottom: 10px;
	overflow: hidden;
}

.ad_banner_side li {
	margin-bottom: 10px;
}

.ad_banner_side li img {
	border: 1px solid #555;
}

@media screen and (min-width: 600px) and (max-width: 1169px) {
	.ad_banner_side li {
		float: left;
		width: 48%;
		margin: 1%;
	}
}


/*supple
----------------*/
#ad_banner_header {
	display: none;
}

@media only screen and (max-width: 1169px) {

	#ad_banner_side {
		display: none;
	}

	#ad_banner_header {
		display: block;
		width: 820px;
		margin: 0 auto;
	}
}

@media only screen and (max-width: 859px) {

	#ad_banner_header {
		width: auto;
		padding: 0 5px;
	}
}

/*main
----------------------------------------------------------*/
#main h2 {
	color: #ff0000;
	font-size: 1.3em;
	padding: 5px;
	margin-bottom: 10px;
	border: 2px solid #d4b511;
	border-radius: 3px;
	background: -webkit-gradient(linear, left top, left bottom, color-stop(1.00, #e9cc33), color-stop(0.51, #fef793), color-stop(0.00, #e9cc31));
	background: -webkit-linear-gradient(top, #e9cc31 0%, #fef793 51%, #e9cc33 100%);
	background: -moz-linear-gradient(top, #e9cc31 0%, #fef793 51%, #e9cc33 100%);
	background: -o-linear-gradient(top, #e9cc31 0%, #fef793 51%, #e9cc33 100%);
	background: -ms-linear-gradient(top, #e9cc31 0%, #fef793 51%, #e9cc33 100%);
	background: linear-gradient(to bottom, #e9cc31 0%, #fef793 51%, #e9cc33 100%);
	box-shadow: 1px 1px 1px #666666;
}

@media screen and (max-width:600px) {
	#main h2 {
		font-size: 1.1em;
	}
}

#main #sent,
#main #im_sent {
	background-color: #000000;
	background-image: url(https://www.kigyou-sapporo.com/img/sent_bg.jpg);
	background-repeat: no-repeat;
	background-position: right top;
	border: 2px solid #f8e062;
	border-radius: 8px;
	padding: 10px;
	margin-bottom: 10px;
}

@media screen and (max-width:859px) {

	#main #sent,
	#main #im_sent {
		border: none;
		border-radius: 0;
	}
}

#main p {
	margin-bottom: 1em;
}

/* sitepic
----------------------------------------------------------*/
#sitepic_box {
	margin-bottom: 20px;
}

#sitepic_box h3 {
	line-height: 20px;
	font-weight: bold;
	color: #F3C;
	padding: 5px 8px;
	border-left: 5px solid #F3C;
	background-color: #333333;
	margin-bottom: 5px;
	overflow: hidden;
	position: relative;
}

#sitepic_box h3 i {
	display: none;
}

#sitepic_box h3 em {
	float: left;
	display: block;
	color: #fff;
	margin-right: 5px;
}

.sitepic {
	overflow: hidden;
	margin: 0 -5px 20px;
}

.sitepic li {
	float: left;
	width: 25%;
}

.sitepic li dl {
	margin: 5px;
	background: #000;
	border: 1px solid #272727;
	border-radius: 5px;
	position: relative;
	overflow: hidden;
}

.sitepic li dt img {
	display: block;
	width: 100%;
	opacity: 1;
	-webkit-transition: opacity 0.4s, transform 0.4s;
	transition: opacity 0.4s, transform 0.4s;
	-webkit-transform: scale3d(1, 1, 1);
	transform: scale3d(1, 1, 1);
}

.sitepic li dl:hover img {
	opacity: 0.3;
	-webkit-transform: scale3d(1.2, 1.2, 1);
	transform: scale3d(1.2, 1.2, 1);
}

.sitepic li dd {
	opacity: 0;
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	width: 100%;
	text-align: center;
	-webkit-transition: opacity 0.4s;
	transition: opacity 0.4s;
	font-weight: bold;
	color: #FF0;
}

.sitepic li dl:hover dd {
	opacity: 1;
}

.sitepic li dl a {
	color: #FFFF00;
}

@media screen and (max-width:1169px) {
	#sitepic_box h3 {
		cursor: pointer;
	}

	#sitepic_box h3 i {
		display: block;
		font-size: 20px;
		position: absolute;
		right: 10px;
		top: 30%;
	}

	.sitepic {
		display: none;
	}

	#sitepic_box h3 em {
		float: none;
		margin-right: 0px;
		font-weight: normal;
		font-size: 12px;
	}

	#sitepic_box h3:after {
		font-size: 18px;
		right: 10px;
		top: 30%;
	}
}

@media screen and (max-width:539px) {
	.sitepic li {
		width: 50%;
	}
}


/* info_box
----------------------------------------------------------*/
#info_box {
	margin-bottom: 10px;
	overflow: hidden;
}

#info_pic {
	margin-bottom: 10px;
	margin-left: 270px;
	max-width: 600px;
}

#info_pic img {
	border: 2px solid #f2ed77;
	box-shadow: 2px 2px 2px #333333;
	border-radius: 15px;
}

#info_mb {
	float: left;
	width: 256px;
	height: 296px;
	background-image: url(https://www.kigyou-sapporo.com/img/mb_bg.jpg);
	background-repeat: no-repeat;
	margin-bottom: 10px;
	padding: 10px;
}

#info_mb #subtitle {
	font-size: 14px;
	font-weight: bold;
	color: #FF0099;
	line-height: 18px;
	padding: 8px 5px;
	margin-bottom: 10px;
}

#info_mb #point {
	height: 110px;
}

#info_mb #point li {
	line-height: 30px;
	font-size: 24px;
	color: #FF0000;
	font-weight: bold;
	padding-left: 8px;
	margin-bottom: 8px;
}

#info_mb #point li em {
	margin-right: 1em;
}

#info_mb #mb_sent {
	padding-left: 5px;
	width: 140px;
	padding-top: 28px;
	font-size: 12px;
	line-height: 18px;
	color: #FFFFFF;
	float: left;
}

#info_mb #qr {
	height: 90px;
	width: 90px;
	float: left;
	margin-top: 8px;
}

#info_mb #qr img {
	width: 90px;
	height: 90px;
}

#info_box #info {
	clear: both;
	border: 2px solid #f2ed77;
	-moz-border-radius: 10px;
	-webkit-border-radius: 10px;
	border-radius: 10px;
	background: url(https://www.kigyou-sapporo.com/img/info.jpg) no-repeat top right;
	padding: 10px;
	margin-bottom: 20px;
}

#info_box #info p {
	margin-bottom: 1em;
	line-height: 1.4em;
	color: #CCC;
}

@media screen and (max-width:839px) {
	#info_pic {
		width: 100%;
		height: auto;
		float: none;
		margin: 0 auto 20px;
	}

	#info_box {
		text-align: center;
	}

	#info_mb {
		float: none;
		width: auto;
		height: auto;
		padding: 0;
		background-image: none;

		display: inline-block;
		width: 600px;
	}

	#info_mb #subtitle {
		font-size: 16px;
		line-height: 1.5em;
	}

	#info_mb #point {
		height: auto;
		overflow: hidden;
		margin: 0 -5px;
	}

	#info_mb #point li {
		float: left;
		width: 33.3%;
		padding: 0;
	}

	#info_mb #point li em {
		margin-right: 0;
	}

	#info_mb #point li span {
		display: block;
		line-height: 1.5em;
		font-size: 18px;
		color: #FF0000;
		font-weight: bold;
		padding: 2px 7px;
		border-radius: 2px;
		margin: 5px;
		background: -webkit-gradient(linear, left top, left bottom, color-stop(1.00, #fff68a), color-stop(0.48, #fffbc7), color-stop(0.01, #fef7aa));
		background: -webkit-linear-gradient(top, #fef7aa 1%, #fffbc7 48%, #fff68a 100%);
		background: -moz-linear-gradient(top, #fef7aa 1%, #fffbc7 48%, #fff68a 100%);
		background: -o-linear-gradient(top, #fef7aa 1%, #fffbc7 48%, #fff68a 100%);
		background: -ms-linear-gradient(top, #fef7aa 1%, #fffbc7 48%, #fff68a 100%);
		background: linear-gradient(to bottom, #fef7aa 1%, #fffbc7 48%, #fff68a 100%);
	}

	#info_mb #mb_sent, #info_mb #qr {
		display: none;
	}

	#info_box #info {
		max-width: 600px;
		margin: 0 auto;
	}

	#info_box #info p {
		text-align: left;
	}
}

@media screen and (max-width:619px) {
	#info_mb {
		width: 100%;
		padding: 0;
	}

	#info_box #info {
		border: none;
		padding: 0;
	}

	#info_mb #point {
		margin: 0 -3px;
	}

	#info_mb #point li span {
		font-size: 14px;
		line-height: 1.2em;
		padding: 5px 2px;
		margin: 3px;
	}
}

#guide {
	text-align: center;
	margin-bottom:20px;
}

#guide span {
    display: inline-block;
}
#guide a.pure-button {
  max-width: 640px;
  margin: auto;
  display: block;
}

.pure-button:after {
	font-family: "FontAwesome";
	content: "\f0a9";
	margin-left: 10px;
}

.pure-button {
	display: inline-block;
	padding: 8px 10px;
	color: #FFFFFF !important;
	background: #fabd0f !important;
	border-radius: 5px;
	font-weight: bold;
}

.pure-button:hover {
	background: #ff007f !important;
}

@media screen and (max-width:459px) {
	.pure-button {
		display: block;
	}
}

/*下段----------------------------------------------------------*/

#underbox {
	clear: both;
	text-align: center;
	font-size: 12px;
}

#copy {
	font-size: 12px;
	text-align: center;
	color: #FFF;
	background-color: #333333;
	padding: 5px;
}

#copy a {
	color: #FFFFFF;
}

/* スクロールトップ*/
#page-top {
	position: fixed;
	bottom: 50px;
	right: 20px;
}

/*パンくずリスト*/
.breadcrumbs {
	width: 100%;
	white-space: nowrap;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	margin-bottom: 10px;
}

.breadcrumbs ol {
	padding: 5px;
}

.breadcrumbs li {
	display: inline-block;
	vertical-align: top;
}

.breadcrumbs li:first-child::before {
	padding: 0 1px 0 0;
	font-family: FontAwesome;
	content: "\f015";
	font-size: 14px;
}

.breadcrumbs li:before {
	padding: 0 4px 0 2px;
	content: "\f105";
	font-family: FontAwesome;
	font-size: 14px;
	color: #09F;
}

.breadcrumbs a {
	color: #09F;
}

.breadcrumbs a.disabled {
	pointer-events: none;
	cursor: default;
	text-decoration: none;
	color: #FFF;
}

aside.ads {
	margin:30px 0;
}
aside.ads .title {
	line-height: 20px;
	font-weight: bold;
	color: #F00;
	padding: 5px 8px;
	border-left: 5px solid #F00;
	border-right: 5px solid #F00;
	background-color: #FFF;
	margin-bottom: 10px;
  text-align: center;
}

/***************************
 ダブルレクタング広告
****************************/
.ads-flexbox .item {
  flex-basis: auto;
  padding: 5px;
  margin: 0px;
  text-align: center;
}
.ads-flexbox .item img {
  max-width: 100%;
  height: auto;
  border: 1px solid #CCC;
  border-radius: 5px;
}
@media ( min-width : 600px ){
  .ads-flexbox {
    display: flex;
    flex-wrap: wrap;
  }
  .ads-flexbox .item {
    width: 50%;
  }
}
.inner300 {
	max-width: 300px;
	width: 100%;
	height: 100%;
	aspect-ratio: 300/250;
	margin: auto;
}
.inner728{
	width: 100%;
	height: 100%;
	margin: auto;
	max-width: 728px;
	aspect-ratio: 728/200;
}
.inner600{
	width: 100%;
	height: 100%;
	margin: auto;
	max-width: 600px;
	aspect-ratio: 600/315;
}

/*広告表示*/
header::after {
	content: url(https://www.kigyou-sapporo.com/img/ad_display_header.png);
	display: flex;
	justify-content: center;
	margin: 10px 0;
}

#info_box::before {
	content: url(https://www.kigyou-sapporo.com/img/ad_display_post.png);
	display: flex;
	justify-content: center;
    margin:1em 0 2em;
}

a.pr-txt-link::before {
	content: "PR";
	font-size: 12px;
	border: 1px solid;
	border-radius: 5px;
	padding: 2px 5px;
	font-weight: bold;
	vertical-align: middle;
	margin-right: 5px;
}

#guide .pr-txt-link::before {
	background-color:#fff;
	color:#fabd0f;
	margin-right:0;
}

a.pr-img-link {
	position: relative;
	display: inline-block;
}

a.pr-img-link::before {
	content: "PR・18禁";
	background-color: #FFF;
    border: 1px solid #f00;
	padding: 0 3px;
	color: #FF0000;
	font-weight: bold;
	font-size: 12px;
	vertical-align: middle;
	position: absolute;
	right: 5px;
	top: 5px;
	z-index: 1;
}

.label_ad {
	position: relative;
}
.label_ad::after{
    content: "AD";
    font-size: 11px;
    background-color: #000;
    border-radius: 3px;
    color: #fff;
    padding: 0 5px;
    position: absolute;
    top: 5px;
    right: 6px;
    height:20px;
    line-height:20px;
}
