/* -----------------------------
   MuzBiz Form Styles (Hero/Pill UI)
   File: assets/muzbiz.css
   ----------------------------- */

/* Base variables */
:root {
  --muz-primary: #5b6cf6;      /* primary blue (can tweak) */
  --muz-accent: #ffffff;       /* form background */
  --muz-text: #2b2b2b;         /* main text */
  --muz-muted: #8c92a6;        /* placeholder / muted */
  --muz-radius-pill: 50px;
  --muz-form-max: 1100px;
  --muz-field-height: 64px;
  --muz-gap: 18px;
}


/*Home page slider */
/*home page category slider */
/* span.address-icon img {
    height: auto;
    width: 30px;
} */
/* Make editor width fluid */
.business_logo img {
    border-radius: 50% !important;
    height: 70px !important;
    width: 70px !important;
    border: 1px solid #000 !important;
}
.business_logo {
    position: relative;
    top: 25px;
    float: left;
    margin-top: -86px;
    border-radius: 50%;
    left: 12px;
}
.state_and_cate {
    display: flex;
    gap: 14px;
    margin-top: 28px;
    text-align: center;
}
.profile-links a svg{height:1em;width:1em;}
.inline-error {
    color: #ff9395;
    font-size: 13px;
    margin-top: 4px;
}
input#search {
    background: #fafafa;
    border-radius: 30px;
    border: 1px solid #ddd;
}
button#resetFilters {
    background: transparent;
    padding: 2px 12px !important;
    border: 2px solid #3B82F6;
    color: #000;
    border-radius: 5px !important;;
	font-family: 'Montserrat';
}
.muzbiz-filters-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.muzbiz-reset-btn {
    background: none;
    border: none;
    color: #888;
    font-size: 14px;
    cursor: pointer;
}

.muzbiz-reset-btn:hover {
    color: #000;
}

.sharibiz {
    position: absolute;
    top: 36px;
}
span.req-color {
    color: #ff4848;
    font-size: 19px;
}
.ck.ck-editor__main>.ck-editor__editable {
    background: var(--ck-color-base-background);
    border-radius: 0;
    color: #000;
	min-height: 100px;
}
.ck-editor__editable,
.ck-editor {
    width: 100% !important;
    max-width: 100%;
    box-sizing: border-box;
	min-height: 100px;
}

/* Ensure toolbar and editable area scale */
.ck-editor__main,
.ck-content {
    width: 100% !important;
}

/* Fix overflow issues in small screens */
.ck-reset_all,
.ck {
    max-width: 100% !important;
}



.category-img {
    width: 100%;
    height: 240px;
    background-size: cover;
    background-position: center;
    transition: transform .3s 
ease;
}
/* .category-img img {
    position: relative;
    top: 24px;
    left: 24px;
} */
/*End home page category slider */
.region-card {
	border-radius: 18px;
	overflow: hidden;
	position: relative;
}
.region-img {
	width: 100%;
	height: 240px;
	background-size: cover;
	background-position: center;
	transition: transform .3s ease;
}
.region-card:hover .region-img {
	transform: scale(1.05);
}
.region-content {
	position: absolute;
	bottom: 20px;
	left: 20px;
	color: #fff;
	text-shadow: 0 2px 8px rgba(0,0,0,0.4);
}
.region-title {
	font-size: 24px;
	font-weight: 700;
	margin: 0;
}
.region-desc {
	font-size: 15px;
	margin: 4px 0 0;
}

.swiper-pagination {
    position: relative !important;
    text-align: center;
    transition: .3s opacity;
    transform: translate3d(0,0,0);
    z-index: 10;
    margin-top: 20px;
}
/* End of slider */

/**** Directory Page CSS ****/

.mainimage span{
    color: #000!important;
}
.listing-certificate {
    margin: 13px 1px 30px 0px;
    padding: 0;
}

.listing-certificate span {
    padding: 10px 24px;
    background: #5674FF33;
    color: #5674FF;
    font-family: 'Montserrat';
    font-weight: 500;
    border-radius: 20px;
    font-size: 16px;
}

.file-btn input[type="file"]{
  position: absolute;
  opacity: 0;
  pointer-events: none;
  width: 0;
  height: 0;
}

.form-group.mainimage label {
    width: 100%;
	overflow:hidden;
}

.mainimage input {
    border: 1px solid #fff;
    padding: 11px 18px;
    background: #fff;
    color: #000;
    border-radius: 8px;
	    width: 100%;
}

/* Form container */

.muzbiz-search {
    display: flex;
    gap: 15px; /* space between fields */
    align-items: center;
    justify-content: center;
    flex-wrap: nowrap; /* keep all fields in one row */
}

