/* --------------------------------------------COLORS */

/* Blue :#2C323F; */
/* Red :#2C323F; */
/* Yellow: #FFB806; */
/* Green: #61CE70; */
/* Dark Blue :#001D5B; */
/* Light Gray :#EBEFF5; */



/* --------------------------------------------LAYOUT */

html {
	height:100%;
	padding:0;
	margin:0;
	width: 100%;
	max-width: 100%;
  overflow-x: hidden;  /* Prevent horizontal overflow */
}

body {
	font-family: Arial, "Helvetica Neue", Helvetica, sans-serif;
	font-size:12px;
	background-color:#2C323F;
	padding:0;
	margin:0;
	height:100%;
	  width: 100%;
  max-width: 100%;
  overflow-x: hidden;  /* Prevent horizontal overflow */
}



html, body {
  width: 100%;
  max-width: 100%;
  overflow-x: hidden;  /* Prevent horizontal overflow */
  margin: 0;
  padding: 0;
}

.site_container {

	margin:0 auto;
	background-color:#2C323F;
	height:100%;
	position:relative;
}

.content_container {
	border-left:1px solid #f1f1f1;
	max-width:100%;
	overflow:hidden;
	display:block;
	padding:30px;
	background-color:#ffffff;
	min-height:100%;
}

.footer {
	display:block;
	width:100%;
	background-color:#2C323F;
	color:#ffffff;
	bottom: 0;  
	height: 40px; 
}

.footer p {
	padding-top:13px;
}

.header {
	width:100%;
	display:block;
	background-color:#2C323F;
}

.admin_header {
	max-width:100%;
	display:block;
	background-color:#F7F7F9;
}

.header_content {
	margin:0 auto;
	padding:20px;
	display:block;
	height:30px;
}

.logo {
	float:left;
	width:20%;
	display:block;
	padding-top:5px;
}

.admin_logo {
	display:block;
	padding-bottom:10px;
}

.menu {
	color:#ffffff;
	display:block;
	padding-top:5px;
	text-align:right;
}

.menu a {
	color:#ffffff;
	font-size:14px;
	text-decoration: none;
}

.menu ul li {
  display:inline;
  padding-left:10px;
}

.admin_menu {
	color:#000000;
	display:block;
	padding-top:5px;
	text-align:right;
}

.admin_menu a {
	color:#000000;
	font-size:14px;
	text-decoration: none;
}

.admin_menu ul li {
  display:inline;
  padding-left:10px;
}

.admin_header_content {
	margin:0 auto;
	padding:20px;
	display:block;
}

.header_title {
	display:block;
	max-width:100%;
	padding:0px;
}

.header_title h1 {
    line-height: 1.2; /* Adjust this to fine-tune line spacing */
    margin:0;
	padding: 0px 20px; /* Adjust padding as needed */
    display: inline-block; /* Prevents extra space below the element */
    overflow: hidden;
    text-overflow: ellipsis;
    word-wrap: break-word; /* Allows long words to wrap to the next line */
}

/* Default sidebar for desktop */
.sidebar {
  background-color: #2D3240;
  color: #ffffff;
  width: 20%;  /* Sidebar stays 20% on desktop */
  float: left;
  height: 100%;
  padding: 30px;
}

/* Hide mobile menu button by default on desktop */
.menu-button-mobile {
  display: none;
}

/* Center the logo */
.admin_logo {
  text-align: center;  /* Center the logo */
  margin-bottom: 10px;
}

.admin_logo img {
  display: inline-block;
  max-width: 100%;  /* Ensure the logo doesn't overflow */
}

/* Mobile-specific styles */
@media screen and (max-width: 600px) {
  .sidebar {
    width: 100%;  /* Ensure the sidebar takes the full width of the viewport */
    max-width: 100%;  /* Remove any width restrictions */
    padding: 10px;
    float: none;
    height: auto;  /* Adjust height based on content */
  }

  /* Custom Menu button for mobile */
  .menu-button-mobile {
    display: block;  /* Visible only on mobile */
    background-color: #282d38;
    color: #ffffff;
    padding: 10px;
    text-align: center;
    cursor: pointer;
    width: 100%;
    max-width: 100%;  /* Ensure button does not exceed mobile width */
    font-size: 18px;
    border: none;
  }

  /* Initially hide the menu content */
  .menu-content-mobile {
    display: none;
    background-color: #2D3240;
    width: 100%;
    max-width: 100%;  /* Ensure menu content fits within mobile screen */
  }

  .menu-content-mobile .sidebar-dashboard,
  .menu-content-mobile ul {
    width: 100%;  /* Ensure the menu content is full width */
  }

  .menu-content-mobile ul {
    padding: 0;
    margin: 0;
    list-style: none;
  }
}













