body {
	font-family: 'Open Sans', sans-serif;
	font-weight: 400;
	color: #666;
	font-size: 12px;
	line-height: 20px;
	width: 100%;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	color: #444;
}

/* default font size */
.fa {
	font-size: 14px;
}

/* Override the bootstrap defaults */
h1 {
	font-size: 33px;
}

h2 {
	font-size: 27px;
}

h3 {
	font-size: 21px;
}

h4 {
	font-size: 15px;
}

h5 {
	font-size: 12px;
}

h6 {
	font-size: 10.2px;
}

a {
	color: #23a1d1;
}

a:hover {
	text-decoration: none;
}

legend {
	font-size: 18px;
	padding: 7px 0px
}

label {
	font-size: 12px;
	font-weight: normal;
}

select.form-control,
textarea.form-control,
input[type="text"].form-control,
input[type="password"].form-control,
input[type="datetime"].form-control,
input[type="datetime-local"].form-control,
input[type="date"].form-control,
input[type="month"].form-control,
input[type="time"].form-control,
input[type="week"].form-control,
input[type="number"].form-control,
input[type="email"].form-control,
input[type="url"].form-control,
input[type="search"].form-control,
input[type="tel"].form-control,
input[type="color"].form-control {
	font-size: 12px;
}

.input-group input,
.input-group select,
.input-group .dropdown-menu,
.input-group .popover {
	font-size: 12px;
}

.input-group .input-group-addon {
	font-size: 12px;
	height: 30px;
}

/* Fix some bootstrap issues */
span.hidden-xs,
span.hidden-sm,
span.hidden-md,
span.hidden-lg {
	display: inline;
}

.nav-tabs {
	margin-bottom: 15px;
}

div.required .control-label:before {
	content: '* ';
	color: #F00;
	font-weight: bold;
}

/* Gradent to all drop down menus */
.dropdown-menu li>a:hover {
	text-decoration: none;
	color: #ffffff;
	background-color: #229ac8;
	background-image: linear-gradient(to bottom, #23a1d1, #1f90bb);
	background-repeat: repeat-x;
}

/* top */
#top {
	background-color: #EEEEEE;
	border-bottom: 1px solid #e2e2e2;
	padding: 4px 0px 3px 0;
	margin: 0 0 20px 0;
	min-height: 40px;
}

#top .container {
	padding: 0 20px;
}

#top #form-currency .currency-select,
#top #form-language .language-select {
	text-align: left;
}

#top #form-currency .currency-select:hover,
#top #form-language .language-select:hover {
	text-shadow: none;
	color: #ffffff;
	background-color: #229ac8;
	background-image: linear-gradient(to bottom, #23a1d1, #1f90bb);
	background-repeat: repeat-x;
}

#top .btn-link,
#top-links li,
#top-links a {
	color: #888;
	text-shadow: 0 1px 0 #FFF;
	text-decoration: none;
}

#top .btn-link:hover,
#top-links a:hover {
	color: #444;
}

#top-links .dropdown-menu a {
	text-shadow: none;
}

#top-links .dropdown-menu a:hover {
	color: #FFF;
}

#top .btn-link strong {
	font-size: 14px;
	line-height: 14px;
}

#top-links {
	padding-top: 6px;
}

#top-links a+a {
	margin-left: 15px;
}

/* logo */
#logo {
	margin: 0 0 10px 0;
}

/* search */
#search {
	margin-bottom: 0px;
}

#search .input-lg {
	height: 20px;
	line-height: 20px;
	padding: 0 10px;
}

#search .btn-lg {
	font-size: 15px;
	line-height: 18px;
	padding: 10px 35px;
	text-shadow: 0 1px 0 #FFF;
}

/* cart */
#cart {
	margin-bottom: 10px;
}

#cart>.btn {
	font-size: 12px;
	line-height: 18px;
	color: #FFF;
}

#cart.open>.btn {
	background-image: none;
	background-color: #FFFFFF;
	border: 1px solid #E6E6E6;
	color: #666;
	box-shadow: none;
	text-shadow: none;
}

#cart.open>.btn:hover {
	color: #444;
}

#cart .dropdown-menu {
	background: #eee;
	z-index: 1001;
}

#cart .dropdown-menu {
	min-width: 100%;
	overflow-y: auto;
	max-height: 800px;
	scrollbar-width: thin;
	overflow-x: hidden;
}

@media (max-width: 478px) {
	#cart .dropdown-menu {
		width: 100%;
	}
}

#cart .dropdown-menu table {
	margin-bottom: 10px;
}

#cart .dropdown-menu li>div {
	min-width: 290px;
	padding: 0 10px;
}

@media (max-width: 478px) {
	#cart .dropdown-menu li>div {
		min-width: 100%;
	}
}

#cart .dropdown-menu li p {
	margin: 20px 0;
}

/* menu */
#menu {
	background-color: #229ac8;
	background-image: linear-gradient(to bottom, #23a1d1, #1f90bb);
	background-repeat: repeat-x;
	border-color: #1f90bb #1f90bb #145e7a;
	min-height: 40px;
}

#menu .nav>li>a {
	color: #fff;
	text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.25);
	padding: 10px 15px 10px 15px;
	min-height: 15px;
	background-color: transparent;
}

#menu .nav>li>a:hover,
#menu .nav>li.open>a {
	background-color: rgba(0, 0, 0, 0.1);
}

#menu .dropdown-menu {
	padding-bottom: 0;
}

#menu .dropdown-inner {
	display: table;
}

#menu .dropdown-inner ul {
	display: table-cell;
}

#menu .dropdown-inner a {
	min-width: 160px;
	display: block;
	padding: 3px 20px;
	clear: both;
	line-height: 20px;
	color: #333333;
	font-size: 12px;
}

#menu .dropdown-inner li a:hover {
	color: #FFFFFF;
}

#menu .see-all {
	display: block;
	margin-top: 0.5em;
	border-top: 1px solid #DDD;
	padding: 3px 20px;
	-webkit-border-radius: 0 0 4px 4px;
	-moz-border-radius: 0 0 4px 4px;
	border-radius: 0 0 3px 3px;
	font-size: 12px;
}

#menu .see-all:hover,
#menu .see-all:focus {
	text-decoration: none;
	color: #ffffff;
	background-color: #229ac8;
	background-image: linear-gradient(to bottom, #23a1d1, #1f90bb);
	background-repeat: repeat-x;
}

#menu #category {
	float: left;
	padding-left: 15px;
	font-size: 16px;
	font-weight: 700;
	line-height: 40px;
	color: #fff;
	text-shadow: 0 1px 0 rgba(0, 0, 0, 0.2);
}

#menu .btn-navbar {
	font-size: 15px;
	font-stretch: expanded;
	color: #FFF;
	padding: 2px 18px;
	float: right;
	background-color: #229ac8;
	background-image: linear-gradient(to bottom, #23a1d1, #1f90bb);
	background-repeat: repeat-x;
	border-color: #1f90bb #1f90bb #145e7a;
}

#menu .btn-navbar:hover,
#menu .btn-navbar:focus,
#menu .btn-navbar:active,
#menu .btn-navbar.disabled,
#menu .btn-navbar[disabled] {
	color: #ffffff;
	background-color: #229ac8;
}

@media (min-width: 768px) {
	#menu .dropdown:hover .dropdown-menu {
		display: block;
	}
}

@media (max-width: 767px) {
	#menu {
		border-radius: 4px;
	}

	#menu div.dropdown-inner>ul.list-unstyled {
		display: block;
	}

	#menu div.dropdown-menu {
		margin-left: 0 !important;
		padding-bottom: 10px;
		background-color: rgba(0, 0, 0, 0.1);
	}

	#menu .dropdown-inner {
		display: block;
	}

	#menu .dropdown-inner a {
		width: 100%;
		color: #fff;
	}

	#menu .dropdown-menu a:hover,
	#menu .dropdown-menu ul li a:hover {
		background: rgba(0, 0, 0, 0.1);
	}

	#menu .see-all {
		margin-top: 0;
		border: none;
		border-radius: 0;
		color: #fff;
	}
}

/* content */
#content {
	min-height: 600px;
}

/* footer */
footer {
	margin-top: 30px;
	padding-top: 30px;
	background-color: #303030;
	border-top: 1px solid #ddd;
	color: #e2e2e2;
}

footer hr {
	border-top: none;
	border-bottom: 1px solid #666;
}

footer a {
	color: #ccc;
}

footer a:hover {
	color: #fff;
}

footer h5 {
	font-family: 'Open Sans', sans-serif;
	font-size: 13px;
	font-weight: bold;
	color: #fff;
}

