@charset 'utf-8';

/*******************************
	bese setting.
*******************************/
body {
	font-size: 14px;
	font-family: '游ゴシック', YuGothic, 'ヒラギノ角ゴ Pro', 'Hiragino Kaku Gothic Pro', 'メイリオ', 'Meiryo', Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
	color: #666;
	letter-spacing: 1px;
	padding-bottom: 20px;
}
@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
	body {
		font-family: 'メイリオ', '游ゴシック', YuGothic, 'ヒラギノ角ゴ Pro', 'Hiragino Kaku Gothic Pro', 'Meiryo', Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
	}
}


h1 {
	letter-spacing: 3px;
	margin-bottom: 0;
}
h1.title {
	margin-top: 8px;
}

a {
	color: inherit;
}
#office-view a:hover,
#office-view a:focus {
	color: transparent;
	text-decoration: none;
}

header {
	border-top: 1px solid #E4F0FD;
	background: #f9f9f9 url(../imgs/stripe.png);
}

header .user-line {
	display: inline-block;
	width: 100%;
}


/*******************************
	outline setting.
*******************************/
.content {
	background: #f9f9f9 url(../imgs/stripe.png) repeat;
	border-radius: 10px;
	border: 1px solid #aaa;
	width: 100%;
	padding: 60px 20px;
	margin: 50px auto;
}

#login-view .content .login-page {
	max-width: 400px;
	margin: auto;
}


/*******************************
	table setting.
*******************************/
#officeForm:first-child th,
#officeForm:first-child td,
#collection-view tr:nth-child(n + 1) td:nth-child(5),
#mail-view thead th:last-child,
#mail-view tbody tr:first-child td:last-child {
	text-align: center;
}

#collection-view tr:nth-child(4) td,
#collection-view tfoot td,
#cardboard-view tr:nth-child(2) td,
#cardboard-view tr:last-child td,
#mail-view tr:nth-child(3) td {
	padding-top: 25px !important;
}

#collection-view tfoot td {
	border: 0;
}

#collection-view td,
#cardboard-view td,
#mail-view td,
#member-view td {
	vertical-align: middle !important;
}

#collection-view tr:nth-child(n + 5) td:nth-child(-n + 1),
#cardboard-view tr:nth-child(n + 3) td:first-child,
#mail-view tr:nth-child(n + 4) td:first-child,
#mail-view tfoot td:first-child {
	border: 0;
	background: #fff;
}

#office-view table {
	letter-spacing: 0;
}


#office-view .list-table {
	border-bottom: 2px solid #ddd;
}
#office-view .input-table {
	background: inherit !important;
	margin-top: 20px;
	font-size: 13px;
}
#office-view .list-table th:last-child,
#office-view .list-table td:last-child,
#office-view .input-table th {
	text-align: justify;
}

#member-view tr {
	height: 45px;
}

#member-view th,
.radio-icon + label,
.chk-icon + label {
	font-weight: normal;
}

#member-view td {
	padding: 5px;
}

#mail-view td.order-cnt {
	border-left: 1px solid #ddd;
}
#mail-view tr:nth-child(even) {
	background: #f9f9f9;
}


/*******************************
	button setting.
*******************************/
.btn {
	letter-spacing: 1px;
}

/* orange button（white） */
.btn-orange,
.btn-orange:focus {
	color: #daa458;
	background: #fff;
	border-color: #e7b979;
}
.btn-orange:hover {
	color: #fff;
	background: #daa458;
}

/* green button（white） */
.btn-green,
.btn-green:focus {
	color: #7ACCBE;
	border-color: #7ACCBE;
	background: #fff;
}
.btn-green:hover {
	color: #fff;
	background: #7ACCBE;
}

/* gray button */
.btn-gray,
.btn-gray:focus,
.add-icon:focus,
.btn-plus:focus,
.btn-minus:focus {
	color: #aaa;
	background: #fff;
	border-color: #aaa;
}
.btn-gray:hover,
.add-icon:hover,
.btn-plus:hover,
.btn-minus:hover {
	color: #fff;
	background: #aaa;
}

