	/* ======= basics ============= */
	/* #upload * { margin: 0; padding: 0; } same as Price calc */
	#upload {
		width: 100%;
	}
	#upload form { background: url(../images/upload/back.gif) repeat-y right top; width: 550px; }
	#upload table {padding: 10px; }
	#upload h1 {
		display: block;
		height: 52px;
		background: url(../images/upload/top.gif) no-repeat center top; }
	.upload-divider{clear:both;}

	#upload h2 {
		display: block;
		height: 18px;
		margin: 0;
		padding: 0; }
	#upload h2.standard {
		width: 184px;
		background: url(../images/upload/standard.gif) no-repeat left top; } /* same as Price calc */
	#upload h2.shipping {
		width: 174px;
		background: url(../images/upload/shipping.gif) no-repeat left top; }
	#upload h2.more {
		width: 159px;
		background: url(../images/upload/more_op.gif) no-repeat left top; }
	#upload h2.sum {
		width: 171px;
		background: url(../images/upload/summary.gif) no-repeat left top; }
	#upload a { color: #6b2213; outline: none; text-decoration: none; }

	/* ======= enclosing divs ========= */
	#upload #stand { width: 340px; padding: 0 15px 10px 15px; } /* same as Price calc */
	#upload #ship, #upload #more, #upload #summary { width: 340px; padding: 10px 15px 15px 15px; }
	#upload #total { display: block; padding: 0 20px; }
	#upload #check { padding: 40px 20px 30px 195px;  }
	#upload .split {
		width: 338px;
		margin: 0 auto;
		background: #a1a1a1;
		height: 18px; } /* same as Price calc */
	#upload .split .fold {
		display: block;
		height: 11px;
		background: url(../images/upload/minus.gif) no-repeat 5px 1px;

		/* uncomment below for collapsed image */
		/*height: 17px;
		 background: url(../images/upload/plus.gif) no-repeat 5px 1px; */
		 } /* same as Price calc */


	/* ======== form menus ========= */
	#upload ul {list-style: none; margin-left: 10px;}
	#upload ul.left { list-style: none; display: block; width: 50%;} /* same as Price calc */
	#upload ul.right { list-style: none; display: block; width: 50%; float: right; } /* same as Price calc */
	#upload ul li { display: block; margin: 5px 0;} /* same as Price calc */
	#upload legend { display: block; width: 150px; margin: 2px 0; } /* same as Price calc */
	#upload select {
		display: block;
		width: 150px;
		margin: 2px 0;
		border: 1px #aaa solid;
		background: #fff; } /* same as Price calc */
	#upload li.rad { padding: 3px 0 0 20px; }
	#upload li.rad label { position: relative; top: -3px; }
	#upload li p { line-height: 150%; padding: 2px 0 0 0;}
	#upload ul.rightside { text-align: right;  margin: 0 60px 0 0;}


	/* =========== Buttons =========== */
	#upload .btnholder { margin: 0 0 30px 0; text-align: right; }
	#upload a#uploadnew { display: block; float: right; width: 47px; height: 21px; background: url(../images/upload/btn_new.gif) no-repeat 0 0; }
	#upload a#uploadedit { display: block; float: right; width: 47px; height: 21px; background: url(../images/upload/btn_edit.gif) no-repeat 0 0; margin: 0 20px 0 0; }
	#upload a#checkout { display: block; width: 137px; height: 31px; text-align: right; background: url(../images/upload/btn_checkout.gif) no-repeat 0 0; }

	/* ========= Total fields ========= */
	#upload #total #tot {  position: relative; left: 125px; top: 15px; display: block; width: 61px; height: 16px; background: url(../images/upload/total.gif) no-repeat right bottom; } /* same as Price calc */
	#upload #total input { float: right; font-size: 16px; border: 1px #aaa solid; font-weight: bold; width: 100px; padding: 3px; position: relative; top: -8px;} /* same as Price calc */

	/* ===== hide this stuff (it's visible without stylesheet) ===== */
	#upload h1 span, #upload h2 span, #upload .split span, #upload #total #tot span, #upload #uploadnew span, #upload #uploadedit span, #upload #check span { display: none; }

	/* ==== IE6 stuff == */
	* html #upload h1 { position: relative; left: 1px; }
	* html #upload ul.left,
	* html #upload ul.right { width: 49%; }
	* html #upload #stand { position: relative; left: 12px; padding: 0 0 10px 0; }
	* html #upload #more { position: relative; left: 12px; padding: 10px 0; }
	* html #upload #ship { position: relative; left: 12px; padding: 10px 0; }
	* html #upload #summary { position: relative; left: 12px; padding: 10px 0; }
	* html #upload #total { position: relative; left: 12px; padding: 0;  }
	* html #upload #total #tot {  position: relative; left: 125px; top: 15px; }
	* html #upload #total input { position: relative; right: 40px; top: -8px; }


#uploadOption0 li {
	background:url(../images/nav-arrow.jpg) no-repeat center left;
	list-style:none;
	padding-left:10px;
}

/* ===== Modern upload refresh ===== */
#content_area {
    background: #f6f8fb;
}

.upload-shell {
    border: none;
    padding: 10px 14px;
    margin: 0;
}

#content_area .upload-breadcrumb {
    display: flex !important;
    align-items: center;
    gap: 6px;
    padding: 8px 0 10px;
    margin-bottom: 6px;
    background: transparent;
    border: 0;
}

#content_area .upload-breadcrumb li {
    font-weight: 600;
    color: #1f2a44;
}

#content_area .upload-breadcrumb li a {
    color: #1f3d71;
}

#content_area .upload-breadcrumb > li + li:before {
    color: #9aa5b1;
}