/* alert */
.alert {
	padding: 8px 14px 8px 14px;
}

/* breadcrumb */
.breadcrumb {
	margin: 0 0 20px 0;
	padding: 8px 0;
	border: 1px solid #ddd;
}

.breadcrumb i {
	font-size: 15px;
}

.breadcrumb>li {
	text-shadow: 0 1px 0 #FFF;
	padding: 0 20px;
	position: relative;
	white-space: nowrap;
}

.breadcrumb>li+li:before {
	content: '';
	padding: 0;
}

.breadcrumb>li:after {
	content: '';
	display: block;
	position: absolute;
	top: -3px;
	right: -5px;
	width: 26px;
	height: 26px;
	border-right: 1px solid #DDD;
	border-bottom: 1px solid #DDD;
	-webkit-transform: rotate(-45deg);
	-moz-transform: rotate(-45deg);
	-o-transform: rotate(-45deg);
	transform: rotate(-45deg);
}

html[dir=rtl] .breadcrumb>li::after {
	top: -3px;
	left: -5px;
	width: 26px;
	height: 26px;
	border-left: 1px solid #DDD;
	border-top: 1px solid #DDD;
	right: unset;
	border-right: unset;
	border-bottom: unset;

}

.pagination {
	margin: 0;
}

/* buttons */
.buttons {
	margin: 1em 0;
}

.btn {
	padding: 7.5px 12px;
	font-size: 12px;
	border: 1px solid #cccccc;
	border-radius: 4px;
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, .2), 0 1px 2px rgba(0, 0, 0, .05);
}

.btn-xs {
	font-size: 9px;
}

.btn-sm {
	font-size: 10.2px;
}

.btn-lg {
	padding: 10px 16px;
	font-size: 15px;
}

.btn-group>.btn,
.btn-group>.dropdown-menu,
.btn-group>.popover {
	font-size: 12px;
}

.btn-group>.btn-xs {
	font-size: 9px;
}

.btn-group>.btn-sm {
	font-size: 10.2px;
}

.btn-group>.btn-lg {
	font-size: 15px;
}

.btn-default {
	color: #777;
	text-shadow: 0 1px 0 rgba(255, 255, 255, 0.5);
	background-color: #e7e7e7;
	background-image: linear-gradient(to bottom, #eeeeee, #dddddd);
	background-repeat: repeat-x;
	border-color: #dddddd #dddddd #b3b3b3 #b7b7b7;
}

.btn-primary {
	color: #ffffff;
	text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.25);
	background-color: #229ac8;
	background-image: linear-gradient(to bottom, #23a1d1, #1f90bb);
	background-repeat: repeat-x;
	border-color: #1f90bb #1f90bb #145e7a;
}

.btn-primary:hover,
.btn-primary:active,
.btn-primary.active,
.btn-primary.disabled,
.btn-primary[disabled] {
	background-color: #1f90bb;
	background-position: 0 -15px;
}

.btn-warning {
	color: #ffffff;
	text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.25);
	background-color: #faa732;
	background-image: linear-gradient(to bottom, #fbb450, #f89406);
	background-repeat: repeat-x;
	border-color: #f89406 #f89406 #ad6704;
}

.btn-warning:hover,
.btn-warning:active,
.btn-warning.active,
.btn-warning.disabled,
.btn-warning[disabled] {
	box-shadow: inset 0 1000px 0 rgba(0, 0, 0, 0.1);
}

.btn-danger {
	color: #ffffff;
	text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.25);
	background-color: #da4f49;
	background-image: linear-gradient(to bottom, #ee5f5b, #bd362f);
	background-repeat: repeat-x;
	border-color: #bd362f #bd362f #802420;
}

.btn-danger:hover,
.btn-danger:active,
.btn-danger.active,
.btn-danger.disabled,
.btn-danger[disabled] {
	box-shadow: inset 0 1000px 0 rgba(0, 0, 0, 0.1);
}

.btn-success {
	color: #ffffff;
	text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.25);
	background-color: #5bb75b;
	background-image: linear-gradient(to bottom, #62c462, #51a351);
	background-repeat: repeat-x;
	border-color: #51a351 #51a351 #387038;
}

.btn-success:hover,
.btn-success:active,
.btn-success.active,
.btn-success.disabled,
.btn-success[disabled] {
	box-shadow: inset 0 1000px 0 rgba(0, 0, 0, 0.1);
}

.btn-info {
	color: #ffffff;
	text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.25);
	background-color: #df5c39;
	background-image: linear-gradient(to bottom, #e06342, #dc512c);
	background-repeat: repeat-x;
	border-color: #dc512c #dc512c #a2371a;
}

.btn-info:hover,
.btn-info:active,
.btn-info.active,
.btn-info.disabled,
.btn-info[disabled] {
	background-image: none;
	background-color: #df5c39;
}

.btn-link {
	border-color: rgba(0, 0, 0, 0);
	cursor: pointer;
	color: #23A1D1;
	border-radius: 0;
}

.btn-link,
.btn-link:active,
.btn-link[disabled] {
	background-color: rgba(0, 0, 0, 0);
	background-image: none;
	box-shadow: none;
}

.btn-inverse {
	color: #ffffff;
	text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.25);
	background-color: #363636;
	background-image: linear-gradient(to bottom, #444444, #222222);
	background-repeat: repeat-x;
	border-color: #222222 #222222 #000000;
}

.btn-inverse:hover,
.btn-inverse:active,
.btn-inverse.active,
.btn-inverse.disabled,
.btn-inverse[disabled] {
	background-color: #222222;
	background-image: linear-gradient(to bottom, #333333, #111111);
}

/* list group */
.list-group a {
	border: 1px solid #DDDDDD;
	color: #888888;
	padding: 8px 12px;
}

.list-group a.active,
.list-group a.active:hover,
.list-group a:hover {
	color: #444444;
	background: #eeeeee;
	border: 1px solid #DDDDDD;
	text-shadow: 0 1px 0 #FFF;
}

/* carousel */
.carousel-caption {
	color: #FFFFFF;
	text-shadow: 0 1px 0 #000000;
}

.carousel-control .icon-prev:before {
	content: '\f053';
	font-family: FontAwesome;
}

.carousel-control .icon-next:before {
	content: '\f054';
	font-family: FontAwesome;
}

/* product list */
.product-thumb {
	border: 1px solid #ddd;
	margin-bottom: 20px;
	overflow: auto;
}

.product-thumb .image {
	text-align: center;
}

.product-thumb .image a {
	display: block;
}

.product-thumb .image a:hover {
	opacity: 0.8;
}

.product-thumb .image img {
	margin-left: auto;
	margin-right: auto;
}

.product-grid .product-thumb .image {
	float: none;
}

@media (min-width: 767px) {
	.product-list .product-thumb .image {
		float: left;
		padding: 0 15px;
	}
}

.product-thumb h4 {
	font-weight: bold;
}

.product-thumb .caption {
	padding: 0 20px;
	min-height: 180px;
}

.product-list .product-thumb .caption {
	margin-left: 230px;
}

@media (max-width: 1200px) {
	.product-grid .product-thumb .caption {
		min-height: 210px;
		padding: 0 10px;
	}
}

@media (max-width: 767px) {
	.product-list .product-thumb .caption {
		min-height: 0;
		margin-left: 0;
		padding: 0 10px;
	}

	.product-grid .product-thumb .caption {
		min-height: 0;
	}
}

.product-thumb .rating {
	padding-bottom: 10px;
}

.rating .fa-stack {
	font-size: 8px;
}

.rating .fa-star-o {
	color: #999;
	font-size: 15px;
}

.rating .fa-star {
	color: #FC0;
	font-size: 15px;
}

.rating .fa-star+.fa-star-o {
	color: #E69500;
}

h2.price {
	margin: 0;
}

.product-thumb .price {
	color: #444;
}

.product-thumb .price-new {
	font-weight: 600;
}

.product-thumb .price-old {
	color: #999;
	text-decoration: line-through;
	margin-left: 10px;
}

.product-thumb .price-tax {
	color: #999;
	font-size: 12px;
	display: block;
}

.product-thumb .button-group {
	border-top: 1px solid #ddd;
	background-color: #eee;
	overflow: auto;
}

.product-list .product-thumb .button-group {
	border-left: 1px solid #ddd;
}

@media (max-width: 768px) {
	.product-list .product-thumb .button-group {
		border-left: none;
	}
}

.product-thumb .button-group button {
	width: 100%;
	border: none;
	display: inline-block;
	float: left;
	background-color: #eee;
	color: #888;
	line-height: 38px;
	font-weight: bold;
	text-align: center;
	text-transform: uppercase;
}

.product-thumb .button-group button+button {
	width: 20%;
	border-left: 1px solid #ddd;
}

.product-thumb .button-group button:hover {
	color: #444;
	background-color: #ddd;
	text-decoration: none;
	cursor: pointer;
}

@media (max-width: 1200px) {

	.product-thumb .button-group button,
	.product-thumb .button-group button+button {
		width: 33.33%;
	}
}

@media (max-width: 767px) {

	.product-thumb .button-group button,
	.product-thumb .button-group button+button {
		width: 33.33%;
	}
}

.thumbnails {
	overflow: auto;
	clear: both;
	list-style: none;
	padding: 0;
	margin: 0;
}

.thumbnails>li {
	margin-left: 20px;
}

.thumbnails {
	margin-left: -20px;
}

.thumbnails>img {
	width: 100%;
}

.image-additional a {
	margin-bottom: 20px;
	padding: 5px;
	display: block;
	border: 1px solid #ddd;
}

.image-additional {
	max-width: 78px;
}

.thumbnails .image-additional {
	float: left;
	margin-left: 20px;
}

@media (min-width: 1200px) {

	#content .col-lg-2:nth-child(6n+1),
	#content .col-lg-3:nth-child(4n+1),
	#content .col-lg-4:nth-child(3n+1),
	#content .col-lg-6:nth-child(2n+1) {
		clear: left;
	}
}

@media (min-width: 992px) and (max-width: 1199px) {

	#content .col-md-2:nth-child(6n+1),
	#content .col-md-3:nth-child(4n+1),
	#content .col-md-4:nth-child(3n+1),
	#content .col-md-6:nth-child(2n+1) {
		clear: left;
	}
}