.muzbiz-search select,.muzbiz-search input,
.muzbiz-search button {
    height: 50px;
    padding: 0 15px;
    border-radius: 30px!important;
    border: 1px solid #fff;
    font-size: 16px;
}
.muzbiz-search input{
	 height: 50px;
    padding: 0 15px;
    border-radius: 30px;
    border: 1px solid #fff!important;
    font-size: 16px;

}
/* Make fields equal width */


/* Style search button */
.muzbiz-search button {
    background: #fff;
    border: 2px solid #fff;
    cursor: pointer;
    min-width: 120px;
}


#muzbiz-submit-form,
.muzbiz-search {
  max-width: var(--muz-form-max);
  margin: 0 auto;
  padding: 28px;
  box-sizing: border-box;

  color: #fff;
}
form#muzbiz-submit-form label {
    padding-bottom: 10px;
}
/* Success message */
.muzbiz-success {
  background: rgba(255,255,255,0.08);
  color: #19ff00;
  padding: 12px 16px;
  border-radius: 10px;
  margin-bottom: 18px;
  text-align: center;
  font-weight: 600;
}

/* Form layout: use columns on large screens */
#muzbiz-submit-form p {
  margin: 0 0 var(--muz-gap) 0;
}

/* Inputs / textareas / selects */
#muzbiz-submit-form input[type="text"],
#muzbiz-submit-form input[type="email"],
#muzbiz-submit-form input[type="url"],
#muzbiz-submit-form input[type="tel"],
#muzbiz-submit-form textarea,
#muzbiz-submit-form select {
  display: block;
  width: 100%;
  height: 50px;
  line-height: 1.2;
  padding: 0 26px;
  background: var(--muz-accent);
  border: none;
 /*  border-radius: var(--muz-radius-pill);
  box-shadow: 0 6px 20px rgba(22, 43, 95, 0.12); */
  font-size: 16px;
  color: var(--muz-text);
  outline: none;
  box-sizing: border-box;
}

/* Textarea specific */
#muzbiz-submit-form textarea {
  min-height: 160px;
  height: auto;
  padding-top: 16px;
  padding-bottom: 16px;
  border-radius: 18px;
}

/* Placeholder color */
#muzbiz-submit-form input::placeholder,
#muzbiz-submit-form textarea::placeholder,
#muzbiz-submit-form select option[disabled] {
  color: var(--muz-muted);
}

/* Select caret styling: wrap select to add custom arrow */
#muzbiz-submit-form p label { position: relative; display: block; }
#muzbiz-submit-form select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  padding-right: 56px;
}
.form-group {
    width: 100%;
	overflow:hidden;
}
#muzbiz-submit-form p label::after {
  content: "▾";
  position: absolute;
  right: 22px;
  top: 50%;
  transform: translateY(-50%);
  pointer-events: none;
  color: var(--muz-muted);
  font-size: 18px;
}

/* File inputs: make them look like a button + text */
/* #muzbiz-submit-form input[type="file"] {
  display: none;
} */
.muzbiz-file-wrap {
  display: flex;
  align-items: center;
  gap: 12px;
}
.muzbiz-file-btn {
  background: var(--muz-accent);
  border-radius: var(--muz-radius-pill);
  padding: 10px 18px;
  box-shadow: 0 6px 20px rgba(22, 43, 95, 0.12);
  cursor: pointer;
  font-weight: 600;
  border: none;
}
.muzbiz-file-label {
  color: var(--muz-muted);
  font-size: 14px;
}

/* Checkbox */
#muzbiz-submit-form input[type="checkbox"]{
  transform: scale(1.1);
  margin-right: 10px;
}
.inquiry-form span {
    color: #ed4e4e;
}
/* Buttons */
#muzbiz-submit-form button[type="submit"],
.muzbiz-search button , .inquiry-form button[type="submit"]{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 54px;
  padding: 0 34px;
  border-radius: 999px;
  border: 2px solid #fff;
  background: #5674FF;
  color: #fff;
  font-weight: 700;
  font-size: 16px;
  cursor: pointer;
  transition: all 180ms ease;
}

/* Primary solid submit (for pages where you want filled look) */
#muzbiz-submit-form button.primary {
  background: var(--muz-primary);
  color: #fff;
  border: none;
  box-shadow: 0 10px 30px rgba(91,108,246,0.25);
}

/* Hover / focus */
#muzbiz-submit-form input:focus,
#muzbiz-submit-form textarea:focus,
#muzbiz-submit-form select:focus {
  box-shadow: 0 10px 30px rgba(91,108,246,0.16);
}
#muzbiz-submit-form button:hover,
.muzbiz-search button:hover { transform: translateY(-2px); }