/* blue button */
.btn-blue,
.btn-blue:focus {
	color: #5bc0de;
	background: #fff;
	border-color: #46b8da;
}
.btn-blue:hover {
	color: #fff;
	background: #5bc0de;
}

.btn-blue.logout {
	letter-spacing: -2px;
	margin-top: 1px;
	margin-right: -4px;
}

/* red button(white) */
.btn-red,
.btn-red:focus {
	color: #F091A1;
	background: #fff;
	border-color: #F091A1;
}
.btn-red:hover,
#office-view .btn-red:focus {
	color: #fff;
	background: #F091A1;
}

/* +,- button */
.btn-minus,
.btn-plus {
	cursor: pointer;
}

#login-view .btn,
#password-view .btn {
	margin-top: 25px;
}

/* modal button */
.modal-btnarea {
	text-align: center;
	width: 100%;
	margin-top: 40px;
}
.modal-btnarea .btn:nth-child(n + 2) {
	margin-left: 65px;
}

/* collapse buttonarea */
.collapse-btnarea {
	margin-left: 8px;
}


/*******************************
	width setting.
*******************************/
.width-small {
	width: 52px;
}
.width-70 {
	width: 70px
}
.width-110 {
	width: 110px;
	letter-spacing: 3px;
}
.width-150 {
	width: 150px;
	letter-spacing: 4px;
}
.width-400 {
	width: 400px;
	letter-spacing: 4px;
}
.width-max {
	width: 100%;
	letter-spacing: 4px;
}


/*******************************
	group setting.
*******************************/
#collection-info .form-inline > .input-group {
	margin-bottom: 10px;
}

#login-view .input-group,
#home-view .input-group {
	width: 100%;
}

#history-wrap > div {
	display: none;
}

#history-wrap > div .input-group {
	margin-bottom: 7px;
}

.input-group-addon {
	width: 40px;
	letter-spacing: 0;
}

#home-view .input-group-addon {
	color: #888;
	background: #f6f6f6;
	font-size: 13px;
	text-align: right;
	font-weight: bold;
	line-height: 14px;
	width: 120px;
}

#home-view .input-group-addon p {
	margin: 0;
}

#mail-view .barcode-add {
	width: 100%;
	height: 60px;
}



/*******************************
	checkbox setting.
	radio setting.
*******************************/
input[type=checkbox],
input[type=radio] {
	display: none;
}

/* checkbox */
input[type=checkbox] ~ .chk-icon {
	display: inline-block;
	border: 2px solid #aaa;
	background: #fff;
	width: 30px;
	height: 30px;
	padding: 13px;
	vertical-align: middle;
	cursor: pointer;
}
/* checkmark */
input[type=checkbox]:checked ~ .chk-icon:before {
	content: '';
	position: absolute;
	border-left: 4px solid #E71063;
	border-bottom: 4px solid #E71063;
	width: 26px;
	height: 13px;
	margin-left: -13px;
	margin-top: -9px;
	-webkit-transform: rotate(-45deg);
	-ms-transform: rotate(-45deg);
	transform: rotate(-45deg);
}

/* radio */
input[type=radio] + .radio-icon {
	display: inline-block;
	border: 2px solid #aaa;
	background: #fff;
	width: 25px;
	height: 25px;
	border-radius: 50%;
	vertical-align: middle;
	cursor: pointer;
}
/* radiomark */
input[type=radio]:checked + .radio-icon:before {
	content: '';
	position: absolute;
	background: #E71063;
	width: 15px;
	height: 15px;
	border-radius: 50%;
	margin: 3px;
}
/* radio + label */
.radio-icon + label {
	margin: 0;
	vertical-align: middle;
	font-size: 13px;
	cursor: pointer;
}

input[type=checkbox] + .chk-icon:hover,
input[type=radio] + .radio-icon:hover {
	background: #FBEFF5;
}