.sidebar-back a {
	color:#ffffff !important;
	font-size:14px;
}

.sidebar-admin a {
	color:#ffffff !important;
}

.sidebar-heading {
	background-color:#2C323F;
	color:#ffffff;
	padding:5px;
	margin:15px 0 15px 0;
}

.sidebar-heading-title {
	font-weight:bold;
	font-size:16px;
	color:#ffffff;
}

.sidebar-dashboard {
	color:#ffffff !important;
	background-color: #5ba0e4;
	border-radius:5px;
	padding:9px 0px 9px 13px;
	margin:17px 0px 3px 0px;
	font-size:16px;
}

.sidebar-dashboard a {
	color:#ffffff !important;
	text-decoration:none;
}

.sidebar-heading-dates {
	font-size:12px;
}

.sidebar-item {
	clear:both;
	padding:15px;
}

.sidebar-item-active {
	clear:both;
	padding:15px;
	background-color:#212429;
}

.sidebar-icon {
	display:block;
	width:20%;
	float:left;
}
.sidebar-item {
	display:block;
	font-size:14px;
	padding-top:5px;
}

.admin_sidebar {
	background-color:#2C323F;
	color:#ffffff;
	max-width:20%;
	overflow:hidden;
	display:block;
	float:left;
	padding:10px;
	height: 100%;
}

.sidebar a, .admin_sidebar a {
	color:#000000;
}

.comments {
	display:block;
	color:#000000;
	padding:20px;
	background-color:#F1F1F1;
}



/* --------------------------------------------TEXT */



h1 {
	font-size:30px;
	color:#2C323F;
}

h2 {
	color:#2C323F;
	font-size:20px;
}

h3 {
	
}

h4 {
	
}

h5 {
	
}

p {
	font-size:13px;
}

a {
	color:#2C323F;
}

h4.line-heading {
	border-bottom:1px solid #cccccc;
	margin-right:10px;
	font-size:16px;
	text-transform:uppercase;
	color:#617aaf;
}

ul {
	    padding-inline-start:5px;
}

.ui-state-active {
	background-color:#2C323F !important;
	border:#2C323F !important;;
}

img.blog-list {
	width:300px;
  height:300px;
  object-fit:cover;
}


/* --------------------------------------------PHASE MENU */

.phase_box {
	display:block;
	margin-bottom:10px ;
}
	
.status-current {
	display:inline-block;
	background-color:#2C323F;
	font-weight:bold;
	padding:10px;
	text-align:center;
	margin-bottom:20px;
}

.status-late {
	display:inline-block;
	background-color:#2C323F;
	color:#ffffff;
	font-weight:bold;
	padding:10px;
	text-align:center;
	margin-bottom:20px;
}

.status-waiting {
	display:inline-block;
	background-color:#EBEFF5;
	font-weight:bold;
	padding:10px;
	text-align:center;
	margin-bottom:20px;
}

.status-complete {
	display:inline-block;
	background-color:#61CE70;
	font-weight:bold;
	padding:10px;
	text-align:center;
	margin-bottom:20px;
}

.phase {
	display:block;
	background-color:#ffffff;
	border:1px solid #cccccc;
	padding:10px 10px 20px 10px;
	text-align:center;
}

.buttons {
	display:block;
	margin-top:-27px;
	padding:0 10px 0 10px;
	text-align:center;
}


/* --------------------------------------------BUTTONS */

.button {
	display:inline-block;
	background-color:#2C323F;
	color:#ffffff;
	border-radius:25px;
	padding:10px 25px;
	cursor: pointer;
	border:none;
	text-align:center;
}

.button-grey {
	display:inline-block;
	background-color:#EBEFF5;
	color:#000000;
	border-radius:25px;
	padding:10px 25px;
	cursor: pointer;
	border:none;
	text-align:center;
}

.button a {
	color:#ffffff !important;
	text-decoration:none;
}

