﻿:root {
	--sky: #1a8fe3;
	--sky-mid: #2196f3;
	--sky-light: #e8f4fd;
	--sky-glow: rgba(26,143,227,.15);
	--slate: #2c3e50;
	--slate-mid: #3d5166;
	--cool-gray: #647d93;
	--surface: #f4f8fb;
	--border: #dce8f0;
	--white: #ffffff;
	--ff-display: 'Plus Jakarta Sans', sans-serif;
	--ff-body: 'Literata', Georgia, serif;
	--r-sm: 8px;
	--r-md: 16px;
	--r-lg: 24px;
	--r-xl: 36px;
}

html {
	scroll-behavior: smooth;
}

*, *::before, *::after {
	box-sizing: border-box;
}

body {
	font-family: var(--ff-body);
	color: var(--slate);
	background: var(--white);
	-webkit-font-smoothing: antialiased;
	overflow-x: hidden;
}

h1, h2, h3, h4, h5, h6 {
	font-family: var(--ff-display);
}

/* NAV */
.navbar {
	background: var(--white);
	border-bottom: 1px solid var(--border);
	padding: .9rem 0;
}

.navbar-brand {
	font-family: var(--ff-display);
	font-weight: 800;
	font-size: 1.1rem;
	color: var(--slate) !important;
	display: flex;
	align-items: center;
	gap: .65rem;
	letter-spacing: -.01em;
}

.navbar-brand img {
	height: 38px;
	border-radius: 8px;
	object-fit: contain;
}

.nav-link {
	font-family: var(--ff-display);
	font-weight: 600;
	font-size: .8rem;
	letter-spacing: .04em;
	text-transform: uppercase;
	color: var(--cool-gray) !important;
	padding: .4rem .85rem !important;
	border-radius: 6px;
	transition: color .2s,background .2s;
}

.nav-link:hover {
	color: var(--sky) !important;
	background: var(--sky-light);
}

.btn-nav {
	background: var(--sky);
	color: var(--white) !important;
	border-radius: var(--r-sm);
	padding: .5rem 1.2rem !important;
	font-size: .8rem;
	font-weight: 700;
	transition: background .2s,transform .15s;
	box-shadow: 0 3px 12px var(--sky-glow);
	text-align: center;
}

.btn-nav:hover {
	background: #157acc;
	transform: translateY(-1px);
}

/* HERO */
.hero {
	position: relative;
	min-height: 92vh;
	display: flex;
	flex-direction: column;
	justify-content: center;
	background: var(--slate);
	overflow: hidden;
}

.hero-img {
	position: absolute;
	inset: 0;	
	opacity: .25;
}
/* clean geometric accent */
.hero-arc {
	position: absolute;
	top: -10%;
	right: -5%;
	width: 55%;
	aspect-ratio: 1;
	border-radius: 50%;
	background: radial-gradient(circle,rgba(26,143,227,.18) 0%,transparent 65%);
	pointer-events: none;
}

.hero-grid {
	position: absolute;
	inset: 0;
	background-image: linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);
	background-size: 48px 48px;
	pointer-events: none;
}

.hero-inner {
	position: relative;
	z-index: 2;
	padding: 6rem 1.5rem 4rem;
}
/* small brand mark */
.hero-brandmark {
	display: inline-flex;
	align-items: center;
	gap: .6rem;
	margin-bottom: 1.5rem;
}

.hero-brandmark-dot {
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background: var(--sky);
}

.hero-brandmark-line {
	width: 40px;
	height: 2px;
	background: var(--sky);
	opacity: .6;
}

.hero-brandmark-text {
	font-family: var(--ff-display);
	font-size: .68rem;
	font-weight: 700;
	letter-spacing: .2em;
	text-transform: uppercase;
	color: var(--sky);
}

.hero h1 {
	font-size: clamp(2.8rem,6.5vw,5.2rem);
	font-weight: 800;
	color: var(--white);
	line-height: 1.08;
	margin-bottom: 1.4rem;
	max-width: 680px;
}

.hero h1 .sky-word {
	color: var(--sky);
}