@media (min-width: 768px) and (max-width: 991px) {

	#content .col-sm-2:nth-child(6n+1),
	#content .col-sm-3:nth-child(4n+1),
	#content .col-sm-4:nth-child(3n+1),
	#content .col-sm-6:nth-child(2n+1) {
		clear: left;
	}
}

/* fixed colum left + content + right*/
@media (min-width: 768px) {
	#column-left .product-layout .col-md-3 {
		width: 100%;
	}

	#column-left+#content .product-layout .col-md-3 {
		width: 50%;
	}

	#column-left+#content+#column-right .product-layout .col-md-3 {
		width: 100%;
	}

	#content+#column-right .product-layout .col-md-3 {
		width: 100%;
	}
}

/* fixed product layouts used in left and right columns */
#column-left .product-layout,
#column-right .product-layout {
	width: 100%;
}

/* fixed mobile cart quantity input */
.input-group .form-control[name^=quantity] {
	min-width: 50px;
}

/* Missing focus and border color to overwrite bootstrap */
.btn-info:hover,
.btn-info:active,
.btn-info.active,
.btn-info.disabled,
.btn-info[disabled] {
	background-image: none;
	background-color: #df5c39;
}

html[dir=rtl] .checkbox input[type="checkbox"],
html[dir=rtl] .checkbox-inline input[type="checkbox"],
html[dir=rtl] .radio input[type="radio"],
html[dir=rtl] .radio-inline input[type="radio"] {
	position: absolute;
	margin-top: 4px\9;
	margin-right: -20px;
	margin-left: unset;
}

html[dir=rtl] .input-group-btn:last-child>.btn {
	border-top-right-radius: 0;
	border-bottom-right-radius: 0;
	border-top-left-radius: 5px;
	border-bottom-left-radius: 5px;
}

html[dir=rtl] .input-group .form-control:first-child {
	border-top-right-radius: 5px;
	border-bottom-right-radius: 5px;
	border-top-left-radius: unset;
	border-bottom-left-radius: unset;
}

html[dir=rtl] .container .row:first-child .col-sm-4,
html[dir=rtl] .container .row:first-child .col-sm-5 {
	float: right;

}

html[dir=rtl] #cart .dropdown-menu {
	left: 0;
	right: auto;

}

@media (min-width: 768px) {

	html[dir=rtl] .navbar-nav {
		float: right;
		margin: 0;
	}

	html[dir=rtl] .navbar-nav>li {
		float: right;
	}

}

/* === Modern Theme Overrides (OC 3.0.3.x) === */
:root {
	--oc-bg: #f8fafc;
	--oc-surface: #ffffff;
	--oc-text: #111827;
	--oc-muted: #6b7280;
	--oc-border: rgba(17, 24, 39, 0.12);

	--oc-primary: #2563eb;
	--oc-primary-hover: #1d4ed8;
	--oc-success: #16a34a;
	--oc-danger: #dc2626;
	--oc-warning: #f59e0b;

	--oc-radius: 12px;
	--oc-radius-sm: 10px;
	--oc-shadow-sm: 0 6px 18px rgba(17, 24, 39, 0.08);
	--oc-shadow-md: 0 14px 38px rgba(17, 24, 39, 0.12);
}

body.oc-modern {
	font-family: "Open Sans", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
	font-size: 14px;
	line-height: 1.15;
	color: var(--oc-text);
	background: var(--oc-bg);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

body.oc-modern a {
	color: var(--oc-primary);
}

body.oc-modern a:hover,
body.oc-modern a:focus {
	color: var(--oc-primary-hover);
}

/* General surfaces */
body.oc-modern .container,
body.oc-modern #content {
	position: relative;
}

/* Top bar + header */
body.oc-modern #top {
	background: var(--oc-surface);
	border-bottom: 1px solid var(--oc-border);
	margin: 0;
}

body.oc-modern header {
	background: var(--oc-surface);
	border-bottom: 1px solid var(--oc-border);
	padding: 16px 0 16px 0;
	margin-bottom: 14px;
}

body.oc-modern #logo img {
	max-height: 52px;
	width: auto;
}

/* Search */
body.oc-modern #search .form-control.input-lg {
	height: 44px;
	border-radius: var(--oc-radius);
	border: 1px solid var(--oc-border);
	box-shadow: none;
	background: #fff;
}

body.oc-modern #search .btn.btn-default.btn-lg {
	height: 44px;
	border-radius: var(--oc-radius);
	border: 1px solid var(--oc-border);
	background: #fff;
	box-shadow: none;
}

body.oc-modern #search .btn.btn-default.btn-lg:hover {
	border-color: rgba(37, 99, 235, 0.35);
}

/* Cart button */
body.oc-modern #cart>.btn {
	border-radius: var(--oc-radius);
	background: var(--oc-primary);
	border-color: var(--oc-primary);
	text-shadow: none;
	box-shadow: none;
}

body.oc-modern #cart>.btn:hover {
	background: var(--oc-primary-hover);
	border-color: var(--oc-primary-hover);
}

body.oc-modern #cart .dropdown-menu {
	background: #fff;
	border: 1px solid var(--oc-border);
	border-radius: var(--oc-radius);
	box-shadow: var(--oc-shadow-md);
}

/* Main menu */
body.oc-modern #menu {
	background: var(--oc-surface);
	border: 1px solid var(--oc-border);
	border-radius: var(--oc-radius);
	background-image: none;
}

body.oc-modern #menu .nav>li>a {
	color: var(--oc-text);
	text-shadow: none;
	font-weight: 600;
	padding: 12px 14px;
}

body.oc-modern #menu .nav>li>a:hover,
body.oc-modern #menu .nav>li.open>a {
	background: rgba(37, 99, 235, 0.08);
}

body.oc-modern #menu .dropdown-menu {
	border-radius: var(--oc-radius);
	border: 1px solid var(--oc-border);
	box-shadow: var(--oc-shadow-md);
	padding: 10px 0;
}

body.oc-modern #menu .dropdown-inner a {
	font-size: 13px;
	color: var(--oc-text);
	padding: 8px 16px;
}

body.oc-modern #menu .dropdown-inner li a:hover {
	background: rgba(37, 99, 235, 0.08);
	color: var(--oc-text);
}

body.oc-modern #menu .see-all {
	border-top: 1px solid var(--oc-border);
	padding: 10px 16px;
	color: var(--oc-primary);
	background: transparent;
}

body.oc-modern #menu .see-all:hover {
	background: rgba(37, 99, 235, 0.06);
}

/* Buttons + inputs */
body.oc-modern .btn {
	border-radius: var(--oc-radius-sm);
	box-shadow: none;
}

body.oc-modern .btn-primary {
	background: var(--oc-primary);
	border-color: var(--oc-primary);
	background-image: none;
	text-shadow: none;
}