#upload h1 {
    background: none !important;
    height: auto;
    padding: 0;
    margin: 0;
    color: #0f172a;
    font-size: 26px;
    font-weight: 700;
}

#upload.upload-layout {
    display: grid;
    grid-template-columns: 1.65fr 1fr;
    gap: 20px;
    margin-top: 6px;
}

#upload .upload-left,
#upload .upload-right {
    float: none;
    width: auto;
}

.upload-top-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 4px;
    margin-bottom: 12px;
    flex-wrap: wrap;
    gap: 12px;
}

.upload-chip {
    display: inline-flex;
    align-items: center;
    padding: 6px 14px;
    border-radius: 999px;
    font-weight: 700;
    font-size: 13px;
    letter-spacing: .01em;
    border: 1px solid #cbd5e1;
    background: #fff;
    color: #334155;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
}

.upload-chip--soft {
    background: #f8fafc;
    border-color: #e2e8f0;
    color: #64748b;
}

.upload-chip--warning {
    background: #fffbeb;
    border-color: #fde68a;
    color: #92400e;
}

.upload-chip--success {
    background: #f0fdf4;
    border-color: #bbf7d0;
    color: #166534;
}

#upload .upload-card {
    background: #fff;
    border: 1px solid #e7ebf3;
    border-radius: 16px;
    box-shadow: 0 10px 28px rgba(15, 23, 42, 0.08);
    padding: 18px 20px;
    height: 100%;
}

#upload .upload-card--form {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

#upload .upload-card--specs {
    background: linear-gradient(180deg, #ffffff, #f8fafc);
    border-color: #e0e7ff;
}

#upload .upload-card__title {
    margin: 0 0 10px 0;
    font-size: 16px;
    color: #0f172a;
}

#upload .upload-job-heading {
    margin-bottom: 6px;
}

#upload .upload-job-title {
    font-weight: 700;
    color: #0f172a;
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 16px;
}

#upload .upload-job-subtitle {
    margin: 4px 0 0 0;
    color: #4b5563;
    font-size: 13px;
}

#upload .upload-alert {
    margin: 10px 0;
    border-radius: 10px;
    box-shadow: 0 6px 20px rgba(220, 38, 38, 0.16);
}

#upload .upload-form {
    background: transparent;
    width: 100%;
}

#upload .upload-file-grid {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-top: 6px;
}

#upload .upload-file-card {
    border: 1px dashed #cbd5e1;
    border-radius: 12px;
    padding: 12px 14px;
    background: #f8fafc;
    transition: border-color .2s ease, box-shadow .2s ease;
}

#upload .upload-file-card:hover {
    border-color: #1f87ff;
    box-shadow: 0 6px 24px rgba(31, 135, 255, 0.14);
}

#upload .upload-file-card__title {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    flex-wrap: wrap;
}

#upload .upload-file-label {
    font-weight: 700;
    color: #0f172a;
}

#upload .upload-file-meta {
    color: #6b7280;
    font-size: 12px;
}

#upload .file-upload {
    width: 100%;
    margin-top: 8px;
    padding: 10px;
    border: 1px solid #cbd5e1;
    border-radius: 12px;
    background: #fff;
    color: #111827;
}

#upload .file-upload:focus {
    outline: none;
    border-color: #1f87ff;
    box-shadow: 0 0 0 3px rgba(31, 135, 255, 0.15);
}

#upload .file-upload::file-selector-button,
#upload .file-upload::-webkit-file-upload-button {
    background: linear-gradient(135deg, #1f87ff, #0f65d2);
    border: none;
    color: #fff;
    padding: 10px 14px;
    margin-right: 12px;
    border-radius: 10px;
    font-weight: 700;
    cursor: pointer;
}

#upload .file-upload::-webkit-file-upload-button {
    -webkit-appearance: none;
}

#upload .upload-progress {
    margin-top: 10px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

#upload #progress_container {
    border: 1px solid #d1d5db !important;
    background: #eef2ff !important;
    border-radius: 12px !important;
    max-width: none !important;
    height: 18px !important;
    overflow: hidden;
}

#upload #progress_bar {
    background: linear-gradient(90deg, #16a34a, #22c55e) !important;
    font-weight: 700;
    font-size: 12px !important;
    line-height: 18px !important;
}

#upload .upload-actions {
    margin-top: 12px;
    display: flex;
    justify-content: flex-end;
}

#upload .upload-actions .btn-success {
    padding: 10px 18px;
    border-radius: 10px;
    font-weight: 700;
    box-shadow: 0 10px 18px rgba(52, 211, 153, 0.3);
}

#upload .upload-terms-section {
    margin-top: 20px;
}

#upload .click-terms p {
    margin-bottom: 8px;
    color: #4b5563;
}

#upload .click-terms a {
    color: #1f87ff;
    font-weight: 600;
    text-decoration: underline;
}

#upload .accept-terms {
    display: flex;
    align-items: flex-start;
    gap: 8px;
}

#upload .accept-terms input[type="checkbox"] {
    margin-top: 4px;
}

#upload .upload-spec-list {
    margin: 0;
    padding-left: 18px;
    display: grid;
    gap: 8px;
    color: #1f2937;
}

#upload .upload-thumbs {
    grid-column: 1 / -1;
    margin-top: 8px;
    min-height: 10px;
}

#upload .upload-result {
    grid-column: 1 / -1;
    margin-top: 14px;
}

@media (max-width: 1100px) {
    #upload.upload-layout {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 640px) {
    #upload .upload-card {
        padding: 16px;
    }

    #upload .upload-card__title {
        font-size: 15px;
    }
}