/*******************************
	text setting.
*******************************/
input[type=text] {
	display: inline-block;
	font-weight: normal;
	box-shadow: none;
	line-height: normal;
}

input.buy {
	width: 80px !important;
	font-size: 16px !important;
	text-align: center;
}

input.zipcode-top,
input.zipcode-last {
	width: 80px;
}

#password-view input:first-child {
	margin-bottom: 8px;
}

#password-view input:nth-child(n + 2) {
	margin-bottom: 20px;
}

.form-control {
	line-height: 25px;
}

#member-view .edit,
#member-view .btn-save {
	display: none;
}

.datepicker {
	width: 150px;
	cursor: pointer;
}


/*******************************
	select setting.
*******************************/
select:hover,
input[type=text]:hover {
	background: #FEFEF5;
}

select {
	cursor: pointer;
	border-color: #ccc;
	border-radius: 4px;
	height: 34px;
	font-size: 13px;
}

#collection-view select,
#cardboard-view select {
	border-radius: 0 4px 4px 0;
	width: 350px;
}

#member-view select,
#office-view select {
	width: 150px;
	padding-left: 8px;
}

#home-view select {
	display: none;
	color: #30add1;
	border-color: #30add1;
	font-size: 13px;
	letter-spacing: 1px;
	width: 120px;
	height: 28px;
}


/*******************************
	inline setting.
*******************************/
span.product-total,
span.subtotal,
span.carry,
span.tax,
span.total,
#mail-view td:nth-child(3) > span {
	display: inline-block;
	width: 60px;
	text-align: right;
}

span.product,
span.total {
	font-weight: bold;
}

span.forget,
.notice {
	font-size: 12px;
}
.notice,
.disclaimer {
	color: #F78B6C;
}
.disclaimer {
	font-size: 13px;
	margin-bottom: 23px;
	margin-top: -18px;
}

.chk-place-word {
	display: inline-block;
	vertical-align: middle;
	margin-top: 5px;
	line-height: 16px;
}


/*******************************
	icon setting.
*******************************/
/* required mark */
.required:before {
	content: '必須';
	display: inline-block;
	vertical-align: middle;
	color: #fff;
	background: #F78B6C;
	font-size: 12px;
	padding: 2px 7px;
	border-radius: 10px;
	margin-left: 3px;
	line-height: 16px;
}

.input-icon {
	display: inline-block;
	width: 100%;
	padding: 0 20px;
}

.input-icon .fa {
	display: inline-block;
	position: absolute;
	right: 88px;
	margin-top: -24px;
	padding-left: 30px;
}

.circle {
	display: inline-block;
	background: #f5f5f5;
	border: 1px solid #aaa;
	height: 23px;
	width: 23px;
	border-radius: 50%;
	text-align: center;
}
.circle > .fa {
	margin-top: 5px;
	margin-left: 1px;
}

.fa.pull-left {
	padding-top: 2px;
	color: #30add1;
}

.fa.pull-left.two-row {
	padding-top: 12px;
}

.afeature .fa {
	color: #30add1;
}

.modal-title .fa {
	color: #d9534f;
}
.alert-info .fa.fa-exclamation-triangle {
	color: #31708f;
}

.add-icon,
.delete-icon {
	cursor: pointer;
}

.add-icon:active,
.delete-icon:active {
	box-shadow: 0 0 3px 1px #ddd inset;
	-moz-box-shadow: 0 0 3px 1px #ddd inset;
	-webkit-box-shadow: 0 0 3px 1px #ddd inset;
}

.badge.unread {
	background: #30add1;
	margin-left: 3px;
}


/*******************************
	original object.
*******************************/
.afeature {
	float: right;
	width: 100px;
	height: 100px;
	background: #eee url(../imgs/stripe.png) repeat;
	border-radius: 250px;
	border: 5px solid #fff;
	margin-top: 10px;
	margin-right: -30px;
	box-shadow: 0 0 3px #aaa;
	text-align: center;
	padding-top: 12px;
	-webkit-transition: border 1s ease;
	-moz-transition: border 1s ease;
	-o-transition: border 1s ease;
	transition: border 1s ease;
}
.afeature:hover {
	border: 5px solid #30add1;
	cursor: pointer;
}

