/*
Theme Name: BuysellPortal-2021
Author: Buysell Technologies
Author URI: https://buysell-technologies.com/
*/

/* -------------------------------------------------------------------------- */
/*	CSS Reset
/* -------------------------------------------------------------------------- */

html,
body {
	border: none;
	margin: 0;
	padding: 0;

  /* scroll-behavior: smooth; */
}

h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
address,
big,
cite,
code,
em,
font,
img,
small,
strike,
sub,
sup,
li,
ol,
ul,
fieldset,
form,
label,
legend,
button,
table,
caption,
tr,
th,
td {
	border: none;
	font-size: inherit;
	line-height: 1.2;
	margin: 0;
	padding: 0;
	text-align: inherit;
}

blockquote::before,
blockquote::after {
	content: "";
}


/* -------------------------------------------------------------------------- */
/*	1. Document Setup
/* -------------------------------------------------------------------------- */


html {
  line-height: 1.15; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */

  font-family: "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro", "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "メイリオ", sans-serif;
}

/* Sections
   ========================================================================== */

/**
 * Render the `main` element consistently in IE.
 */

main {
  display: block;
}
.pcdevice main .container {
  min-height: 62.5vw;
}
@media only screen and (min-width: 1281px) {
  .pcdevice main .container {
    min-height: 800px;
  }
}

/* Grouping content
   ========================================================================== */

/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */

