@charset "utf-8";

html { scroll-behavior: smooth; }
#globalMain, #globalContents{ overflow: visible; }
#globalWrapper { box-sizing: border-box; }


/* Variables & Setup -------------------- */
:root {
  scroll-padding: 100px;
}

.roland-container-wrapper {
  container-type: inline-size;
  container-name: roland-container-wrapper;
}

.roland-container * { box-sizing: border-box; }

:root .roland-container {
  --color-black: #000;
  --color-white: #fff;
  --color-accent: #ffc000;
  /* --hover-opacity: 0.7; */
  /* --drop-shadow: drop-shadow(3px 3px 4px rgba(0, 0, 0, 0.2)) */
  --item-gap: 1rem;
  --padding-common: 1.5rem;
  --spacing-common: 1rem;
}


/* common -------------------- */ 
.roland-container {
  max-width: 1420px;
  margin-inline: auto;
  padding-bottom: 2rem;
  background-color: var(--color-white);
  color: var(--color-black);
  font-size: 16px;
  line-height: 1.4;
  @container roland-container-wrapper (max-width: 768px) {
    font-size: 14px;
  }
  @container roland-container-wrapper (max-width: 350px) {
    font-size: 13px;
  }

  & section{
    padding-block: 1rem;
  }


  & .inner{
    max-width: 1200px;
    margin-inline: auto;
    padding-inline: var(--padding-common);
  }

  & figure{ 
    text-align: center;
    overflow: hidden;
    & figcaption{
      margin-top: .25rem;
    }
  }

  & img{
    max-width: 100%;
    height: auto;
    vertical-align: bottom;
  }

  & a{
    color: inherit;
    text-decoration: none;
  }

  & span{
    color: inherit;
    font-weight: inherit;
  }
}


/* PC用
#globalContents  */

/* スマホ用
#wrapper */



/* element -------------------- */
/* 汎用コンテナ */
.roland-container .general-container + .general-container{
  margin-top: calc( var(--spacing-common) * 2);
}
/* 汎用ボックス */
.roland-container .general-wrapper{
  margin-block: var(--spacing-common)
}

/* 見出し（帯） */
.roland-container .el-hgroup-label{
  margin-bottom: .5rem;
  padding-block: .5rem;
  padding-inline: 1rem;
  background-color: var(--color-accent);
  & > *{
    width: fit-content;
    margin-inline: auto;
    font-weight: bold;
    font-size: 125%;
  }
@container roland-container-wrapper (max-width: 768px) {
  & > *{
    font-size: 112%;
  }
}
}

/* 小見出し */
.roland-container .el-sub-heading{
  margin-bottom: .25rem;
  font-size: 112%;
  font-weight: bold;
  &::before{
    content: "●";
  }
}

/* 見出し */
.roland-container .el-heading{
	text-align: center;

  &  h2{
    color: var(--color-red);
    text-align: center;
    font-size: 300%;
    font-weight: bold;
    letter-spacing: 0.03em;
    text-transform: uppercase;
  }

  & p{
    font-size: 120%;

    &::before,
    &::after{
      content: " ー ";

    }
  }
}

/* CTAボタン */
.roland-container .el-btn-cta{
	display: block;
	width: 50%;
	margin: auto;
	margin-top: 1rem;
	padding: .3em 0;
  border-radius: 100vmax;
	border: 2px solid var(--color-red);
	background-color: var(--color-red);
	color: var(--color-white);
	text-align: center;
  font-weight: bold;

  &:hover{
    background-color: var(--color-white);
    color: var(--color-red);
  }
}

/* 文字リンク */
.roland-container .el-tlink{
  display: inline-block;
  padding-inline: .3em;
  border-radius: .25em;
  color: var(--color-link);
  font-weight: bold;

  &:hover{
    background-color: var(--color-link);
    color: var(--color-white);
  }
}

/* 視覚的に非表示 */
.roland-container .el-visually-hidden{
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
  border: 0;
}

/* img：祖先要素ホバーで拡大 */
.roland-container .fx-expansion{
 
  & img {
    transition: transform 0.3s ease;
  }

  &:hover img {
    transform: scale(1.03);
  }
} 


/* 文章 */
.roland-container .paragraph{
  line-height: 1.7;
  /* text-align: justify; */

  & + .paragraph{
    margin-top: .5rem;
  }
}

/* 2行以上で... */
.roland-container .textellipsis-2{
	display: -webkit-box;
	-webkit-box-orient: vertical;
	overflow: hidden;
	text-overflow: ellipsis;
  line-clamp: 2;
	-webkit-line-clamp: 2;
}