.button-grey a {color:#000000;text-decoration:none;}

/* --------------------------------------------FORMS */

/*

input {
	width:100%
}
select {
	width:100%
}

*/

input[type=text], input[type=password], input[type=date],  input[type=number],  input[type=email],input[type=time],select {
  width: 100%;
  padding: 12px 20px;
  margin: 8px 0;
  display: inline-block;
  border: 1px solid #ccc;
  border-radius: 4px;
  box-sizing: border-box;
}

input[type=button], input[type=submit], input[type=reset] {
	background-color:#2C323F;
	color:#ffffff;
	border-radius:25px;
	padding:10px 35px;
	cursor: pointer;
	border:none;
}


textarea
{

    width: 100%;
  padding: 12px 20px;
  margin: 8px 0;
  display: inline-block;
  border: 1px solid #ccc;
  border-radius: 4px;
  box-sizing: border-box;
}

.scroll {
	padding:4px; 
	width: 100%; 
	height: 300px; 
	overflow-x: hidden; 
	overflow-y: scroll; 
	text-align:justify;
	border:1px solid #cccccc;
}

.wrapper {
  position: relative;
  width: 400px;
  height: 200px;
  -moz-user-select: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  user-select: none;
  border:1px solid #cccccc;
}

.signature-pad {
  position: absolute;
  left: 0;
  top: 0;
  width:400px;
  height:200px;
}

.login-box {
	background-color:#EBEFF5;
	border-radius: 10px;
	width: 40%;
	margin:0px auto;
	padding:20px;
	color:#000000;
}

.login_site_container {
	background-color:#2C323F;
	margin:0 auto;
	min-height: 100%;
	position:relative;
}

.loginbody {
	background-color:#2C323F;
}
		
@media (max-width: 600px) {
	.login-box {
	min-width: 90% !important;
  }
}

/* The switch - the box around the slider */
.switch {
  position: relative;
  display: inline-block;
  width: 60px;
  height: 34px;
}

/* Hide default HTML checkbox */
.switch input {
  opacity: 0;
  width: 0;
  height: 0;
}

/* The slider */
.slider {
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #ccc;
  -webkit-transition: .4s;
  transition: .4s;
}

.slider:before {
  position: absolute;
  content: "";
  height: 26px;
  width: 26px;
  left: 4px;
  bottom: 4px;
  background-color: white;
  -webkit-transition: .4s;
  transition: .4s;
}

input:checked + .slider {
  background-color: #7ABD00;
}

input:focus + .slider {
  box-shadow: 0 0 1px #7ABD00;
}

input:checked + .slider:before {
  -webkit-transform: translateX(26px);
  -ms-transform: translateX(26px);
  transform: translateX(26px);
}

/* Rounded sliders */
.slider.round {
  border-radius: 34px;
}

.slider.round:before {
  border-radius: 50%;
}

/* --------------------------------------------TABLES */

.datatable {
  border-collapse: collapse;
  max-width: 100%;
}

.datatable td, #customers th {
  border: 1px solid #ddd;
  padding: 8px;
}

.datatable th {
	padding: 12px;
	text-align: left;
	background-color: #001D5B;
	color: white;
}

