/*----------
	Theme Name : 河南濮阳代妈代怀中心
	Start Date : 2024
	Version: 1.0
----------*/

/* 颜色方案 */
:root {
	--primary-color: #ff3300;
	--secondary-color: #99ccff;
	--accent-color: #336699;
	--dark-blue: #003366;
	--deep-blue: #000033;
}

/* ## Global ******************************************* */
body {
	font-family: 'Open Sans', sans-serif;
	font-size: 14px;
	color: #333;
	overflow-x: hidden;
	background-color: #f8f9fa;
}

img {
	max-width: 100%;
	height: auto;
}

a {
	outline: 0 !important;
	text-decoration: none;
	color: var(--accent-color);
	transition: color 0.3s ease;
}

a:hover {
	color: var(--primary-color);
	text-decoration: none;
}

h1, h2, h3, h4, h5, h6, p, a, li, span {
	word-wrap: break-word;
}

/* - Padding/Margin */
.no-padding { padding: 0; }
.no-left-padding { padding-left: 0; }
.no-right-padding { padding-right: 0; }
.no-top-padding { padding-top: 0; }
.no-bottom-padding { padding-bottom: 0; }
.no-margin { margin: 0; }
.no-left-margin { margin-left: 0; }
.no-right-margin { margin-right: 0; }
.no-top-margin { margin-top: 0; }
.no-bottom-margin { margin-bottom: 0; }

/* - Section Padding */
.section-padding {
	padding-top: 75px;
	padding-bottom: 75px;
}
.padding-10 { padding-top: 5px; padding-bottom: 5px; }
.padding-20 { padding-top: 10px; padding-bottom: 10px; }
.padding-30 { padding-top: 15px; padding-bottom: 15px; }
.padding-40 { padding-top: 20px; padding-bottom: 20px; }
.padding-50 { padding-top: 25px; padding-bottom: 25px; }
.padding-60 { padding-top: 30px; padding-bottom: 30px; }
.padding-70 { padding-top: 35px; padding-bottom: 35px; }
.padding-80 { padding-top: 40px; padding-bottom: 40px; }
.padding-90 { padding-top: 45px; padding-bottom: 45px; }
.padding-100 { padding-top: 50px; padding-bottom: 50px; }

.vertical_middle {
	position: absolute;
	top: 50%;
	left: 0;
	right: 0;
	transform: translate(0, -50%);
}

.align_left { text-align: left; }
.align_right { text-align: right; }
.align_center { text-align: center; }

.ow-pull-left { float: left; }
.ow-pull-right { float: right; }

.main-container {
	width: 1920px;
	max-width: 100%;
	margin: 0 auto;
	overflow-x: hidden;
}

/* ## Site Header ******************************************* */
.header_s {
	background-color: var(--deep-blue);
	padding: 10px 0;
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 1000;
	width: 100%;
}

.ownavigation {
	background-color: transparent;
	border: none;
	border-radius: 0;
	min-height: 1px;
	margin-bottom: 0;
}

.navbar-brand {
	height: auto;
	padding: 0;
	color: var(--primary-color) !important;
	font-size: 18px;
	font-weight: 700;
	text-decoration: none;
	line-height: 50px;
}

.navbar-brand:hover {
	color: var(--secondary-color) !important;
	text-decoration: none;
}

.navbar-brand img {
	height: 50px;
}

.ownavigation .navbar-nav li a {
	color: #fff;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.56px;
	background-color: transparent;
	padding: 15px 20px;
	transition: all 0.3s ease;
}

.ownavigation .navbar-nav > .active > a,
.ownavigation .navbar-nav > .active > a:focus,
.ownavigation .navbar-nav > .active > a:hover,
.ownavigation .navbar-nav li:hover > a,
.ownavigation .navbar-nav li a:hover,
.ownavigation .navbar-nav li a:focus {
	background-color: transparent;
	color: var(--secondary-color);
}

.navbar-toggle {
	border-color: var(--secondary-color);
	background-color: var(--accent-color);
}

.navbar-toggle .icon-bar {
	background-color: #fff;
}

