/* Hide the system-provided file selection, replace it with a custom button */
.fileUpload {
    position: relative;
    overflow: hidden;
}
.fileUpload input.upload {
    position: absolute;
    top: 0;
    right: 0;
    margin: 0;
    padding: 0;
    font-size: 20px;
    cursor: pointer;
    opacity: 0;
    filter: alpha(opacity=0);
}

.svgCanvas {
    background: #e0e0e0;
    font-size: 16px;
    box-sizing: border-box;
    width: 100%;
    height: 100%;
    text-align: center;
}

.stlCanvas {
    background: #e0e0e0;
    font-size: 16px;
    box-sizing: border-box;
    width: 100%;
		height: auto;
    /* height: 100%; */
}

.optionsDiv {
    /* background: #e0e0e0; */
    display: inline-block;
    width: 196px;
    /*padding: 0 5px 0 5px;*/
    border-width: 0 2px 0 2px;
    border-style: solid;
    border-color: black;
    height: 100%;
}
.activebg{
    background-color: #5a5c69;
}
.valign-middle {
    display: inline-block;
    height: 100%;
    vertical-align: middle;
}

#uploadedSVG {
    display: none;
    width: 96%;
    height: 96%;
}

.imgwrapper { 
    text-align: center;
    z-index: 25;
}
.rotatedegree{
    transform: rotate(180deg);
}
.overlayIMG {
    position: absolute; 
    top: 0; 
    left: 0;
    width: 100%; 
    height: 100%;
    z-index: 999;
    text-align: center;
}
.modal-confirm {		
	color: #434e65;
}
.modal-confirm .modal-content {
	padding: 20px;
	font-size: 16px;
	border-radius: 5px;
	border: none;
}
.modal-confirm .modal-header {
	background: #47c9a2;
	border-bottom: none;   
	position: relative;
	text-align: center;
	margin: -20px -20px 0;
	border-radius: 5px 5px 0 0;
	padding: 35px;
}
.modal-confirm h4 {
	text-align: center;
	font-size: 36px;
	margin: 10px 0;
}
.modal-confirm .form-control, .modal-confirm .btn {
	min-height: 40px;
	border-radius: 3px; 
}
.modal-confirm .close {
	position: absolute;
	top: 15px;
	right: 15px;
	color: #fff;
	text-shadow: none;
	opacity: 0.5;
}
.modal-confirm .close:hover {
	opacity: 0.8;
}
.modal-confirm .icon-box {
	color: #fff;		
	width: 95px;
	height: 95px;
	display: inline-block;
	border-radius: 50%;
	z-index: 9;
	border: 5px solid #fff;
	padding: 15px;
	text-align: center;
}
.modal-confirm .icon-box i {
	font-size: 64px;
	margin: -4px 0 0 -4px;
}
.modal-confirm.modal-dialog {
	margin-top: 80px;
}
.modal-confirm .btn, .modal-confirm .btn:active {
	color: #fff;
	border-radius: 4px;
	background: #eeb711 !important;
	text-decoration: none;
	transition: all 0.4s;
	line-height: normal;
	border-radius: 30px;
	margin-top: 10px;
	padding: 6px 20px;
	border: none;
}
.modal-confirm .btn:hover, .modal-confirm .btn:focus {
	background: #eda645 !important;
	outline: none;
}
.modal-confirm .btn span {
	margin: 1px 3px 0;
	float: left;
}
.modal-confirm .btn i {
	margin-left: 1px;
	font-size: 20px;
	float: right;
}