.afeature p {
	font-weight: bold;
	letter-spacing: 1px;
}

.list-wrap {
	border: 5px solid #fff;
	border-radius: 3px;
	margin: 5px auto;
}

.list-wrap .list {
	background: #fff;
	border: 1px dashed #aaa;
	font-size: 12px;
	padding: 4px 10px;
}


/*******************************
	calendar setting.
*******************************/
/* calendar */
.datepicker.dropdown-menu {
	background: #f9f9f9 url(../imgs/bg_gnavi.png);
	padding: 15px;
	width: 235px;
}

.datepicker table tr td.today {
	color: #fff;
	background: #7ACCBE;
	border-radius: 50%;
}


/*******************************
	line setting.
*******************************/
.hr-dot {
	background: url(../imgs/dot.png);
	margin: 10px 0;
	height: 20px;
}

/* title line */
h1 + .hr-dot {
	margin-top: -15px;
	margin-bottom: 23px;
}

.hr-dash {
	border-top: 1px dashed #aaa;
	margin: 4px auto;
}


/*******************************
	image setting.
*******************************/
img.logo-mark {
	display: inline-block;
	max-width: 100%;
	width: 110px;
	height: auto;
	margin-top: 2px;
}

.logo img {
	max-width: 100%;
	width: 170px;
	height: auto;
	margin-top: -30px;
}

#operation-view img.cardboard {
	min-width: 200px;
	width: 40%;
	margin-right: 20px;
	margin-top: 15px;
}


/*******************************
	alert setting.
*******************************/
.alert {
	margin-bottom: 5px;
	padding: 6px;
	line-height: normal;
}

#home-view #history-wrap .alert {
	margin: 0;
}

.alert-redend {
	color: #a94442;
	border-color: #ebccd1;
	background: #F8EDED;
}

.alert-greenend {
	color: #3c763d;
	border-color: #d6e9c6;
	background: #ECF7E8;
}

.alert-yellowend {
	color: #8a6d3b;
	border-color: #faebcc;
	background: #FDFBF0;
}

.alert-purple {
	color: #800080;
	border-color: #e8d6e8;
	background: #f9f1f9;
}

.alert-message:last-child {
	margin-bottom: 15px;
}

#login-view .alert:first-child,
#password-view .alert:first-child {
	margin-top: 20px;
}

/* mail barcode */
.barcode-no {
	float: left;
	width: 49%;
	height: 40px;
	padding: 10px 30px 0 10px;
	margin-bottom: 5px;
}
.barcode-no:nth-child(even) {
	margin-left: 2%;
	background: #ECFEFB;
	border-color: #d9edf7;
}

.alert-set {
	border: 1px solid #ccc;
	border-radius: 0 4px 4px 0;
	padding: 4px;
}


/*******************************
	label setting.
*******************************/
.label {
	display: inline-block;
	line-height: normal;
	padding: 3px 6px 18px;
	height: 15px;
}

.alert-redend .label {
	background: #EEB1B0;
}

.alert-greenend .label {
	background: #A0D6A0;
}

.alert-yellowend .label {
	background: #F7CF9B;
}

.alert-purple .label {
	background: #c398c3;
}

.label-gray {
	background: #aaa;
}

.label-red {
	background: #E27C7A;
}

#collection-info .panel-body > div > label {
	width: 210px;
	height: 30px;
	margin: 0;
	cursor: pointer;
}

#collection-view td label,
#mail-view td label {
	margin: 0;
}


/*******************************
	modal setting.
*******************************/
.modal-body {
	padding-top: 20px;
	padding-bottom: 23px;
	line-height: 25px;
}

.modal-title {
	letter-spacing: 2px;
}

.modal-body p {
	margin: 0;
}