.hero h1 em {
	font-style: italic;
	font-family: var(--ff-body);
	font-weight: 300;
}

.hero-sub {
	font-size: 1rem;
	color: rgba(255,255,255,.6);
	font-weight: 300;
	font-style: italic;
	max-width: 460px;
	line-height: 1.9;
	margin-bottom: 2.2rem;
}

.hero-btns {
	display: flex;
	gap: .9rem;
	flex-wrap: wrap;
}

.btn-sky {
	background: var(--sky);
	color: var(--white);
	border: none;
	border-radius: var(--r-sm);
	padding: .9rem 2rem;
	font-family: var(--ff-display);
	font-weight: 700;
	font-size: .88rem;
	letter-spacing: .03em;
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: .55rem;
	transition: background .2s,transform .15s,box-shadow .2s;
	box-shadow: 0 6px 20px var(--sky-glow);
}

.btn-sky:hover {
	background: #157acc;
	transform: translateY(-2px);
	color: var(--white);
	box-shadow: 0 10px 28px var(--sky-glow);
}

.btn-ghost-white {
	background: transparent;
	color: rgba(255,255,255,.8);
	border: 1.5px solid rgba(255,255,255,.25);
	border-radius: var(--r-sm);
	padding: .88rem 2rem;
	font-family: var(--ff-display);
	font-weight: 600;
	font-size: .88rem;
	letter-spacing: .03em;
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: .55rem;
	transition: border-color .2s,color .2s,transform .15s;
}

.btn-ghost-white:hover {
	border-color: var(--sky);
	color: var(--sky);
	transform: translateY(-2px);
}
/* patient trust strip */
.trust-strip {
	background: var(--white);
	border-top: 3px solid var(--sky);
	box-shadow: 0 -4px 24px rgba(44,62,80,.12);
	position: relative;
	z-index: 10;
}

.ts-inner {
	display: flex;
	align-items: stretch;
}

.ts-item {
	flex: 1;
	display: flex;
	align-items: center;
	gap: .9rem;
	padding: 1.3rem 1.6rem;
	border-right: 1px solid var(--border);
	transition: background .2s;
}

.ts-item:last-child {
	border-right: none;
}

.ts-item:hover {
	background: var(--sky-light);
}

.ts-ico {
	width: 44px;
	height: 44px;
	min-width: 44px;
	border-radius: 10px;
	background: var(--sky-light);
	color: var(--sky);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1rem;
	transition: background .2s,color .2s;
}

.ts-item:hover .ts-ico {
	background: var(--sky);
	color: var(--white);
}

.ts-num {
	font-family: var(--ff-display);
	font-size: 1.4rem;
	font-weight: 800;
	color: var(--slate);
	line-height: 1;
}

.ts-lbl {
	font-family: var(--ff-display);
	font-size: .7rem;
	font-weight: 600;
	letter-spacing: .05em;
	text-transform: uppercase;
	color: var(--cool-gray);
	margin-top: .12rem;
}

/* SHARED */
.sec-pad {
	padding: 96px 0;
}

.sec-tag {
	display: inline-flex;
	align-items: center;
	gap: .55rem;
	font-family: var(--ff-display);
	font-size: .68rem;
	font-weight: 700;
	letter-spacing: .15em;
	text-transform: uppercase;
	color: var(--sky);
	margin-bottom: .6rem;
}

.sec-tag::before {
	content: '';
	width: 20px;
	height: 2px;
	background: var(--sky);
}

.sec-title {
	font-family: var(--ff-display);
	font-size: clamp(1.9rem,4.5vw,3rem);
	font-weight: 800;
	color: var(--slate);
	line-height: 1.1;
}

.sec-body {
	font-size: .98rem;
	color: var(--cool-gray);
	font-weight: 300;
	font-style: italic;
	max-width: 540px;
	line-height: 1.85;
}

/* SERVICES */
.svc-section {
	background: var(--surface);
}

