/* ---- Root ---- */

:root {
  --tbscol-dark: #1f2937;
  --tbscol-red: #9b0b0e;
  --tbscol-green: #1baf20;
  --tbscol-white: #ffffff;
  --tbscol-grey: #ededed;
  --tbs-radius: 2px;
  --tbs-shadow: 0 0 15px -9px var(--tbscol-dark);
  --tbs-ease: ease .3s;
  --tbs-gbg-red-dark: linear-gradient(var(--tbscol-red), #000000);
  --tbs-gbg-dark-red: linear-gradient(#000000, var(--tbscol-red));
}

/* ---- 
	Page Layout 
	---- */

.rsgdxtbs-hidden {
	display: none!important;
}

hr.rsgdxtbs-hr {
	margin: 10px 0;
	background-color: var(--tbscol-dark);
}
span.rsgdxtbs-hr {
	margin: 10px 0;
	background-color: var(--tbscol-dark);
	display: block;
	height: 1px;
	width: 70%;
}

.rsgdxtbs-flex-center {
	display: flex;
	flex-direction: row;
	align-items: center;
	flex-wrap: nowrap;
	gap: 10px;
}

.rsgdxtbs-flex-start {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	gap: 10px;
	align-items: stretch;
}

.rsgdxtbs-flex-end {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	gap: 10px;
	align-items: flex-end;
}

.rsgdxtbs-flex-space {
	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 10px;
}

.rsgdxtbs-text-left {
	text-align: left;
}
.rsgdxtbs-text-center {
	text-align: center;
}
.rsgdxtbs-text-right {
	text-align: right;
}

.rsgdxtbs-wd-40 {
	width: 40%;
}
.rsgdxtbs-wd-100 {
	width: 100%;
}

.rsgdxtbs-bg-red {
	background: var(--tbs-gbg-red-dark);
}

.rsgdxtbs-col-red {
	color: var(--tbscol-red);
}
/* ---- 
	CARDS 
	---- */
.rsgdxtbs-card-shadow {
	box-shadow: var(--tbs-shadow);
	padding: 10px;
	position: relative;
}

.rsgdxtbs-card-shadow input,
.rsgdxtbs-card-shadow select,
.rsgdxtbs-card-shadow textarea {
	width: 100%;
	display: inline-block;
	max-width: 100%;
}
.rsgdxtbs-card-shadow input[type="checkbox"] {
	width: 15px;
	height: 15px;
	border-radius: 2px;
}
.rsgdxtbs-card-id {
	font-size: 9px;
}

/* ---- ---- ---- ----
	BUTTON 
	---- ---- ---- ---- */

button.rsgdxtbs-btn, .rsgdxtbs-btn, a.rsgdxtbs-btn {
	cursor: pointer;
	transition: var(--tbs-ease);
	padding: 5px 10px;
	border-radius: var(--tbs-radius);
	display: inline-block;
	position: relative;
	background: var(--tbscol-white);
	color: var(--tbscol-dark);
	border: 1px solid var(--tbscol-dark);
	outline: none!important;
	text-decoration: none;
	box-shadow: none !important;
	line-height: 12px;
	font-size: 12px;
}
button.rsgdxtbs-btn:hover, .rsgdxtbs-btn:hover {
	transition: var(--tbs-ease);
}

/* ---- 
	BUTTON: DARK 
	---- */

button.rsgdxtbs-btn.dark, .rsgdxtbs-btn.dark {
	background: var(--tbscol-dark);
	border: 1px solid var(--tbscol-dark);
	color: var(--tbscol-white);
}
button.rsgdxtbs-btn.dark:hover, .rsgdxtbs-btn.dark:hover {
	color: var(--tbscol-dark);
	background: var(--tbscol-white);
}

/* ---- 
	BUTTON: WARNING BACKGROUND
	---- */

button.rsgdxtbs-btn.warn, .rsgdxtbs-btn.warn {
	background-color: var(--tbscol-red);
	background-image: var(--tbs-gbg-red-dark);
	color: var(--tbscol-white);
}
button.rsgdxtbs-btn.warn:hover, .rsgdxtbs-btn.warn:hover {
	font-weight: 600;
}

/* ---- 
	BUTTON: WARNING RED 
	---- */

button.rsgdxtbs-btn.red, .rsgdxtbs-btn.red {
	background-color: var(--tbscol-red);
	border: 1px solid var(--tbscol-red);
	color: var(--tbscol-white);
}
button.rsgdxtbs-btn.red:hover, .rsgdxtbs-btn.red:hover {
	color: var(--tbscol-red);
	background: var(--tbscol-white);
}

/* ---- 
	BUTTON: SUCCESS 
	---- */

button.rsgdxtbs-btn.success, .rsgdxtbs-btn.success {
	background: var(--tbscol-green);
	border: 1px solid var(--tbscol-green);
	color: var(--tbscol-white);
}
button.rsgdxtbs-btn.success:hover, .rsgdxtbs-btn.success:hover {
	color: var(--tbscol-green);
	background: var(--tbscol-white);
}

/* ---- 
	BUTTON: BLANK 
	---- */

button.rsgdxtbs-btn.blank, .rsgdxtbs-btn.blank {
	background: none;
	border: 1px solid transparent;
	color: var(--tbscol-dark);
}
button.rsgdxtbs-btn.blank:hover, .rsgdxtbs-btn.blank:hover {
	color: var(--tbscol-dark);
	transform: scale(1.1);
}

/* ---- 
	BUTTON: BORDERED 
	---- */

button.rsgdxtbs-btn.border, .rsgdxtbs-btn.border {
	background: var(--tbscol-white);
	border: 1px solid var(--tbscol-dark);
	color: var(--tbscol-dark);
}
button.rsgdxtbs-btn.border:hover, .rsgdxtbs-btn.border:hover {
	color: var(--tbscol-white);
	background: var(--tbscol-dark);
	border: 1px solid var(--tbscol-white);
}

/* ---- 
	BUTTON: CLEAN 
	---- */

button.rsgdxtbs-btn.clean, .rsgdxtbs-btn.clean {
	background: none;
	border: none;
	border-bottom: 1px solid var(--tbscol-dark);
	border-radius: 0;
	color: var(--tbscol-dark);
}
button.rsgdxtbs-btn.clean:hover, .rsgdxtbs-btn.clean:hover {
	color: var(--tbscol-white);
	background: var(--tbscol-dark);
}

/* ---- 
	SEARCH 
	---- */

.rsgdxtbs-tb-search {
	position: relative;
	gap: ;
}
.rsgdxtbs-tb-search input,
.rsgdxtbs-tb-search select {
	width: 100%;
	border: 1px solid var(--tbscol-dark);
	border-radius: var(--tbs-radius);
	color: var(--tbscol-dark);
	outline: none!important;
	box-shadow: none!important;
	max-width: 300px;
	font-size: 14px;
}

.rsgdxtbs-input-wrap {
	display: flex;
	gap: 5px;
	align-items: center;
	padding: 1px 10px;
	border: 1px solid var(--tbscol-dark);
	border-radius: var(--tbs-radius);
	max-width: 300px;
}
.rsgdxtbs-input-wrap > input {
	padding: 0;
	border: none;
}

/* ---- 
	TOOLTIP 
	---- */

.rsgdxtbs-td-tooltip {
	position: relative;
	cursor: help;
}
.rsgdxtbs-td-tooltip:hover .rsgdxtbs-td-tooltip-small {
	display: block;
}
.rsgdxtbs-td-tooltip .rsgdxtbs-td-tooltip-small {
	display: none;
	position: absolute;
	z-index: 2;
	background: #fff;
	border: 1px solid #aeaeae;
	padding: 10px;
	left: 10px;
	top: 80%;
	font-style: italic;
	font-size: 10px;
	font-weight: 400;
}

/* ---- 
	LOADER 
	---- */

.rsgdxtbs-content-loader {
	position: absolute;
	inset: 0;
	background: rgba(0,0,0,0.5);
	width: 100%;
	padding: 20px;
	display: none;
	justify-content: center;
	align-items: center;
	height: 100%;
	z-index: 0;
	pointer-events: none;
}
.rsgdxtbs-content-loader.active {
	z-index: 9999;
	display: flex;
	pointer-events: auto;
}
.rsgdxtbs-loader-spin {
	width:32px;
	height:32px;
	border:4px solid #e5e7eb;
	border-top-color:#1f2937;
	border-radius:50%;
	animation:rsgdxtbs-loader-spin 0.8s linear infinite;
}

@keyframes rsgdxtbs-loader-spin {
	from { transform:rotate(0deg); }
	to   { transform:rotate(360deg); }
}

/* ---- Left Sidebar Navigation ---- */

.rsgdxtbs-tabs-nav {
	width:220px;
	background:#1f2937;
	border-radius:2px;
	padding:20px;
	display:flex;
	flex-direction:column;
}

.rsgdxtbs-page-title {
	color:#fff;
	font-size:18px;
	font-weight:600;
	margin:0;
}

hr.rsgdxtbs-tabs-nav-hr {
	width: 100%;
	border-top: 0;
	border-color: #aeaeae;
}

/* ---- Sidebar Buttons ---- */

.rsgdxtbs-tab-btn {
	display:block;
	width:auto;
	text-align:left;
	padding:12px 20px;
	background:none;
	border:none;
	color:#cbd5e1;
	font-size:14px;
	cursor:pointer;
	transition:0.2s;
	border-radius:0;
	outline: none!important;
	text-decoration: none!important;
}

.rsgdxtbs-tab-btn:hover {
	background:#374151;
	color:#fff;
}

.rsgdxtbs-tab-btn.active {
	background:#4b5563;
	color:#fff;
}

/* ---- Right Content Panel ---- */

.rsgdxtbs-tab-content {
	flex:1;
	background:#fff;
	padding:20px;
	border-radius:2px;
	border:1px solid #e5e7eb;
	box-shadow:0 1px 3px rgba(0,0,0,0.08);
	display:none;
}

.rsgdxtbs-tab-content.active {
	display:block;
}

.rsgdxtbs-tab-content-no-left {
	display: block;
	flex:1;
	background:#fff;
	padding:20px;
	border-radius:2px;
	border:1px solid #e5e7eb;
	box-shadow:0 1px 3px rgba(0,0,0,0.08);
}

/* ---- Personal Form ---- */

.rsgdxtbs-personal-form {
	max-width:600px;
}

.rsgdxtbs-field {
	margin-bottom:20px;
}

.rsgdxtbs-label {
	display:block;
	font-weight:600;
	margin-bottom:6px;
}

.rsgdxtbs-input,
.rsgdxtbs-textarea {
	width:100%;
	padding:10px;
	border:1px solid #cfcfcf;
	border-radius:6px;
	font-size:14px;
	background:#fff;
}

.rsgdxtbs-textarea {
	height:100px;
	resize:vertical;
}

/* ---- Avatar Preview ---- */

.rsgdxtbs-avatar-preview {
	margin-bottom:10px;
}

.rsgdxtbs-avatar-img {
	width:80px;
	height:80px;
	border-radius:50%;
	object-fit:cover;
}

/* ---- Note Text ---- */

.rsgdxtbs-note {
	font-size:13px;
	color:#555;
}

.rsgdxtbs-error-note {
	font-size: 12px;
	color: var(--tbscol-white);
	background: var(--tbscol-red);
	padding: 20px;
	text-align: center;
	position: fixed;
	z-index: 99999;
	bottom: 20%;
	right: 0;
	width: 100%;
	max-width: 300px;
}
.rsgdxtbs-error-note.success {
	background: var(--tbscol-green);
}

.rsgdxtbs-error-note.page-warning {
	inset: 0;
	
}

/* ---- Save Button ---- */

.rsgdxtbs-save-btn {
	margin-top:10px;
	padding:8px 16px;
	font-size:14px;
	border-radius:6px;
}

/* ---- ---- ---- ---- 
	Table | TABLE
	---- ---- ---- ---- */
table.rsgdxtbs-bordered-table {
	margin: 20px 0;
	border: none;
	border-radius: unset;
	outline: none;
	width: 100%;
}
table.rsgdxtbs-bordered-table thead tr {
	background: var(--tbscol-dark);
	color: var(--tbscol-white);
}
table.rsgdxtbs-bordered-table thead tr th {
	padding: 5px;
	font-size: 15px;
}
table.rsgdxtbs-bordered-table tbody tr td {
	padding: 5px;
	font-size: 14px;
	border-bottom: 1px solid var(--tbscol-dark);
}
table.rsgdxtbs-bordered-table tbody tr td.align-top {
	vertical-align: top;
}
table.rsgdxtbs-bordered-table thead tr th.max-width,
table.rsgdxtbs-bordered-table tbody tr td.max-width {
	width: 200px!important;
}
table.rsgdxtbs-bordered-table tbody tr.cancelled > td {
	/*background: #c38585;*/
	/*color: var(--tbscol-white);*/
}
table.rsgdxtbs-bordered-table td img.thumbnail {
	width: 100%;
	max-width: 200px;
	height: 80px;
	object-fit: cover;
}
table.rsgdxtbs-bordered-table td img.thumbnail.rsgdxtbs-modal-trigger {
	cursor: zoom-in;
	transition: ease .2s;
}
table.rsgdxtbs-bordered-table td img.thumbnail.rsgdxtbs-modal-trigger:hover {
	transform: scale(1.1);
	transition: ease .2s;
}
table.rsgdxtbs-bordered-table .rsgdxtbs-bg-grey {
	background: var(--tbscol-grey);
	padding: 5px;
}
table.rsgdxtbs-bordered-table .rsgdxtbs-bg-red {
	background: #c38585;
	padding: 5px;
	color: var(--tbscol-white);
}

.rsgdxtbs-custom-table {
	margin: 20px 0;
}
.rsgdxtbs-custom-table-avatar-container {
	display: flex;
	flex-direction: row;
	align-items: center;
	flex-wrap: nowrap;
	gap: 2px;
}
.rsgdxtbs-custom-table-avatar {
	width:40px;
	height:40px;
	border-radius:50%;
	object-fit:cover;
}
.rsgdxtbs-item-edit {
	cursor: pointer;
	transition: ease .3s;
	background: #1f2937;
	border: 1px solid #1f2937;
	color: #fff;
	padding: 2px 10px;
	border-radius: 2px;
	display: inline-block;
	margin-top: 5px;
}
.rsgdxtbs-item-edit:hover {
	background: #fff;
	color: #1f2937;
	transition: ease .3s;
}
tr.rsgdxtbs-editing .rsgdxtbs-item-edit {
	transition: ease .3s;
	background: #c82121;
	border-radius: 5px;
	border-color: #c82121;
	transition: ease .3s;
}
tr.rsgdxtbs-editing .rsgdxtbs-item-edit:hover {
	transition: ease .3s;
	background: #fff;
	color: #c82121;
}


/* ---- Service Icons ---- */

.rsgdxtbs-service-icons {
	display:flex;
	gap:6px;
	flex-wrap:wrap;
}

.rsgdxtbs-service-icon {
	width:32px;
	height:32px;
	border-radius:4px;
	object-fit:cover;
	cursor:pointer;
}

/* ---- Badges ---- */

.rsgdxtbs-badge {
	padding:4px 8px;
	border-radius:4px;
	font-size:12px;
	display:inline-block;
	font-weight:600;
}

.rsgdxtbs-badge-info {
	background:#e5f0ff;
	color:#1d4ed8;
}

.rsgdxtbs-badge-success {
	background:#dcfce7;
	color:#15803d;
}

.rsgdxtbs-badge-danger {
	background:#fee2e2;
	color:#b91c1c;
}

/* ---- Active Dropdown ---- */

.rsgdxtbs-active-select {
	padding:6px 8px;
	font-size:13px;
	border-radius:6px;
	border:1px solid #cfcfcf;
	background:#fff;
}

/* ---- Loading Screen ---- */
.rsgdxtbs-loading-screen {
	background: rgba(0, 0, 0, 0.3);
	position: fixed;
	width: 100%;
	padding: 20px;
	display: flex;
	justify-content: center;
	align-items: center;
	height: 100%;
	inset: 0;
	z-index: 9999;
}

.rsgdxtbs-spinner {
	width:32px;
	height:32px;
	border:4px solid #e5e7eb;
	border-top-color:#2563eb;
	border-radius:50%;
	animation:rsgdxtbs-spin 0.8s linear infinite;
}

@keyframes rsgdxtbs-spin {
	from { transform:rotate(0deg); }
	to   { transform:rotate(360deg); }
}

/* ---- Loading Screen ---- */
.rsgdxtbs-custom-table-search {
	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content: space-between;
}
input.rsgdxtbs_custom_table_search {
	border-radius: 2px;
	border: none;
	outline: none!important;
	box-shadow: 0 0 15px -4px #1f2937!important;
	width: 100%;
	padding: 5px 10px;
	font-size: 11px;
	max-width: 250px;
}
.rsgdxtbs-custom-table-search-actions {
	display: flex;
	flex-direction: row;
	gap: 5px;
}


/* ---- My Service Table ---- */
table#rsgdxtbs-tab-services-table thead th {
	width: 120px;
}
table#rsgdxtbs-tab-services-table thead th:last-child {
	width: 200px;
}
.rsgdxtbs-myservice-edit {
	width: 100%;
}
.rsgdxtbs-availability-weekly {
	display: flex;
	flex-direction: row;
	gap: 10px;
	flex-wrap: wrap;
}