body.oc-modern .btn-primary:hover,
body.oc-modern .btn-primary:focus,
body.oc-modern .btn-primary:active {
	background: var(--oc-primary-hover);
	border-color: var(--oc-primary-hover);
}

body.oc-modern .btn-success {
	background: var(--oc-success);
	border-color: var(--oc-success);
	background-image: none;
	text-shadow: none;
}

body.oc-modern .btn-danger {
	background: var(--oc-danger);
	border-color: var(--oc-danger);
	background-image: none;
	text-shadow: none;
}

body.oc-modern .form-control {
	border-radius: var(--oc-radius-sm);
	border: 1px solid var(--oc-border);
	box-shadow: none;
}

body.oc-modern .form-control:focus {
	border-color: rgba(37, 99, 235, 0.55);
	box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.12);
}

/* Breadcrumb */
body.oc-modern .breadcrumb {
	background: transparent;
	border: 0;
	padding: 0;
	margin: 0 0 16px 0;
}

body.oc-modern .breadcrumb>li {
	padding: 0;
	text-shadow: none;
}

body.oc-modern .breadcrumb>li:after {
	display: none;
}

body.oc-modern .breadcrumb>li+li:before {
	content: "/";
	padding: 0 10px;
	color: var(--oc-muted);
}

/* Product cards */
body.oc-modern .product-thumb {
	background: var(--oc-surface);
	border: 1px solid var(--oc-border);
	border-radius: var(--oc-radius);
	overflow: hidden;
	box-shadow: none;
	transition: box-shadow 180ms ease, transform 180ms ease, border-color 180ms ease;
}

body.oc-modern .product-thumb:hover {
	transform: translateY(-2px);
	box-shadow: var(--oc-shadow-sm);
	border-color: rgba(37, 99, 235, 0.25);
}

body.oc-modern .product-thumb .caption {
	padding: 0px 0px 0px 0px;
	min-height: auto;
}

body.oc-modern .product-thumb h4 {
	font-weight: 700;
	font-size: 14px;
	line-height: 1.35;
	margin: 6px 0 8px 0;
}

body.oc-modern .product-thumb .price {
	font-size: 14px;
	margin: 10px 0 0 0;
}

body.oc-modern .product-thumb .button-group {
	background: transparent;
	border-top: 0px solid var(--oc-border);
	display: flex;
}

body.oc-modern .product-thumb .button-group button {
	width: auto;
	flex: 1;
	background: transparent;
	color: var(--oc-text);
	border-left: 1px solid var(--oc-border);
	text-transform: none;
	font-weight: 600;
}

body.oc-modern .product-thumb .button-group button:first-child {
	border-left: 0;
}

body.oc-modern .product-thumb .button-group button:hover {
	background: rgba(37, 99, 235, 0.06);
	color: var(--oc-text);
}

/* Footer */
body.oc-modern footer {
	background: #0b1220;
	border-top: 1px solid rgba(255, 255, 255, 0.08);
	color: rgba(255, 255, 255, 0.78);
}

body.oc-modern footer a {
	color: rgba(255, 255, 255, 0.78);
}

body.oc-modern footer a:hover {
	color: #fff;
}

body.oc-modern footer h5 {
	color: #fff;
	font-size: 14px;
	letter-spacing: 0.2px;
}

/* Category / listing toolbar spacing */
body.oc-modern #product-category h2 {
	margin: 8px 0 16px 0;
	font-weight: 800;
	letter-spacing: -0.2px;
}

body.oc-modern #product-category .form-group {
	margin-bottom: 12px;
}

body.oc-modern #product-category .btn-group .btn {
	border-color: var(--oc-border);
}

body.oc-modern #product-category .btn-link {
	color: var(--oc-primary);
}

/* Product list layout: make it feel like modern cards */
@media (min-width: 768px) {
	body.oc-modern .product-list .product-thumb {
		display: flex;
		align-items: stretch;
	}

	body.oc-modern .product-list .product-thumb .image {
		flex: 0 0 220px;
		padding: 14px;
	}

	body.oc-modern .product-list .product-thumb .image img {
		width: 100%;
		height: auto;
		border-radius: calc(var(--oc-radius) - 4px);
	}

	body.oc-modern .product-list .product-thumb>div {
		flex: 1;
		display: flex;
		flex-direction: column;
	}

	body.oc-modern .product-list .product-thumb .caption {
		min-height: auto;
		flex: 1;
	}
}

/* Product grid: tighter, consistent media area */
body.oc-modern .product-grid .product-thumb .image {
	padding: 14px 14px 0 14px;
}

body.oc-modern .product-grid .product-thumb .image img {
	border-radius: calc(var(--oc-radius) - 4px);
}

body.oc-modern .product-thumb .caption p {
	color: var(--oc-muted);
	margin: 0 0 10px 0;
}

body.oc-modern .product-thumb .image a:hover {
	opacity: 1;
}

body.oc-modern .product-thumb .image img {
	transition: transform 180ms ease;
}

body.oc-modern .product-thumb:hover .image img {
	transform: scale(1.02);
}

body.oc-modern .product-grid .product-thumb .caption p {
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 3;
	overflow: hidden;
}

body.oc-modern .product-thumb .price-old {
	color: var(--oc-muted);
}

/* Product page */
body.oc-modern #product-product h1 {
	margin-top: 0;
	font-weight: 800;
	letter-spacing: -0.3px;
}

body.oc-modern #product-product .thumbnails .thumbnail {
	border: 1px solid var(--oc-border);
	border-radius: var(--oc-radius);
	box-shadow: none;
	background: #fff;
}

body.oc-modern #product-product .nav-tabs>li>a {
	border-radius: var(--oc-radius-sm) var(--oc-radius-sm) 0 0;
}

body.oc-modern #product-product .tab-content {
	background: #fff;
	border: 1px solid var(--oc-border);
	border-top: 0;
	border-radius: 0 0 var(--oc-radius) var(--oc-radius);
	padding: 14px 16px;
}

body.oc-modern #product-product .btn-group .btn {
	border-color: var(--oc-border);
}

/* ============================================================
   SUCCESS PAGE — Premium Modern Design
   ============================================================ */

/* Wrapper: full-bleed centered layout */
body.oc-modern .success-wrapper {
	position: relative;
	padding: 48px 16px 64px;
	overflow: hidden;
}

/* ---- Confetti particles ---- */
body.oc-modern .success-particles {
	pointer-events: none;
	position: absolute;
	inset: 0;
	overflow: hidden;
	z-index: 0;
}

body.oc-modern .success-particles .particle {
	position: absolute;
	border-radius: 50%;
	opacity: 0;
	animation: particleFall 3.5s ease-in forwards;
}

body.oc-modern .success-particles .p1 {
	width: 10px;
	height: 10px;
	background: #2563eb;
	top: -10px;
	left: 15%;
	animation-delay: 0.1s;
	border-radius: 2px;
}

body.oc-modern .success-particles .p2 {
	width: 8px;
	height: 8px;
	background: #16a34a;
	top: -10px;
	left: 30%;
	animation-delay: 0.35s;
}

body.oc-modern .success-particles .p3 {
	width: 12px;
	height: 12px;
	background: #f59e0b;
	top: -10px;
	left: 50%;
	animation-delay: 0.2s;
	border-radius: 3px;
}

body.oc-modern .success-particles .p4 {
	width: 7px;
	height: 7px;
	background: #ec4899;
	top: -10px;
	left: 65%;
	animation-delay: 0.5s;
}

body.oc-modern .success-particles .p5 {
	width: 9px;
	height: 9px;
	background: #8b5cf6;
	top: -10px;
	left: 78%;
	animation-delay: 0.15s;
	border-radius: 2px;
}

body.oc-modern .success-particles .p6 {
	width: 11px;
	height: 11px;
	background: #06b6d4;
	top: -10px;
	left: 42%;
	animation-delay: 0.6s;
}

body.oc-modern .success-particles .p7 {
	width: 8px;
	height: 8px;
	background: #f97316;
	top: -10px;
	left: 85%;
	animation-delay: 0.25s;
	border-radius: 4px;
}

body.oc-modern .success-particles .p8 {
	width: 10px;
	height: 10px;
	background: #2563eb;
	top: -10px;
	left: 8%;
	animation-delay: 0.45s;
}

@keyframes particleFall {
	0% {
		transform: translateY(0) rotate(0deg);
		opacity: 1;
	}

	80% {
		opacity: 0.8;
	}

	100% {
		transform: translateY(480px) rotate(540deg);
		opacity: 0;
	}
}

