@charset "utf-8";

/* PC：style_pc.css
 * **************************************************
 * Site Width
 * Header
 * Header Bottom
 * Common Elements
 * Content
 * Article
 * Page Top
 * Footer
 * **************************************************
 */

/*  Site Width
------------------------------------------------------------------- */
* {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}
body {
	background: #ffffff;
	min-width: 320px;
}
.inner {
	margin: 0 auto;
	padding: 0;
	width: 1084px;
}


/*  Header
------------------------------------------------------------------- */
#header .inner {
	height: 120px;
	position: relative;
}

/* title */
#header .title {
	position: absolute;
	top: -6px; left: -40px;
}

/* Logo */
#header .logo {
	position: absolute;
	bottom: 15px; right: 0;
}



/* Header Bottom
------------------------------------------------------------------ */
#headerBottom .inner {
	position: relative;
}
#headerBottom ul {
	line-height: none;
	padding: 14px 0 0 0;
}
#headerBottom ul li {
	display: inline-block;
	font-size: 12px;
	vertical-align: middle;
}
/* siteLink */
#headerBottom ul.siteLink {
	position: absolute;
	top: 0; right: 290px;
}
#headerBottom ul.siteLink li {
	background: url(../images/common/arrow_sitelink.png) no-repeat left 0.45em;
	margin: 0 10px 0 0;
	padding: 0 0 0 11px;
}
#headerBottom ul.siteLink li a {
	text-decoration: underline;
}
/* shareBtn */
#headerBottom ul.shareBtn {
	line-height: 1;
	position: absolute;
	top: 0; right: 0;
}


/* Common Elements
------------------------------------------------------------------ */
/* リンク */
a {
	color: #333333;
	text-decoration: none;
	-webkit-transition: .3s;
	transition: .3s;
}
a:hover {
	color: #3366cc;
	text-decoration: none;
}
a:hover img {
	opacity: 0.8;
	-webkit-transition: .3s;
	transition: .3s;
}
a.underline {
	text-decoration: underline;
}

/* img */
img {
	height: auto;
	vertical-align: bottom;
	max-width: 100%;
}



/* headline */
#content h1,
#content h2,
#content h3,
#content h4 {
	color: #000000;
	line-height: 1.2;
	-webkit-transition: .3s;
	transition: .3s;
}
#content a:hover h1,
#content a:hover h2,
#content a:hover h3,
#content a:hover h4 {
	color: #3366cc;
}
#content h1 {
	font-size: 30px;
}
#content h2 {
	font-size: 26px;
}
#content h3 {
	font-size: 20px;
}
#content h4 {
	font-size: 18px;
}

/* list */
#content ul {
	list-style: none;
}
#content ul:after {
	clear: both;
	content: ".";
	display: block;
	font-size: 0;
	height: 0;
	visibility: hidden;
}

/* bnrProducts */
#content .bnrProducts {
	text-align: center;
	background: #ffffff;
}
#content .bnrProducts ul {
	text-align: center;
}
#content .bnrProducts ul li {
	padding: 10px 0 0 0;
}

#content .caption{
	font-size:85%;
	padding:30px 0 0 0;
	line-height:1.5;
	color: #666666;
}


/* Content
------------------------------------------------------------------ */
/* main */
#content .main {
	float: left;
	width: 744px;
}
#archive #content .main {
	background: #ffffff;
	float: none;
	width: 100%;
}
#archive #content .main:after {
	clear: both;
	content: ".";
	display: block;
	font-size: 0;
	height: 0;
	visibility: hidden;
}


/* side */
#content .side {
	float: right;
	width: 300px;
}

/* Article
------------------------------------------------------------------ */
#content .article {
	background: #ffffff;
	padding: 35px 40px 60px;
}

/* mainvisual */
#content .article .mainvisual {
	margin: 12px 0 0 0;
}

/* lead */
#content .article .lead {
	margin: 15px 0 0 0;
}

/* headline */
#content .section h2 {
	border-left: 8px solid #3366cc;
	margin: 0 0 15px 0;
	padding: 0 0 0 18px;
}
#content .section.conclusion h2 {
	color: #000000;
	font-size: 24px;
}
#content .section h3 {
	margin: 40px 0 15px 0;
}
#content .section h3.border {
	border-bottom: 6px solid #f2f2f2;
	padding: 0 0 8px 24px;
}
#content .section h3.border:before {
	background: #3366cc;
	content: '';
	display: inline-block;
	height: 16px;
	margin: 0 8px 0 -24px;
	width: 16px;
}
#content .section h3.bg {
	background: #3366cc;
	border-left: 5px solid #01599f;
	color: #ffffff;
	min-height: 35px;
	padding: 5px 12px 3px 12px;
}