/* ## Hero Section ******************************************* */
.hero-section {
	background: linear-gradient(135deg, var(--dark-blue) 0%, var(--accent-color) 50%, var(--secondary-color) 100%);
	color: #fff;
	padding: 160px 0 100px;
	text-align: center;
	position: relative;
	overflow: hidden;
}

.hero-section::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: url('data:image/svg+xml,%3Csvg width="60" height="60" viewBox="0 0 60 60" xmlns="http://www.w3.org/2000/svg"%3E%3Cg fill="none" fill-rule="evenodd"%3E%3Cg fill="%23ffffff" fill-opacity="0.05"%3E%3Cpath d="M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z"/%3E%3C/g%3E%3C/g%3E%3C/svg%3E');
}

.hero-content {
	position: relative;
	z-index: 1;
}

.hero-content h1 {
	font-size: 48px;
	font-weight: 700;
	margin-bottom: 20px;
	text-shadow: 2px 2px 4px rgba(0,0,0,0.3);
}

.hero-content .subtitle {
	font-size: 24px;
	color: var(--secondary-color);
	margin-bottom: 15px;
}

.hero-content .description {
	font-size: 18px;
	margin-bottom: 30px;
	opacity: 0.9;
}

.hero-buttons {
	margin-top: 30px;
}

.btn-primary, .btn-secondary {
	display: inline-block;
	padding: 12px 30px;
	border-radius: 4px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 1px;
	transition: all 0.3s ease;
	margin: 0 10px;
}

.btn-primary {
	background-color: var(--primary-color);
	color: #fff;
	border: 2px solid var(--primary-color);
}

.btn-primary:hover {
	background-color: transparent;
	color: var(--primary-color);
}

.btn-secondary {
	background-color: transparent;
	color: #fff;
	border: 2px solid #fff;
}

.btn-secondary:hover {
	background-color: #fff;
	color: var(--dark-blue);
}

/* ## Services Section ******************************************* */
.services-section {
	padding: 60px 0;
	background-color: #fff;
}

.services-section .section-header {
	margin-bottom: 50px;
}

.services-section .section-header h2 {
	font-size: 32px;
	color: var(--deep-blue);
	margin-bottom: 15px;
}

.services-section .section-header p {
	font-size: 16px;
	color: #666;
}

.service-box {
	background-color: #fff;
	border-radius: 8px;
	padding: 30px;
	text-align: center;
	transition: all 0.3s ease;
	border: 1px solid #eee;
	margin-bottom: 30px;
}

.service-box:hover {
	box-shadow: 0 10px 30px rgba(0,0,0,0.1);
	transform: translateY(-5px);
	border-color: var(--secondary-color);
}

.service-icon {
	font-size: 48px;
	margin-bottom: 20px;
}

.service-box h3 {
	font-size: 20px;
	color: var(--deep-blue);
	margin-bottom: 15px;
}

.service-box p {
	color: #666;
	line-height: 1.6;
}