.datatable tr:nth-child(even){background-color: #f2f2f2;}

.datatable tr:hover {background-color: #ddd;}

.order_table {
	border-collapse: collapse;
	min-width: 96.5%;
	border: 1px solid #ddd;
	padding: 8px;
	margin:20px;
}

.order_table th {
	padding: 12px;
	text-align: left;
	font-size:13px;
	background-color: #F8F8F8;

}

.order_table td, th {
	border: 1px solid #ddd;
	padding: 8px;
}

	

/* --------------------------------------------ROWS & COLUMNS */

.column-1-5 {
  float: left;
  width: 20%;
  box-sizing: border-box;
  word-wrap: break-word;
  
}.column-1-4 {
  float: left;
  width: 25%;
  box-sizing: border-box;
  word-wrap: break-word;
}
.column-1-3 {
  float: left;
  width: 33%;
  box-sizing: border-box;
  word-wrap: break-word;
}
.column-2-3 {
  float: left;
  width: 66%;
  box-sizing: border-box;
  word-wrap: break-word;
}
.column-3-4 {
  float: left;
  width: 75%;
  box-sizing: border-box;
  word-wrap: break-word;
}
.column-1-2 {
  float: left;
  width: 50%;
  box-sizing: border-box;
  word-wrap: break-word;
}

.column-1 {
  width: 100%;
  box-sizing: border-box;
}

/* Clear floats after the columns */
.row:after {
  content: "";
  display: table;
  clear: both;
}

/* Responsive - Screen < 600px wide then stack em */
@media screen and (max-width: 600px) {
 .column-1-4, .column-1-3, .column-2-3, .column-1-2, .column-1-5 {
    width: 100%;
	clear:both;
  }
}

/* --------------------------------------------ROWS & COLUMNS - COLORED */

.column-1-3-grey {
  float: left;
  box-sizing: border-box;
  word-wrap: break-word;
  background-color:#f8f8f8;
  border-radius:15px;
  margin:1%;
  width:31%;
  padding:10px 20px;
}

/* Responsive - Screen < 600px wide then stack em */
@media screen and (max-width: 600px) {
 .column-1-3-grey {
    width: 100%;
	clear:both;
  }
}

  /* --------------------------------------------PRODUCT CATEGORY */
  
  .prod_img
  {
	display:block;
	max-width:100%;
	max-height:200px;
	margin-left: auto;
	margin-right: auto;
  }

  
  .listing_box {
	  background-color:#ffffff;
	  display:block;
	  padding:10px;
		
  }
  
  	.reset-button {
	color: var(--fw-red);
    background-color: #ffffff;
	border:0;
	padding:0;
	text-decoration:underline;
	margin:20px 0;
  }
  
	.product_name {
		font-size:16px;
		color:#54595F;
		text-align:center;
	}
		  
	.product_price {
		font-size:14px;
		color:#000000;
		text-align:center;
	}
	
	.pdp_price {
		font-size:16px;
		color: var(--fw-red);
		font-weight:bold;
	}
	
	  /* -------------------------------------------- OTHER UI */
	  
	  .alert {
	  	background-color:#daefff;
	  	text-align:center;
	  	padding:10px;
	  	font-size:14px;
	  }
	  
	  .hero {
	  	background-color:#2D3240;
	  	color:#ffffff;
	  	text-align:center;
	  	padding:20px;
	  }
	  .hero h1 {
	  	font-size:30px;
	  	color:#ffffff;
	  }
	  
	  /* --------------------------------------------ADMIN BUTTONS */
	  
	.admin_button_right {
	display:block;
	float:right;
	color:#ffffff;
	background-color: #5ba0e4;
	border-radius:25px;
	padding:10px 20px;
	font-size:14px;
	margin:10px 0px;
	}
	
		.admin_button_left {
	display:block;
	color:#ffffff;
	background-color: #5ba0e4;
	border-radius:25px;
	padding:10px 20px;
	font-size:14px;
	margin:10px 0px;
	}
	  
	  /* -------------------------------------------- PAGE EDITOR */	  
	  
.edit-sidebar {
	background-color:#F9F9F9;
	border-right:1px solid #000000;
	color:#000000;
	max-width:20%;
	width:260px;
	display:block;
	float:left;
	height: 100vh;
	overflow-y: scroll;
	overflow-x: hidden;
}

.ui-state-highlight, .ui-widget-content .ui-state-highlight, .ui-widget-header .ui-state-highlight {
	border:1px solid #cccccc !important;
	background:none !important;
	max-width:100%;
}

.edit-back {
	background-color:#8e8e8e;
	float:left;
	width:50%;
	clear:left;
	box-sizing: border-box;
	padding:5px;
	text-align:center;
	color:#ffffff;
}

.edit-save {
	background-color:#50b25d;
	float:left;
	width:50%;
	clear:right;
	box-sizing: border-box;
	padding:5px;
	text-align:center;
	color:#ffffff;
}

.edit-back a {
	text-decoration: none;
	color:#ffffff;
}
	
.edit-save a {
	text-decoration: none;
	color:#ffffff;
}

.edit-sidebar-heading {
	background-color:#2C323F;
	color:#ffffff;
	margin-top:0;
	padding:5px;
}

.edit-sidebar-logo {
	float:left;
	padding:5px;
}

.edit-sidebar-name h1 {
	font-weight:bold;
	font-size:16px;
	color:#ffffff;
	display:inline-block;
}

.ui-corner-all {
	border-radius: 0px !important;
}

.ui-tabs {
	padding:0 !important;
}

.edit-tabs {
	border-radius: 0px !important;
	font-size:10px;
}

.ul_sidebar {
    list-style-type: none;
}

.ui-accordion .ui-accordion-content   {
	background-color:#2C323F !important;
	padding:0px 0px 0px 35px !important;
	margin:0px !important;
}

.ui-accordion-content  {
	border:0px !important;
}

.ui-accordion .ui-widget-content a {
	color:#ffffff !important;
	text-decoration:none;
	padding-bottom:5px;
}

.ul_sidebar li {
	font-size:13px;
	padding-bottom:5px;
}

.sidebar h3 {
	font-size:16px !important;
	color:#cccccc !important;
	border-radius:5px !important;
}

.sidebar h3:hover {
	background-color:#242731 !important;
	border-radius:5px !important;
	color:#000000;
}

.ui-accordion .ui-accordion-header {
    display: block;
    cursor: pointer;
    position: relative;
    margin: 2px 0 0 0;
    padding: 0.5em 0.5em 0.5em 0.7em;
    font-size: 16px;
	color:#ffffff;
	background-color:#282d38 !important;
	border-radius:5px;
	border:0;
}

h3.ui-state-active {
	background-color:red;
}

.edit-main {
	max-width:100%;
	overflow:hidden;
	display:block;
	padding:15px 15px 0px 15px;
}

.edit-sidebar ul {
	list-style-type:none;
}

ul#sortable {
	list-style-type:none;
}

#content_box_drag p img {
	max-width:72%;
	border:1px solid #cccccc;
}