/* section */
#content .article .section {
	margin: 55px 0 0 0;
}
#content .article .section + .section {
	margin-top: 100px;
}
#content .article .section.conclusion {
	margin-top: 85px;
}
#content .article .section p + p {
	margin: 35px 0 0 0;
}
#content .article .section > img {
	display: block;
	margin: 20px auto 0;
}
#content .article .section > a img {
	display: block;
	margin: 20px auto 0;
}
#content .article .section > div img {
	display: block;
	margin: 20px auto 0;
}
#content .article .section > div a img {
	display: block;
	margin: 20px auto 0;
}
#content .article .section > ul {
	margin: 20px 0 0 0;
}
#content .article .section > ul li {
	float: left;
}
#content .article .section > ul li p {
	margin: 5px 0 0 0;
	text-align: center;
}
#content .article .section > ul.fourColumn { /* 4カラムの場合 */
	margin-right: -13px;
}
#content .article .section > ul.fourColumn li {
	margin-right: 13px;
	width: 156px;
}
#content .article .section ul.disc{
	list-style:disc;
	margin-left:1.5em;
}
#content .article .section ul.disc2{
	list-style:none;
	margin-left:1.5em;
}
#content .article .section ul.disc li{
	width:100%;
}
#content .section .column{
	border: 1px solid #0009AF;
	padding: 10px;
	margin-top: 15px;
}

#content .section .column p{
	color: #0009AF;
}

#content .recommended {
	margin: 0 0 30px 0;
}

#content .recommended_strong {
	margin: 50px 0 0 0;
	font-size: 120%;
}




/* 調整 */
#content .article .section .m10 {
	margin:10px 0 20px 0;
}

/* 目次 */
#content .article .section2 {
	margin: 20px;
}
#content .article .section2 .box {
    margin: 30px 0;
	background: #ffffff;
	border: 1px solid #3366cc;
	line-height: 2.0;
}
#content .article .section2 .box .box-title {
    font-size: 110%;
    background: #3366cc;
    text-align: center;
    color: #FFF;
    font-weight: bold;
}
#content .article .section2 .box p {
    padding: 15px 20px;
    margin: 0;
}

#content .article .section2 ul.sublist {
	margin-left:1.0em;
}

#content .article .section2 .box .list{
	margin-left:1.8em;
}

/* related */
#content .related {
	background: #ffffff;
	margin: 30px 0 0 0;
	padding: 20px 40px 25px;
}
#content .related ul {
	margin: 10px -13px 0 0;
}
#content .related ul li {
	float: left;
	margin: 0 13px 0 0;
	width: 156px;
}
#content .related ul li p {
	line-height: 1.2;
	margin: 12px 0 0 0;
}

/* backnumber */
#content .backnumber {
	background: #ffffff;
	padding: 26px 28px;
}
#content .backnumber ul li {
	margin: 10px 0 0 0;
}
#content .backnumber ul li:after {
	clear: both;
	content: ".";
	display: block;
	font-size: 0;
	height: 0;
	visibility: hidden;
}
#content .backnumber ul li a {
	display: block;
}
#content .backnumber ul li img {
	float: left;
	width: 70px;
}
#content .backnumber ul li p {
	float: left;
	line-height: 1.2;
	padding: 0 0 0 15px;
	width: 174px;
}

/* backnumber_contents */
#content .backnumberContents {
	background: #ffffff;
	padding: 0 16px 20px 16px;
	border:solid 1px #666666;
	width:100%;
	margin: 20px 0 20px 0;
}
#content .backnumberContents ul li {
	margin: 10px 0 0 0;
}
#content .backnumberContents ul li:after {
	clear: both;
	content: ".";
	display: block;
	font-size: 0;
	height: 0;
	visibility: hidden;
}
#content .backnumberContents ul li a {
	display: block;
}
#content .backnumberContents ul li img {
	float: left;
	width: 70px;
}
#content .backnumberContents ul li p {
	float: left;
	line-height: 1.2;
	padding: 30px 0 0 15px;

}


span.underline{
	border-bottom:solid 1px #333333;
}


#content .table{
	border-collapse: collapse;
	margin: 0 auto;
}
#content .table-img,
#content .table-txt{
	vertical-align: top;
	width: 300px;
	padding: 0;
	padding: 2em 0 0 2em;
}