.svc-card {
	background: var(--white);
	border: 1.5px solid var(--border);
	border-radius: var(--r-md);
	padding: 1.8rem;
	height: 100%;
	transition: border-color .25s,box-shadow .25s,transform .2s;
	position: relative;
	overflow: hidden;
}

	.svc-card::after {
		content: '';
		position: absolute;
		top: 0;
		right: 0;
		width: 0;
		height: 3px;
		background: var(--sky);
		transition: width .3s ease;
	}

	.svc-card:hover::after {
		width: 100%;
	}

	.svc-card:hover {
		border-color: var(--sky);
		box-shadow: 0 10px 32px var(--sky-glow);
		transform: translateY(-3px);
	}

.svc-num {
	font-family: var(--ff-display);
	font-size: 2.2rem;
	font-weight: 800;
	color: var(--border);
	line-height: 1;
	margin-bottom: .5rem;
	transition: color .25s;
}

.svc-card:hover .svc-num {
	color: var(--sky-light);
}

.svc-icon {
	width: 50px;
	height: 50px;
	border-radius: 12px;
	background: var(--sky-light);
	color: var(--sky);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.15rem;
	margin-bottom: 1rem;
	transition: background .25s,color .25s;
}

.svc-card:hover .svc-icon {
	background: var(--sky);
	color: var(--white);
}

.svc-card h5 {
	font-size: 1rem;
	font-weight: 700;
	color: var(--slate);
	margin-bottom: .4rem;
}

.svc-card p {
	font-size: .86rem;
	color: var(--cool-gray);
	margin: 0;
	line-height: 1.75;
	font-style: italic;
}

/* ABOUT */
.about-section {
	background: var(--white);
}

.about-img {
	width: 100%;
	object-fit: cover;
	display: block;
	border-radius: var(--r-xl);
	aspect-ratio: 4/5;
	box-shadow: 0 24px 64px rgba(44,62,80,.14);
}

.about-img-wrap {
	position: relative;
}

.about-badge {
	position: absolute;
	bottom: 2rem;
	right: -1.5rem;
	background: var(--sky);
	color: var(--white);
	border-radius: var(--r-md);
	padding: 1.1rem 1.4rem;
	text-align: center;
	box-shadow: 0 10px 28px var(--sky-glow);
	min-width: 100px;
}

.ab-num {
	font-family: var(--ff-display);
	font-size: 2.4rem;
	font-weight: 800;
	line-height: 1;
}

.ab-lbl {
	font-family: var(--ff-display);
	font-size: .62rem;
	font-weight: 700;
	letter-spacing: .1em;
	text-transform: uppercase;
	opacity: .85;
	margin-top: .25rem;
}

.about-hr {
	width: 36px;
	height: 3px;
	background: var(--sky);
	border-radius: 2px;
	margin: 1.4rem 0;
}

.feat-checklist {
	list-style: none;
	padding: 0;
	margin: 0 0 2rem;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: .6rem;
}

	.feat-checklist li {
		display: flex;
		align-items: flex-start;
		gap: .7rem;
		padding: .7rem .9rem;
		background: var(--surface);
		border-radius: var(--r-sm);
		border: 1px solid transparent;
		transition: border-color .2s;
	}

		.feat-checklist li:hover {
			border-color: var(--sky);
			background: var(--white);
		}

.feat-check {
	width: 22px;
	height: 22px;
	min-width: 22px;
	border-radius: 50%;
	background: var(--sky-light);
	color: var(--sky);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: .65rem;
	margin-top: .1rem;
}

.feat-checklist h6 {
	font-size: .88rem;
	font-weight: 700;
	color: var(--slate);
	margin-bottom: .1rem;
}

.feat-checklist p {
	font-size: .76rem;
	color: var(--cool-gray);
	margin: 0;
	font-style: italic;
}

.btn-slate {
	background: var(--slate);
	color: var(--white);
	border: none;
	border-radius: var(--r-sm);
	padding: .85rem 1.8rem;
	font-family: var(--ff-display);
	font-weight: 700;
	font-size: .85rem;
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: .55rem;
	transition: background .2s,transform .15s;
}

	.btn-slate:hover {
		background: var(--slate-mid);
		transform: translateY(-1px);
		color: var(--white);
	}

/* TESTIMONIALS */
.testi-section {
	background: var(--slate);
	position: relative;
	overflow: hidden;
}