/* ---- Main card ---- */
body.oc-modern .success-card {
	position: relative;
	z-index: 1;
	background: #ffffff;
	border-radius: 24px;
	padding: 56px 48px 48px;
	text-align: center;
	box-shadow: 0 24px 64px rgba(17, 24, 39, 0.11), 0 4px 16px rgba(37, 99, 235, 0.07);
	margin: 0 auto;
	max-width: 640px;
	border: 1px solid rgba(17, 24, 39, 0.07);
	animation: cardSlideUp 0.6s cubic-bezier(0.22, 1, 0.36, 1) both;
}

@keyframes cardSlideUp {
	from {
		transform: translateY(32px);
		opacity: 0;
	}

	to {
		transform: translateY(0);
		opacity: 1;
	}
}

/* Top accent bar */
body.oc-modern .success-card::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 4px;
	border-radius: 24px 24px 0 0;
	background: linear-gradient(90deg, #2563eb 0%, #16a34a 50%, #06b6d4 100%);
}

/* ---- Animated SVG Checkmark ---- */
body.oc-modern .success-icon-wrap {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 32px;
}

body.oc-modern .success-glow-ring {
	position: absolute;
	width: 120px;
	height: 120px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(22, 163, 74, 0.18) 0%, transparent 70%);
	animation: pulseGlow 2.5s ease-in-out infinite;
}

@keyframes pulseGlow {

	0%,
	100% {
		transform: scale(1);
		opacity: 0.7;
	}

	50% {
		transform: scale(1.18);
		opacity: 1;
	}
}

body.oc-modern .success-icon-circle {
	position: relative;
	width: 96px;
	height: 96px;
	border-radius: 50%;
	background: linear-gradient(135deg, #16a34a, #22c55e);
	box-shadow: 0 8px 28px rgba(22, 163, 74, 0.38), 0 2px 8px rgba(22, 163, 74, 0.2);
	display: flex;
	align-items: center;
	justify-content: center;
	animation: iconBounce 0.7s 0.2s cubic-bezier(0.175, 0.885, 0.32, 1.275) both;
}

@keyframes iconBounce {
	from {
		transform: scale(0) rotate(-30deg);
		opacity: 0;
	}

	to {
		transform: scale(1) rotate(0deg);
		opacity: 1;
	}
}

body.oc-modern .success-checkmark {
	width: 52px;
	height: 52px;
}

body.oc-modern .success-checkmark .checkmark-circle {
	stroke: rgba(255, 255, 255, 0.3);
	stroke-width: 2;
	stroke-dasharray: 166;
	stroke-dashoffset: 166;
	animation: strokeDraw 0.6s 0.5s cubic-bezier(0.65, 0, 0.45, 1) forwards;
}

body.oc-modern .success-checkmark .checkmark-check {
	stroke: #ffffff;
	stroke-width: 3;
	stroke-dasharray: 48;
	stroke-dashoffset: 48;
	stroke-linecap: round;
	stroke-linejoin: round;
	animation: strokeDraw 0.4s 0.8s ease forwards;
}

@keyframes strokeDraw {
	to {
		stroke-dashoffset: 0;
	}
}

/* ---- Title ---- */
body.oc-modern .success-title {
	font-weight: 800;
	font-size: 30px;
	letter-spacing: -0.5px;
	color: #111827;
	margin: 0 0 20px;
	line-height: 1.2;
	animation: fadeUp 0.5s 0.35s ease both;
}

/* ---- Divider ---- */
body.oc-modern .success-divider {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	margin-bottom: 24px;
	animation: fadeUp 0.5s 0.45s ease both;
}

body.oc-modern .success-divider .divider-line {
	display: block;
	width: 72px;
	height: 2px;
	border-radius: 2px;
	background: linear-gradient(90deg, transparent, rgba(37, 99, 235, 0.35), transparent);
}

body.oc-modern .success-divider .divider-dot {
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: var(--oc-primary);
	opacity: 0.5;
}

/* ---- Message ---- */
body.oc-modern .success-message {
	font-size: 15.5px;
	line-height: 1.65;
	color: #4b5563;
	margin-bottom: 36px;
	animation: fadeUp 0.5s 0.5s ease both;
}

body.oc-modern .success-message p {
	margin-bottom: 8px;
}

body.oc-modern .success-message a {
	color: var(--oc-primary);
	font-weight: 600;
	text-decoration: underline;
	text-underline-offset: 2px;
}

/* ---- CTA Button ---- */
body.oc-modern .success-actions {
	margin-bottom: 36px;
	animation: fadeUp 0.5s 0.58s ease both;
}

body.oc-modern .btn-success-modern {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 15px 40px;
	border-radius: 50px;
	font-size: 15.5px;
	font-weight: 700;
	color: #fff;
	background: linear-gradient(135deg, #2563eb 0%, #1e40af 100%);
	border: none;
	text-decoration: none;
	box-shadow: 0 8px 24px rgba(37, 99, 235, 0.35), 0 2px 8px rgba(37, 99, 235, 0.2);
	transition: transform 0.22s ease, box-shadow 0.22s ease, background 0.22s ease;
	position: relative;
	overflow: hidden;
	letter-spacing: 0.2px;
}

body.oc-modern .btn-success-modern::before {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, rgba(255, 255, 255, 0.18) 0%, transparent 60%);
	border-radius: inherit;
}

body.oc-modern .btn-success-modern:hover {
	transform: translateY(-3px) scale(1.02);
	box-shadow: 0 14px 36px rgba(37, 99, 235, 0.42), 0 4px 12px rgba(37, 99, 235, 0.25);
	background: linear-gradient(135deg, #1d4ed8 0%, #1e3a8a 100%);
	color: #fff;
	text-decoration: none;
}

body.oc-modern .btn-success-modern:active {
	transform: translateY(-1px) scale(0.99);
}

body.oc-modern .btn-success-modern .btn-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0.9;
}

/* ---- Badges row ---- */
body.oc-modern .success-badges {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
	flex-wrap: wrap;
	animation: fadeUp 0.5s 0.68s ease both;
	padding-top: 24px;
	border-top: 1px solid rgba(17, 24, 39, 0.07);
}

body.oc-modern .success-badges .badge-item {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	padding: 7px 16px;
	background: #f8fafc;
	border: 1px solid rgba(17, 24, 39, 0.09);
	border-radius: 50px;
	font-size: 12.5px;
	font-weight: 600;
	color: #374151;
	transition: background 0.18s, border-color 0.18s, transform 0.18s;
}

body.oc-modern .success-badges .badge-item:hover {
	background: rgba(37, 99, 235, 0.06);
	border-color: rgba(37, 99, 235, 0.2);
	transform: translateY(-1px);
}

body.oc-modern .success-badges .badge-item svg {
	color: var(--oc-primary);
	flex-shrink: 0;
}

/* ---- Shared fade-up animation ---- */
@keyframes fadeUp {
	from {
		transform: translateY(14px);
		opacity: 0;
	}

	to {
		transform: translateY(0);
		opacity: 1;
	}
}

/* ---- Responsive ---- */
@media (max-width: 576px) {
	body.oc-modern .success-card {
		padding: 40px 24px 36px;
		border-radius: 18px;
	}

	body.oc-modern .success-title {
		font-size: 24px;
	}

	body.oc-modern .success-icon-circle {
		width: 80px;
		height: 80px;
	}

	body.oc-modern .success-checkmark {
		width: 42px;
		height: 42px;
	}

	body.oc-modern .btn-success-modern {
		width: 100%;
		justify-content: center;
		padding: 14px 24px;
	}

	body.oc-modern .success-badges {
		gap: 8px;
	}

	body.oc-modern .success-badges .badge-item {
		font-size: 12px;
		padding: 6px 12px;
	}
}

/* ============================================================
   FOOTER — Premium Modern Design
   ============================================================ */

/* ---- Accent line at very top of footer ---- */
body.oc-modern .oc-footer .footer-accent-line {
	height: 3px;
	background: linear-gradient(90deg, #2563eb 0%, #16a34a 40%, #06b6d4 70%, #8b5cf6 100%);
}

/* ---- Outer element ---- */
body.oc-modern .oc-footer {
	background: #0b1120;
	color: rgba(255, 255, 255, 0.72);
	font-size: 14px;
	line-height: 1.6;
	border-top: none;
	padding: 0;
	margin-top: 48px;
}

body.oc-modern .oc-footer .footer-body {
	padding: 56px 0 40px;
}

/* ---- 4-column grid ---- */
body.oc-modern .oc-footer .footer-grid {
	display: grid;
	grid-template-columns: 1.5fr 1fr 1fr 1fr;
	gap: 40px 32px;
}

/* ---- Brand section ---- */
body.oc-modern .oc-footer .footer-col--brand .footer-logo-link {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	text-decoration: none;
	margin-bottom: 16px;
}

body.oc-modern .oc-footer .footer-logo-icon {
	width: 36px;
	height: 36px;
	flex-shrink: 0;
	border-radius: 10px;
}

body.oc-modern .oc-footer .footer-brand-name {
	font-size: 20px;
	font-weight: 800;
	color: #ffffff;
	letter-spacing: -0.5px;
}

body.oc-modern .oc-footer .footer-brand-desc {
	color: rgba(255, 255, 255, 0.50);
	font-size: 13.5px;
	line-height: 1.65;
	margin: 0 0 24px;
	max-width: 280px;
}

/* ---- Social buttons ---- */
body.oc-modern .oc-footer .footer-socials {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
}

body.oc-modern .oc-footer .footer-social-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: 10px;
	border: 1px solid rgba(255, 255, 255, 0.12);
	background: rgba(255, 255, 255, 0.05);
	color: rgba(255, 255, 255, 0.65);
	text-decoration: none;
	transition: background 0.2s, border-color 0.2s, color 0.2s, transform 0.2s;
}

body.oc-modern .oc-footer .footer-social-btn svg {
	width: 18px;
	height: 18px;
}

body.oc-modern .oc-footer .footer-social-btn:hover {
	background: rgba(37, 99, 235, 0.22);
	border-color: rgba(37, 99, 235, 0.6);
	color: #ffffff;
	transform: translateY(-2px);
}

/* ---- Column heading ---- */
body.oc-modern .oc-footer .footer-col-title {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 11.5px;
	font-weight: 700;
	color: #ffffff;
	text-transform: uppercase;
	letter-spacing: 1px;
	margin: 0 0 18px;
}

body.oc-modern .oc-footer .footer-col-title-dot {
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: #2563eb;
	flex-shrink: 0;
	box-shadow: 0 0 8px rgba(37, 99, 235, 0.75);
}

/* ---- Link list ---- */
body.oc-modern .oc-footer .footer-link-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 11px;
}