#content .table-img > img{
	width: 100%;
}

#content .list{
  margin: 10px;
}

#content ol.raid{
	list-style: decimal;
	padding: 10px 0 0 30px;
}

.search{
	margin: 0 0 20px 0;
	width: 20%;
}

/* PageTop
------------------------------------------------------------------ */
#pageTop {
	display: none;
	height: 80px;
	position: fixed;
	bottom: 3%; right: 20px;
	width: 80px;
	z-index: 98;
}
#pageTop a {
	background: #3366cc;
	cursor: pointer;
	display: block;
	height: 80px;
	line-height: 40px;
	outline: none;
	padding: 14px 0 0 0;
	text-align: center;
	width: 80px;
}
#pageTop a img {
	height: 52px;
	width: 56px;
}


/* Footer
------------------------------------------------------------------ */
/* copyRight */
#footer .copyRight {
	font-size: 12px;
	text-align: center;
}

/* =========================
   footer (PC)
   ========================= */

#footer {
  /* 既存の全体デザインがある場合は極力邪魔しない */
}

#footer .inner{
  /* inner は既存で幅指定がある想定。無い場合だけ効くように控えめに */
  max-width: 1084px;
  margin: 0 auto;
  padding: 40px 20px 24px;
  box-sizing: border-box;
}

#footer .footernav_column ul{
  list-style: none;
  margin: 0;
  padding: 0;

  display: flex;
  flex-wrap: wrap;
  justify-content: left; /* 中央寄せ */
  gap: 12px 18px;
}

#footer .footernav_column li{ margin: 0; }

  /* 画像 */
  #footer .bnr_fullwid__img{ display:block; width:100%; height:auto; }

  /* バナーは2カラム */
  #footer .bnr_fullwid{
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    margin: 0 0 28px;
  }

  /* sitemap：4列（ECは2列分 + 法人 + メニュー） */
  #footer .footer_sitemap_column{
    display: grid;
    grid-template-columns: 1fr 1fr 1fr 1fr;
    gap: 28px;
    align-items: start;
    margin: 0 0 20px;
  }
  #footer .footer_ec_block{ grid-column: 1 / span 2; }

  /* 箇条書きの●/○を消す（キャプチャの崩れ原因の一つ） */
  #footer .footer_sitemap_column ul{
    list-style: none;
    margin: 0;
    padding: 0;
  }
  #footer .footer_sitemap_column li ul{
    margin-top: 8px;
    padding-left: 0; /* 文字として ├└ が入っている前提 */
  }

  /* PCは常時展開なのでトグルは隠す */
  #footer .footer_acc_toggle{ display:none; }
  #footer .footer_acc_toggle ~ ul{ display:block !important; }

  /* 見出し */
  #footer .footer_acc_title{
    margin: 0 0 12px;
    font-size: 16px;
    line-height: 1.4;
    font-weight: 700;
  }
  #footer .footer_acc_title > label{
    cursor: default;
  }
  #footer .footer_acc_title > label::after{ content:none; } /* PCは＋なし */

/* ECカテゴリ枠：上辺に“帯タイトル”をくっつける（確実版） */
#footer .footer_ec_block{
  position: relative !important;
  /* 帯の分だけ上に余白を増やす（既存paddingがあるなら上だけ足す） */
  padding-top: 44px !important;
}

/* 帯（枠の上辺に密着） */
#footer .footer_ec_block::before{
  content: "ロジテックダイレクト公式ページ" !important;

  position: absolute !important;
  left: -1px !important;   /* 枠線に合わせる */
  right: -1px !important;  /* 枠線に合わせる */
  top: -1px !important;    /* 枠線に合わせる */

  display: block !important;
  padding: 10px 14px !important;

  background: #0177bd !important;
  color: #fff !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  line-height: 1.2 !important;
　padding: 0 10px;
  /* 枠の角丸と一体化（枠と同じ角丸に合わせる） */
  border-radius: 12px 12px 0 0 !important;
}

/* ECカテゴリ枠：枠線＋背景色（帯と一体化） */
#footer .footer_ec_block{
  border: 1px solid #d9d9d9 !important;
  background: #f7fbff !important;       /* 薄い背景色（お好みで変更可） */
  border-radius: 12px !important;
  box-sizing: border-box !important;
}