.modal-warning {		
	color: #434e65;
}
.modal-warning p {
	font-size: 0.85rem;
}
.modal-warning .modal-content {
	padding: 20px;
	font-size: 16px;
	border-radius: 5px;
	border: none;
}
.modal-warning .modal-header {
	background: orange;
	border-bottom: none;   
	position: relative;
	text-align: center;
	margin: -20px -20px 0;
	border-radius: 5px 5px 0 0;
	padding: 35px;
}
.modal-warning h4 {
	text-align: center;
	font-size: 1.5rem;
	margin: 10px 0;
}
.modal-warning .form-control, .modal-warning .btn {
	min-height: 40px;
	border-radius: 3px; 
}
.modal-warning .close {
	position: absolute;
	top: 15px;
	right: 15px;
	color: #fff;
	text-shadow: none;
	opacity: 0.5;
}
.modal-warning .list-group .list-group-item{
	border: none;
	font-size: 0.8rem;
	padding-bottom: 0rem;
}
.modal-warning a{
	color: #007bff!important;
	font-size: 0.8rem;
}
.modal-warning .close:hover {
	opacity: 0.8;
}
.modal-warning .icon-box {
	color: #fff;		
	width: 95px;
	height: 95px;
	display: inline-block;
	border-radius: 50%;
	z-index: 9;
	/* border: 5px solid #fff; */
	padding: 15px;
	text-align: center;
}
.modal-warning .icon-box i {
	font-size: 64px;
	margin: -4px 0 0 -4px;
}
.modal-warning.modal-dialog {
	margin-top: 80px;
}
.modal-warning .btn, .modal-warning .btn:active {
	color: #fff;
	border-radius: 4px;
	background: #eeb711 !important;
	text-decoration: none;
	transition: all 0.4s;
	line-height: normal;
	border-radius: 30px;
	margin-top: 10px;
	padding: 6px 20px;
	border: none;
}
.modal-warning .btn:hover, .modal-warning .btn:focus {
	background: #eda645 !important;
	outline: none;
}
.modal-warning .btn span {
	margin: 1px 3px 0;
	float: left;
}
.modal-warning .btn i {
	margin-left: 1px;
	font-size: 20px;
	float: right;
}
.text-custom-title{
	font-size: 1rem;
}
@media (max-width: 768px) {
	.g-recaptcha{
		transform:scale(0.77);
		-webkit-transform:scale(0.77);
		transform-origin:0 0;
		-webkit-transform-origin:0 0;
		}
}
@media (max-width: 991px){
	.desktop-responsive{
		display: none!important;
	}
	.mobile-responsive{
		display: block!important;
	}
}
.desktop-responsive{
	display: block;
}
.mobile-responsive{
	display: none;
}
.horizontal-flow{
	max-width: 80%;
}
.vertical-flow{
	max-width: 80%;
}
@media (max-width: 1024px){
	.horizontal-flow{
		max-width: 100%!important;
	}
}
@media (max-width: 767px){
	.vertical-flow{
		max-width: 100%!important;
	}
}


.tableImg{
	display:none!important;
}
@media (max-width: 280px) {
	.g-recaptcha{
		transform:scale(0.66);
		-webkit-transform:scale(0.66);
		transform-origin:0 0;
		-webkit-transform-origin:0 0;
		}

}

a.request-printing.is-loading::before {
	content: '';
	position: absolute;
	display: block;
	background-size: 100%;
	height: 25px;
	width: 25px;
	background-image: url(https://drawsth3d.com/img/page-loader.svg);
	opacity: .7;
}

a.welcome-btn {
  font-family: "微軟正黑體", "Microsoft JhengHei","Montserrat", sans-serif;
  font-weight: 500;
  font-size: 16px;
  letter-spacing: 1px;
  display: inline-block;
  padding: 10px 30px;
  border-radius: 50px;
  transition: 0.3s;
  color: #fff;
  background: #1acc8d;
}
a.welcome-btn:hover {
  background: #17b57d;
}
.pricing-desc a.welcome-btn{
  font-size: 0.7rem!important;
}


/* mobile.php loading 3d model */
#loading_3d {
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: hsla(0, 0%, 35%, 0.8); /* 黑色 80% 不透明度 */
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 9999;
}


.loader {
  width: 60px;
  height: 60px;
  border: 5px solid rgba(255, 255, 255, 0.3);
  border-radius: 50%;
  border-top-color: #fff;
  animation: spin 1s ease-in-out infinite;
}

@keyframes spin {
  to { transform: rotate(360deg); }
}