.testi-geo {
	position: absolute;
	bottom: -15%;
	left: -5%;
	width: 50%;
	aspect-ratio: 1;
	border-radius: 50%;
	border: 60px solid rgba(26,143,227,.06);
	pointer-events: none;
}

.testi-geo2 {
	position: absolute;
	top: -10%;
	right: -5%;
	width: 35%;
	aspect-ratio: 1;
	border-radius: 50%;
	border: 40px solid rgba(26,143,227,.05);
	pointer-events: none;
}

.testi-section .sec-tag {
	color: var(--sky);
}

	.testi-section .sec-tag::before {
		background: var(--sky);
	}

.testi-section .sec-title {
	color: var(--white);
}

.testi-section .sec-body {
	color: rgba(255,255,255,.45);
}

.pull-quote {
	background: rgba(26,143,227,.12);
	border: 1px solid rgba(26,143,227,.25);
	border-radius: var(--r-xl);
	padding: 3rem 3.5rem;
	margin-bottom: 2rem;
	position: relative;
	overflow: hidden;
}

.pq-icon {
	position: absolute;
	top: 1.5rem;
	right: 2.5rem;
	font-size: 6rem;
	color: rgba(26,143,227,.12);
	font-family: var(--ff-body);
}

.pq-text {
	font-family: var(--ff-body);
	font-style: italic;
	font-size: clamp(1.2rem,2.3vw,1.7rem);
	font-weight: 300;
	color: var(--white);
	line-height: 1.6;
	margin-bottom: 1.4rem;
	position: relative;
	z-index: 1;
	max-width: 680px;
}

.pq-stars {
	color: #fbbf24;
	font-size: .78rem;
	margin-bottom: .4rem;
}

.pq-name {
	font-family: var(--ff-display);
	font-weight: 700;
	color: var(--sky);
	font-size: .95rem;
}

.pq-role {
	font-size: .76rem;
	color: rgba(255,255,255,.45);
	font-family: var(--ff-body);
}

.mini-t {
	background: rgba(255,255,255,.05);
	border: 1px solid rgba(255,255,255,.09);
	border-radius: var(--r-md);
	padding: 1.6rem;
	height: 100%;
	transition: background .25s,border-color .25s,transform .2s;
}

	.mini-t:hover {
		background: rgba(255,255,255,.08);
		border-color: rgba(26,143,227,.35);
		transform: translateY(-3px);
	}

.mt-stars {
	color: #fbbf24;
	font-size: .75rem;
	margin-bottom: .7rem;
}

.mt-text {
	font-family: var(--ff-body);
	font-style: italic;
	font-size: .9rem;
	color: rgba(255,255,255,.78);
	line-height: 1.8;
	margin-bottom: 1.2rem;
}

.mt-name {
	font-family: var(--ff-display);
	font-size: .88rem;
	font-weight: 700;
	color: var(--white);
}

.mt-role {
	font-size: .73rem;
	color: rgba(255,255,255,.4);
}

/* CONTACT */
.contact-section {
	background: var(--surface);
}

.contact-card {
	background: var(--white);
	border-radius: var(--r-xl);
	padding: 2.8rem;
	box-shadow: 0 16px 50px rgba(44,62,80,.09);
}

	.contact-card h4 {
		font-family: var(--ff-display);
		font-size: 1.5rem;
		font-weight: 800;
		color: var(--slate);
		margin-bottom: 1.6rem;
	}

.form-label {
	font-family: var(--ff-display);
	font-size: .7rem;
	font-weight: 700;
	letter-spacing: .1em;
	text-transform: uppercase;
	color: var(--cool-gray);
	margin-bottom: .4rem;
}

.form-control, .form-select {
	border: 1.5px solid var(--border);
	border-radius: var(--r-sm);
	padding: .72rem 1rem;
	font-family: var(--ff-body);
	font-size: .92rem;
	color: var(--slate);
	background: var(--white);
	transition: border-color .2s,box-shadow .2s;
}

	.form-control:focus, .form-select:focus {
		border-color: var(--sky);
		box-shadow: 0 0 0 3px var(--sky-glow);
		outline: none;
	}

	.form-control::placeholder {
		color: var(--cool-gray);
		font-style: italic;
	}