/* 帯（上辺にベタ付け）：枠線に合わせる */
#footer .footer_ec_block::before{
  /* 既に入れている内容がある前提で、枠線と角丸だけ念押し */
  left: -1px !important;
  right: -1px !important;
  top: -1px !important;
  border-radius: 12px 12px 0 0 !important;
}

  /* ECカテゴリ見出し強調 */
  #footer .footer_ec_block .footer_acc_title{
    font-weight: 800;
    color: #111;
    padding-left: 12px;
    border-left: 5px solid #0177bd;
  }

/* ECカテゴリ（ulが2本あるブロック）を2列表示：inline-blockは使わずgridで固定 */
#footer .footer_ec_block{
  display: grid;
  grid-template-columns: 1fr 1fr;
  column-gap: 20px;
  row-gap: 12px;
	padding: 20px;
}

/* 見出しは2列またぎ */
#footer .footer_ec_block > .footer_acc_title{
  grid-column: 1 / -1;
}

/* 2本のulを左右に固定配置 */
#footer .footer_ec_block > ul:first-of-type{
  grid-column: 1;
}
#footer .footer_ec_block > ul:nth-of-type(2){
  grid-column: 2;
}

/* ul側はブロック扱いに戻す（念のため） */
#footer .footer_ec_block > ul{
  display: block;
  width: auto;
  margin: 0;
  padding: 0;
}

 /* フッター全体を 3列（左2列 + 右1列）にする */
  #footer .inner{
    display: grid;
    grid-template-columns: 1fr 1fr 280px; /* 右カラム幅。必要なら調整 */
    column-gap: 28px;
    row-gap: 18px;
    align-items: start;
  }

  /* バナーは全幅 */
  #footer .bnr_fullwid{
    grid-column: 1 / -1;
  }

  /* サイトマップ（カテゴリ/法人/メニュー）は左2列に */
  #footer .footer_sitemap_column{
    grid-column: 1 / span 2;

    /* ←ここ重要：footer_sitemap_column自体は「2列」に戻す（4列指定をやめる） */
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 28px !important;
    align-items: start !important;
    margin: 0 !important;
  }

  /* ECカテゴリブロックを2列ぶん（1段目で横断） */
  #footer .footer_sitemap_column > .sitemap_block_column:first-child{
    grid-column: 1 / -1;
  }

  /* 法人＝左、メニュー＝右（2段目） */
  #footer .footer_sitemap_column > .sitemap_block_column:nth-child(2){
    grid-column: 1;
  }
  #footer .footer_sitemap_column > .sitemap_block_column:nth-child(3){
    grid-column: 2;
  }

  /* 会社概要など（footernav）は右1列に */
  #footer .footernav_column{
    grid-column: 3;
    align-self: start;
    margin: 0; /* 既存marginがある場合のズレ防止 */
  }

  /* コピーライトは全幅（最下段） */
  #footer .copyRight{
    grid-column: 1 / -1;
  }

  /* PCでも ul の●を消す（崩れ防止） */
  #footer .footer_sitemap_column ul{
    list-style: none;
    margin: 0;
    padding: 0;
  }
  #footer .footer_sitemap_column li ul{
    margin-top: 8px;
    padding-left: 0;
    font-size: 14px;
  }


  #footer .footernav_column::before{
    content: "詳しく解説!HDD/SSD!!について";
    display: block;
    font-weight: 800;
    font-size: 14px;
    line-height: 1.4;
    color: #111;
    margin: 0 0 10px;
   /*    padding-left: 10px;
    border-left: 4px solid #0177bd; */
  }

  /* 右カラムを“箱”にして左側カテゴリとトーンを揃える（任意だが整う） */
  #footer .footernav_column{
    border-radius: 12px;
    background: #fff;
    padding: 14px 14px 12px;
    box-sizing: border-box;
  }

  /* 縦並び＋間隔統一 */
  #footer .footernav_column ul{
    display: flex;
    flex-direction: column;
    align-items: flex-start;     /* 左揃え */
    justify-content: flex-start; /* 念のため */
    gap: 10px;
    list-style: none;
    margin: 0;
    padding: 0;
    font-size: 13px;
  }

  #footer .footernav_column li{
    margin: 0;
  }

  /* リンクの見た目（任意） */
  #footer .footernav_column a{
    text-decoration: none;
  }
  #footer .footernav_column a:hover{
    text-decoration: underline;
  }

#footer .copyRight{
  border-top: 1px solid #e5e5e5;
  padding-top: 12px;
  margin-top: 18px;
  text-align: center;
}	