/* ## About Section ******************************************* */
.about-section {
	padding: 60px 0;
	background: linear-gradient(135deg, #f5f7fa 0%, #e4e8ec 100%);
}

.about-content h2 {
	font-size: 32px;
	color: var(--deep-blue);
	margin-bottom: 20px;
}

.about-content p {
	font-size: 16px;
	color: #666;
	line-height: 1.8;
	margin-bottom: 15px;
}

.features {
	list-style: none;
	padding: 0;
	margin-top: 20px;
}

.features li {
	font-size: 16px;
	color: var(--accent-color);
	margin-bottom: 10px;
}

/* ## Process Section ******************************************* */
.process-section {
	padding: 60px 0;
	background-color: #fff;
}

.process-section .section-header {
	margin-bottom: 50px;
}

.process-section .section-header h2 {
	font-size: 32px;
	color: var(--deep-blue);
	margin-bottom: 15px;
}

.process-section .section-header p {
	font-size: 16px;
	color: #666;
}

.process-steps {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}

.step {
	width: 15%;
	text-align: center;
	margin-bottom: 30px;
	position: relative;
}

.step::after {
	content: '';
	position: absolute;
	top: 25px;
	left: 100%;
	width: 100%;
	height: 2px;
	background: linear-gradient(90deg, var(--secondary-color), var(--accent-color));
}

.step:last-child::after {
	display: none;
}

.step-number {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 50px;
	height: 50px;
	background: linear-gradient(135deg, var(--accent-color), var(--dark-blue));
	color: #fff;
	border-radius: 50%;
	font-size: 24px;
	font-weight: 700;
	margin-bottom: 15px;
}

.step h4 {
	font-size: 16px;
	color: var(--deep-blue);
	margin-bottom: 10px;
}

.step p {
	font-size: 14px;
	color: #666;
}

/* ## Testimonials Section ******************************************* */
.testimonials-section {
	padding: 60px 0;
	background: linear-gradient(135deg, var(--accent-color) 0%, var(--dark-blue) 100%);
	color: #fff;
}

.testimonials-section .section-header h2 {
	font-size: 32px;
	margin-bottom: 15px;
}

.testimonials-section .section-header p {
	font-size: 16px;
	opacity: 0.8;
}

.testimonials {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}

.testimonial {
	width: 30%;
	padding: 30px;
	background-color: rgba(255,255,255,0.1);
	border-radius: 8px;
	margin: 0 15px;
	text-align: center;
}

.testimonial p {
	font-size: 16px;
	line-height: 1.8;
	opacity: 0.9;
	margin-bottom: 20px;
	font-style: italic;
}

.testimonial h4 {
	font-size: 16px;
	font-weight: 600;
}

/* ## Contact CTA Section ******************************************* */
.contact-cta {
	padding: 60px 0;
	text-align: center;
	background: linear-gradient(135deg, var(--primary-color) 0%, #cc2900 100%);
	color: #fff;
}

.contact-cta h2 {
	font-size: 32px;
	margin-bottom: 15px;
}

.contact-cta p {
	font-size: 18px;
	margin-bottom: 30px;
	opacity: 0.9;
}

/* ## Page Hero ******************************************* */
.page-hero {
	background: linear-gradient(135deg, var(--dark-blue) 0%, var(--accent-color) 100%);
	color: #fff;
	padding: 120px 0 60px;
	text-align: center;
}

.page-hero h1 {
	font-size: 36px;
	margin-bottom: 15px;
}

.page-hero p {
	font-size: 18px;
	opacity: 0.9;
}

/* ## Content Section ******************************************* */
.content-section {
	padding: 60px 0;
	background-color: #fff;
}

.content-section h2 {
	font-size: 28px;
	color: var(--deep-blue);
	margin-bottom: 20px;
}

.content-section p {
	font-size: 16px;
	color: #666;
	line-height: 1.8;
	margin-bottom: 20px;
}

.features-list {
	display: flex;
	flex-wrap: wrap;
	gap: 30px;
	margin-bottom: 30px;
}

.feature-item {
	width: 48%;
	background-color: #f8f9fa;
	padding: 25px;
	border-radius: 8px;
}

.feature-item h3 {
	font-size: 20px;
	color: var(--deep-blue);
	margin-bottom: 15px;
}

.feature-item p {
	margin-bottom: 0;
}

.requirements {
	list-style: none;
	padding: 0;
}

.requirements li {
	font-size: 16px;
	color: #666;
	padding: 10px 0;
	border-bottom: 1px solid #eee;
}

.requirements li:last-child {
	border-bottom: none;
}

.guarantees, .success-factors, .benefits, .reasons {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 30px;
	margin-top: 30px;
}

.guarantee-item, .factor-item, .benefit-item, .reason-item {
	width: 22%;
	text-align: center;
	padding: 25px;
	background-color: #f8f9fa;
	border-radius: 8px;
}

.guarantee-icon, .factor-icon, .benefit-icon, .reason-icon {
	font-size: 36px;
	margin-bottom: 15px;
}

.guarantee-item h4, .factor-item h4, .benefit-item h4, .reason-item h4 {
	font-size: 18px;
	color: var(--deep-blue);
	margin-bottom: 10px;
}

.guarantee-item p, .factor-item p, .benefit-item p, .reason-item p {
	font-size: 14px;
	color: #666;
}

/* ## Management System ******************************************* */
.management-system {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
}

.system-item {
	width: 48%;
	background-color: #f8f9fa;
	padding: 25px;
	border-radius: 8px;
	border-left: 4px solid var(--primary-color);
}

.system-item h4 {
	font-size: 18px;
	color: var(--deep-blue);
	margin-bottom: 10px;
}

.system-item p {
	font-size: 14px;
	color: #666;
	margin-bottom: 0;
}

/* ## Plans ******************************************* */
.plans {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 30px;
	margin-top: 30px;
}

.plan-card {
	width: 30%;
	background-color: #fff;
	border-radius: 8px;
	border: 2px solid #eee;
	padding: 30px;
	text-align: center;
	transition: all 0.3s ease;
}

.plan-card.featured {
	border-color: var(--primary-color);
	background-color: rgba(255,51,0,0.05);
}

.plan-card h3 {
	font-size: 22px;
	color: var(--deep-blue);
	margin-bottom: 20px;
}

.plan-card ul {
	list-style: none;
	padding: 0;
	margin-bottom: 30px;
}

.plan-card li {
	font-size: 14px;
	color: #666;
	padding: 10px 0;
	border-bottom: 1px solid #eee;
}

.plan-card li:last-child {
	border-bottom: none;
}

/* ## Footer ******************************************* */
.footer-main {
	background-color: var(--deep-blue);
	color: #fff;
	padding: 60px 0 30px;
}

.footer-content {
	display: flex;
	flex-wrap: wrap;
	gap: 40px;
	margin-bottom: 40px;
}

.footer-section {
	width: 30%;
}

.footer-section h3 {
	font-size: 22px;
	margin-bottom: 20px;
	color: var(--secondary-color);
}

.footer-section h4 {
	font-size: 18px;
	margin-bottom: 15px;
	color: var(--secondary-color);
}

.footer-section p {
	font-size: 14px;
	color: #ccc;
	line-height: 1.8;
}

.footer-section ul {
	list-style: none;
	padding: 0;
}

.footer-section ul li {
	margin-bottom: 10px;
}

.footer-section ul li a {
	color: #ccc;
	transition: color 0.3s ease;
}

.footer-section ul li a:hover {
	color: var(--secondary-color);
}

.footer-bottom {
	border-top: 1px solid rgba(255,255,255,0.1);
	padding-top: 30px;
	text-align: center;
}

.footer-bottom p {
	color: #ccc;
	font-size: 14px;
}

/* ## Responsive ******************************************* */
@media (min-width: 1200px) {
	.container { width: 1200px; }
}

@media (min-width: 992px) {
	.desktop-hide { display: none; }
	.ownavigation .navbar-nav > li { margin: 0 10px; }
	.ownavigation .navbar-nav > li > a { padding: 15px 15px; }
}

@media (max-width: 991px) {
	.mobile-hide { display: none; }
	.ownavigation { padding-left: 15px; padding-right: 15px; }
	.ownavigation .navbar-nav { width: 100%; }
	.ownavigation .navbar-nav > li { float: none; clear: both; }
	.ownavigation .navbar-nav > li > a { padding: 10px 0; }
	.navbar-collapse.in { overflow: auto !important; }
	
	.navbar-brand { font-size: 14px; line-height: 40px; }
	
	.hero-content h1 { font-size: 32px; }
	.hero-content .subtitle { font-size: 20px; }
	.hero-content .description { font-size: 16px; }
	
	.step { width: 45%; }
	.step::after { display: none; }
	
	.testimonial { width: 100%; margin-bottom: 20px; }
	
	.feature-item, .system-item { width: 100%; }
	
	.guarantee-item, .factor-item, .benefit-item, .reason-item { width: 45%; }
	
	.plan-card { width: 100%; }
	
	.footer-section { width: 100%; text-align: center; }
}

@media (max-width: 767px) {
	.btn-primary, .btn-secondary { margin-bottom: 15px; }
	
	.hero-section { padding: 60px 0; }
	.hero-content h1 { font-size: 28px; }
	
	.service-box { padding: 20px; }
	
	.guarantee-item, .factor-item, .benefit-item, .reason-item { width: 100%; }
}

@media (max-width: 479px) {
	.hero-content h1 { font-size: 24px; }
	.hero-content .subtitle { font-size: 18px; }
	
	.page-hero h1 { font-size: 28px; }
}