/* 
ZigZag Template
http://www.templatemo.com/tm-471-zigzag
*/

/* --** Reset CSS **-- */
* { margin: 0px; padding: 0px; -webkit-box-sizing: border-box; 	-moz-box-sizing: border-box; box-sizing: border-box; -webkit-font-smoothing: antialiased; }
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, font, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td { border: 0; font-family: inherit; font-size: 100%; font-weight: inherit; margin: 0; outline: 0; padding: 0; vertical-align: baseline; }
article, aside, details, figcaption, figure, footer, header, hgroup, main, menu, nav, section, summary { display: block; }
html, body, button, input, select, textarea { font-family: Arial; font-size: 12px; color: #8c806e; }
ul, ol { margin-top: 0; margin-bottom: 10px; }
ul ul, ol ul, ul ol, ol ol { margin-bottom: 0; }
li { font-size: 13px; margin: 5px 0px 10px 0px; }
pre { overflow: auto; }
table { border-collapse: separate; border-spacing: 0; }
caption, th, td { font-weight: normal; text-align: left; }
blockquote:before, blockquote:after, q:before, q:after { content: ""; }
blockquote, q { -webkit-hyphens: none; -moz-hyphens: none; -ms-hyphens: none; hyphens: none; quotes: none; }
a img { border: 0; }
a, input { outline: none; }
a { -webkit-transition: all 0.5s ease-in-out; -moz-transition: all 0.5s ease-in-out; -ms-transition: all 0.5s ease-in-out; -o-transition: all 0.5s ease-in-out; transition: all 0.5s ease-in-out; color: #06C;  }
a:hover { text-decoration: none; }
h1, h2, h3, h4, h5, h6 { margin: 5px 0px 15px 0px; clear: both; font-weight: lighter; }
h1 { font-size: 36px; }
h2 { font-size: 30px; }
h3 { font-size: 24px; }
h4 { font-size: 20px; }
h5 { font-size: 18px; }
h6 { font-size: 14px; }
p {font-size: 13px; margin: 5px 0px 15px 0px; }

img { -ms-interpolation-mode: bicubic; border: 0; height: auto; max-width: 100%; vertical-align: middle; display: block;  }
figure { margin: 0; }
::-webkit-input-placeholder { color: rgba(51, 51, 51, 0.7); }
:-moz-placeholder { color: rgba(51, 51, 51, 0.7); }
::-moz-placeholder { color: rgba(51, 51, 51, 0.7); opacity: 1; /* Since FF19 lowers the opacity of the placeholder by default */ }
:-ms-input-placeholder { color: rgba(51, 51, 51, 0.7); }
input:focus, textarea:focus { outline: none; background-color: #fff; border: 1px solid #c1c1c1; border: 1px solid rgba(51, 51, 51, 0.3); color: #333; }
input:focus, select:focus { outline: 2px solid #c1c1c1; outline: 2px solid rgba(51, 51, 51, 0.3); }

.clear { clear: both; height: 0px; overflow: hidden; }

/* <<< Design Holder >>> */
.DesignHolder { position: relative; display: block; width: 100%; min-height: 100%; }

/* <<< Layout Frame >>> */
.LayoutFrame { margin: 0 auto; width: 100%; display: block; }

/* <<< Body >>> */
body { 
	background: #f5f5f5;
	font-family: 'Open Sans', sans-serif;
}
	
	/* <<< Header >>> */
	.header { padding: 75px 0px 145px 0px; width: 100%; background: url(../img/header-bg.png) top center no-repeat; }
	.header .Center { max-width: 1098px; margin: auto; position: relative; }
	.header .arrow { position: absolute; bottom: -146px; right: -2px; }

	/* <<< Top Bar >>> */
	.Top_Bar { padding-bottom: 147px;  width: 100%; }
	.Top_Bar .site-logo { padding-left: 1px; width: 285px; float: left; }
	.Top_Bar .site-logo a { display: block; }
	
	/* Logo Text Styling */
	.logo-text {
		font-size: 22px;
		font-weight: 700;
		color: #fff;
		font-family: 'Open Sans', sans-serif;
		text-transform: uppercase;
		letter-spacing: 1px;
		margin: 0;
		padding: 15px 0;
		display: inline-block;
		white-space: nowrap;
		word-wrap: break-word;
		max-width: 280px;
		line-height: 1.2;
	}
	
	/* <<< Navigation >>> */
	.Navigation { margin-right: -3px; position: relative; width: 66.5%; float: right; background: url(../img/menu-bg.png) top center no-repeat; }
	.Navigation ul { list-style: none; margin: 0px;  }
	.Navigation li { float: left; margin: 0px; line-height: 80px; }
	.Navigation li a { padding: 0px 0px 0px 80px; font-size: 14px; color: #fff; font-family: 'Open Sans', sans-serif; font-weight: 600; display: block; text-decoration: none; text-transform: uppercase; }
	.Navigation li a:hover, .Navigation li.active a { background: url(../img/menu-left-hover.png) left center no-repeat; }
	.Navigation li a:hover span, .Navigation li.active a span { display: block; background: url(../img/menu-right-hover.png) right center no-repeat; }

	.Navigation li a span { padding: 0px 127px 0px 62px; }
	.Navigation li.gap { margin-left: -80px; }
	.Navigation li.gap a span { padding: 0px 134px 0px 18px; }
	.Navigation li.gap1 a span { padding: 0px 138px 0px 11px; }
	
	
	
	
	.Navigation li:last-child a { padding-right: 0px; }
	.Navigation .triangle { position: absolute; top: 79px; left: 0px; }
	
	/* Hamburger Menu Toggle */
	.menu-toggle { display: none; width: 40px; height: 40px; flex-direction: column; justify-content: center; align-items: center; cursor: pointer; float: right; margin-right: 20px; margin-top: 20px; z-index: 1000; }
	.menu-toggle span { display: block; width: 28px; height: 3px; background-color: #fff; margin: 4px 0; transition: all 0.3s ease; border-radius: 2px; }
	.menu-toggle.active span:nth-child(1) { transform: rotate(45deg) translate(8px, 8px); }
	.menu-toggle.active span:nth-child(2) { opacity: 0; }
	.menu-toggle.active span:nth-child(3) { transform: rotate(-45deg) translate(7px, -7px); }

	/* <<< Product Section >>> */
	.Product_sec { width: 100%; overflow: visible; padding: 60px 0 0px 0; }
	.hero-slider-container { position: relative; width: 100%; max-width: 1098px; margin: 0 auto; }
	.hero-slider { display: flex; overflow: hidden; width: 100%; border-radius: 12px; }
	.hero-slide { display: none; width: 100%; flex-shrink: 0; padding: 40px; background: linear-gradient(135deg, rgba(29, 35, 44, 0.9) 0%, rgba(0, 0, 0, 0.85) 100%); border-radius: 12px; box-shadow: 0 8px 25px rgba(0, 0, 0, 0.3); flex-direction: row; align-items: center; gap: 40px; animation: slideIn 0.6s ease-in-out; }
	.hero-slide.active { display: flex; }
	.hero-slide.hero-slide-reverse { flex-direction: row-reverse; }
	@keyframes slideIn { from { opacity: 0; transform: translateX(20px); } to { opacity: 1; transform: translateX(0); } }
	.hero-image { flex: 0 0 40%; }
	.hero-image figure { margin: 0; }
	.hero-image img { max-width: 100%; height: auto; border-radius: 12px; transition: transform 0.3s ease; }
	.hero-image img:hover { transform: scale(1.05); }
	.hero-content { flex: 1; }
	.hero-content h3 { font-size: 32px; color: #fff; font-family: 'Open Sans', sans-serif; font-weight: 700; text-transform: uppercase; margin: 0 0 20px 0; line-height: 40px; }
	.hero-content h3 span { display: block; font-weight: 300; font-size: 26px; color: #4dd0ca; }
	.hero-content p { font-size: 15px; color: #e0e0e0; margin: 0 0 25px 0; line-height: 24px; }
	.cta-group { display: flex; flex-direction: column; gap: 12px; align-items: flex-start; }
	.cta-group .button { display: inline-block; }
	.phone-badge { font-size: 12px; color: #00b3ae; font-weight: 600; font-family: 'Open Sans', sans-serif; letter-spacing: 0.5px; }
	
	/* Hero Slider Dots Navigation */
	.hero-dots { display: flex; justify-content: center; gap: 10px; margin-top: 20px; padding: 15px 0; }
	.dot { width: 12px; height: 12px; border-radius: 50%; background: #ddd; cursor: pointer; transition: all 0.3s ease; border: 2px solid transparent; }
	.dot.active { background: #00b3ae; width: 14px; height: 14px; border-color: #00b3ae; }

	/* <<< Services Section >>> */
	.Services_sec { width: 100%; overflow: hidden; background: #fff; padding: 80px 0; position: relative; }
	.Services_sec::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: linear-gradient(90deg, #00b3ae 0%, #008b82 100%); }
	.Services_sec .Center { max-width: 1098px; margin: auto; }
	.services-wrapper { display: grid; grid-template-columns: 1fr 1fr; gap: 50px; align-items: center; }
	.services-image { grid-column: 1; display: flex; align-items: center; justify-content: center; }
	.services-image figure { margin: 0; position: relative; display: flex; align-items: center; justify-content: center; width: 100%; height: 100%; min-height: 400px; }
	.services-image img { max-width: 80%; height: auto; border-radius: 16px; box-shadow: 0 12px 40px rgba(0, 179, 174, 0.15); transition: all 0.4s cubic-bezier(0.34, 1.56, 0.64, 1); object-fit: contain; }
	.services-image img:hover { transform: translateY(-8px); box-shadow: 0 20px 60px rgba(0, 179, 174, 0.25); }
	.services-content { grid-column: 2; }
	.services-content h2 { font-size: 38px; color: #1d232c; font-family: 'Open Sans', sans-serif; font-weight: 700; margin: 0 0 15px 0; line-height: 48px; position: relative; padding-bottom: 20px; }
	.services-content h2::after { content: ''; position: absolute; bottom: 0; left: 0; width: 60px; height: 4px; background: linear-gradient(90deg, #00b3ae 0%, #008b82 100%); border-radius: 2px; }
	.Services_sec .section-intro { font-size: 16px; color: #666; text-align: left; margin-bottom: 35px; font-weight: 500; line-height: 26px; }
	.Services_sec .services-list { list-style: none; margin: 0; padding: 0; }
	.Services_sec .services-list li { float: none; margin-bottom: 28px; padding: 0; background: #f8f9fb; border-left: 4px solid #00b3ae; padding: 20px; border-radius: 8px; box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05); transition: all 0.3s ease; }
	.Services_sec .services-list li:hover { transform: translateX(5px); box-shadow: 0 8px 20px rgba(0, 179, 174, 0.12); background: #f0fffe; }
	.Services_sec .services-list h4 { font-size: 17px; color: #00b3ae; font-family: 'Open Sans', sans-serif; font-weight: 700; margin: 0 0 10px 0; text-transform: uppercase; letter-spacing: 0.5px; }
	.Services_sec .services-list p { font-size: 14px; color: #666; margin: 0; line-height: 22px; }

	/* <<< Service Areas >>> */
	.Service_Areas { width: 100%; overflow: hidden; padding: 80px 0; }
	.Service_Areas .Center { max-width: 1098px; margin: auto; }
	.Service_Areas h2 { font-size: 30px; color: #1d232c; font-family: 'Open Sans', sans-serif; font-weight: 700; text-align: center; margin-bottom: 15px; }
	.Service_Areas .section-intro { font-size: 14px; color: #8a8a8a; text-align: center; margin-bottom: 40px; }
	.Service_Areas .areas-list { list-style: none; margin: 0; padding: 0; column-count: 2; column-gap: 40px; }
	.Service_Areas .areas-list li { font-size: 14px; color: #333; margin-bottom: 10px; padding-bottom: 10px; border-bottom: 1px solid #e0e0e0; break-inside: avoid; }

	/* <<< FAQ Section >>> */
	.FAQ_sec { width: 100%; overflow: hidden; background: #f5f5f5; padding: 80px 0; }
	.FAQ_sec .Center { max-width: 1098px; margin: auto; }
	.FAQ_sec h2 { font-size: 30px; color: #1d232c; font-family: 'Open Sans', sans-serif; font-weight: 700; text-align: center; margin-bottom: 40px; }
	.FAQ_sec .faq-item { margin-bottom: 30px; padding: 25px; background: #fff; }
	.FAQ_sec .faq-item h4 { font-size: 16px; color: #1d232c; font-family: 'Open Sans', sans-serif; font-weight: 600; margin: 0 0 12px 0; }
	.FAQ_sec .faq-item p { font-size: 13px; color: #8a8a8a; margin: 0; line-height: 20px; }

	/* <<< Contact Section >>> */
	.Contact_sec { padding: 80px 0; width: 100%; overflow: hidden; background: linear-gradient(135deg, #f0f9f8 0%, #e8f5f4 100%); position: relative; }
	.Contact_sec::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 4px; background: linear-gradient(90deg, #00b3ae 0%, #008b82 100%); }
	.Contact_sec .Center { max-width: 1098px; margin: auto; }
	.Contact_sec h3 { font-size: 36px; color: #1d232c; font-family: 'Open Sans', sans-serif; font-weight: 700; text-transform: uppercase; margin: 0 0 50px 0; text-align: center; position: relative; padding-bottom: 25px; }
	.Contact_sec h3::after { content: ''; position: absolute; bottom: 0; left: 50%; transform: translateX(-50%); width: 80px; height: 4px; background: linear-gradient(90deg, #00b3ae 0%, #008b82 100%); border-radius: 2px; }
	.Contact_sec h3 span { color: #00b3ae; font-weight: 300; }
	.contact-details { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; margin-top: 40px; }
	.contact-details p { font-size: 15px; color: #333; margin: 0; line-height: 26px; background: #fff; padding: 25px; border-radius: 12px; box-shadow: 0 4px 15px rgba(0, 179, 174, 0.08); transition: all 0.3s ease; }
	.contact-details p:hover { transform: translateY(-5px); box-shadow: 0 8px 25px rgba(0, 179, 174, 0.15); }
	.contact-details strong { display: block; color: #00b3ae; font-weight: 700; margin-bottom: 8px; text-transform: uppercase; font-size: 12px; letter-spacing: 0.5px; }
	.contact-details a { color: #00b3ae; text-decoration: none; font-weight: 600; }
	.contact-details a:hover { text-decoration: underline; }

	/* <<< Map Section >>> */
	.map_sec iframe { width: 100%; height: 100%; }



	/* <<< Middle Section / About Section >>> */
	.Middle_sec { width: 100%; overflow: hidden; background: #222a36 url(../img/sollication-bg.jpg) top center no-repeat; padding: 80px 0; }
	.Middle_sec .Center { max-width: 1098px; margin: auto; overflow: hidden; }
	.about-wrapper { display: flex; gap: 50px; align-items: flex-start; }
	.about-image { flex: 0 0 40%; }
	.about-image figure { margin: 0; }
	.about-image img { max-width: 100%; height: auto; border-radius: 8px; }
	.about-content { flex: 1; }
	.about-content h2 { font-size: 28px; color: #fff; font-family: 'Open Sans', sans-serif; font-weight: 700; margin: 0 0 30px 0; }
	.about-features { margin: 0; }
	.feature-item { margin-bottom: 30px; }
	.feature-item h4 { font-size: 18px; color: #00b3ae; font-family: 'Open Sans', sans-serif; font-weight: 700; margin: 0 0 12px 0; }
	.feature-item p { font-size: 14px; color: #8a929f; margin: 0; line-height: 22px; }

	/* <<< Contact Section >>> */
	.Contact_sec { padding: 80px 0; width: 100%; overflow: hidden; background: #f5f5f5; }
	.Contact_sec .Center { max-width: 1098px; margin: auto; text-align: center; }
	.Contact_sec h3 { font-size: 28px; color: #1d232c; font-family: 'Open Sans', sans-serif; font-weight: 700; text-transform: uppercase; margin: 0 0 40px 0; }
	.Contact_sec h3 span { font-family: 'Open Sans', sans-serif; font-weight: 400; }

	/* <<< Map Section >>> */
	.Map_sec { width: 100%; overflow: hidden; padding: 80px 0; background: #fff; }
	.Map_sec .Center { max-width: 1098px; margin: auto; }
	.Map_sec h2 { font-size: 30px; color: #1d232c; font-family: 'Open Sans', sans-serif; font-weight: 700; text-align: center; margin: 0 0 40px 0; }
	.map-container { width: 100%; height: 500px; border-radius: 8px; overflow: hidden; }

	/* <<< Detailed Services Section >>> */
	.Detailed_Services { width: 100%; overflow: hidden; padding: 70px 0; }
	.Detailed_Services .Center { max-width: 1098px; margin: auto; }
	.service-detail-wrapper { display: flex; gap: 50px; align-items: flex-start; }
	.service-detail-alt { flex-direction: row-reverse; }
	.detail-image { flex: 0 0 40%; display: flex; align-items: center; justify-content: center; }
	.detail-image figure { margin: 0; display: flex; align-items: center; justify-content: center; width: 100%; height: 100%; min-height: 500px; }
	.detail-image img { max-width: 100%; height: 550px; border-radius: 12px; box-shadow: 0 8px 25px rgba(0, 0, 0, 0.12); transition: transform 0.4s ease; object-fit: cover; }
	.detail-image img:hover { transform: translateY(-5px); box-shadow: 0 12px 35px rgba(0, 0, 0, 0.18); }
	.detail-content { flex: 1; }
	.detail-content h2 { font-size: 32px; color: #1d232c; font-family: 'Open Sans', sans-serif; font-weight: 700; margin: 0 0 20px 0; line-height: 40px; }
	.intro-text { font-size: 15px; color: #555; margin: 0 0 30px 0; line-height: 25px; }
	.service-benefits { margin: 30px 0; }
	.service-benefits h4 { font-size: 18px; color: #00b3ae; font-weight: 700; margin: 0 0 18px 0; font-family: 'Open Sans', sans-serif; }
	.benefits-list { list-style: none; margin: 0; padding: 0; }
	.benefits-list li { font-size: 14px; color: #333; margin: 0 0 12px 0; padding-left: 25px; position: relative; line-height: 22px; }
	.benefits-list li:before { content: "✓"; position: absolute; left: 0; color: #00b3ae; font-weight: bold; font-size: 16px; }
	.service-areas-geo { background: #f5f5f5; padding: 20px; border-radius: 8px; border-left: 4px solid #00b3ae; margin: 25px 0; }
	.service-areas-geo p { font-size: 14px; color: #555; margin: 0; line-height: 22px; }
	.Detailed_Services.carpet-cleaning-detail { background: #fff; border-bottom: 1px solid #e8e8e8; }
	.Detailed_Services.pet-odor-detail { background: linear-gradient(135deg, #f9f9f9 0%, #f5f5f5 100%); }
	.Detailed_Services.upholstery-detail { background: #fff; }
	.button-primary { background: #00b3ae; color: #fff; padding: 14px 30px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; font-size: 13px; display: inline-block; border-radius: 4px; transition: all 0.3s ease; }
	.button-primary:hover { background: #008b82; transform: translateY(-2px); box-shadow: 0 6px 20px rgba(0, 179, 174, 0.3); text-decoration: none; color: #fff; }

	/* <<< footer >>> */
	footer { overflow: hidden; width: 100%; background: linear-gradient(135deg, #1a2332 0%, #0f1419 100%); position: relative; border-top: 4px solid #00b3ae; }
	footer::before { content: ''; position: absolute; top: -4px; left: 0; right: 0; height: 4px; background: linear-gradient(90deg, #00b3ae 0%, #008b82 100%); }
	footer .Center { padding: 50px 0px 50px 0px; max-width: 1180px; margin: auto; text-align: center; }
	footer p { font-size: 14px; color: #bbbcbc; margin: 0px; font-family: 'Open Sans', sans-serif; font-weight: 400; line-height: 24px; }
	footer p br { display: block; content: ''; margin: 8px 0; }
	footer a { color: #00b3ae; text-decoration: none; font-weight: 600; transition: color 0.3s ease; }
	footer a:hover { color: #4dd0ca; text-decoration: underline; }