/* Search form (hero) — horizontal pills */
.muzbiz-hero-row {
  display: flex;
  gap: 16px;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
}
.muzbiz-hero-row .muzbiz-field {
  flex: 1 1 280px;
  max-width: 420px;
}

/* Make the search button smaller & outlined */
.muzbiz-search select,
.muzbiz-search input {
  height: 56px;
  border-radius: 999px;
  padding-left: 22px;
  padding-right: 22px;
  box-shadow: none;
}
.muzbiz-search button {
  height: 56px;
  min-width: 140px;
  border-radius: 999px;
  border: 2px solid rgba(255,255,255,0.24);
  background: rgba(255,255,255,0.06);
  color: #fff;
  font-weight: 700;
}

/* On hero, make text color light for contrast against overlay */

.muzbiz-search select,
.muzbiz-search input { background: #fff;color: #666;}

/* Responsive behavior */
@media (max-width: 980px) {
  #muzbiz-submit-form {
    padding: 18px;
  }

  .muzbiz-hero-row {
    gap: 12px;
  }

  #muzbiz-submit-form input[type="text"],
  #muzbiz-submit-form input[type="email"],
  #muzbiz-submit-form select {
    height: 56px;
    padding-left: 18px;
    padding-right: 18px;
  }
}

@media (max-width: 640px) {
  .muzbiz-hero-row {
    flex-direction: column;
    align-items: stretch;
  }
  #muzbiz-submit-form button[type="submit"],
  .muzbiz-search button { width: 100%; }
  #muzbiz-submit-form textarea { min-height: 140px; }
  .muzbiz-search select, .muzbiz-search input, .muzbiz-search button {
		height: 50px;
	 
		margin-bottom: 25px;
	}
	.muzbiz-search {
		display: inline-block;
	 
	}
}

/* Tiny utility classes for Elementor integration */
.mzb-hidden { display: none !important; }
.mzb-muted { color: var(--muz-muted); font-size: 13px; }

/* Accessibility: focus ring */
#muzbiz-submit-form input:focus-visible,
#muzbiz-submit-form select:focus-visible,
#muzbiz-submit-form textarea:focus-visible,
#muzbiz-submit-form button:focus-visible {
  outline: 3px solid rgba(91,108,246,0.18);
  outline-offset: 3px;
}
/* --- Two Column Layout Wrapper --- */
.muzbiz-form-grid {
    /* max-width: 1100px; */
    margin: auto;
    padding: 20px 10px;
    display: flex;
    gap: 40px;
}
.inquiry-form .muzbiz-form-grid {
    margin: auto;
    padding: 10px 10px;
    display: flex;
    gap: 40px;
}

/* Convert form fields into grid */
.muzbiz-form-grid form {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 25px 40px; /* row gap, column gap */
}

/* Make full-width fields span both columns */
.muzbiz-form-grid textarea,
.muzbiz-form-grid .description,
.muzbiz-form-grid input[type="file"],
.muzbiz-form-grid .muzbiz-file-wrap {
    grid-column: span 2;
}

/******************  Directory Page *************************/
/* ================================
   WRAPPER LAYOUT
===================================*/
.muzbiz-directory-wrapper {
    display: flex;
    gap: 40px;
    padding: 40px 20px;
    max-width: 1250px;
    margin: 0 auto;
}

/* ================================
   LEFT FILTER BOX
===================================*/
.muzbiz-left-filter {
    width: 300px;
    flex-shrink: 0;
	font-family: 'Montserrat';
}

.muzbiz-filters-box {
    background: #ffffff;
    padding: 30px;
    border-radius: 16px;
    box-shadow: 0px 4px 34px 0px #00000033;
	font-family: 'Montserrat';
}

.muzbiz-filters-box h3 {
    font-size: 30px;
    font-weight: 700;
    margin-bottom: 20px;
    display: flex;
    align-items: center;
    gap: 6px;
	font-family: 'Montserrat';
}

/* Labels */
.muzbiz-filter-label {
    font-size: 16px;
    font-weight: 500;
    color: #000000;
    margin-top: 34px;
    margin-bottom: 6px;
    display: block;
    font-family: 'Montserrat';
}

/* Select styling */
.muzbiz-select {
    width: 100%;
    padding: 10px 14px;
    border: 1px solid #ddd;
    border-radius: 30px;
    font-size: 14px;
    background: #fafafa;
    cursor: pointer;
	font-family: 'Montserrat';
}

/* Checkbox styles */
.muzbiz-checkbox-list {
    margin-top: 10px;
}

.muzbiz-checkbox-list label {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    margin-bottom: 8px;
	font-family: 'Montserrat';
}