body.oc-modern .oc-footer .footer-link-list li a {
	color: rgba(255, 255, 255, 0.56);
	text-decoration: none;
	font-size: 13.5px;
	display: inline-flex;
	align-items: center;
	gap: 7px;
	transition: color 0.18s, gap 0.18s;
}

body.oc-modern .oc-footer .footer-link-list li a::before {
	content: '';
	display: inline-block;
	width: 5px;
	height: 1.5px;
	background: rgba(37, 99, 235, 0.55);
	flex-shrink: 0;
	border-radius: 2px;
	transition: width 0.2s, background 0.2s;
}

body.oc-modern .oc-footer .footer-link-list li a:hover {
	color: #ffffff;
	gap: 10px;
}

body.oc-modern .oc-footer .footer-link-list li a:hover::before {
	width: 10px;
	background: #2563eb;
}

/* ---- Trust bar ---- */
body.oc-modern .oc-footer .footer-trust-bar {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 0;
	margin-top: 44px;
	padding: 18px 28px;
	border-radius: 14px;
	background: rgba(255, 255, 255, 0.04);
	border: 1px solid rgba(255, 255, 255, 0.08);
}

body.oc-modern .oc-footer .footer-trust-item {
	display: flex;
	align-items: center;
	gap: 9px;
	padding: 0 24px;
	color: rgba(255, 255, 255, 0.60);
	font-size: 13px;
	font-weight: 500;
	flex: 1;
	min-width: 120px;
	justify-content: center;
	transition: color 0.18s;
}

body.oc-modern .oc-footer .footer-trust-item:first-child {
	padding-left: 0;
}

body.oc-modern .oc-footer .footer-trust-item:hover {
	color: #ffffff;
}

body.oc-modern .oc-footer .footer-trust-item svg {
	flex-shrink: 0;
	color: #2563eb;
}

body.oc-modern .oc-footer .footer-trust-sep {
	width: 1px;
	height: 30px;
	background: rgba(255, 255, 255, 0.1);
	flex-shrink: 0;
}

/* ---- Payment badges ---- */
body.oc-modern .oc-footer .footer-payment-badges {
	display: flex;
	align-items: center;
	gap: 7px;
	padding: 0 0 0 24px;
	flex-wrap: wrap;
}

body.oc-modern .oc-footer .pay-badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 4px 10px;
	border-radius: 6px;
	border: 1px solid rgba(255, 255, 255, 0.15);
	background: rgba(255, 255, 255, 0.06);
	color: rgba(255, 255, 255, 0.72);
	font-size: 10.5px;
	font-weight: 700;
	letter-spacing: 0.3px;
	transition: background 0.18s, border-color 0.18s;
}

body.oc-modern .oc-footer .pay-badge:hover {
	background: rgba(255, 255, 255, 0.12);
	border-color: rgba(255, 255, 255, 0.28);
}

/* ---- Bottom bar ---- */
body.oc-modern .oc-footer .footer-bottom {
	border-top: 1px solid rgba(255, 255, 255, 0.07);
	padding: 18px 0;
}

body.oc-modern .oc-footer .footer-bottom-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 12px;
}

body.oc-modern .oc-footer .footer-copy {
	color: rgba(255, 255, 255, 0.36);
	font-size: 12.5px;
}

body.oc-modern .oc-footer .footer-copy a {
	color: rgba(255, 255, 255, 0.44);
	text-decoration: none;
	transition: color 0.18s;
}

body.oc-modern .oc-footer .footer-copy a:hover {
	color: rgba(255, 255, 255, 0.78);
}

body.oc-modern .oc-footer .footer-bottom-links {
	display: flex;
	gap: 22px;
}

body.oc-modern .oc-footer .footer-bottom-links a {
	font-size: 12.5px;
	color: rgba(255, 255, 255, 0.36);
	text-decoration: none;
	transition: color 0.18s;
}

body.oc-modern .oc-footer .footer-bottom-links a:hover {
	color: rgba(255, 255, 255, 0.78);
}

/* ---- Responsive ---- */
@media (max-width: 991px) {
	body.oc-modern .oc-footer .footer-grid {
		grid-template-columns: 1fr 1fr;
		gap: 36px 28px;
	}

	body.oc-modern .oc-footer .footer-col--brand {
		grid-column: 1 / -1;
	}

	body.oc-modern .oc-footer .footer-brand-desc {
		max-width: 100%;
	}

	body.oc-modern .oc-footer .footer-trust-sep {
		display: none;
	}

	body.oc-modern .oc-footer .footer-trust-item {
		padding: 8px 12px;
		justify-content: flex-start;
		flex: 0 1 auto;
	}

	body.oc-modern .oc-footer .footer-payment-badges {
		padding-left: 12px;
	}
}

@media (max-width: 640px) {
	body.oc-modern .oc-footer .footer-body {
		padding: 40px 0 28px;
	}

	body.oc-modern .oc-footer .footer-grid {
		grid-template-columns: 1fr;
		gap: 28px;
	}

	body.oc-modern .oc-footer .footer-trust-bar {
		flex-direction: column;
		align-items: flex-start;
		gap: 12px;
		padding: 16px 20px;
	}

	body.oc-modern .oc-footer .footer-trust-item {
		justify-content: flex-start;
		padding: 0;
	}

	body.oc-modern .oc-footer .footer-payment-badges {
		padding-left: 0;
	}

	body.oc-modern .oc-footer .footer-bottom-inner {
		flex-direction: column;
		align-items: flex-start;
		gap: 8px;
	}

	body.oc-modern .oc-footer .footer-bottom-links {
		gap: 16px;
	}
}

/* ============================================================
   CHECKOUT — Premium Modern UI
   ============================================================ */
.checkout-modern-ui {
	padding-top: 32px;
	padding-bottom: 64px;
}

.checkout-layout {
	display: flex;
	gap: 32px;
	align-items: flex-start;
}

.checkout-main {
	flex: 1;
	min-width: 0;
}

.checkout-header-info {
	margin-bottom: 32px;
}

.checkout-title {
	font-size: 32px;
	font-weight: 800;
	letter-spacing: -1px;
	color: #111827;
	margin: 0 0 8px;
}

.checkout-subtitle {
	color: #6b7280;
	font-size: 15px;
}

