@charset "utf-8";

/* ---------------
RESET
--------------- */
a,article,body,dd,div,dl,dt,em,form,footer,header,h1,h2,h3,h4,h5,h6,html,i,iframe,img,label,legend,li,nav,ol,p,section,main,span,table,tbody,tfoot,thead,time,tr,th,td,ul,video{font-family:inherit;font-size:100%;font-weight:inherit;font-style:inherit;vertical-align:baseline;white-space:normal;margin:0;padding:0;border:0;outline:0;background:transparent;line-height:1.6;text-align:left}textarea{/*font-family:inherit;font-size:100%;*/font-weight:inherit;font-style:inherit;vertical-align:baseline;margin:0;padding:0;border:0;outline:0;background:transparent;/*line-height:1.6;*/text-align:left}article,footer,header,nav,section,main{display:block}ol,ul{list-style:none}table{border-collapse:collapse;border-spacing:0}

/* ---------------
COMMON
--------------- */
* {	margin: 0;padding: 0;}
html{font-size: 62.5%;}
body{
	font-family:"メイリオ", Meiryo,sans-serif;
	font-size: 16px;
	line-height: 1.6;
	margin: 0;
	padding: 0;
	color:#464646; /* グレー */
}
img {border: none;}
table{border-collapse:collapse; width:100%;}
ul{list-style:none;}
header, main, section, footer{padding: 0;margin: 0 auto;}

.uline {text-decoration: underline;color: #fff;}
.uline:hover{color: #b33e5c;}

* {box-sizing: border-box;}

/* Footer */
.f-menu{
  display: flex;
  flex-wrap: nowrap;
}
.right-left{text-align: right;}
@media screen and (max-width: 768px){
    .f-menu{flex-direction: column;}
    .right-left{text-align: left;}
}
.f-item{
  width: 100%;
  height: auto;
  margin: 10px;
  color: white;
  font-size: 1.4rem;
}


/* To Top */
#page-top {
    position: fixed;
    bottom: 80px;
    right: 32px;
    margin: 0 auto;
    z-index: 200;
}
 
#page-top a {
    display: table-cell;
    width: 60px;
    height: 60px;
    text-align: center;
    vertical-align: middle;
    color: #fff;
    font-size: 12px;
    font-weight: 800;
    text-decoration: none;
    line-height: 1;
    border-radius: 10%;
    background: #7F96D1;
    opacity: 0.7;
    border: 2px solid #fff;
}

#page-top a:hover {
    background:#202f55;
    color: #fff;
    text-decoration: none;
}

/* ---------------
Wrap + Text
--------------- */

h1{font-size: 4.0rem;}
h2{font-size: 3.6rem;}
h3{font-size: 3.4rem;}
h4{font-size: 3.0rem;}
p{font-size: 2.4rem;}

.container{margin: 0 auto; width: 1280px;height: auto;}
@media screen and (max-width: 1341px){
    .container{width: calc(100% - 60px);}
}
@media screen and (max-width: 1280px){
}
@media screen and (min-width: 1025px){
    html{font-size: 75%;}
}
@media screen and (max-width: 768px){
    .container{width:  calc(100% - 40px);}
    html{font-size: 56.5%;}
}
@media screen and (max-width: 480px) {
    .container{width:  calc(100% - 20px);}
    html{font-size: 50%;}
}