/* 動画のabsoアイコン（aにクラス名つける）*/
.roland-container .icon-movie{
	display: block;
	width: 100%;
	position: relative;

  &::after { position: absolute; display: block;	content: ""; width: 100%; height: 0; padding-top: 56.25%;top: 0;	left: 0;	background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" height="100%" version="1.1" viewBox="0 0 68 48" width="100%" fill="%23ffffff"><path d="M66.52,7.74c-0.78-2.93-2.49-5.41-5.42-6.19C55.79,.13,34,0,34,0S12.21,.13,6.9,1.55 C3.97,2.33,2.27,4.81,1.48,7.74C0.06,13.05,0,24,0,24s0.06,10.95,1.48,16.26c0.78,2.93,2.49,5.41,5.42,6.19 C12.21,47.87,34,48,34,48s21.79-0.13,27.1-1.55c2.93-0.78,4.64-3.26,5.42-6.19C67.94,34.95,68,24,68,24S67.94,13.05,66.52,7.74z" fill="%23f00"></path><path d="M 45,24 27,14 27,34" fill="%23fff"></path></svg>') no-repeat center center;	background-size: 20%; }
}

/* 点々のリスト */
.roland-container .disc-list{
  list-style: disc;
  margin-left: 1.5rem;
  & > li + li{
    margin-top: .5rem;
  }
}

/* 画像１枚 */
/* .roland-container .el-image-block{
  margin-block: var(--spacing-common);
} */

/* 画像２つ横並びボックス */
/* ※figcaptionは1行まで */
.roland-container .el-dual-box{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--item-gap);
  margin-block: var(--spacing-common);
  & img{
    display: block;
    width: 100%;
    height: calc(100% - 1.5rem);
    object-fit: contain
  }
@container roland-container-wrapper (max-width: 600px) {
  grid-template-columns: 100%;
  & img{
    height: auto;
  }
  & a{
    display: contents;
    pointer-events: none;
  }
  & .note{
    display: none;
  }
}
}


/* gLightbox -------------------- */
.goverlay {
	background: rgba(0, 0, 0, .7);
}


/* Section-by-section -------------------- */
/* FV */
.roland-container .sec-fv{
  padding-block: 0;
}

/* オペレーションの省力化を～ */
.sec-customize .unit-box{
  display: flex;
  flex-direction: row-reverse;
  align-items: center;
  gap: var(--spacing-common);
  & .el-image-block{
    width: 350px;
  }
  & .text-block{
    flex: 1;
  }
}

.sec-customize .customize-list{
  display: flex;
  flex-direction: column;
  gap: 2rem var(--spacing-common);
  & > li{
    display: flex;
    flex-direction: row-reverse;
    gap: .5rem var(--spacing-common);
  }
  & > li:nth-child(even){
    flex-direction: row;
    align-items: center;
  }

  & .text-block{
    flex: 1;
  }
  & .image-block{
    width: 400px;
    max-width: 100%;
  }
  & .pattern-box{
    width: 550px;
    max-width: 100%;
  }
@container roland-container-wrapper (max-width: 900px) {
  & > li,
  & > li:nth-child(even){
    flex-direction: column;
    align-items: flex-start;
  }
}
}

.sec-customize .pattern-box{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: .5rem;
  width: fit-content;
}

/* アプリケーションにもフル対応 */
.sec-application .el-sub-heading{
  margin-top: var(--spacing-common);
  font-weight: normal;
  &::before{content: "＜";}
  &::after{content: "＞";}
}

/* 主な仕様 */
.sec-spec .table-container{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--spacing-common);
  margin-top: var(--spacing-common);
@container roland-container-wrapper (max-width: 600px) {
  grid-template-columns: 100%;
}
}

.sec-spec .spec-table{
  border-collapse: collapse;
  font-size: 85%;
  width: 100%;
  & th, & td{
    border: 1px solid #333;
    padding: .25em .5em;
    font-weight: normal;
  }
  & th{
    width: 10rem;
    
  }
  & td > div + div{
    margin-top: .5rem;
  }
}

/* 商品ページへ */
.roland-container .btn-to-product{
  display: block;
  width: fit-content;
  min-width: 50%;
  margin-inline: auto;
  margin-block: 1.5rem;
  padding-block: .5rem;
  padding-inline: 1.5rem;
  border-radius: 100vmax;
  background-color: var(--color-black);
  color: var(--color-white);
  text-align: center;
  &:hover{
    opacity: 0.7;
  }
}

/* 背景画像のショートハンド */
.test{
  background: url("画像パス") no-repeat center / contain;
}