/* --- Steps list --- */
.checkout-steps {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.checkout-step {
	background: #fff;
	border: 1px solid #e5e7eb;
	border-radius: 16px;
	overflow: hidden;
	transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.checkout-step.active {
	border-color: #2563eb;
	box-shadow: 0 10px 25px -5px rgba(37, 99, 235, 0.1);
}

.checkout-step.completed {
	border-color: #d1fae5;
}

/* --- Step Header --- */
.step-header {
	padding: 24px;
	display: flex;
	align-items: center;
	gap: 16px;
	cursor: pointer;
	user-select: none;
	background: #fff;
	text-decoration: none !important;
	outline: none !important;
	color: inherit !important;
}

.step-header:hover,
.step-header:focus {
	text-decoration: none !important;
	color: inherit !important;
}

.step-number {
	width: 32px;
	height: 32px;
	border-radius: 50%;
	background: #f3f4f6;
	color: #6b7280;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 14px;
	font-weight: 700;
	transition: all 0.3s;
	border: 1px solid #e5e7eb;
}

.active .step-number {
	background: #2563eb;
	color: #fff;
	border-color: #2563eb;
	box-shadow: 0 0 0 4px rgba(37, 99, 235, 0.1);
}

.completed .step-number {
	background: #10b981;
	color: #fff;
	border-color: #10b981;
}

.step-title {
	font-size: 18px;
	font-weight: 700;
	margin: 0;
	color: #374151;
	flex: 1;
}

.active .step-title {
	color: #111827;
}

.step-status {
	width: 24px;
	height: 24px;
	border-radius: 50%;
	background: #10b981;
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 10px;
	opacity: 0;
	transform: scale(0.5);
	transition: all 0.3s;
}

.completed .step-status {
	opacity: 1;
	transform: scale(1);
}

/* --- Step Content --- */
.step-content {
	padding: 0 24px 32px 72px;
}

/* Inline Step Layout (Address Select + New Option + Button) */
.checkout-inline-step {
	display: flex;
	align-items: flex-end;
	gap: 16px;
	margin-bottom: 24px;
}

.inline-option {
	background: #f9fafb;
	border: 1px solid #e5e7eb;
	border-radius: 12px;
	padding: 6px 6px;
	transition: all 0.2s ease;
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.existing-address-option {
	flex: 2;
	min-width: 0;
}

.new-address-option {
	flex: 1;
	white-space: nowrap;
	justify-content: center;
	height: 94px;
	/* Matches height with select box */
}

.inline-actions {
	flex-shrink: 0;
}

.inline-option .radio {
	margin: 0;
}

.inline-option .option-label {
	font-size: 14px;
	font-weight: 700;
	color: #2563eb;
}

.inline-option .form-control {
	height: 40px;
	border-radius: 8px;
}

/* Option Groups (Radio/Checkbox) as Grid for other steps */
.step-content .step-content-options,
#collapse-shipping-method .step-content,
#collapse-payment-method .step-content {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 16px;
	align-items: start;
}

.step-content .radio,
.step-content .checkbox {
	margin: 5px 0px 5px 0px;
	padding: 0;
}

.step-content .radio label,
.step-content .checkbox label {
	display: flex;
	align-items: center;
	padding: 16px 16px 16px 32px;
	background: #ffffff;
	border: 1px solid #e5e7eb;
	border-radius: 12px;
	width: 100%;
	cursor: pointer;
	transition: all 0.2s ease;
	font-weight: 600;
	color: #4b5563;
	gap: 12px;
	margin-bottom: 0;
}

@media (max-width: 992px) {
	.checkout-inline-step {
		flex-direction: column;
		align-items: stretch;
	}

	.new-address-option {
		height: auto;
	}

	#collapse-shipping-method .step-content,
	#collapse-payment-method .step-content {
		grid-template-columns: 1fr;
	}
}


/* Shipping Method Step Refinements */
.shipping-method-container {
	display: flex;
	gap: 24px;
	align-items: flex-start;
	margin-bottom: 20px;
}

.shipping-options-side {
	flex: 1;
}

.shipping-comment-side {
	flex: 1;
	background: #f9fafb;
	padding: 16px;
	border-radius: 12px;
	border: 1px solid #e5e7eb;
}

.comment-small-label {
	display: block;
	font-size: 13px;
	font-weight: 700;
	color: #6b7280;
	margin-bottom: 8px;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.shipping-comment-side textarea {
	border: 1px solid #d1d5db;
	resize: none;
	font-size: 14px;
}

/* Payment Methods Grid */
.payment-methods-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 16px;
	margin-top: 12px;
}

@media (max-width: 768px) {
	.shipping-method-container {
		flex-direction: column;
	}

	.payment-methods-grid {
		grid-template-columns: 1fr;
	}
}

.step-content .radio label:hover,
.step-content .checkbox label:hover {
	background: #f3f4f6;
	border-color: #d1d5db;
}

.step-content .radio input[type="radio"]:checked+label,
.step-content .radio input[type="radio"]:checked~label,
.step-content .radio label:has(input:checked) {
	background: #eff6ff;
	border-color: #3b82f6;
	color: #1e40af;
}

/* Button Positioning */
.step-content .buttons {
	margin-top: 24px;
	padding-top: 20px;
	border-top: 1px solid #f3f4f6;
	display: flex;
	justify-content: flex-end;
}

.step-content .pull-right {
	float: none !important;
}

/* Custom form elements within steps */
.step-content .form-group {
	margin-bottom: 20px;
}

.step-content label {
	font-weight: 600;
	color: #374151;
	margin-bottom: 6px;
}

.step-content .form-control {
	border-radius: 10px;
	height: 44px;
	border: 1px solid #d1d5db;
	padding: 0 14px;
}

.step-content .btn-primary {
	height: 48px;
	padding: 0 32px;
	font-weight: 700;
	border-radius: 12px;
	background: #2563eb;
	box-shadow: 0 4px 10px rgba(37, 99, 235, 0.2);
	border: none;
	margin: 0;
	/* Removed margin-top */
}

.step-content .btn-primary:hover {
	background: #1d4ed8;
	transform: translateY(-1px);
}

/* --- Sidebar --- */
.checkout-sidebar {
	width: 380px;
	flex-shrink: 0;
	display: none;
	opacity: 0;
	transition: opacity 0.4s ease-in-out;
}

.checkout-layout.show-sidebar .checkout-sidebar {
	display: block;
	opacity: 1;
}

.checkout-layout.show-sidebar .checkout-main {
	flex: 1;
}

.checkout-layout:not(.show-sidebar) .checkout-main {
	width: 100%;
	max-width: 900px;
	margin: 0 auto;
}


.sticky-sidebar {
	position: sticky;
	top: 24px;
}

.summary-card {
	background: #fff;
	border-radius: 20px;
	padding: 28px;
	border: 1px solid #e5e7eb;
	margin-bottom: 24px;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
}

.summary-title {
	font-size: 20px;
	font-weight: 800;
	margin: 0 0 20px;
	color: #111827;
	border-bottom: 1px solid #f3f4f6;
	padding-bottom: 12px;
}

.summary-placeholder {
	text-align: center;
	padding: 32px 0;
	color: #9ca3af;
}

.summary-placeholder i {
	font-size: 40px;
	margin-bottom: 12px;
	display: block;
	opacity: 0.3;
}

/* Trust Badges */
.trust-badges {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.trust-item {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 16px;
	background: #f9fafb;
	border-radius: 12px;
	border: 1px solid #f3f4f6;
}

.trust-item i {
	color: #2563eb;
	font-size: 18px;
}

.trust-item span {
	font-size: 13px;
	font-weight: 600;
	color: #4b5563;
}

/* Confirm Table in Sidebar/Last Step */
.step-content .table-responsive {
	border: none;
	margin: 0;
}

.step-content .table {
	margin: 0;
}

.step-content .table thead {
	display: none;
	/* Hide header for cleaner look */
}

.step-content .table tbody tr td {
	border-top: 1px solid #f3f4f6;
	padding: 12px 0;
}

.step-content .table tfoot tr td {
	padding: 8px 0;
	border: none;
}

/* --- Responsive --- */
@media (max-width: 1024px) {
	.checkout-layout {
		flex-direction: column;
	}

	.checkout-sidebar {
		width: 100%;
	}
}

@media (max-width: 640px) {
	.step-header {
		padding: 16px;
	}

	.step-content {
		padding: 0 16px 24px 56px;
	}

	.checkout-title {
		font-size: 26px;
	}
}

/* --- Confirm Table Modernization --- */
.modern-confirm-table {
	border: none;
	margin-bottom: 24px;
}

.modern-confirm-table thead td {
	border: none;
	text-transform: uppercase;
	font-size: 11px;
	font-weight: 800;
	color: #9ca3af;
	letter-spacing: 0.5px;
	padding-bottom: 12px;
}

.modern-confirm-table tbody td {
	padding: 16px 0;
	border-top: 1px solid #f3f4f6;
	vertical-align: middle;
}

.confirm-product-info {
	line-height: 1.4;
}

.product-name {
	font-weight: 700;
	color: #111827;
	font-size: 15px;
}

.product-qty {
	display: inline-block;
	background: #f3f4f6;
	color: #4b5563;
	padding: 2px 8px;
	border-radius: 6px;
	font-size: 11px;
	font-weight: 800;
	margin-left: 6px;
}

.product-option {
	color: #6b7280;
	font-size: 12px;
}

.product-total-price {
	font-weight: 700;
	color: #111827;
}

.modern-confirm-table tfoot td {
	border: none;
	padding: 8px 0;
	color: #4b5563;
}

.modern-confirm-table tfoot .grand-total td {
	padding-top: 20px;
	padding-bottom: 20px;
	border-top: 2px solid #2563eb;
	color: #2563eb;
	font-size: 24px;
	font-weight: 800;
}

.total-row td {
	padding: 10px 0;
	font-size: 15px;
}

/* Modern One-Page Checkout */
:root {
	--checkout-accent: #3b82f6;
	/* Premium Blue */
	--checkout-bg: #f8fafc;
	--checkout-card-bg: #ffffff;
	--checkout-text: #1e293b;
	--checkout-border: #e2e8f0;
	--checkout-radius: 16px;
	--checkout-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
}

.checkout-modern-grid {
	display: grid;
	grid-template-columns: 1fr 1fr 400px;
	gap: 24px;
	align-items: start;
	margin-top: 30px;
}

@media (max-width: 1200px) {
	.checkout-modern-grid {
		grid-template-columns: 1fr 1fr;
	}
}

@media (max-width: 768px) {
	.checkout-modern-grid {
		grid-template-columns: 1fr;
	}
}

.checkout-panel {
	background: var(--checkout-card-bg);
	border-radius: var(--checkout-radius);
	box-shadow: var(--checkout-shadow);
	padding: 24px;
	border: 1px solid var(--checkout-border);
	margin-bottom: 24px;
}

.checkout-panel-title {
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--checkout-text);
	margin-top: 0;
	margin-bottom: 20px;
	display: flex;
	align-items: center;
	gap: 10px;
}

.checkout-panel-title .num {
	background: var(--checkout-accent);
	color: #fff;
	width: 28px;
	height: 28px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 0.9rem;
}

.checkout-summary-column {
	position: sticky;
	top: 20px;
}

.checkout-sidebar-card {
	background: #fff;
	border-radius: var(--checkout-radius);
	box-shadow: var(--checkout-shadow);
	overflow: hidden;
	border: 1px solid var(--checkout-border);
}

.checkout-sidebar-header {
	background: #f1f5f9;
	padding: 16px 20px;
	font-weight: 700;
	border-bottom: 1px solid var(--checkout-border);
}

.checkout-sidebar-body {
	padding: 20px;
}

#button-complete-order {
	width: 100%;
	padding: 18px;
	font-size: 1.1rem;
	font-weight: 700;
	border-radius: 12px;
	background: var(--checkout-accent);
	border: none;
	transition: all 0.2s;
	color: #fff;
	margin-top: 20px;
}