.tx-shadow{text-shadow: 0.2rem 0.2rem 0.1rem #000,
    -0.2rem 0.2rem 0.1rem #000,
    0.2rem -0.2rem 0.1rem #000,
    -0.2rem -0.2rem 0.1rem #000;}

/* ---------------
Wrap + Text
--------------- */

.tx-purple{color: #DC669B;}
.tx-orange{color: #E8AC51;}
.tx-white{color: #FFF;}
.tx-gray{color: #808080; }
.tx-black{color: #555555; }
.tx-blue{color: #4784BF;}
.tx-green{color: #39A869;}
.tx-disc{color: #008080;}
.tx-red{color: #b33e5c;}
.tx-navy{color: #202f55;}

.bg-orange{background-color: #E8AC51;}
.bg-green{background-color: #39A869;}
.bg-blue{background-color: #4784BF;}
.bg-purple{background-color: #DC669B;}
.bg-red{background-color: #b33e5c;}
.bg-navy{background-color: #202f55;}
.bg-skyblue{background-color: #bbbcde;}
.bg-gray{background-color: #808080;}

.center{text-align: center;}
.left{text-align: left;}
.right{text-align: right;}
.top{vertical-align: top;}
.middle{vertical-align: middle;}
.bottom{vertical-align: bottom;}
.bold{font-weight: bold;}

.pt2{padding-top: 2.0rem;}
.pb2{padding-bottom: 2.0rem;}

/* ---------------
TOP
--------------- */
.bg-ttl{
    background: url(../images/solid_edge_subscription/powerful.jpg) no-repeat center center scroll; 
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
    height: 100vh;
   /* height: calc(100vh - 80px); */
    position: relative;
    width: 100%;
    color: #fff;
    background-attachment: fixed;
}
.bg-ttl::before{
    content: ' ';
	background-color: rgba(0,0,0,0.7);
	position: absolute;
    top: 0;
	right: 0;
	bottom: 0;
	left: 0;
}
/*TOP PAGE ONLY */
.sec-top{padding-top: 15.0rem;padding-bottom: 10.0rem;}
.sec-ttl{font-size: 3.0rem;padding-top: 2.0rem; padding-bottom: 2.0rem;}

/* ---------------
SECTION MESSAGES
--------------- */
.sec-gen{padding-top: 5.0rem;padding-bottom: 5.0rem;}

.item-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: stretch;
}
.mess_item {
    display: flex;
    flex-direction: column;
    width: calc(50% - 10.0rem);
    border: 1px solid #ccc;
    box-sizing: border-box;
    margin: 2.0rem 5.0rem;
    padding: 4.0rem;
    -webkit-box-shadow: 0 0 15px rgba(0,0,0,0.4);
    box-shadow: 0 0 15px rgba(0,0,0,0.4);
    -webkit-border-radius: 5px;
    -ms-border-radius: 5px;
    -o-border-radius: 5px;
    border-radius: 5px;
    margin: auto;
}
.mess_item_bk{
    display: flex;
    flex-direction: column;
    width: calc(50% - 10.0rem);
    box-sizing: border-box;
    margin: 2.0rem 5.0rem;
    padding: 4.0rem;
    margin: auto;
}
@media screen and (max-width: 1024px) {
    .mess_item{width: calc(50% - 4.0rem);
    margin: 2.0rem 2.0rem;}
}
@media screen and (max-width: 768px) {
    .mess_item{width: calc(100% - 10.0rem);
    margin: 4.0rem 5.0rem;}
    .mess_item_bk{width: calc(100% - 10.0rem);
    margin: 4.0rem 5.0rem;}
}
@media screen and (max-width: 560px) {
    .mess_item{width: 100%; margin: 4.0rem 0;padding: 2.0rem 1.0rem;}
    .mess_item_bk{width: 100%; margin: 4.0rem 0;padding: 2.0rem 1.0rem;}
}
.mess_item img {
  width: 100%;!important
  height: auto;!important
  /* object-fit: cover;*/
  vertical-align: bottom;
}
.zoom_image {
overflow: hidden;
width: 100%;
height: 100%;
background: #fff;
/*ADD*/
    vertical-align: bottom;
}
.zoom_image img {
display: block;
width: 100%;
height: auto;
transition-duration: 0.5s;
}
.zoom_image img:hover {
transform: scale(1.2);
transition-duration: 0.5s;
/* IF YOU NEED -> opacity: 0.6;*/
}

.mess-ttl{font-size: 2.4rem;padding-bottom: 1.2rem;}
.mess-body-b{font-size: 2.0rem;padding-top: 1.2rem;}
.mess-body{font-size: 1.8rem;padding-top: 1.2rem;}
.mess-caution{font-size: 1.4rem;padding-top: 1.0rem;padding-bottom: 2.0rem;}

/* Button*/
.mess_item-btn {
    margin-top: auto;
    text-align: center;
    font-weight: bold;
    font-size: 2.0rem;
}
.mess_item-btn a {
    display: inline-block;
    padding: 10px;
    border-radius: 5px;
    color: #4784BF;
    text-decoration: none;
    border: 2px solid #4784BF;
}
.mess_item-btn a:hover {
    background: #b33e5c;
    color: #FFFFFF;
    border: 1px solid #b33e5c;
}

/* DELETE */
.mes-cont{padding-top: 2.0rem;}

/* ---------------
OVERVIEW
--------------- */
.check-mark{text-indent: -1em;
    margin-left: 2em;}
.check-mark:before {
    content: url(../images/solid_edge_subscription/check-red-32.png);
    display: inline-block;
    width: 1em;
    text-indent: -0.5em;}
.notice-mark{text-indent: -1em;
    margin-left: 2em;}
.notice-mark:before {
    content: "※";
    display: inline-block;
    width: 1em;
    text-indent: -0.5em;}

/* ---------------
PACKAGE
--------------- */

.prod_item {
  display: flex;
  flex-direction: column;
  width: calc(25% - 3.0rem);
  border: 1px solid #ccc;
  box-sizing: border-box;
    margin-top: ;2.0rem;
    margin-right: 3.0rem;
    margin-bottom: 2.0rem;
    -webkit-box-shadow: 0 0 15px rgba(0,0,0,0.4);
    box-shadow: 0 0 15px rgba(0,0,0,0.4);
    -webkit-transition: all 0.25s ease;
    -o-transition: all 0.25s ease;
    transition: all 0.25s ease;
    -webkit-border-radius: 5px;
    -ms-border-radius: 5px;
    -o-border-radius: 5px;
    border-radius: 5px;
}
.prod_item:nth-child(4){margin-right: 0;}
.prod_item:hover {
    -webkit-transform: scale(1.06);
    -ms-transform: scale(1.06);
    -o-transform: scale(1.06);
    transform: scale(1.06);
}
.prod_item-image {
  min-height: 0%;
  margin-bottom: 1em;
}
.prod_item-image img {
  width: 100%;!important
  height: auto;!important
    object-fit: cover;
  vertical-align: bottom;
}
.prod_item-btn {
  margin-top: auto;
}
.prod_item-btn a {
  display: block;
  padding: 10px;
  border-radius: 5px;
  color: #fff;
  text-decoration: none;
  text-align: center;
}
.height-4{height: 4.0rem;}
.height-6{height: 6.0rem;}
.height-8{height: 8.5rem;}
.height-10{height: 10.0rem;}
.height-12{height: 12.0rem;}
.height-14{height: 14.0rem;}
.fs-12{font-size: 1.2rem;}
.fs-14{font-size: 1.4rem;}
.fs-16{font-size: 1.6rem;}
.fs-20{font-size: 2.0rem;}
.fs-22{font-size: 2.2rem;}
.fs-28{font-size: 2.8rem;}
.prod_inner p{line-height: 1.2;}
.jp-ad{display: inline-block;line-height: 1.2;}
.prod_outer{
    display:table;
    width:100%;
    padding: 1.0rem;
}
.prod_inner{
    display:table-cell;
    color: #FFF;
    font-weight: bold;
    line-height: 1.2;
}
.mtop-auto{margin-top: auto;}

.check-mark24{text-indent: -1em;
    margin-left: 2em;}
.check-mark24:before {
        content: url(../images/solid_edge_subscription/check-red-24.png);}
@media screen and (max-width: 1024px){
    .check-mark24:before {
        content: url(../images/solid_edge_subscription/check-red-22.png);}
}
@media screen and (max-width: 768px){
    .check-mark24:before {
        content: url(../images/solid_edge_subscription/check-red-18.png);}
}
@media screen and (max-width: 480px) {
    .check-mark24:before {
        content: url(../images/solid_edge_subscription/check-red-16.png);}
}


@media screen and (max-width: 1024px){
    .prod_item{width: calc(33.33% - 20px) ;}
    .prod_item:nth-child(3){margin-right: 0;}
}
@media screen and (max-width: 768px){
    .prod_item{width: calc(50% - 20px);}
    .prod_item:nth-child(2){margin-right: 0;}
    .prod_item:nth-child(4){margin-right: 0;}
}
@media screen and (max-width: 480px) {
    .prod_item{width: 100%; margin-right: 0; }
}


/*--------------------------------
GLOBAL NAVI
　
--------------------------------*/
.inner {
	max-width: 1280px;
	margin: 0 auto;
}
.inner:after {
	content: "";
	clear: both;
	display: block;
}
#top-head {
	font-size: 1.4rem;
	top: -100px;
	position: absolute;
	width: 100%;
	margin: 100px auto 0;
	padding: 10px 0 0;
	line-height: 1;
	z-index: 999;
}
#top-head a,
#top-head {
    color: #333;
    background: #fff;
	text-decoration: none;
}
#top-head .inner {
	position: relative;
}
#top-head .logo {
	float: left;
	font-size: 36px;
    width: 139px;
}
#top-head .logo img {
	width: 100%;
}
#global-nav ul {
	list-style: none;
	position: absolute;
	right: 0;
	bottom: 10px; 
	font-size: 1.4rem;
    font-weight: bold;
}
#global-nav ul li {
	float: left;
	position: relative;
}
#global-nav ul li a {
	padding: 0 20px;
}
#global-nav ul li a:hover {
	color: #b33e5c;
}
/* Btn Hover */
#global-nav ul li:after {
	position: absolute;
	content: "";
	display: block;
	width: 100%;
	height: 3px;
	bottom: -10px;
	transition: all 0.3s ease;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
}
#global-nav ul li:hover:after {
	background: #b33e5c; 
	bottom: -10px;
}
#top-head.fixed {
	margin-top: 0;
	top: 0;
	position: fixed;
	padding-top: 5px; 
	height: 60px; 
	background: #fff;
    z-index: 998;
}
#top-head.fixed .logo {
	font-size: 12px;
    width: 112px; 
}
#top-head.fixed .logo img {
	width: 100%;
}
#top-head.fixed #global-nav ul li a {
	color: #333;
	padding: 0 20px;
}
#top-head.fixed #global-nav ul li:after {
	bottom: -10px;
}
#top-head.fixed #global-nav ul li:hover:after {
	background: #b33e5c;
	bottom: -10px; 
}
#nav-toggle {
	display: none;
	position: absolute;
	right: 12px;
	top: 14px;
	width: 34px;
	height: 36px;
	cursor: pointer;
	z-index: 101;
}
#nav-toggle div {
	position: relative;
}
#nav-toggle span {
	display: block;
	position: absolute;
	height: 4px;
	width: 100%;
	background: #666;
	left: 0;
	-webkit-transition: .35s ease-in-out;
	-moz-transition: .35s ease-in-out;
	transition: .35s ease-in-out;
}
#nav-toggle span:nth-child(1) {
	top: 0;
}
#nav-toggle span:nth-child(2) {
	top: 11px;
}
#nav-toggle span:nth-child(3) {
	top: 22px;
}
@media screen and (max-width: 1341px){
    .inner{width: calc(100% - 60px);}
}
@media screen and (max-width: 1280px) {
	#global-nav ul li a {
		padding: 0 20px;
	}
	#top-head.fixed #global-nav ul li a {
		padding: 0 15px;
	}
}
@media screen and (max-width: 1024px){
    /* .inner{width: calc(100% - 30px);}*/
}
@media screen and (max-width: 768px) {

	.inner {
        width: 100%;
	}
	#top-head {
		top: 0;
		position: fixed;
		margin-top: 0;
        width: 100%;
	}
	#top-head.fixed {
		padding-top: 0;
		background: #fff;
	}
	#mobile-head {
		background: #fff;
		width: 100%;
		height: 56px;
		z-index: 999;
		position: relative;
	}
	#top-head.fixed .logo,
	#top-head .logo {
		position: absolute;
        left: 2.2rem;
        top: 8px;
		color: #333;
		font-size: 12px;
        width: 98px;
	}
	#global-nav {
		position: absolute;
		top: -500px;
		/* background: #333; */background: #fff;
		width: 100%;
		text-align: center;
		padding: 10px 0;
		-webkit-transition: .5s ease-in-out;
		-moz-transition: .5s ease-in-out;
		transition: .5s ease-in-out;
	}
	#global-nav ul {
		list-style: none;
		position: static;
		right: 0;
		bottom: 0;
		font-size: 14px;
        padding-left: 1.0rem;
	}
	#global-nav ul li {
		float: none;
		position: static;
	}
	#global-nav ul li:after  {
		display: none;
	}
	#top-head #global-nav ul li a,
	#top-head.fixed #global-nav ul li a {
		width: 100%;
		display: block;
		/* color: #fff; */ color: #333;
		padding: 1.8rem 0;
	}
    /*TEST*/
    #top-head #global-nav ul li a:hover,
    #top-head.fixed #global-nav ul li a:hover {
        color: #b33e5c;
    } 
	#nav-toggle {
		display: block;
	}
	.open #nav-toggle span:nth-child(1) {
		top: 11px;
		-webkit-transform: rotate(315deg);
		-moz-transform: rotate(315deg);
		transform: rotate(315deg);
	}
	.open #nav-toggle span:nth-child(2) {
		width: 0;
		left: 50%;
	}
	.open #nav-toggle span:nth-child(3) {
		top: 11px;
		-webkit-transform: rotate(-315deg);
		-moz-transform: rotate(-315deg);
		transform: rotate(-315deg);
	}
	.open #global-nav {
		-moz-transform: translateY(556px);
		-webkit-transform: translateY(556px);
		transform: translateY(556px);
	}
}
@media screen and (max-width: 480px) {
    #top-head.fixed .logo,
    #top-head .logo {left: 2.0rem;}
}