/*******************************
	global navigation setting.
*******************************/
.navbar {
	background: #f9f9f9 url(../imgs/bg_gnavi.png);
	border-radius: 0 !important;
	height: 50px;
	z-index: 1000;
}

nav #gnavi {
	margin-top: 2px;
}

nav .navbar-header .navbar-toggle {
	background: #fff;
}

nav .navbar-nav a {
	font-size: 13px;
	border: 5px solid #fff;
	background: #f9f9f9 url(../imgs/stripe.png) repeat;
	border-radius: 10px;
	padding: 2px 5px;
	margin-top: 5px;
	margin-right: 5px;
	line-height: normal;
	box-shadow: 0 0 3px #aaa;
	-webkit-transition: border 1s ease;
	-moz-transition: border 1s ease;
	-o-transition: border 1s ease;
	transition: border 1s ease;
}

nav .navbar-nav a:hover {
	border: 5px solid #30add1;
}

nav .navbar-nav li:last-child a {
	margin-right: 0;
}

nav .navbar-nav .dropdown-menu {
	border-top: 1px solid #ddd !important;
	border-bottom: 1px solid #ddd !important;
	background: #f9f9f9 url(../imgs/bg_gnavi.png);
	border-radius: 0;
	box-shadow: none;
	margin-top: 15px !important;
}

nav .navbar-nav .dropdown-menu a {
	margin: 10px !important;
}


/*******************************
	panel setting.
*******************************/
#mail-view .panel {
	border: 1px solid #7BBFCA;
	margin: 0;
}

#mail-view .panel .panel-heading {
	background: #7BBFCA;
	color: #fff;
	padding: 7px 15px;
}

#mail-view .panel .barcode-view {
	overflow: auto;
	min-height: 60px;
	max-height: 300px;
	padding: 10px 10px 5px;
}

#password-view .panel {
	max-width: 350px;
	width: 100%;
	margin: auto;
	border-color: #aaa;
}

#password-view .panel .panel-heading {
	background: #6bc3b0;
	color: #fff;
}

#collection-info .panel {
	display: inline-block;
	border-color: #ccc;
	padding: 0;
	margin: 0;
}
#collection-info .panel-heading {
	padding: 6px 12px;
	background-color: #eee;
	border-color: #ccc;
}
#collection-info .panel-body {
	padding: 10px;
}


/*******************************
	tab setting.
*******************************/
/* two tabs */
#login-view .tab-pane {
	border: 1px solid #aaa;
	border-top-color: transparent;
	background: #fff;
	padding: 20px;
	border-bottom-left-radius: 5px;
	border-bottom-right-radius: 5px;
}

#login-view .tab-pane label {
	font-weight: normal;
	font-size: 13px;
	color: #ccc;
}

#login-view .nav-tabs li .fa {
	display: block;
	margin-bottom: 7px;
	margin-top: 5px;
}

#login-view .nav-tabs li a {
	color: #00999D !important;
	border: 1px solid #aaa !important;
	background: #fff;
	border-radius: 0;
	margin: 0 !important;
	padding: 10px 14px;
	-webkit-transition: background 0.7s ease;
	-moz-transition: background 0.7s ease;
	-o-transition: background 0.7s ease;
	-ms-transition: background 0.7s ease;
	transition: background 0.7s ease;
	font-size: 15px !important;
	font-weight: 600;
	letter-spacing: 0.02em;
}

#login-view .nav-tabs li.active a {
	background: #F5FFFA url(../imgs/bg_gnavi.png) !important;
}

#login-view .nav-tabs li:first-child a {
	border-right-color: transparent !important;
	border-top-left-radius: 5px;
}

#login-view .nav-tabs li:last-child a {
	border-top-right-radius: 5px;
}

#login-view .nav-tabs li a:hover {
	filter: brightness(90%);
	-webkit-transition: background 0.7s ease;
	-moz-transition: background 0.7s ease;
	-o-transition: background 0.7s ease;
	-ms-transition: background 0.7s ease;
	transition: background 0.7s ease;
}

