﻿@charset "UTF-8";

/* -- Base -- */
body {
  margin: 0;
  font-family: "Noto Sans CJK JP", 'Noto Sans Japanese', sans-serif, "ヒラギノ角ゴ Pro W6", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 14px;
  line-height: 1.5;
  color: #000;
	background: #F7F7F7 url("../../img/usr/common/background.png") top 32px center / 1920px auto no-repeat;
	overflow-x: hidden;
}

img { vertical-align: top;}

.sp-only { display: none;}

.lazyload { opacity: 0;}
.lazyloading { opacity: 1;}
.lazyloaded { opacity: 1; transition: opacity 200ms;}

a img,
a input { transition: 0.3s;}
a:hover img,
a:hover input { opacity: 0.7;}
a { color: #111111;}
a.btn { text-decoration: none;}
a:hover,
a:focus { text-decoration: none;}

a .blank-icon { padding: 0 0 0 18px; margin: 0 0 0 3px; text-indent: 0; text-decoration: underline; display: inline-block; background: url("../../img/usr/common/icon_othersite.png") left center no-repeat; -webkit-background-size: 11px 10px; background-size: 11px 10px;}
a .blank-icon:hover { text-decoration: none;}

/* -- TextColor -- */
.text-muted   { color: #777;}
.text-warning { color: #8a6d3b;}
.text-danger  { color: #a94442;}
.tax { font-size: 11px; font-weight: normal; letter-spacing: -1px; white-space: nowrap; word-break: keep-all;}
.price { color: #111111;}
.on-sale .price { font-size: 16px; color: #CC0000;}
.price .mile    { font-size: 12px;}
.default-price  { font-size: 14px; font-weight: normal; text-decoration: line-through;}
.default-price .mile { font-size: 12px;}
.exchange-price { color: #555;}
.net-price      { display: none !important;}
.mile-point     { display: none !important;}
.jal-card-price { display: none !important;}

.form-error { color: #CC0000;}
.block-addr2-message { color: #CC0000;}
.promotion-benefit   { color: #CC0000;}
.block-birth-message { color: #CC0000;}

.required:after { content: "必須"; padding: .2em .6em; border-radius: .25em; display: inline-block; font-size: 11px; text-align: center; vertical-align: baseline; white-space: nowrap; color: #fff; background-color: #CC0000;}

/* -- Button -- */
.action-buttons { width: 100%; margin-top: 10px; text-align: center; display: block;}
.action { margin-left: 10px; margin-right: 10px; display: inline;}
.action .btn { min-width: 200px; margin-top: 10px; padding: 10px; border-radius: 5px; border-bottom-width: 0; font-size: 16px;}

.btn { padding: 4px 10px; margin: 0; border-radius: 5px; text-align: center; vertical-align: middle; white-space: nowrap; display: inline-block; cursor: pointer;}
.btn-default { border: solid 1px #dcdcdc; background-color: #e5e5e5; color: #333;}
.btn-primary { border: 0; background: linear-gradient(to bottom right, #C00A65 0%, #C00A1D 100%); color: #fff;}
.btn-secondary { border: solid 1px #333; background-color: #666; color: #fff;}
.btn-danger { border: solid 1px #999; border-radius: 5px; background-color: #999; color: #fff;}
.hidden-btn { width: 1px; height: 1px; position: absolute; left: -9999px;}

/* -- Pager -- */
.pager { height: 36px; padding: 0; margin: 20px 0; display: flex; align-items: center; justify-content: center; flex-wrap: nowrap; position: relative;}
.pager > * { vertical-align: middle; display: inline-block;}
.pager-scope { padding: 3px; margin-right: 5px; display: inline-block;}
.pager-total { height: 28px; padding: 0; margin: 0; position: absolute; top: calc(50% - 14px); left: 0;}
.pager-total .pager-count { font-size: 14px;}
.pager-total .pager-count span { margin: 0 2px 0 0; font-family: "Mulish", "Noto Sans CJK JP", 'Noto Sans Japanese', sans-serif, "ヒラギノ角ゴ Pro W6", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif; font-size: 17px; font-weight: 500;}
.pager-frame { display: flex;}
.pagination { display: flex;}
.pagination > * { padding: 0; margin: 0; border: none; background-color: none; list-style-type: none; float: none; background: none;}
.pagination li { width: 28px; height: 28px; margin: 0 5px; border: transparent 1px solid; font-size: 14px; box-sizing: border-box; display: flex; justify-content: center; align-items: center;}
.pagination li a { width: 28px; height: 28px; display: flex; justify-content: center; align-items: center;}
.pagination li.pager-next,
.pagination li.pager-previous { border: #CCCCCC 1px solid; font-size: 0; position: relative; background: #fff;}
.pagination li.pager-first,
.pagination li.pager-last     { display: none !important;}
.pagination li.pager-first a::before,
.pagination li.pager-first a::after,
.pagination li.pager-previous a::before,
.pagination li.pager-next a::before,
.pagination li.pager-last a::before,
.pagination li.pager-last a::after { content: ""; width: 8px; height: 8px; border-right: #000 1px solid; border-top: #000 1px solid; position: absolute; left: 11px; top: calc(50% - 4px); display: block; transform: rotate(-135deg);}
.pagination li.pager-first a::before { left:  8px;}
.pagination li.pager-first a::after  { left: 14px;}
.pagination li.pager-next a::before  { left:  7px; transform: rotate(45deg);}
.pagination li.pager-last a::before  { left:  4px; transform: rotate(45deg);}
.pagination li.pager-last a::after   { left: 11px; transform: rotate(45deg);}
.pagination li.pager-current { border: #000 1px solid; background: #000000; color: #fff;}
.pagination > .disabled { color: #777;}
.pagination li.pager-first a::before { left: 11px;}
.pagination li.pager-first a::after  { display: none !important;}
.pagination li.pager-last a::before  { left:  7px; transform: rotate(45deg);}
.pagination li.pager-last a::after   { display: none !important;}

.pager-frame.custom-pager { opacity: 0;}
.pager-frame.custom-pager .pagination li:not(.pager-current):not(.pager-previous):not(.pager-next):not(.pager-show) { display: none;}

/* -- Headline -- */
div.headline { margin: 0 0 30px 0;}
div.headline .eng { padding: 0; margin: 0 0 10px 0; font-size: 32px; font-weight: bold; text-align: center; line-height: 1.0; color: #111111;}
div.headline .jpn { font-size: 12px; font-weight: bold; text-align: center; letter-spacing: 1.5px; color: #666666;}

.design-title-line-header { padding: 0; margin: 0 0 40px 0; font-size: 24px; font-weight: bold; text-align: center; position: relative;}
.design-title-line-header::before { content: ''; width: 100%; height: 1px; display: block; background: #111111; position: absolute; left: 0; top: calc(50% - 0.5px); z-index: 1;}
.design-title-line-header span { padding: 0 20px; margin: 0 auto; display: inline-block; background: #fff; position: relative; z-index: 2;}

.block-design-title-line { padding: 5px 0 20px 35px; margin: 0 0 30px 0; border-bottom: #A19059 1px solid; font-size: 30px; font-weight: bold; line-height: 1.0; display: flex; align-items: center; background:  url("../../img/usr/common/eye_catch.png") left 10px no-repeat; -webkit-background-size: 16px 16px; background-size: 16px 16px;}
.block-design-title-line .sub { margin: 0 0 0 30px; font-size: 14px; font-weight: bold; color: #A19059; position: relative; top: 3px;}

/* -- input -- */
input[type="text"],
input[type="tel"],
input[type="email"],
input[type="search"],
input[type="password"],
input[type="url"],
input[type="number"],
textarea { min-height: 42px; padding: 4px 10px; border: 1px solid #ccc; background-color: #fff;}
select { height: 42px; padding: 4px; border: 1px solid #ccc; background-color: #fff; line-height: 34px;}
input[type="number"] { -webkit-appearance: none; -moz-appearance: none; -ms-appearance: none; min-width: 50px; min-height: 42px; padding: 4px; border: 1px solid #ccc; background-color: #fff; box-sizing: border-box;}

input::placeholder { color: #CCC;}

/* radio */
input[type="radio"] { -webkit-appearance: none; -moz-appearance: none; -ms-appearance: none; width: 16px; height: 16px; margin-bottom: 3px; margin-right: 5px; border: #CCC 1px solid; border-radius: 16px; background: #fff; position: relative; outline: 0; transition: 0.3s;}
input[type="radio"]:before { transition: 0.3s;}
input[type="radio"]:checked { border: #A19059 1px solid;}
input[type="radio"]:checked:before { content: ""; width: 10px; height: 10px; margin: 0; border: #A19059 1px solid; border-radius: 10px; position: absolute; left: calc(50% - 5px); top: calc(50% - 5px); display: block; background: #A19059;}
input[type="radio"]:checked + label { color: #A19059; font-weight: 700;}

/* checkbox */
input[type="checkbox"] { -webkit-appearance: none; -moz-appearance: none; -ms-appearance: none; width: 16px; height: 16px; margin-bottom: 3px; margin-right: 5px; border: #CCC 1px solid; background: #fff; position: relative; outline: 0; transition: 0.3s;}
input[type="checkbox"]:before { transition: 0.3s;}
input[type="checkbox"]:checked { border: #999 1px solid; background: #FFF;}
input[type="checkbox"]:checked:before { content: ""; width: 10px; height: 6px; margin: 0; border-right: 2px solid #CC0000; border-top: 2px solid #CC0000; transform: rotate(135deg); position: absolute; left: calc(50% - 5px); top: calc(50% - 4px); display: block;}
input[type="checkbox"]:checked + label { font-weight: 700;}

/* -- fieldset -- */
.fieldset { width: 100%; margin-top: 10px; margin-bottom: 10px;}
.fieldset .form-group { width: 100%; border-top: #F4F5F6 1px solid; display: table;}
.fieldset .form-group:last-child { border-bottom: #F4F5F6 1px solid;}
.fieldset .form-label,
.fieldset .constraint,
.fieldset .form-control { display: table-cell;}
.fieldset .form-label { width: 23%; padding: 25px 10px 25px 25px; text-align: left; background: #F4F5F6;}
.fieldset .form-label label { font-weight: bold;}
.fieldset .constraint { width: 65px; padding: 5px; background: #F4F5F6;}
.fieldset .form-control { padding: 5px 0 5px 20px; background: #ffffff;}

.fieldset-vertical .form-label { margin-right: 0;}

/* -- PanKuzu -- */
.block-topic-path { padding: 12px 0;}
.block-topic-path--list li { padding-right: 5px; font-size: 12px; display: inline-block;}
.block-topic-path--list a { font-size: 12px; text-decoration: none;}
.block-topic-path--list li:last-child a { pointer-events: none; color: #777777;}
.block-topic-path--list .block-topic-path--item__home a { padding: 0 0 0 15px; display: inline-block; background: url("../../img/usr/common/icon_home.png") left center no-repeat; -webkit-background-size: 10px 10px; background-size: 10px 10px;}

/* -- Icon -- */
.block-icon img { width: auto; max-height: 20px;}

/* -- Sort -- */
.block-goods-list--sort-order-items { padding: 0; margin: 20px 0; font-size: 12px; display: flex; align-items: center;}
.block-goods-list--sort-order-items .active { color: #c00;}
.block-goods-list--sort-order-items dt { display: none;}
.block-goods-list--sort-order-items dd { width: 180px; height: 36px; margin: 0; padding: 0; font-size: 14px; display: block; font-weight: normal; box-sizing: border-box; position: relative;}
.block-goods-list--sort-order-items dd .sort-wrap { width:100%; height: 36px; border-radius: 18px; display: flex; flex-direction: column; position: relative; transition: 0.3s; overflow: hidden; box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16); z-index: 1;}
.block-goods-list--sort-order-items dd .sort-wrap .sort-item { width: 100%; height: 36px; background: #fff; text-align: left; order: 2;}
.block-goods-list--sort-order-items dd .sort-wrap .sort-item a { padding: 0 32px 0 16px; height: 100%; line-height: 36px; display: block; background: #fff url("../../img/usr/common/ico_arrow_r.png") center right 12px / 7px auto no-repeat;}
.block-goods-list--sort-order-items dd .sort-wrap .sort-item.active { padding: 0 32px 0 16px; height: 36px; line-height: 36px; color: #111; display: block; background: #fff; order: 1;}
.block-goods-list--sort-order-items dd .sort-wrap .sort-item a:hover { background-color: #F8F8F8;}
.block-goods-list--sort-order-items dd .sort-wrap::after { position: absolute; top: 15px; right: 10px; width: 12px; height: 7px; display: block; background: url("../../img/usr/common/ico_arrow_r_down.png") center center / 12px auto no-repeat; content: '';}
.block-goods-list--sort-order-items dd .sort-wrap.active { height: auto;}
.block-goods-list--sort-order-items dd .sort-wrap:hover { height: auto;}

.block-goods-list--pager-top { position: relative;}
.block-goods-list--pager-top .block-goods-list--sort-order-items { margin: 0; position: absolute; right: 0; top: -1px;}

/* -- Flow -- */
.block-order-flow--step { margin: 30px auto 60px; padding: 0; text-align: center;}
.block-order-flow--step ul { display: flex; justify-content: center; align-items: center;}
.block-order-flow--step1,
.block-order-flow--step2,
.block-order-flow--step3,
.block-order-flow--step4,
.block-order-flow--step5 { min-width: 200px; height: 60px; padding: 2px 0 0 0; margin: 0; border-bottom: #BBBBBB 2px solid; display: flex; justify-content: center; align-items: center; position: relative; background: none; font-size: 16px; color: #BBBBBB;}
.block-order-flow--step1:after,
.block-order-flow--step2:after,
.block-order-flow--step3:after,
.block-order-flow--step4:after,
.block-order-flow--step5:after { content: ''; width: 10px; height: 10px; border: none; border-radius: 10px; position: absolute; top: auto; left: calc(50% - 5px); right: auto; bottom: -5.5px; background: #BBBBBB;}
.block-order-flow--step-current { border-bottom: #CC0000 2px solid; background: none; font-weight: bold; color: #111111;}
.block-order-flow--step-current:after { border-left: none; background: #CC0000;}

/* -- modal -- */
.modal-body { word-break: break-all;}
.modal-body p { word-break: break-all;}