#button-complete-order:hover {
	filter: brightness(1.1);
	transform: translateY(-2px);
}

.opc-section-divider {
	margin: 30px 0;
	border-top: 1px solid #f1f5f9;
}

/* Loading States */
.opc-loading {
	position: relative;
	opacity: 0.6;
	pointer-events: none;
}

.opc-loading::after {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	width: 32px;
	height: 32px;
	margin-top: -16px;
	margin-left: -16px;
	border: 3px solid var(--checkout-accent);
	border-top-color: transparent;
	border-radius: 50%;
	animation: opc-spin 0.6s linear infinite;
	z-index: 10;
}

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

.payment-methods-grid,
.shipping-methods-grid {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.opc-radio-box {
	border: 1px solid #e2e8f0;
	padding: 15px;
	border-radius: 12px;
	cursor: pointer;
	transition: all 0.2s;
}

.opc-radio-box:hover {
	border-color: var(--checkout-accent);
	background: #f0f7ff;
}

.opc-radio-box.active {
	border-color: var(--checkout-accent);
	background: #eff6ff;
	box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.1);
}

/* --- PREMIUM CATEGORY GRID UPGRADE (OLMASI GEREKEN) --- */
body.oc-modern .product-thumb {
	border-radius: 12px !important;
	border: 1px solid #eef2f6 !important;
	box-shadow: 0 4px 15px rgba(0, 0, 0, 0.03) !important;
	background: #fff !important;
	transition: all 0.3s ease !important;
	position: relative !important;
	height: 100%;
	display: flex !important;
	flex-direction: column !important;
	overflow: visible !important;
}

body.oc-modern .product-thumb:hover {
	transform: translateY(-5px);
	box-shadow: 0 10px 25px rgba(0, 0, 0, 0.06) !important;
}

body.oc-modern .product-thumb .image {
	padding: 15px !important;
	position: relative !important;
	text-align: center !important;
	background: transparent !important;
}

body.oc-modern .product-thumb .image img {
	margin: 0 auto;
	transition: transform 0.4s;
	max-width: 100%;
	height: auto;
}

body.oc-modern .product-thumb:hover .image img {
	transform: scale(1.05);
}

/* Wishlist Button - Top Right Corner (Olması Gereken) */
body.oc-modern .wishlist-btn-modern {
	position: absolute;
	top: 15px;
	right: 15px;
	z-index: 10;
	width: 32px;
	height: 32px;
	border-radius: 50% !important;
	background: #cbd5e1 !important;
	/* Görseldeki gri tonu */
	border: none !important;
	color: #ffffff !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	transition: all 0.3s ease;
	padding: 0;
	cursor: pointer;
	box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
}

body.oc-modern .wishlist-btn-modern:hover {
	background: #94a3b8 !important;
	transform: scale(1.1);
	box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
}

body.oc-modern .wishlist-btn-modern i {
	font-size: 14px;
	line-height: 1;
}

/* General fallback for any wishlist button inside a modern thumb */
body.oc-modern .product-thumb button[onclick*="wishlist.add"] {
	position: absolute;
	top: 15px;
	right: 15px;
	z-index: 10;
	width: 32px;
	height: 32px;
	border-radius: 50% !important;
	background: #cbd5e1 !important;
	color: #fff !important;
	border: none !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	padding: 0;
}


/* Caption Styles */
body.oc-modern .product-thumb .caption {
	padding: 0 15px 15px 15px !important;
	flex-grow: 1;
	text-align: center !important;
}

body.oc-modern .product-thumb .caption h4 {
	font-size: 14px !important;
	font-weight: 600 !important;
	margin-bottom: 5px !important;
	height: 40px;
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
}

body.oc-modern .product-thumb .caption h4 a {
	color: #333 !important;
	text-decoration: none;
}

body.oc-modern .product-thumb .price {
	font-size: 15px !important;
	font-weight: 700 !important;
	color: #333 !important;
	margin-bottom: 0 !important;
	display: block !important;
	text-align: center !important;
}

body.oc-modern .product-thumb .price-new {
	color: #333 !important;
}

body.oc-modern .product-thumb .price-old {
	font-weight: 400 !important;
	font-size: 12px;
	text-decoration: line-through;
	color: #999 !important;
	margin-left: 5px;
}

/* Add to Cart Button - Modern Full Width */
body.oc-modern .product-thumb .button-group {
	padding: 0 15px 15px 15px !important;
	background: transparent !important;
	border-top: 0 !important;
	display: block !important;
}

body.oc-modern .btn-cart-modern {
	width: 100% !important;
	background: #cff0ff !important;
	color: #1a202c !important;
	border: none !important;
	border-radius: 10px !important;
	font-weight: 700 !important;
	font-size: 13px !important;
	height: 42px;
	transition: all 0.3s;
	text-transform: capitalize;
	cursor: pointer;
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.02);
}

body.oc-modern .btn-cart-modern:hover {
	background: #2563eb !important;
	color: #ffffff !important;
	box-shadow: 0 4px 12px rgba(37, 99, 235, 0.2);
}

/* Handle nth-child variety for button colors as shown in image */
body.oc-modern .product-layout:nth-child(4n+3) .btn-cart-modern {
	background: #fde047 !important;
}

body.oc-modern .product-layout:nth-child(4n+3) .btn-cart-modern:hover {
	background: #facc15 !important;
	color: #000 !important;
}