.muzbiz-filter-btn {
    width: 100%;
    margin-top: 25px;
    background: #3B82F6;
    color: #fff;
    border: none;
    padding: 12px;
    border-radius: 30px;
    font-weight: 600;
    cursor: pointer;
    transition: 0.2s;
	font-family: 'Montserrat';
}

.muzbiz-filter-btn:hover {
    background: #2563eb;
}

/* ================================
   RIGHT SIDE LISTING GRID
===================================*/
.muzbiz-right-listing {
    flex: 1;
}

/* 2-column layout */
.muzbiz-right-listing {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 30px;
	font-family: 'Montserrat';
}
.listing-cat {
    font-size: 18px;
    color: #454545;
    font-family: 'Montserrat';
	    margin-bottom: 18px;
}
.listing-cat a {
    font-size: 15px;
    color: var( --e-global-color-secondary ) !important;
    font-family: 'Montserrat';
    background: #5674FF29;
    font-weight: 500;
    padding: 6px 20px 9px 20px;
    border-radius: 30px 30px 30px 30px;
}
.listing-add {
   
   /*  display: flex; */
    gap: 6px;
    color: #5674FF;
    font-family: 'Montserrat';
    font-size: 16px;
    font-weight: 500;
}
.profile-links {
    display: flex;
    gap: 20px;
}
.profile-links .view-btn {
    background-color: var(--e-global-color-secondary);
    font-family: var(--e-global-typography-secondary-font-family), Sans-serif;
    font-weight: var(--e-global-typography-secondary-font-weight);
    line-height: var(--e-global-typography-secondary-line-height);
    fill: var(--e-global-color-2b9c7ff);
    color: var(--e-global-color-2b9c7ff);
    border-radius: 50px 50px 50px 50px;
    padding: 15px 25px 15px 25px;
}
.listing-add a{
    color: #5674FF;
    font-family: 'Montserrat';
    font-size: 15px;
    font-weight: 500;
	background-color: #5674FF29;
    margin: 0px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;
    padding: 6px 20px 9px 20px;
    border-radius: 30px 30px 30px 30px;
}
/* ================================
   LISTING CARD DESIGN
===================================*/
.list_info {
    padding: 1px 20px 24px 20px;
	margin-top:28px;
}
.listing-card {
    background: #ffffff;
    border-radius: 30px;
    padding: 0px;
    box-shadow: 0px 4px 34px 0px #00000033;
    transition: 0.2s;
}

.listing-card:hover {
    /* transform: translateY(-4px); */
    box-shadow: 0 6px 24px rgba(0,0,0,0.10);
}

.listing-thumb img {
    width: 100%;
    max-height: 230px !important;
    object-fit: cover;
    margin-bottom: 15px;
   /*  border-top-right-radius: 12px !important;
    border-top-left-radius: 12px !important; */
	border-radius: 30px 30px 30px 30px !important;
	border-style: solid !important;
    border-color: var(--e-global-color-secondary) !important;
	
}

.listing-card h3 a{
     margin-top: 30px;
    font-family: "Montserrat", Sans-serif;
    font-size: 25px;
    font-weight: 700;
    line-height: 1.2em;
    color: var(--e-global-color-primary);
}

.listing-excerpt {
    font-size: 14px;
    color: #555;
    margin-bottom: 18px;
}

/* View Profile Button */
.view-btn {
  display: inline-block;
    width: 100%;
    text-align: center;
    padding: 9px 8px;
    background: #5674FF;
    color: white;
    border-radius: 20px;
    font-size: 15px;
    text-decoration: none;
    transition: 0.2s;
	margin-top: 22px;
	margin-bottom: 10px;
}

.view-btn:hover {
    background: #2563EB;
}

/* ================================
   RESPONSIVE
===================================*/
@media (max-width: 992px) {
    .muzbiz-directory-wrapper {
        flex-direction: column;
    }

    .muzbiz-left-filter {
        width: 100%;
    }

    .muzbiz-right-listing {
        grid-template-columns: 1fr;
    }
}


/****************** End Directory Page *********************/

/* Mobile responsive */
@media (max-width: 767px) {
    .muzbiz-form-grid form {
        grid-template-columns: 1fr;
    }
	.muzbiz-form-grid {
    
		display: inline;
	
	}
	 .ck-editor__editable {
        min-height: 120px !important;
    }
	.sharibiz {
			position: absolute;
			z-index: 999;
			overflow: hidden;
			top: unset;
		}
		
   .listing-cat a {

    padding: 6px 20px 9px 12px;
 
	}
	.profile-links {
		display: block;
		gap: 20px;
	}
}
/* Optional: Adjust height for small devices */