/* ---- Settings: Payment ---- */
.rsgdxtbs-payment-box {
	width: 100%;
	max-width: 400px;
	box-shadow: 0 0 15px -9px #000;
	padding: 10px;
	position: relative;
}
.rsgdxtbs-payment-box input[type="text"],
.rsgdxtbs-payment-box textarea {
	width: 100%;
}

/* ---- ---- ----
	Modal | MODAL
	---- -------- */
.rsgdxtbs-modal-wrap {
	position: fixed;
	inset: 0;
	top: 100%;
	z-index: 0;
	opacity: 0;
	background: #1f293794;
	display: flex;
	justify-content: center;
	align-items: flex-start;
	padding: 20px;
	padding-top: 100px;
	transition: ease .2s;
}
.rsgdxtbs-modal-wrap.active {
	transition: ease .2s;
	z-index: 2;
	opacity: 1;
	top: 0;
}
.rsgdxtbs-modal-container {
	width: 100%;
	max-width: 767px;
	background-color: var(--tbscol-white);
	color: var(--tbscol-dark);
	overflow: hidden;
	position: relative;
}
.rsgdxtbs-modal-body {
	position: relative;
	overflow-x: hidden;
	overflow-y: auto;
	max-height: 70vh;
	display: block;
	padding: 20px;
}
.rsgdxtbs-modal-header {
	position: relative;
	padding: 10px 40px 10px 10px;
	background: var(--tbscol-dark);
	color: var(--tbscol-white);
	font-size: 14px;
}
.rsgdxtbs-modal-header h5 {
	font-size: 20px;
	font-family: serif;
	text-transform: uppercase;
	margin: 0!important;
}
.rsgdxtbs-modal-header-small {
	font-size: 16px;
	font-weight: 700;
}
.rsgdxtbs-modal-warning-section {
	background: var(--tbs-gbg-red-dark);
	color: var(--tbscol-white);
	padding: 10px;
	border-radius: 3px;
}
.rsgdxtbs-modal-close {
	position: absolute;
	top: 0;
	right: 0;
	z-index: 3;
	font-size: 20px;
	cursor: pointer;
	transition: ease .2s;
	color: var(--tbscol-white);
	background: var(--tbscol-red);
	width: 40px;
	height: 95%;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 1px solid var(--tbscol-red);
}
.rsgdxtbs-modal-close:hover {
	transition: ease .2s;
	background: var(--tbscol-white);
	color: var(--tbscol-red);
}
.rsgdxtbs-modal-wrap.rsgdxtbs-thumbnail-modal .rsgdxtbs-modal-container img {
	object-fit: cover;
	width: 100%;
	height: 100%;
	max-height: 60vh;
	display: block;
}
.rsgdxtbs-modal-footer {
	padding: 10px;
	background: var(--tbscol-grey);
	position: relative;
	display: flex;
	align-items: center;
	justify-content: flex-end;
	flex-direction: row;
	flex-wrap: nowrap;
	gap: 5px;
}