hr {
  box-sizing: content-box; /* 1 */
  height: 0; /* 1 */
  overflow: visible; /* 2 */
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */

pre {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/* Text-level semantics
   ========================================================================== */

/**
 * Remove the gray background on active links in IE 10.
 */

a {
  background-color: transparent;
  display: block;
  text-decoration: underline;
  color: var(--mrcr-blue);
}
a.col, a.col:active, a.col:visited {
  color: var(--link-blue);
}
a:hover,a img:hover, a svg:hover, a svg g path:hover {
  cursor: pointer;
  -webkit-transition: all 0.3s;
	-moz-transition: all 0.3s;
	-ms-transition: all 0.3s;
	-o-transition: all 0.3s;
	transition: all 0.3s;
  opacity: 0.7;
}
a.disabled {
  pointer-events: none; /* リンク無効 */
}


/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */

abbr[title] {
  border-bottom: none; /* 1 */
  text-decoration: underline; /* 2 */
  text-decoration: underline dotted; /* 2 */
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */

b,
strong {
  font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */

code,
kbd,
samp {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/**
 * Add the correct font size in all browsers.
 */

small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* Embedded content
   ========================================================================== */

/**
 * Remove the border on images inside links in IE 10.
 */

img {
  border-style: none;
}

/* Forms
   ========================================================================== */

/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */

button,
input,
optgroup,
select,
textarea {
  font-family: inherit; /* 1 */
  font-size: 100%; /* 1 */
  line-height: 1.15; /* 1 */
  margin: 0; /* 2 */
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */

button,
input { /* 1 */
  overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */

button,
select { /* 1 */
  text-transform: none;
}

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */

button,
[type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button;
}

/**
 * Remove the inner border and padding in Firefox.
 */

button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */

button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

/**
 * Correct the padding in Firefox.
 */

fieldset {
  padding: 0.35em 0.75em 0.625em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */

legend {
  box-sizing: border-box; /* 1 */
  color: inherit; /* 2 */
  display: table; /* 1 */
  max-width: 100%; /* 1 */
  padding: 0; /* 3 */
  white-space: normal; /* 1 */
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */

progress {
  vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */

textarea {
  overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10.
 * 2. Remove the padding in IE 10.
 */

[type="checkbox"],
[type="radio"] {
  box-sizing: border-box; /* 1 */
  padding: 0; /* 2 */
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */

[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */

[type="search"] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */

[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */

::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/* Interactive
   ========================================================================== */

/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */

details {
  display: block;
}

/*
 * Add the correct display in all browsers.
 */

summary {
  display: list-item;
}

/* Misc
   ========================================================================== */

/**
 * Add the correct display in IE 10+.
 */

template {
  display: none;
}

/**
 * Add the correct display in IE 10.
 */

[hidden] {
  display: none;
}


/* Common Setting
   ========================================================================== */
* {
  position: relative;
  box-sizing: border-box;
}

*::after {
  clear: both;
}
.cf::after {
  content: "";
  display: block;
  clear: both;
  height: 0;
  visibility: hidden;
}

.sp, .pcdevice .pc {
  display: block;
}
.pc, .pcdevice .sp {
  display: none;
}
@media only screen and (min-width: 768px){
  .sp {
    display: none;
  }
  .pc {
    display: block;
  }
}

p {
  margin: 0;
  padding: 0;
  line-height: 1.2;
  overflow-wrap: break-word;
  word-break: break-all;
}

ul li {
  list-style: none;
}

picture, img {
  display: block;
  height: auto;
}
picture img, a img {
  width: 100%;
  vertical-align: bottom;
}

.width-nolimit {
  max-width: none !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.inline {
  display: inline;
}

/* Animation Fade-in */
.fadein {
  animation-name: anim-fadein;
  animation-duration: 0.2s;
}
@keyframes anim-fadein{
  from{
    opacity: 0;
  }
  to{
    opacity: 1;
  }
}

/* 上下マージン */
.no-margin_top > * {
  margin-top: 0 !important;
}
.no-margin_bottom > * {
  margin-bottom: 0 !important;
}

/* ボックス中央寄せ */
.box-center {
  position: absolute;
  top: 50%;
  left: 50%;
  margin-right: -50%;
  transform: translate(-50%, -50%);
}

/* archive: データなし 非表示対応 */
.nodata {
  display: none;
}

/* Color variable */
:root {
  --buysell-gold: #a87704;  /* バイセルカラー */
  --buysell-gold_old: #c7982c;  /* 旧バイセルカラー */
  --buysell-darkbrown: #765300;  /* バイセル濃茶 */

  --basic-textcol: #333333; /* 文字基本色 */
  --price-red: #ef2604; /* 価格赤 */
  --attent-red: #E61919; /* 重要箇所赤 */
  --link-blue: #0d4c96; /* テキストリンク */
  --point-yellow: #fae77a;  /* 差し色 イエロー */
  
  --bg-gray: #f4f4f4; /* タイトル背景 グレー */
  --bg-darkgray: #4d4d4d; /* フッター背景 */
  --bg-rightgray: #f5f2eb; /* コンテンツ背景 */
  --bg-beige: #F8F7F3; /* コンテンツ背景 */

  --flame-gray: #cccccc; /* 枠線 グレー */

  --tel-green: #007900; /* 電話番号 */
  --button-orange: #ef6c0c; /* 電話番号ボタン */
  --button-orange-shadow: #a04802; /* 電話番号ボタン影 */
  --bg-ivory: #f4ebd9; /* CTA背景 */

  --mrcr-red: #ff0211;
  --mrcr-red_sdw: #ce0b16;
  --mrcr-cyan: #4dc9ff;
  --mrcr-blue: #0081da;
  --mrcr-green: #00c5a9;
  --mrcr-green_sdw: #029b85;
  --mrcr-bg-gray: #f5f5f5;
  --mrcr-bg-cyan: #ddf3ff;
}
.gold {
  color: var(--buysell-gold);
}
.mc-blue {
  color: var(--mrcr-blue);
}
.mc-cyan {
  color: var(--mrcr-cyan);
}
.mc-red {
  color: var(--mrcr-red);
}

.note {
    color: red !important;
    padding-top: 30px;
}

/* font-size */
/* Mobile - Standard */
.fsz09 { font-size:9px; }
.fsz10 { font-size:10px; }
.fsz11 { font-size:11px; }
.fsz12 { font-size:12px; }
.fsz13,.tag { font-size:13px; }
.fsz14 { font-size:14px; }
.fsz15 { font-size:15px; }
.fsz16,header,main { font-size:16px; }
.fsz17 { font-size:17px; }
.fsz18 { font-size:18px; }
.fsz19 { font-size:19px; }
.fsz20 { font-size:20px; }
.fsz22 { font-size:22px; }
.fsz24 { font-size:24px; }
.fsz25 { font-size:25px; }
.fsz26 { font-size:26px; }
.fsz28 { font-size:28px; }
.fsz30 { font-size:30px; }
.fsz32 { font-size:32px; }
.fsz34 { font-size:34px; }
.fsz35 { font-size:35px; }
.fsz36 { font-size:36px; }
.fsz38 { font-size:38px; }
.fsz39 { font-size:39px; }
.fsz40 { font-size:40px; }
.fsz42 { font-size:42px; }
.fsz45 { font-size:45px; }
.fsz50 { font-size:50px; }
.fsz60 { font-size:60px; }
.fsz65 { font-size:65px; }

/* Mobile - Regacy */
.smalldev .fsz09 { font-size:calc( 9px * ( 320 / 375 ) ); }
.smalldev .fsz10 { font-size:calc( 10px * ( 320 / 375 ) ); }
.smalldev .fsz11 { font-size:calc( 11px * ( 320 / 375 ) ); }
.smalldev .fsz12 { font-size:calc( 12px * ( 320 / 375 ) ); }
.smalldev .fsz13,.tag { font-size:calc( 13px * ( 320 / 375 ) ); }
.smalldev .fsz14 { font-size:calc( 14px * ( 320 / 375 ) ); }
.smalldev .fsz15 { font-size:calc( 15px * ( 320 / 375 ) ); }
.smalldev .fsz16,header,main { font-size:calc( 16px * ( 320 / 375 ) ); }
.smalldev .fsz17 { font-size:calc( 17px * ( 320 / 375 ) ); }
.smalldev .fsz18 { font-size:calc( 18px * ( 320 / 375 ) ); }
.smalldev .fsz19 { font-size:calc( 19px * ( 320 / 375 ) ); }
.smalldev .fsz20 { font-size:calc( 20px * ( 320 / 375 ) ); }
.smalldev .fsz22 { font-size:calc( 22px * ( 320 / 375 ) ); }
.smalldev .fsz24 { font-size:calc( 24px * ( 320 / 375 ) ); }
.smalldev .fsz25 { font-size:calc( 25px * ( 320 / 375 ) ); }
.smalldev .fsz26 { font-size:calc( 26px * ( 320 / 375 ) ); }
.smalldev .fsz28 { font-size:calc( 28px * ( 320 / 375 ) ); }
.smalldev .fsz30 { font-size:calc( 30px * ( 320 / 375 ) ); }
.smalldev .fsz32 { font-size:calc( 32px * ( 320 / 375 ) ); }
.smalldev .fsz34 { font-size:calc( 34px * ( 320 / 375 ) ); }
.smalldev .fsz35 { font-size:calc( 35px * ( 320 / 375 ) ); }
.smalldev .fsz36 { font-size:calc( 36px * ( 320 / 375 ) ); }
.smalldev .fsz38 { font-size:calc( 38px * ( 320 / 375 ) ); }
.smalldev .fsz39 { font-size:calc( 39px * ( 320 / 375 ) ); }
.smalldev .fsz40 { font-size:calc( 40px * ( 320 / 375 ) ); }
.smalldev .fsz42 { font-size:calc( 42px * ( 320 / 375 ) ); }
.smalldev .fsz45 { font-size:calc( 45px * ( 320 / 375 ) ); }
.smalldev .fsz50 { font-size:calc( 50px * ( 320 / 375 ) ); }
.smalldev .fsz60 { font-size:calc( 60px * ( 320 / 375 ) ); }
.smalldev .fsz65 { font-size:calc( 65px * ( 320 / 375 ) ); }

/* PC */
.pcdevice .fsz09, .pcdevice .xfsz09 { font-size: clamp( 1px, 0.70vw, 9px ) }
.pcdevice .fsz10, .pcdevice .xfsz10 { font-size: clamp( 1px, 0.78vw, 10px ) }
.pcdevice .fsz11, .pcdevice .xfsz11 { font-size: clamp( 1px, 0.86vw, 11px ) }
.pcdevice .fsz12, .pcdevice .xfsz12 { font-size: clamp( 1px, 0.94vw, 12px ) }
.pcdevice .fsz13, .pcdevice .xfsz13,.pcdevice .tag { font-size: clamp( 1px, 1.02vw, 13px ) }
.pcdevice .fsz14, .pcdevice .xfsz14 { font-size: clamp( 1px, 1.09vw, 14px ) }
.pcdevice .fsz15, .pcdevice .xfsz15 { font-size: clamp( 1px, 1.17vw, 15px ) }
.pcdevice .fsz16, .pcdevice .xfsz16,.pcdevice header,.pcdevice main { font-size: clamp( 1px, 1.25vw, 16px ) }
.pcdevice .fsz17, .pcdevice .xfsz17 { font-size: clamp( 1px, 1.33vw, 17px ) }
.pcdevice .fsz18, .pcdevice .xfsz18 { font-size: clamp( 1px, 1.41vw, 18px ) }
.pcdevice .fsz19, .pcdevice .xfsz19 { font-size: clamp( 1px, 1.48vw, 19px ) }
.pcdevice .fsz20, .pcdevice .xfsz20 { font-size: clamp( 1px, 1.56vw, 20px ) }
.pcdevice .fsz22, .pcdevice .xfsz22 { font-size: clamp( 1px, 1.72vw, 22px ) }
.pcdevice .fsz24, .pcdevice .xfsz24 { font-size: clamp( 1px, 1.88vw, 24px ) }
.pcdevice .fsz25, .pcdevice .xfsz25 { font-size: clamp( 1px, 1.95vw, 25px ) }
.pcdevice .fsz26, .pcdevice .xfsz26 { font-size: clamp( 1px, 2.03vw, 26px ) }
.pcdevice .fsz28, .pcdevice .xfsz28 { font-size: clamp( 1px, 2.19vw, 28px ) }
.pcdevice .fsz30, .pcdevice .xfsz30 { font-size: clamp( 1px, 2.34vw, 30px ) }
.pcdevice .fsz32, .pcdevice .xfsz32 { font-size: clamp( 1px, 2.50vw, 32px ) }
.pcdevice .fsz34, .pcdevice .xfsz34 { font-size: clamp( 1px, 2.66vw, 34px ) }
.pcdevice .fsz35, .pcdevice .xfsz35 { font-size: clamp( 1px, 2.73vw, 35px ) }
.pcdevice .fsz36, .pcdevice .xfsz36 { font-size: clamp( 1px, 2.81vw, 36px ) }
.pcdevice .fsz38, .pcdevice .xfsz38 { font-size: clamp( 1px, 2.97vw, 38px ) }
.pcdevice .fsz39, .pcdevice .xfsz39 { font-size: clamp( 1px, 3.04vw, 39px ) }
.pcdevice .fsz40, .pcdevice .xfsz40 { font-size: clamp( 1px, 3.13vw, 40px ) }
.pcdevice .fsz42, .pcdevice .xfsz42 { font-size: clamp( 1px, 3.28vw, 42px ) }
.pcdevice .fsz45, .pcdevice .xfsz45 { font-size: clamp( 1px, 3.51vw, 45px ) }
.pcdevice .fsz50, .pcdevice .xfsz50 { font-size: clamp( 1px, 3.91vw, 50px ) }
.pcdevice .fsz60, .pcdevice .xfsz60 { font-size: clamp( 1px, 4.69vw, 60px ) }
.pcdevice .fsz65, .pcdevice .xfsz65 { font-size: clamp( 1px, 5.08vw, 65px ) }

/* letter-spacing */
.letspace1 { letter-spacing: 1px;}
.letspace2 { letter-spacing: 2px;}
.letspace3 { letter-spacing: 3px;}
.letspace4 { letter-spacing: 4px;}
.letspace5 { letter-spacing: 5px;}
.letspace1m { letter-spacing: -1px;}
.letspace2m { letter-spacing: -2px;}
.letspace3m { letter-spacing: -3px;}

.pcdevice .letspace1 { letter-spacing: 0.08333333vw;}
.pcdevice .letspace2 { letter-spacing: 0.16666666vw;}
.pcdevice .letspace3 { letter-spacing: 0.25vw;}
.pcdevice .letspace4 { letter-spacing: 0.33333333vw;}
.pcdevice .letspace5 { letter-spacing: 0.41666666vw;}
.pcdevice .letspace1m { letter-spacing: -0.08333333vw;}
.pcdevice .letspace2m { letter-spacing: -0.16666666vw;}
.pcdevice .letspace3m { letter-spacing: -0.234375vw;}

@media only screen and (min-width: 1281px) {
  .pcdevice .letspace1,.letspace1 { letter-spacing: 1px;}
  .pcdevice .letspace2,.letspace2 { letter-spacing: 2px;}
  .pcdevice .letspace3,.letspace3 { letter-spacing: 3px;}
  .pcdevice .letspace4,.letspace4 { letter-spacing: 4px;}
  .pcdevice .letspace5,.letspace5 { letter-spacing: 5px;}
  .pcdevice .letspace1m,.letspace1m { letter-spacing: -1px;}
  .pcdevice .letspace2m,.letspace2m { letter-spacing: -2px;}
  .pcdevice .letspace3m,.letspace3m { letter-spacing: -3px;}
}

/* Text kerning */
.palt {
  font-feature-settings: "palt";
}

/* Tag: section */
section {
  width: 100%;
  margin: 80px 0;
}
.pcdevice section {
  margin-bottom: 9.375vw 0;
}
section.smalltype {
  margin-top: 60px;
  margin-bottom: 60px;
}
.pcdevice section.smalltype {
  margin-top: 4.6875vw;
  margin-bottom: 4.6875vw;
}
.section_inner {
  padding: 0 5%;
}
.pcdevice .section_inner {
  padding: 0 1.25%;
}

@media only screen and (min-width: 1281px) {
  .pcdevice section {
    margin-bottom: 120px 0;
  }
  .pcdevice section.smalltype {
    margin-top: 60px;
    margin-bottom: 60px;
  }
  .pcdevice .section_inner {
    padding: 0 20px;
  }
}

/* Styling: h1,h2,h3,h4,h5 */
h1,h2,h3,h4,h5,.title {
  display: block;
  font-weight: bold;
}
.center {
  text-align: center;
}
.widetitle,
.widecontent {
  width: calc( 100% + 20px * 2 );
  left: -20px;
}
.pcdevice .widetitle,
.pcdevice .widecontent {
  width: 100%;
  left: 0;
}

/* Styling: bg-color */
.bg-gray {
  background-color: var(--thin-gray);
}
.bg-red {
  background-color: var(--important-red);
}
.bg-yellow {
  background-color: var(--thin-yellow);
}

/* Styling: frame */
.border-gray {
  border: 5px solid var(--thin-gray);
}
.border-red {
  border: 5px solid var(--important-red);
}

/* Styling: tag */
.tag {
  display: inline-block;
  border: 1px solid #ccc;
  border-radius: 5px;
  padding: 10px 15px;
  line-height: 1.0;
  z-index: 2;
}
.pcdevice .tag {
  padding: 0.78125vw 1.171875vw;
}
@media only screen and (min-width: 1281px) {
  .pcdevice .tag {
    padding: 10px 15px;
  }
}


/* Styling: number -- Google Fonts: OpenSans */
.num400 {
  font-weight: 400;
}
.num500 {
  font-weight: 500;
}
.num600 {
  font-weight: 600;
}
.num700 {
  font-weight: 700;
}

/* Styling: Text Indent */
.indent {
  padding-left: 1em;
  text-indent: -1em;
}

/* -------------------------------------------------------------------------- */
/*	Site Header
/* -------------------------------------------------------------------------- */
header {
  display: block;
  width: 100%;
  margin-bottom: 0.78125%;  /* 10px */
}
header > .header__inner {
  width: 100%;
  margin: 0 auto;
  padding: 10px 0 10px 20px;  /* padding-right:0 */
}
header .header__innerbox > .header__inner {
  width: 100%;
  margin: 0 auto;
  padding: 0 40px;
}
.pcdevice header > .header__inner {
  max-width: 1280px;
  width: 100%;
  margin: 0 auto;
  padding: 1.5625vw 3.125vw;
}
.pcdevice header > .header__innerbox > .header__inner {
  max-width: 1280px;
  padding: 0 1.5625vw;
}
@media only screen and (min-width: 1281px) {
  .pcdevice header > .header__inner {
    padding: 20px 40px;
  }
  .pcdevice header > .header__innerbox > .header__inner {
    padding: 0 40px;
  }
}

/* logo */
header .header__inner .logo__box,
header .header__inner .logo__box a {
  max-height: 60px;
}
.pcdevice header .header__inner .logo__box,
.pcdevice header .header__inner .logo__box a {
  max-height: 100px;
}
header .header__inner .logo__box {
  width: 110px;
  display: flex;
  justify-content: center;
  align-items: center;
}
.pcdevice header .header__inner .logo__box {
  width: 15.625vw;
  padding-left: 0;
}
@media only screen and (min-width: 1281px){
  header {
    margin-bottom: 10px;
  }
  .pcdevice header .header__inner .logo__box {
    width: 220px;
    padding-left: 20px;
  }
}

header .header__inner .logo__box a {
  display: flex;
  width: 100%;
  justify-content: center;
  align-items: center;
}

/* -------------------------------------------------------------------------- */
/*	Site Contents
/* -------------------------------------------------------------------------- */

/* --- 基本構造 --- */
header > .header__inner {
  display: flex;
  justify-content:space-between;
  flex-wrap: wrap;
  align-items: center;
}
.header__rightside {
  text-align: center;
}

main {
  width: 100%;
  margin: 0 auto;
  padding: 0 20px;
  color: var(--basic-textcol);
}
.container {
  width: 100%;
}
.contents_container {
  width: 100%;
}
.contents_container > section:last-child,
article > section:last-child {
  margin-bottom: 0 !important;
}
.sidebar_container {
  display: none;
}

/* PCブラウザ表示 */
.pcdevice main {
  max-width: 1280px;
  padding: 0 3.125vw;
}
.pcdevice main#top,
.pcdevice main#onecolumn {
  max-width: none;
  padding: 0;
}
.pcdevice .container {
  display: flex;
  margin-bottom: 0;
}
.pcdevice .contents_container {
  width: calc( 100% - ( 25.833333% + 5.833333% ) );
  margin-bottom: 9.375vw;
}
.pcdevice main#onecolumn .contents_container {
  width: 100%;
  margin-bottom: 0;
}
.pcdevice main#onecolumn .contents_container section {
  margin-left: auto;
  margin-right: auto;
}
.pcdevice .sidebar_container {
  display: block;
  width: 25.833333%; /* 310px */
  margin-right: 5.833333%; /* 70px */
}
@media only screen and (min-width: 768px) {
  .container {
    display: flex;
  }
  .contents_container {
    width: calc( 100% - ( 25.833333% + 5.833333% ) );
  }
  .sidebar_container {
    display: block;
    width: 25.833333%;
    margin-right: 5.833333%;
  }
}
@media only screen and (min-width: 1281px) {
  .pcdevice main {
    padding: 0 40px;
  }
  .pcdevice .contents_container {
    width: calc( 100% - ( 25.833333% + 5.833333% ) );
    margin-bottom: 120px;
  }
}

/* -------------------------------------------------------------------------- */
/*	Site Footer
/* -------------------------------------------------------------------------- */

/* リンク */
footer .footer__inner:nth-child(1) {
  background-color: var(--bg-darkgray);
}
.pcdevice footer .footer__inner {
  margin: 0 auto;
}
footer .footerhref__list a {
  color: #fff;
}
footer .footerhref__list a.disabled {
  pointer-events: none;
}
footer .logo__box {
  padding: 60px 0 0;
}
.pcdevice footer .logo__box {
  width: 14.0625vw;
  margin: 0 auto;
  padding: 4.6875vw 0 0;
}
footer .logo__box img {
  display: block;
  text-align: center;
}
.pcdevice footer .logo__box img {
  width: 14.0625vw;
  height: 4.375vw;
  margin: 0 auto 3.90625vw;
  bottom: -1px;   /* 調整値 */
}
footer .footerhref__container {
  display: flex;
  flex-wrap: nowrap;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 190px 60px;
}
.pcdevice footer .footerhref__container {
  margin: 0 auto;
  padding: 0 6.25vw 4.6875vw;
}
footer .footerhref__container > li {
  width: calc(100% / 6);
}
footer .footerhref__list {
  width: 100%;
}
footer .footerhref__list a {
  height: 32px;
  line-height: 1.0em;
}
.pcdevice footer .footerhref__list a {
  height: 2.5vw;
  line-height: 1.0em;
}
footer .footerhref__list a.title span::after {
  content: '';
  display: inline-block;
  width: 0.8em;
  height: 0.8em;
  margin-left: 0.3em;
  vertical-align: middle;
  background: center / contain url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 7 12"><path fill="%23ffffff" id="Icon_ionic-ios-arrow-back" data-name="Icon ionic-ios-arrow-back" d="M4.89,6,.257,1.462a.842.842,0,0,1,0-1.211A.892.892,0,0,1,1.5.251L6.745,5.391a.844.844,0,0,1,.026,1.182L1.5,11.75a.893.893,0,0,1-1.239,0,.842.842,0,0,1,0-1.211Z"/></svg>') no-repeat;
}
footer .footerhref__list a.title.disabled span::after {
  content: none;
}
footer .footerhref__list a.extlink span::after {
  content: '';
  display: inline-block;
  width: 1.0em;
  height: 1.0em;
  margin-left: 0.5em;
  vertical-align: middle;
  background: center / contain url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 140 140"><path fill="%23ffffff" id="icon_x5F_link_00000133515484282774806390000015775604897463366029_" class="st0" d="M120,76.67v40,	c0,12.86-10.47,23.33-23.33,23.33H23.33C10.46,140,0,129.53,0,116.67V43.33C0,30.46,10.46,20,23.33,20h40c5.52,0,10,4.48,10,10,	s-4.48,10-10,10h-40C21.49,40,20,41.49,20,43.33v73.34c0,1.84,1.49,3.33,3.33,3.33h73.34c1.84,0,3.33-1.49,3.33-3.33v-40,c0-5.52,4.47-10,10-10S120,71.15,120,76.67z M139.23,6.18c-1.01-2.45-2.96-4.4-5.41-5.41C132.6,0.27,131.3,0,130,0H90,c-5.53,0-10,4.48-10,10s4.47,10,10,10h15.86L49.6,76.26c-3.91,3.91-3.91,10.23,0,14.14c1.95,1.95,4.51,2.93,7.07,2.93,s5.12-0.98,7.07-2.93L120,34.14V50c0,5.52,4.47,10,10,10c5.53,0,10-4.48,10-10V10C140,8.7,139.74,7.4,139.23,6.18z"/></svg>') no-repeat;
}
footer .footerhref__list a span {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}
@media only screen and (min-width: 1281px) {
  footer .logo__box,
  .pcdevice footer .logo__box {
    width: 180px;
    padding: 60px 0 0;
  }
  footer .logo__box img,
  .pcdevice footer .logo__box img {
    width: 180px;
    height: 56px;
    margin: 0 auto 50px;
  }
  footer .footerhref__container,
  .pcdevice footer .footerhref__container {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 80px 60px;
  }
  footer .footerhref__list a,
  .pcdevice footer .footerhref__list a {
    height: 32px;
  }
}

/* リンク - mobile */
footer .footer__inner.mobile .footerhref__lists {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}
footer .footer__inner.mobile .footerhref__lists:nth-child(1) .footerhref__list {
  width: 50%;
  border-bottom: 1px solid var(--bg-gray);
}
footer .footer__inner.mobile .footerhref__lists:nth-child(1) .footerhref__list:nth-child(odd) {
  border-right: 1px solid var(--bg-gray);
}
footer .footer__inner.mobile .footerhref__lists:nth-child(1) .footerhref__list a {
  height: auto;
  padding: 20px 0;
  text-align: center;
}
footer .footer__inner.mobile .footerhref__lists:nth-child(2) {
  padding: 25px 20px 10px;
}
footer .footer__inner.mobile .footerhref__lists:nth-child(2) .footerhref__list {
  width: auto;
  margin-bottom: 15px;
  border-right: 1px solid  var(--bg-gray);;
}
footer .footer__inner.mobile .footerhref__lists:nth-child(2) .footerhref__list a {
  height: 1.0em;
  padding: 0 20px;
}
footer .footer__inner.mobile .footerhref__lists:nth-child(2) .footerhref__list:nth-child(1) a,
footer .footer__inner.mobile .footerhref__lists:nth-child(2) .footerhref__list:nth-child(4) a {
  padding-left: 0;
}
footer .footer__inner.mobile .footerhref__lists:nth-child(2) .footerhref__list:nth-child(3),
footer .footer__inner.mobile .footerhref__lists:nth-child(2) .footerhref__list:last-child {
  border-right: none;
}
@media only screen and (max-width: 374px) {
  footer .footer__inner.mobile .footerhref__lists:nth-child(1) .footerhref__list a {
    padding-top: calc( 20px * ( 320 / 375 ) );
    padding-left: 0;
    padding-right: 0;
    padding-bottom: calc( 20px * ( 320 / 375 ) );
  }
  footer .footer__inner.mobile .footerhref__lists:nth-child(2) {
    padding-top: calc( 25px * ( 320 / 375 ) );
    padding-left: calc( 20px * ( 320 / 375 ) );
    padding-right: calc( 20px * ( 320 / 375 ) );
    padding-bottom: calc( 10px * ( 320 / 375 ) );
  }
  footer .footer__inner.mobile .footerhref__lists:nth-child(2) .footerhref__list {
    margin-bottom: calc( 15px * ( 320 / 375 ) );
  }
  footer .footer__inner.mobile .footerhref__lists:nth-child(2) .footerhref__list a {
    padding-top: 0;
    padding-left: calc( 20px * ( 320 / 375 ) );
    padding-right: calc( 20px * ( 320 / 375 ) );
    padding-bottom: 0;
  }
}

/* 住所その他 */
footer .footer__inner:nth-child(2) {
  background-color: #fff;
}
footer .footercompanyinfo__lists {
  display: flex;
  flex-wrap: nowrap;
  justify-content: space-between;
  align-items: center;
  max-width: 1280px;
  margin: 0 auto;
  padding: 30px 40px;
}
.pcdevice footer .footercompanyinfo__lists {
  padding: 2.34375vw 3.125vw;
}
footer .footercompanyinfo__list:nth-child(1) {
  padding-left: 85px;
  background: center left / 70px url(/wp-content/themes/bsportal/assets/img/corporate/logo_corporate.svg) no-repeat;
}
.smalldev footer .footercompanyinfo__list:nth-child(1) {
  background: center left / calc( 60px * (70 / 85) * ( 320 / 375 ) ) url(/wp-content/themes/bsportal/assets/img/corporate/logo_corporate.svg) no-repeat;
}
.pcdevice footer .footercompanyinfo__list:nth-child(1)  {
  padding-left: 7.8125vw;
  background: center left / 6.25vw url(/wp-content/themes/bsportal/assets/img/corporate/logo_corporate.svg) no-repeat;
}
footer .footercompanyinfo__list:nth-child(1) p:nth-child(1) {
  font-weight: bold;
  margin-bottom: 10px;
  line-height: 1.0;
}
.pcdevice footer .footercompanyinfo__list:nth-child(1) p:nth-child(1) {
  margin-bottom: 0.78125vw;
}
footer .footercompanyinfo__list:nth-child(1) p:nth-child(2) {
  line-height: 1.5;
}
footer .footercompanyinfo__list:nth-child(2) {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: 20px;
}
.pcdevice footer .footercompanyinfo__list:nth-child(2) {
  gap: 1.5625vw;
}
footer .footercompanyinfo__list:nth-child(2) a {
  color: var(--basic-textcol);
  text-decoration: underline;
}
@media only screen and (min-width: 1281px) {
  footer .footercompanyinfo__lists,
  .pcdevice footer .footercompanyinfo__lists {
    padding: 30px 40px;
  }
  footer .footercompanyinfo__list:nth-child(1),
  .pcdevice footer .footercompanyinfo__list:nth-child(1)  {
    padding-left: 100px;
    background: center left / 80px url(/wp-content/themes/bsportal/assets/img/corporate/logo_corporate.svg) no-repeat;
  }
  footer .footercompanyinfo__list:nth-child(1) p:nth-child(1),
  .pcdevice footer .footercompanyinfo__list:nth-child(1) p:nth-child(1) {
    margin-bottom: 10px;
  }
  footer .footercompanyinfo__list:nth-child(2),
  .pcdevice footer .footercompanyinfo__list:nth-child(2) {
    gap: 20px;
  }
}

/* 住所その他 - mobile */
footer .footer__inner.mobile .footercompanyinfo__lists {
  display: block;
  max-width: 100%;
  padding: 30px 20px;
}
footer .footer__inner.mobile .footercompanyinfo__list:nth-child(1) {
  display: flex;
  align-items: center;
  height: 50px;
  margin-bottom: 15px;
  padding-left: 85px;
}
footer .footer__inner.mobile .footercompanyinfo__list p {
  margin-bottom: 0;
  line-height: 1.5;
}
@media only screen and (max-width: 374px) {
  footer .footer__inner.mobile .footercompanyinfo__lists {
    padding-top: calc( 30px * ( 320 / 375 ) );
    padding-left: calc( 20px * ( 320 / 375 ) );
    padding-right: calc( 20px * ( 320 / 375 ) );
    padding-bottom: calc( 30px * ( 320 / 375 ) );
  }
  footer .footer__inner.mobile .footercompanyinfo__list:nth-child(1) {
    height: calc( 50px * ( 320 / 375 ) );
    margin-bottom: calc( 15px * ( 320 / 375 ) );
    padding-left: calc( 60px * ( 320 / 375 ) );
  }
}

/* Pマーク・上場マーク */
footer .footer__inner:nth-child(3) {
  background-color: var(--bg-gray);
}
footer .footeretcinfo__lists {
  display: flex;
  flex-wrap: nowrap;
  justify-content: space-between;
  align-items: center;
  max-width: 1280px;
  margin: 0 auto;
  padding: 20px 40px;
}
.pcdevice footer .footeretcinfo__lists {
  padding: 1.5625vw 3.125vw;
}
footer .footeretcinfo__list:nth-child(2) {
  display: flex;
  flex-wrap: nowrap;
  gap: 40px;
  align-items: center;
}
.pcdevice footer .footeretcinfo__list:nth-child(2) {
  gap: 1.5625vw;
}
footer .footeretcinfo__list:nth-child(2) .pmark {
  width: 45px;
}
.pcdevice footer .footeretcinfo__list:nth-child(2) .pmark {
  width: 3.515625vw;
}
footer .footeretcinfo__list:nth-child(2) .pmark a,
footer .footeretcinfo__list:nth-child(2) .pmark a img {
  display: block;
  height: 45px;
}
.pcdevice footer .footeretcinfo__list:nth-child(2) .pmark a,
.pcdevice footer .footeretcinfo__list:nth-child(2) .pmark a img {
  height: 3.515625vw;
}
footer .footeretcinfo__list:nth-child(2) .mothers {
  display: flex;
  align-items: center;
  width: auto;
  height: 45px;
  padding-left: 42px;
  background: center left / contain url(/wp-content/themes/bsportal/assets/img/corporate/jpx_logo.svg) no-repeat;
}
.pcdevice footer .footeretcinfo__list:nth-child(2) .mothers {
  height: 3.515625vw;
  padding-left: 3.28125vw;
}
@media only screen and (min-width: 1281px) {
  footer .footeretcinfo__lists,
  .pcdevice footer .footeretcinfo__lists {
    padding: 20px 40px;
  }
  footer .footeretcinfo__list:nth-child(2),
  .pcdevice footer .footeretcinfo__list:nth-child(2) {
    gap: 20px;
  }
  footer .footeretcinfo__list:nth-child(2) .pmark,
  .pcdevice footer .footeretcinfo__list:nth-child(2) .pmark {
    width: 45px;
  }
  footer .footeretcinfo__list:nth-child(2) .pmark a,
  footer .footeretcinfo__list:nth-child(2) .pmark a img,
  .pcdevice footer .footeretcinfo__list:nth-child(2) .pmark a,
  .pcdevice footer .footeretcinfo__list:nth-child(2) .pmark a img {
    height: 45px;
  }
  footer .footeretcinfo__list:nth-child(2) .mothers,
  .pcdevice footer .footeretcinfo__list:nth-child(2) .mothers {
    height: 45px;
    padding-left: 42px;
  }
}

/* Pマーク・上場マーク - mobile */
footer .footer__inner.mobile .footeretcinfo__lists {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  max-width: 100%;
  padding: 25px 20px 30px;
}
footer .footer__inner.mobile .footeretcinfo__lists .footeretcinfo__list:nth-child(1) {
  display: flex;
  flex-wrap: nowrap;
}
footer .footer__inner.mobile .footeretcinfo__list:nth-child(1) {
  display: flex;
  flex-wrap: nowrap;
  gap: 30px;
  height: 50px;
  margin-bottom: 30px;
}
footer .footer__inner.mobile .footeretcinfo__list:nth-child(1) .pmark {
  width: 45px;
}
footer .footer__inner.mobile .footeretcinfo__list:nth-child(1) .mothers {
  width: calc( 100% - 50px - 30px );
  padding-left: 50px;
  background: center left / contain url(/wp-content/themes/bsportal/assets/img/corporate/jpx_logo.svg) no-repeat;
  display: flex;
  align-items: center;
}
footer .footer__inner.mobile .footeretcinfo__list:nth-child(1) .mothers p {
  line-height: 1.5;
}
footer .footer__inner.mobile .footeretcinfo__list:nth-child(1) a img {
  height: 50px;
  object-fit: contain;
}
footer .footer__inner.mobile .footeretcinfo__list:nth-child(2) {
  text-align: center;
}
footer .footer__inner.mobile .footeretcinfo__list:nth-child(2) {
  display: block;
  width: 100%;
}
@media only screen and (max-width: 374px) {
  footer .footer__inner.mobile .footeretcinfo__lists {
    padding-top: calc(25px * ( 320 / 375 ) );
    padding-left: calc(20px * ( 320 / 375 ) );
    padding-right: calc(20px * ( 320 / 375 ) );
    padding-bottom: calc(30px * ( 320 / 375 ) );
  }
  footer .footer__inner.mobile .footeretcinfo__list:nth-child(1) {
    gap: calc(30px * ( 320 / 375 ) );
    height: calc(50px * ( 320 / 375 ) );
    margin-bottom: calc(30px * ( 320 / 375 ) );
  }
  footer .footer__inner.mobile .footeretcinfo__list:nth-child(1) .pmark {
    width: calc(45px * ( 320 / 375 ) );
  }
  footer .footer__inner.mobile .footeretcinfo__list:nth-child(1) .mothers {
    width: calc( 100% - 68.2666px );
    padding-left: calc(50px * ( 320 / 375 ) );
  }
  footer .footer__inner.mobile .footeretcinfo__list:nth-child(1) a img {
    height: calc(50px * ( 320 / 375 ) );
  }
}

/* -------------------------------------------------------------------------- */
/*	Chatplus 表示連動
/* -------------------------------------------------------------------------- */
footer.set_chatplus {
  padding-bottom: 60px;
}
.pcdevice footer.set_chatplus {
  padding-bottom: 0;
}

/* -------------------------------------------------------------------------- */
/*	iPhone. Setting Reset
/* -------------------------------------------------------------------------- */
input, select {
  -webkit-appearance: none;
  border-radius: 0;
}

/* -------------------------------------------------------------------------- */
/*	Plugin etc.  Setting
/* -------------------------------------------------------------------------- */

/* lity */
.lity-wrap {
  overflow-x: scroll;
}
.lity-container {
  padding: 60px 20px 50px;
  width: 100%;
}
.lity-content {
  background-color: #fff;
}
.lity-content .campaign_detail .lity_cta_section .cta_section_close {
  display: block;
  margin-top: 50px;
  color: #fff;
}
.lity-content .cta_section_body {
  padding-bottom: 30px !important;
}
.lity-content .cta_section_body .cta_section_close:hover {
  cursor: pointer;
  opacity: 0.7;
}
.lity-close[aria-label],
.lity-close[aria-label]:hover,
.lity-close[aria-label]:focus,
.lity-close[aria-label]:active {
  width: 50px;
  height: 50px;
  font-size: 50px;
  line-height: 1.0;
  top: 10px;
  right: 10px;
}
.lity-close[aria-label]:hover,
.lity-close[aria-label]:focus,
.lity-close[aria-label]:active {
  opacity: 0.7;
}
.slick-dots li {
  margin: 0 3px !important;
}
.slick-dots > li:first-child:last-child {
  display: none;
}

/* Modaal */
#modal-content1,#modal-content2 {
  display: none;
}
.modaal-inner-wrapper {
  padding: 60px 20px !important;
}
.modaal-content-container {
  padding: 0 !important;
}
.modaal-wrapper.modaal-fullscreen {
  overflow: auto !important;
  backdrop-filter: blur(5px);
}
.modaal-fullscreen .modaal-inner-wrapper {
  display: table-cell !important;
  vertical-align: middle !important;
}
.modaal-fullscreen .modaal-close {
  background: none !important;
}
.modal_cta_section .modal_cta_section_close {
  display: block;
  margin-top: 50px;
  color: #fff;
}
.modal_cta_section .modal_cta_section_close:hover {
  cursor: pointer;
  opacity: 0.7;
}
/* -- PC */
.pcdevice .modaal-fullscreen .modaal-close {
  right: 2.34375vw;
  top: 1.09375vw;
}
.pcdevice .modaal-fullscreen .modaal-container {
  width: 62.5vw;
  height: auto !important;
}
.pcdevice .modaal-fullscreen .modaal-inner-wrapper {
  margin: 0 auto;
  width: 100vw;
  padding: 4.6875vw 0 0 !important;
}

@media only screen and (min-width: 1280px) {
  .pcdevice .modaal-fullscreen .modaal-close {
    right: 30px;
    top: 14px;
  }
  .pcdevice .modaal-fullscreen .modaal-container {
    width: 800px;
  }
  .pcdevice .modaal-fullscreen .modaal-inner-wrapper {
    padding: 60px 0 0 !important;
  }
}