/* left tabs */
.tab-left .nav-tabs {
	border-color: transparent;
}

.tab-left .nav-tabs {
	float: left;
}

.tab-left .nav-tabs li {
	float: none;
}

.tab-left .nav-tabs li a {
	color: inherit;
	border: 1px solid #ddd !important;
	border-right: transparent !important;
	background: #f0f0f0;
	border-radius: 0;
	margin-right: 0;
}
.tab-left .nav-tabs li a:hover {
	background: #F5FEFE;
}

.tab-left .nav-tabs li:first-child a {
	border-top-left-radius: 4px;
}

.tab-left .nav-tabs li:last-child a {
	border-bottom-left-radius: 4px !important;
}

.tab-left .nav-tabs li.active a {
	background: #fff !important;
}

#operation-view .tab-content {
	overflow: hidden;
	border: 1px solid #ddd;
	border-radius: 0 4px 4px;
	padding: 0 15px;
	min-height: 350px;
}

.tab-left .tab-content p {
	margin-bottom: 3px;
}


/*******************************
	error page setting.
*******************************/
.error-page {
	text-align: center;
}
.error-title {
	color: #f58583;
	font-size: 120px;
	letter-spacing: -37px;
	font-weight: bold;
}
.error-title > .fa {
	position: relative;
	top: -55px;
	font-size: 65px;
}
.error-title > .fa.fa-quote-left {
	margin-right: 20px;
}
.error-title > .fa.fa-quote-right {
	margin-left: 20px;
}
.error-msg {
	font-size: 25px;
	letter-spacing:-1px;
}


/*******************************
	Responsive setting.
*******************************/
@media (max-width: 767px) {
	/* header */
	header .list-wrap {
		margin-top: 25px;
	}

	/* global navigation */
	nav #gnavi {
		border-top: 0;
		border-bottom: 1px solid #e7e7e7;
	}
	nav .navbar-collapse {
		background: #fff;
	}
	nav .navbar-nav li a {
		width: 220px;
		margin: 10px auto;
		font-size: 15px;
		background: none;
		box-shadow: none;
		border: none;
		border-bottom: 2px solid #ddd;
		border-radius: 0;
	}
	nav .navbar-nav li:last-child a {
		margin: 10px auto !important;
	}
	nav .navbar-nav li a:hover {
		color: #30add1;
		border: none;
		border-bottom: 2px solid #30add1;
	}
	nav .caret {
		margin-left: 8px;
	}

	/* ログイン画面 */
	#login-view .nav-tabs li:first-child a {
		border-right-color: #aaa !important;
		border-top-left-radius: 5px;
		border-top-right-radius: 5px;
	}
	#login-view .nav-tabs li:last-child a {
		border-top-right-radius: 0;
	}

	/* ホーム画面 */
	#operation-view img.cardboard {
		margin-right: 100%;
		margin-bottom: 15px;
	}

	/* 発送依頼画面 */
	#mail-view .barcode-no {
		width: 100%;
	}
	#mail-view .barcode-no:nth-child(even) {
		margin-left: 0;
	}
	#mail-view .barcode-area .col-sm-8 {
		padding-left: 15px !important;
		margin-top: 10px;
	}
	#mail-view .input-group,
	#mail-view .barcode-add {
		height: 34px;
	}

	/* 手続き履歴 */
	#home-view .input-group-addon {
		display: block;
		border-right: 1px solid #ccc;
		border-bottom-color: transparent;
		border-radius: 4px 4px 0 0;
		width: 100%;
	}
	#home-view .input-group-addon p {
		display: table-cell;
	}
	#home-view .input-group-addon p:last-child {
		padding-left: 10px;
	}
	#home-view .alert-set {
		border-radius: 0 0 4px 4px;
	}
}

@media (min-width: 768px) {
	/* 回収依頼画面 */
	#chk-unopen-modal .modal-dialog,
	#office-newcreate-modal .modal-dialog {
		width: 750px;
	}
}