.content_box { 
  padding:5px; 
  width:300px; 
  float:left;
  height:250px; 
  font-family:Verdana, Arial, Helvetica, sans-serif;
  margin:10px;
  overflow:auto;
  color:#999999;
  font-size:14px;
}

.content_holder_box{
	width:97%;
	border:1px solid #cccccc;
	float:right;
	height: 100px;
	padding:10px;
	margin:10px;
	color:#999999;
	font-size:14px;
}

.content_holder_box:hover{ 
  border:#0099FF solid 1px; 

}

.dragelement{ 
  padding:5px; 
  margin:3px; 
  width:270px; 
  cursor:move;
  color:#000;
  font-size:13px;
}

.dropper{
	width:100%;
	height:50px;
	margin:10px; 
}

.dropper_hover{ 
  border:#999999 dashed 1px; 
  background-color:#c1ffd5;
}









/* Ensure sidebar is relative so the button positions correctly */
.sidebar {
  position: relative;
  background-color: #2D3240;
  color: #ffffff;
  width: 20%;
  float: left;
  height: 100vh;
  padding: 30px;
  transition: width 0.3s ease-in-out;
}

/* Sidebar Toggle Button */
.sidebar-toggle {
  position: absolute;
  right: -15px; /* Keeps it aligned to sidebar edge */
  background-color: #282d38;
  color: white;
  border: none;
  padding: 8px 12px;
  cursor: pointer;
  font-size: 18px;
  z-index: 1000;
  border-radius: 5px;
  transition: all 0.3s ease-in-out;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.2);
}

/* Adjust hover styles */
.sidebar-toggle:hover {
  background-color: #3a404e;
}

/* When sidebar is collapsed, move button slightly */
.sidebar.collapsed {
  width: 50px; /* Adjust for collapsed state */
}

.sidebar.collapsed .sidebar-toggle {
  right: -20px; /* Keep it aligned */
}

/* Flip the toggle icon when collapsed */
.sidebar.collapsed .toggle-icon {
  transform: rotate(180deg);
  transition: transform 0.3s ease-in-out;
}

/* Change logo when sidebar is collapsed */
.sidebar .admin_logo img {
  width: 75%;
  transition: content 0.3s ease-in-out, width 0.3s ease-in-out;
}

.sidebar.collapsed .admin_logo img {
  content: url('https://tickets.houdinitickets.com/admin/images/houdini-tickets-icon-white.png');
  width: 80%;
}

/* Hide sidebar content when collapsed */
.sidebar.collapsed .sidebar-dashboard,
.sidebar.collapsed h3,
.sidebar.collapsed .ul_sidebar,
.sidebar.collapsed .menu-button-mobile,
.sidebar.collapsed #accordion {
  display: none;
}
/* Rotate the toggle icon when sidebar is collapsed */
.sidebar .toggle-icon {
  transition: transform 0.3s ease-in-out;
}

.admin_button_left{
	margin-top: 10px; 
	background-color: rgb(52, 152, 219); 
	color: white; 
	border: none;
	border-radius: 4px; 
	padding: 8px 16px;
	font-size: 14px; 
	font-weight: bold;
	cursor: pointer; 
	width: 100%;
	margin-bottom: 10px;
}