textarea.form-control {
	resize: vertical;
	min-height: 140px;
}

.btn-submit {
	background: var(--sky);
	color: var(--white);
	border: none;
	border-radius: var(--r-sm);
	padding: .85rem 2rem;
	font-family: var(--ff-display);
	font-weight: 700;
	font-size: .85rem;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	gap: .6rem;
	transition: background .2s,transform .15s,box-shadow .2s;
	box-shadow: 0 4px 16px var(--sky-glow);
}

	.btn-submit:hover {
		background: #157acc;
		transform: translateY(-1px);
		box-shadow: 0 8px 22px var(--sky-glow);
	}

.ci-card {
	background: var(--white);
	border: 1.5px solid var(--border);
	border-radius: var(--r-md);
	padding: 1.15rem 1.3rem;
	display: flex;
	align-items: flex-start;
	gap: 1rem;
	transition: border-color .2s,box-shadow .2s;
}

	.ci-card:hover {
		border-color: var(--sky);
		box-shadow: 0 4px 16px var(--sky-glow);
	}

.ci-ico {
	width: 42px;
	height: 42px;
	min-width: 42px;
	border-radius: 9px;
	background: var(--sky-light);
	color: var(--sky);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: .9rem;
}

.ci-lbl {
	font-family: var(--ff-display);
	font-size: .68rem;
	font-weight: 700;
	letter-spacing: .1em;
	text-transform: uppercase;
	color: var(--cool-gray);
	margin-bottom: .2rem;
}

.ci-val {
	font-size: .88rem;
	color: var(--slate);
	margin: 0;
	line-height: 1.65;
	font-style: italic;
}

.contact-photo {
	width: 100%;
	border-radius: var(--r-lg);
	object-fit: cover;
	aspect-ratio: 16/9;
	display: block;
}

/* FOOTER */
footer {
	background: var(--slate);
	padding: 1.8rem 0;
	border-top: 3px solid var(--sky);
}

.footer-copy {
	font-size: .8rem;
	color: rgba(255,255,255,.35);
}

	.footer-copy a {
		color: rgba(255,255,255,.5);
		text-decoration: none;
	}

		.footer-copy a:hover {
			color: var(--white);
		}

.footer-social {
	display: flex;
	gap: .4rem;
}

	.footer-social a {
		width: 34px;
		height: 34px;
		border-radius: 7px;
		background: rgba(255,255,255,.07);
		color: rgba(255,255,255,.4);
		display: flex;
		align-items: center;
		justify-content: center;
		font-size: .8rem;
		text-decoration: none;
		transition: background .2s,color .2s;
	}

		.footer-social a:hover {
			background: var(--sky);
			color: var(--white);
		}

@keyframes fadeUp {
	from {
		opacity: 0;
		transform: translateY(22px)
	}

	to {
		opacity: 1;
		transform: translateY(0)
	}
}

.hero-brandmark {
	animation: fadeUp .5s ease both;
}

.hero h1 {
	animation: fadeUp .6s .12s ease both;
}

.hero-sub {
	animation: fadeUp .6s .25s ease both;
}

.hero-btns {
	animation: fadeUp .6s .36s ease both;
}

@media(max-width:991.98px) {
	.container {
		padding-left: 1.5rem;
		padding-right: 1.5rem;
	}

	.about-badge {
		right: .5rem;
		bottom: .5rem;
	}
}

@media(max-width:767.98px) {
	.hero {
		min-height: 80vh;
	}

	.hero-inner {
		padding: 4rem 1.5rem 3rem;
	}

	.ts-inner {
		flex-direction: column;
	}

	.ts-item {
		border-right: none;
		border-bottom: 1px solid var(--border);
	}

		.ts-item:last-child {
			border-bottom: none;
		}

	.sec-pad {
		padding: 64px 0;
	}

	.feat-checklist {
		grid-template-columns: 1fr;
	}

	.about-badge {
		display: none;
	}
}
