@font-face {
    font-family: 'Marcellus-Regular';
    src: url('../fonts/Marcellus-Regular.woff2') format('woff2'),url('../fonts/Marcellus-Regular.ttf') format('truetype');
    font-display: swap
}

@font-face {
    font-family: 'Montserrat-Medium';
    src: url('../fonts/monserat/Montserrat-Medium.woff2') format('woff2'),url('../fonts/monserat/Montserrat-Medium.ttf') format('truetype');
    font-display: swap
}

@font-face {
    font-family: 'Montserrat-SemiBold';
    src: url('../fonts/monserat/Montserrat-SemiBold.woff2') format('woff2'),url('../fonts/monserat/Montserrat-SemiBold.ttf') format('truetype');
    font-display: swap
}


/* ============== DESIGN TOKENS — OFFERS PAGE PALETTE ============== */
:root {
	/* ===== COLORS (HopeQure Offers Style) ===== */
	/* Primary Teal — Brand Core */
	--t1: #006d68;
	/* deep teal */
	--t2: #009e96;
	/* brand teal */
	--t3: #00c4ba;
	/* bright teal */
	--t4: #7ddbd7;
	/* mid teal */
	--t5: #c2efed;
	/* pale teal */
	--t6: #e6f9f8;
	/* mint bg */
	--t7: #f2fdfc;
	/* near-white mint */
	--teal-border: #C2EFED;
	--teal-bg: #E6F9F8;
    
    --c-cream: #FAF6EE;
    --c-sage-soft: #E5EFEA;
        --c-accent: #D9573D;


	/* Secondary Green — Wellness */
	--g1: #1a6e3e;
	--g2: #2a9d5c;
	--g3: #38c477;
	--g4: #a3e4c0;
	--g5: #d4f5e4;
	--g6: #edfbf3;

	/* Warm Orange — Energy/CTA */
	--o1: #c4520a;
	--o2: #f26b28;
	/* HopeQure orange CTA */
	--o3: #ff9456;
	--o4: #ffcaa6;
	--o5: #fef0e8;

	/* Purple — Mental Health */
	--p1: #4a3080;
	--p2: #7b5ea7;
	--p3: #a48ed4;
	--p4: #d4c8f0;
	--p5: #f0ecfb;

	/* Coral — Relationships */
	--r1: #b52f52;
	--r2: #e85678;
	--r3: #f5a0b5;
	--r4: #fce4ec;

	/* Sky Blue — Work/Career */
	--s1: #1a5fa8;
	--s2: #3a8bd5;
	--s3: #88bef0;
	--s4: #dceefb;

	/* Amber — Life/Challenges */
	--a1: #916000;
	--a2: #c49000;
	--a3: #f0c040;
	--a4: #fff0b0;
	--a5: #fffbec;

	/* Neutrals */
	--white: #ffffff;
	--bg: #f4fefd;
	--ink: #0a1e1c;
	--body: #1e3a38;
	--muted: #5a7875;
	--border: #c8edeb;
	--card: #ffffff;

	/* WhatsApp */
	--wa: #25d366;
	--wad: #1db954;

	/* Typography */
	--fh: "Merriweather", serif;
	--fb: "Nunito", sans-serif;
	--r: 14px;
	--rr: 10px;
	--rl: 20px;
}

* {
    box-sizing: border-box;
    padding: 0;
    margin: 0;
    list-style: none;
}

html {
	scroll-behavior: smooth;
	-webkit-text-size-adjust: 100%
}


img {
	max-width: 100%;
	height: auto;
	display: block
}



h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: var(--fh);
	color: var(--t1);
	text-transform: capitalize;

}

h1 {
	font-size: clamp(2rem, 5vw, 3.5rem)
}

h2 {
	font-size: clamp(1.625rem, 3.5vw, 2.5rem);
	    line-height: 52px;
}

h3 {
	font-size: clamp(1.25rem, 2.4vw, 1.75rem)
}



p {
    line-height: 1.7;
    font-weight: 500;
    font-family: Montserrat-Medium;
        color: var(--muted);
    font-size: 16px;
    margin-bottom: 1rem;
}

ul,
ol {
	margin: 0 0 1em;
	padding-left: 1.25em
}

strong {
	font-weight: 700;
	color: var(--c-ink)
}

em {
	font-style: italic;
	color: var(--c-primary-2)
}



/* WA path helper */
.wa-path {
  fill: currentColor;
}


/* ============== LAYOUT ============== */




.section {
	    padding: 60px 0;
}

.section-cream {
	background: var(--c-cream)
}

.section-sage {
	background: var(--c-sage-soft)
}

.section-deep {
	background: var(--c-primary);
	color: var(--c-cream)
}

.section-deep h1,
.section-deep h2,
.section-deep h3,
.section-deep h4 {
	color: var(--c-cream)
}

.eyebrow {
	display: inline-block;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: .18em;
	text-transform: uppercase;
	color: var(--c-accent);
	padding: 6px 14px;
	background: rgba(217, 87, 61, .08);
	border-radius: 999px;
	margin-bottom: 14px;
}

.section-deep .eyebrow {
	color: #FFB89A;
	background: rgba(255, 255, 255, .08)
}

.section-head {

	
	text-align: center
}



.section-deep .section-head p {
	color: rgba(250, 246, 238, .85)
}



/* ============== HERO ============== */
.derm-hero {
	position: relative;
background: linear-gradient(150deg, #e0faf8 0%, #f2fdfc 30%, #e8f9f0 60%, #fef5ee 100%);
	padding: 140px 0 64px;
	overflow: hidden;
}

.derm-hero::before {
	content: "";
	position: absolute;
	top: -100px;
	right: -150px;
	width: 500px;
	height: 500px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(15, 76, 70, .08) 0%, transparent 70%);
	pointer-events: none;
}

.derm-hero::after {
	content: "";
	position: absolute;
	bottom: -200px;
	left: -200px;
	width: 600px;
	height: 600px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(217, 87, 61, .06) 0%, transparent 70%);
	pointer-events: none;
}

.hero-grid {
	display: grid;
	grid-template-columns: 1.1fr .9fr;
	gap: 48px;
	align-items: center;
	position: relative;
	z-index: 1
}

@media (max-width:880px) {
	.hero-grid {
		grid-template-columns: 1fr;
		gap: 32px
	}
}

.hero-trust-strip {
	display: inline-flex;
	flex-wrap: wrap;
	gap: 12px;
	padding: 8px 14px;
	background: #fff;
	border-radius: 999px;
	box-shadow: var(--shadow-sm);
	margin-bottom: 18px;
	font-size: .82rem;
	color: var(--c-ink-2);
}

.hero-trust-strip span {
	display: inline-flex;
	align-items: center;
	gap: 5px
}

.hero-tag {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: .85rem;
	color: var(--c-primary);
	background: rgba(184, 214, 203, .4);
	padding: 6px 14px;
	border-radius: 999px;
	margin-bottom: 16px;
	font-weight: 600;
}

.hero-tag .dot {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: #2E7D5F;
	animation: pulse 2s infinite
}

@keyframes pulse {

	0%,
	100% {
		opacity: 1
	}

	50% {
		opacity: .5
	}
}

.derm-hero h1 {
font-family: var(--fh);
    font-size: 46px;
    color: var(--t1);
    line-height: 60px;
    margin-bottom: 35px;
}

.derm-hero h1 em {
font-style: italic;
    color: var(--t2);
    font-size: 44px;
}

.hero-sub {
	font-size: 1.1rem;
	color: var(--c-ink-2);
	max-width: 580px;
	margin-bottom: 24px
}

.hero-features {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 10px 18px;
	list-style: none;
	padding: 0;
	margin: 0 0 28px;
	max-width: 580px;
}

.hero-features li {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    color: var(--color-4);
}

.hero-features svg {
    flex-shrink: 0;
    color: var(--t2);
}

.hero-ctas {
	display: flex;
	gap: 12px;
	flex-wrap: wrap;
	margin-bottom: 4px
}

.hero-cta-meta {
	font-size: .85rem;
	color: var(--c-muted)
}

.hero-cta-meta strong {
	color: var(--c-accent)
}

.hero-stats {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 20px;
	padding: 24px 0 0;
	border-top: 1px solid rgba(15, 76, 70, .10);
	
}

.hero-stat strong {
	display: block;
	font-family: Montserrat-Medium;
	font-size: 1.5rem;
	color: var(--t2);
	line-height: 1.1
}
.hero-stat span {
    font-size: .78rem;
    color: var(--color-4);
    line-height: 18px;
    display: block;
    margin-top: 10px;
        font-family: Montserrat-Medium;
}



.hero-image-wrap {
	position: relative
}

.hero-image-wrap img {
	width: 100%;
	height: auto;
	border-radius: 24px;
	box-shadow: var(--shadow-lg);
	object-fit: cover;
	aspect-ratio: 4/3;
}

.hero-overlay-card {
	position: absolute;
	left: -20px;
	bottom: 30px;
	background: #fff;
	padding: 14px 18px;
	border-radius: 14px;
	box-shadow: var(--shadow-md);
	display: flex;
	align-items: center;
	gap: 12px;
	font-size: .85rem;
	max-width: 240px;
}

.hero-overlay-card .ico-circle {
	flex-shrink: 0;
	width: 42px;
	height: 42px;
	background: var(--c-sage-soft);
	color: var(--c-primary);
	border-radius: 50%;
	display: grid;
	place-items: center;
}

.hero-overlay-card strong {
	display: block;
	color: var(--c-ink);
	font-size: .92rem;
	margin-bottom: 2px
}

.hero-overlay-card span {
	color: var(--c-muted);
	font-size: .78rem;
	line-height: 1.3
}

@media (max-width:600px) {
	.hero-features {
		grid-template-columns: 1fr
	}

	.hero-stats {
		grid-template-columns: repeat(3, 1fr);
		gap: 12px
	}

	.hero-stat strong {
		font-size: 1.25rem
	}

	.hero-overlay-card {
		left: 10px;
		right: 10px;
		bottom: 10px;
		max-width: none
	}
}

/* ============== TRUST BAND ============== */
.trust-band {
    background: var(--t2);
    padding: 15px 0;
    color: var(--c-cream);
}

.trust-band-grid {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-around;
	gap: 18px;
	align-items: center;
	text-align: center;
}

.trust-item {
    flex: 1 1 140px;
    padding: 6px 10px;
    border-right: 1.5px solid var(--t3);
}

.trust-item strong {
    display: block;

    font-size: 1.4rem;
    color: #fff;
    font-family: var(--fh);
}

.trust-item span {
    font-size: 11px;
    color: rgba(250, 246, 238, .85);
}

.cf-bg .stitle {
    color: var(--t1) !important;
}

/* ============== TLDR / QUICK ANSWER ============== */
.derm-tldr {
	background: #fff;
	border: 1px solid var(--c-line);
	border-radius: 20px;
	padding: 28px 32px;
	box-shadow: var(--shadow-sm);
	margin: 32px auto;
	max-width: 880px;
}

.derm-tldr h3 {
	margin-bottom: 16px;
color: var(--t1);
	display: flex;
	align-items: center;
	gap: 8px
}

.derm-tldr ul {
	list-style: none;
	padding: 0;
	margin: 0
}

.derm-tldr li {
	position: relative;
	padding-left: 28px;
	margin-bottom: 10px;
	font-size: .95rem;
	line-height: 1.55;
  color: var(--color-4);
}

.derm-tldr li::before {
	content: "✓";
	position: absolute;
	left: 0;
	top: 0;
	width: 20px;
	height: 20px;
	background: var(--c-sage-soft);
	color: var(--c-primary);
	border-radius: 50%;
	font-weight: 700;
	font-size: .78rem;
	display: grid;
	place-items: center;
}

.derm-quick-answer {
	background: linear-gradient(135deg, var(--c-cream) 0%, #fff 100%);
	border-left: 4px solid var(--c-accent);
	padding: 24px 28px;
	border-radius: 14px;
	margin: 24px auto;
	max-width: 880px;
}

.derm-quick-answer h3 {
	font-size: 1.15rem;
	margin-bottom: 10px;
	color: var(--c-accent);
}

.derm-quick-answer p {
	margin: 0;
	font-size: .95rem;
	color: var(--muted);
}

/* ============== REVIEWED BY BYLINE ============== */
.derm-byline {
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 18px 22px;
	background: #fff;
	border: 1px solid var(--c-line);
	border-radius: 14px;
	margin: 24px auto;
	max-width: 580px;
}

.derm-byline img {
	width: 54px;
	height: 54px;
	border-radius: 50%;
	object-fit: cover;
	border: 3px solid var(--c-sage-soft)
}

.derm-byline-meta strong {
	display: block;
	color: var(--c-primary);
	font-size: .95rem
}

.derm-byline-meta small {
	display: block;
	color: var(--c-muted);
	font-size: .78rem
}

.derm-byline-meta a {
	font-size: .78rem;
	color: var(--c-accent);
	font-weight: 600
}

/* ============== EMERGENCY BANNER ============== */
.derm-emergency {
    background: #FFF1EB;
    border: 1px solid #F2C7B6;
    padding: 16px 22px;
    border-radius: 12px;
    margin: 20px auto;
    max-width: 880px;
    font-size: 13px;
    color: var(--c-accent);
    font-family: Montserrat-Medium;
    font-weight: 500;
    line-height: 21px;
}
.derm-emergency strong {
    color: var(--o2);
}

.derm-emergency a {
	 color: var(--o2);
	text-decoration: underline;
	font-weight: 700
}

/* ============== TOC ============== */
.derm-toc {
	background: #fff;
	border: 1px solid var(--c-line);
	border-radius: 14px;
	padding: 18px 22px;
	margin: 24px auto;
	max-width: 880px;
}

.derm-toc h4 {
	margin: 0 0 10px;
	color: var(--c-primary);
	font-size: .95rem
}

.derm-toc ol {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 6px 18px;
	counter-reset: toc;
}

.derm-toc li {
	counter-increment: toc;
	font-size: .85rem
}

.derm-toc li::before {
	content: counter(toc, decimal-leading-zero);
	color: var(--c-accent);
	font-weight: 700;
	margin-right: 6px
}

.derm-toc a {
    color: var(--muted);
    text-decoration: none;
}

.derm-toc a:hover {
	color: var(--c-accent)
}

@media (max-width:600px) {
	.derm-toc ol {
		grid-template-columns: 1fr
	}
}

/* ============== CONDITIONS GRID ============== */
.cond-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(330px, 1fr));
	gap: 18px;
}

.cond-card {
	background: #fff;
    padding: 18px 15px;
    border: 1px solid #e4e4e4;
	border-radius: 16px;
	display: flex;
	gap: 14px;
	transition: transform .2s ease, box-shadow .2s ease, border-color .2s;
}

.cond-card:hover {
    transform: translateY(-2px);
    border-color: #fff1d6;
    box-shadow: rgb(254 240 210) 0px 2px 8px 0px;
}

.cond-card .ico {
	flex-shrink: 0;
	width: 44px;
	height: 44px;
	background: var(--c-sage-soft);
	color: var(--c-primary);
	border-radius: 12px;
	display: grid;
	place-items: center;
	font-size: 1.2rem;
}

.cond-card h4 {
	margin: 0 0 6px;
	font-size: 1rem
}

.cond-card p {
    margin: 0;
    font-size: 13px;
    color: var(--color-4);
    line-height: 1.45;
}

/* ============== SYMPTOM TABLE ============== */
.derm-symptom-table {
	background: #fff;
	border-radius: 16px;
	overflow: hidden;
	border: 1px solid #d9e5df;
	box-shadow: rgba(99, 99, 99, 0.2) 0px 2px 8px 0px;
    margin-top: 30px;
}

.derm-symptom-table table {
	width: 100%;
	border-collapse: collapse;
	font-size: .9rem
}

.derm-symptom-table th {
	background: var(--t1);
    color: var(--c-cream);
  font-weight: 600;
    padding: 14px 18px;
    text-align: left;
    font-size: .95rem;
    font-family: Montserrat-Medium;
}

.derm-symptom-table td {
	padding: 14px 18px;
	border-top: 1px solid #fff2b9;
	vertical-align: top
}

.derm-symptom-table tbody tr:nth-child(odd) {
	background: var(--c-cream)
}

.derm-symptom-table .sym {
	font-weight: 600;
	      color: var(--color-3);
	width: 25%
}

.derm-symptom-table td {
    font-family: Montserrat-Medium;
    color: var(--muted);
}
.derm-symptom-table .cause {
	    color: var(--muted);
	width: 35%
}

.derm-symptom-table .action {
    color: var(--color-4);
    font-weight: 500;
}

@media (max-width:780px) {



	.derm-symptom-table tr {
		padding: 14px 18px;
		border-top: 1px solid var(--c-line-soft)
	}



	.derm-symptom-table .sym {
		font-size: 1rem;
		padding-bottom: 8px
	}

	.derm-symptom-table .cause::before {
		content: "Causes: ";
		color: var(--c-primary);
		font-weight: 700
	}

	.derm-symptom-table .action::before {
		content: "Action: ";
		color: var(--c-accent);
		font-weight: 700
	}
}

/* ============== HOW IT WORKS / STEPS ============== */
.how-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: 18px
}

.how-card {
	background: #fff;
	padding: 24px 22px;
	border: 1px solid var(--c-line);
	border-radius: 16px;
	text-align: center;
	position: relative;
}

.how-card .step-num {
	position: absolute;
	top: -12px;
	left: 50%;
	transform: translateX(-50%);
	width: 32px;
	height: 32px;
	background: var(--c-accent);
	color: #fff;
	border-radius: 50%;
	display: grid;
	place-items: center;
	font-family: var(--fd);
	font-size: 1rem;
	font-weight: 600;
}

.how-card .step-icon {
	font-size: 2rem;
	margin-bottom: 10px
}

.how-card h4 {
	margin-bottom: 6px
}

.how-card p {
	font-size: .85rem;
	color: var(--c-muted);
	margin: 0
}

/* ============== DOCTOR CARDS — SAME AS OFFERS PAGE ============== */
.doctors-list {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
	gap: 24px;
}

.doc-card {
	background: #fff;
	padding: 28px 24px;
	border: 1px solid var(--c-line);
	border-radius: 20px;
	position: relative;
	transition: transform .2s ease, box-shadow .2s ease;
}

.doc-card:hover {
	transform: translateY(-3px);
	box-shadow: var(--shadow-md)
}

.doc-card .verified-badge {
	position: absolute;
	top: 18px;
	right: 18px;
	width: 24px;
	height: 24px;
	background: var(--c-success);
	color: #fff;
	border-radius: 50%;
	display: grid;
	place-items: center;
	font-size: .78rem;
	font-weight: 700;
}

.doc-card img {
	width: 88px;
	height: 88px;
	border-radius: 50%;
	object-fit: cover;
	border: 3px solid var(--c-sage-soft);
	margin-bottom: 14px;
}

.doc-card .rci-badge {
	display: inline-block;
	padding: 3px 9px;
	background: var(--c-primary);
	color: #fff;
	border-radius: 6px;
	font-size: .7rem;
	font-weight: 700;
	letter-spacing: .05em;
	margin-bottom: 8px;
}

.doc-card h3 {
	font-family: var(--fd);
	font-size: 1.25rem;
	margin: 0 0 4px
}

.doc-card .doc-title {
	color: var(--c-accent);
	font-weight: 600;
	font-size: .88rem;
	margin: 0 0 12px
}

.doc-card .doc-meta {
	display: flex;
	gap: 14px;
	font-size: .82rem;
	color: var(--c-muted);
	margin-bottom: 14px;
	flex-wrap: wrap;
}

.doc-card .doc-meta span {
	display: inline-flex;
	align-items: center;
	gap: 4px
}

.doc-card .doc-slot {
	background: var(--c-sage-soft);
	color: var(--c-primary);
	padding: 6px 12px;
	border-radius: 8px;
	font-size: .78rem;
	font-weight: 600;
	display: inline-block;
	margin-bottom: 14px;
}

.doc-card .doc-section {
	margin-bottom: 10px
}

.doc-card .doc-section-label {
	font-size: .72rem;
	color: var(--c-muted);
	font-weight: 600;
	letter-spacing: .05em;
	text-transform: uppercase;
	margin-bottom: 4px;
}

.doc-card .doc-expertise-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 5px
}

.doc-card .doc-expertise-tags span {
	background: var(--c-sage-soft);
	color: var(--c-primary);
	padding: 3px 9px;
	border-radius: 6px;
	font-size: .72rem;
	font-weight: 600;
}

.doc-card .doc-expertise-tags .more {
	background: var(--c-accent);
	color: #fff
}

.doc-card .doc-cta-row {
	display: flex;
	gap: 10px;
	margin-top: 18px;
	padding-top: 14px;
	border-top: 1px solid var(--c-line-soft);
}

.doc-card .doc-cta-row a {
	flex: 1;
	text-align: center;
	padding: 10px 12px;
	border-radius: 10px;
	font-size: .82rem;
	font-weight: 700;
}

.doc-card .doc-cta-row a:first-child {
	background: transparent;
	color: var(--c-primary);
	border: 1.5px solid var(--c-primary);
}

.doc-card .doc-cta-row a:first-child:hover {
	background: var(--c-primary);
	color: #fff
}

.doc-card .doc-cta-row a:last-child {
	background: var(--c-accent);
	color: #fff;
}

.doc-card .doc-cta-row a:last-child:hover {
	background: var(--c-accent-2);
	color: #fff
}

/* ============== BOOK SESSION WIDGET (OFFERS PAGE STYLE) ============== */
.book-session-widget {
	max-width: 760px;
	margin: 0 auto;
	background: #fff;
	border: 1px solid var(--c-line);
	border-radius: 24px;
	padding: 32px;
	box-shadow: var(--shadow-md);
}

.book-session-widget .book-header {
	text-align: center;
	margin-bottom: 24px
}

.book-session-widget .book-header h3 {
	font-size: 1.6rem;
	color: var(--c-primary);
	margin: 0 0 6px
}

.book-session-widget .book-header p {
	color: var(--c-muted);
	font-size: .92rem;
	margin: 0
}

.book-session-widget .discount-band {
	background: linear-gradient(135deg, #FFF8E7 0%, #FFE7C7 100%);
	color: #7A4F1F;
	padding: 8px 16px;
	border-radius: 8px;
	font-size: .85rem;
	font-weight: 700;
	text-align: center;
	margin-bottom: 18px;
}

.book-stepper {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 24px;
	padding: 0 8px;
}

.book-step {
	display: flex;
	flex-direction: column;
	align-items: center;
	flex: 1;
	position: relative;
}

.book-step:not(:last-child)::after {
	content: "";
	position: absolute;
	top: 18px;
	left: 60%;
	right: -40%;
	height: 2px;
	background: var(--c-line);
}

.book-step.active:not(:last-child)::after,
.book-step.complete:not(:last-child)::after {
	background: var(--c-accent)
}

.book-step .step-circle {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	display: grid;
	place-items: center;
	font-family: var(--fd);
	font-size: 1rem;
	font-weight: 600;
	background: var(--c-line);
	color: var(--c-muted);
	margin-bottom: 6px;
	position: relative;
	z-index: 1;
}

.book-step.active .step-circle {
	background: var(--c-accent);
	color: #fff
}

.book-step.complete .step-circle {
	background: var(--c-primary);
	color: #fff
}

.book-step span {
	font-size: .78rem;
	color: var(--c-muted);
	font-weight: 600
}

.book-step.active span {
	color: var(--c-ink)
}

.plan-tiles {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 14px;
	margin-bottom: 18px
}

@media (max-width:540px) {
	.plan-tiles {
		grid-template-columns: 1fr
	}
}

.plan-tile {
	border: 2px solid var(--c-line);
	padding: 16px 18px;
	border-radius: 14px;
	cursor: pointer;
	transition: all .2s ease;
	position: relative;
}

.plan-tile:hover,
.plan-tile.selected {
	border-color: var(--c-accent);
	background: #FFF8F4
}

.plan-tile.popular::before {
	content: "Most Popular";
	position: absolute;
	top: -10px;
	left: 50%;
	transform: translateX(-50%);
	background: var(--c-accent);
	color: #fff;
	padding: 3px 10px;
	border-radius: 6px;
	font-size: .7rem;
	font-weight: 700;
	letter-spacing: .05em;
}

.plan-tile h4 {
	margin: 0 0 4px;
	font-size: .95rem
}

.plan-tile .plan-price {
	display: flex;
	align-items: baseline;
	gap: 6px;
	margin-bottom: 6px;
}

.plan-tile .plan-price strong {
	font-family: var(--fd);
	font-size: 1.5rem;
	color: var(--c-primary)
}

.plan-tile .plan-price small {
	font-size: .75rem;
	color: var(--c-muted);
	text-decoration: line-through
}

.plan-tile .plan-discount {
	font-size: .7rem;
	color: var(--c-success);
	font-weight: 700;
	background: #DFF2E8;
	padding: 2px 6px;
	border-radius: 5px;
	display: inline-block;
	margin-bottom: 6px
}

.plan-tile .plan-meta {
	font-size: .78rem;
	color: var(--c-muted);
	margin: 0
}

.book-form {
	display: grid;
	gap: 14px
}

.book-form label {
	display: block;
	font-size: .85rem;
	font-weight: 600;
	color: var(--c-ink-2);
	margin-bottom: 6px
}

.book-form input,
.book-form select,
.book-form textarea {
	width: 100%;
	padding: 12px 16px;
	border: 1.5px solid var(--c-line);
	border-radius: 10px;
	font-family: var(--fb);
	font-size: .92rem;
	color: var(--c-ink);
	background: #fff;
}

.book-form input:focus,
.book-form select:focus,
.book-form textarea:focus {
	outline: none;
	border-color: var(--c-accent)
}

.book-form-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 14px
}

@media (max-width:540px) {
	.book-form-row {
		grid-template-columns: 1fr
	}
}

.book-actions {
	display: flex;
	gap: 10px;
	margin-top: 18px;
	flex-wrap: wrap
}

.book-trust-line {
	text-align: center;
	font-size: .78rem;
	color: var(--c-muted);
	margin-top: 14px;
}

/* ============== CONCERN MATRIX (OFFERS-STYLE) ============== */
.concern-matrix {
	margin-top: 24px
}

.concern-tabs {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
	justify-content: center;
	margin-bottom: 24px;
}

.concern-tab {
	padding: 10px 18px;
	background: #fff;
	border: 1.5px solid var(--c-line);
	border-radius: 999px;
	cursor: pointer;
	font-family: var(--fb);
	font-weight: 600;
	font-size: .88rem;
	color: var(--c-ink-2);
	transition: all .2s ease;
}

.concern-tab:hover {
	border-color: var(--c-accent);
	color: var(--c-accent)
}

.concern-tab.active {
	background: var(--c-primary);
	color: #fff;
	border-color: var(--c-primary)
}

.concern-pane {
	display: none;
	max-width: 880px;
	margin: 0 auto
}

.concern-pane.active {
	display: block;
	animation: fadeIn .3s
}

@keyframes fadeIn {
	from {
		opacity: 0;
		transform: translateY(8px)
	}

	to {
		opacity: 1;
		transform: none
	}
}

.concern-pane-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 24px;
	background: #fff;
	padding: 28px;
	border: 1px solid var(--c-line);
	border-radius: 20px;
}

@media (max-width:740px) {
	.concern-pane-grid {
		grid-template-columns: 1fr
	}
}

.concern-pane h3 {
	margin-bottom: 10px;
	color: var(--c-primary)
}

.concern-pane p {
	font-size: .92rem;
	margin-bottom: 14px
}

.concern-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	margin-bottom: 18px
}

.concern-tag {
	padding: 5px 12px;
	background: var(--c-sage-soft);
	color: var(--c-primary);
	border-radius: 999px;
	font-size: .78rem;
	font-weight: 600;
	border: 0;
	cursor: pointer;
	font-family: var(--fb);
	transition: background .2s;
}

.concern-tag:hover {
	background: var(--c-primary);
	color: #fff
}

.concern-pane .concern-doctor {
	background: var(--c-cream);
	padding: 18px;
	border-radius: 14px;
	display: flex;
	gap: 14px;
	align-items: center;
}

.concern-pane .concern-doctor img {
	width: 64px;
	height: 64px;
	border-radius: 50%;
	object-fit: cover;
	flex-shrink: 0;
	border: 2px solid #fff
}

.concern-pane .concern-doctor strong {
	display: block;
	color: var(--c-ink);
	font-size: .95rem
}

.concern-pane .concern-doctor small {
	display: block;
	color: var(--c-muted);
	font-size: .78rem;
	margin-bottom: 8px
}

.concern-pane .concern-doctor a {
	display: inline-block;
	padding: 6px 12px;
	background: var(--c-accent);
	color: #fff;
	border-radius: 8px;
	font-size: .78rem;
	font-weight: 700;
}

/* ============== PRICING ============== */
.pricing-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 18px
}

.price-card {
	background: #fff;
	padding: 28px 24px;
	border: 2px solid var(--c-line);
	border-radius: 18px;
	position: relative;
	transition: border-color .2s, transform .2s;
}

.price-card.popular {
	border-color: var(--c-accent);
	transform: scale(1.02)
}

.price-card.popular::before {
	content: "⭐ Most Effective";
	position: absolute;
	top: -12px;
	left: 50%;
	transform: translateX(-50%);
	background: var(--c-accent);
	color: #fff;
	padding: 4px 14px;
	border-radius: 8px;
	font-size: .72rem;
	font-weight: 700;
	letter-spacing: .05em;
}

.price-card h4 {
	margin-bottom: 8px
}

.price-card .price {
	font-family: var(--fd);
	font-size: 2rem;
	color: var(--c-primary);
	margin: 0 0 4px;
	line-height: 1;
}

.price-card .price small {
	font-size: .72rem;
	color: var(--c-muted);
	font-family: var(--fb);
	font-weight: 600;
	margin-left: 6px
}

.price-card .price-meta {
	font-size: .82rem;
	color: var(--c-muted);
	margin-bottom: 18px
}

.price-card ul {
	list-style: none;
	padding: 0;
	margin: 0 0 18px
}

.price-card li {
	padding: 6px 0;
	font-size: .88rem;
	display: flex;
	gap: 8px;
	align-items: flex-start
}

.price-card li::before {
	content: "✓";
	color: var(--c-success);
	font-weight: 700;
	flex-shrink: 0
}

/* ============== COMPARISON TABLE ============== */
.compare-table {
	background: #fff;
	border-radius: 16px;
	overflow: auto;
	border: 1px solid #d9e5df;
	box-shadow: 0 1px 2px rgba(15, 76, 70, .06), 0 2px 8px rgba(15, 76, 70, .04);
}

.compare-table table {
	width: 100%;
	border-collapse: collapse;
	font-size: .92rem;
	min-width: 640px
}

.compare-table th {
    padding: 16px;
    text-align: left;
    font-weight: 700;
    background: var(--c-cream);
    color: var(--t1);
    font-family: Montserrat-Medium;
    font-size: 14px;
    border-bottom: 2px solid #d9e5df;
}

.compare-table th.us {
    background: var(--t1);
    color: #fff;
}

.compare-table td {
    padding: 14px 16px;
    border-top: 1px solid #e8f0eb;
    vertical-align: top;
 font-family: Montserrat-Medium;
 font-weight: 500;
    font-size: 14px;
	color: var(--muted);
}

.compare-table td.us {
	background: rgba(184, 214, 203, .2);
	font-weight: 500;
    color: var(--t1);
    font-family: Montserrat-Medium;
    font-size: 14px;
}

.compare-table .feat {
	font-weight: 700;
	color: var(--t1);
	width: 30%;
	font-family: Montserrat-SemiBold;
}

.compare-table tr:nth-child(odd) td {
	background: var(--c-cream)
}

.compare-table tr:nth-child(odd) td.us {
	background: rgba(184, 214, 203, .3)
}

/* ============== TESTIMONIALS ============== */
.testimonial-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(330px, 1fr));
	gap: 24px
}

.testimonial {
    background: var(--t7);
  padding: 25px 20px;
    border: 1.5px solid var(--t6);
    border-radius: 20px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    box-shadow: rgb(240 255 254) 0px 2px 8px 0px;
}

.testimonial .badge {
	align-self: flex-start;
	padding: 4px 10px;
	background: var(--c-sage-soft);
	color: var(--c-primary);
	border-radius: 6px;
	font-size: .72rem;
	font-weight: 700;
}

.testimonial .stars {
	color: #F4B400;
	letter-spacing: 2px;
	font-size: .95rem
}

.testimonial blockquote {
    margin: 0;
    font-family: var(--fd);
    font-size: 14px;
    color: var(--muted);
    line-height: 1.5;
    font-family: Montserrat-Medium;
}

.testimonial cite {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-top: auto;
    font-style: normal;
    font-size: .88rem;
    color: var(--muted);
    padding-top: 14px;
    border-top: 1px solid #d5d5d5;
}
.review_bxe .section-head p a {
    text-decoration: none;
}
.testimonial cite .avatar {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: var(--t1);
	color: #fff;
	display: grid;
	place-items: center;
	font-family: var(--fd);
	font-weight: 600;
	font-size: .92rem;
}

.testimonial cite strong {
	color: var(--c-ink);
	display: block;
	line-height: 1.2
}

.testimonial cite small {
    color: var(--color-4);
    font-size: .78rem;
    font-family: Montserrat-Medium;
}

.review_bxe .section-head p{
	font-size: 15px;
}

/* ============== PSYCHO BANNER ============== */
.psycho-band {
	background: linear-gradient(150deg, var(--t1) 0%, #007a74 50%, var(--g1) 100%);
	color: var(--c-cream);
	padding: 48px 32px;
	border-radius: 24px;
}

.psycho-band-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 32px;
	align-items: center;
}

@media (max-width:780px) {
	.psycho-band-grid {
		grid-template-columns: 1fr
	}
}

.psycho-band h2 {
	color: #fff;
	margin-bottom: 14px
}

.psycho-band p {
	color: rgba(250, 246, 238, .9)
}

.psycho-band ul {
	list-style: none;
	padding: 0;
	margin: 14px 0 18px
}

.psycho-band li {
	padding: 6px 0;
	padding-left: 28px;
	position: relative;
	font-size: .95rem
}

.psycho-band li::before {
	content: "✦";
	position: absolute;
	left: 0;
	top: 6px;
	color: #FFB89A;
	font-size: .95rem;
}

.psycho-band img {
	border-radius: 18px;
	box-shadow: var(--shadow-lg)
}

/* ============== APP BAND ============== */
.app-band {
	background: var(--c-cream);
	border-radius: 24px;
	padding: 48px 32px;
	display: grid;
	grid-template-columns: 1.1fr .9fr;
	gap: 32px;
	align-items: center;
}

@media (max-width:780px) {
	.app-band {
		grid-template-columns: 1fr
	}
}

.app-band h2 {
	margin-bottom: 14px
}

.app-band p {
    color: var(--color-4);
    margin-bottom: 14px;
}

.app-band ul {
	list-style: none;
	padding: 0;
	margin: 0 0 22px
}

.app-band li {
	padding: 6px 0;
	padding-left: 24px;
	position: relative;
	font-size: .92rem;
	color: var(--muted);
}

.app-band li::before {
	content: "✓";
	position: absolute;
	left: 0;
	top: 0;
	color: var(--c-accent);
	font-weight: 700
}

.app-band-stores {
	display: flex;
	gap: 12px;
	flex-wrap: wrap
}

.app-band-stores a {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 10px 16px;
    background: #000;
    color: #fff;
    border-radius: 10px;
    font-size: .9rem;
    font-weight: 600;
    text-decoration: none;
}

.app-band-stores a small {
    display: block;
    font-size: .65rem;
    opacity: .8;
    line-height: 1;
    font-weight: 500;
}

.app-band-stores a strong {
	font-family: var(--fd);
	font-size: 13px;
	line-height: 1.1
}

/* ============== FAQ ============== */
.faq-grid {
	max-width: 840px;
	margin: 0 auto;
	display: grid;
	gap: 8px
}

.faq {
	background: #fff;
	border: 1px solid var(--c-line);
	border-radius: 14px;
	padding: 0;
	overflow: hidden;
	transition: box-shadow .2s;
}

.faq:hover {
	box-shadow: var(--shadow-sm)
}

.faq summary {
	list-style: none;
	padding: 18px 22px;
	cursor: pointer;
	font-weight: 700;
	font-size: .95rem;
	color: var(--c-ink);
	position: relative;
	padding-right: 48px;
}

.faq summary::-webkit-details-marker {
	display: none
}

.faq summary::after {
	content: "+";
	position: absolute;
	right: 22px;
	top: 50%;
	transform: translateY(-50%);
	width: 24px;
	height: 24px;
	background: var(--c-sage-soft);
	color: var(--c-primary);
	border-radius: 50%;
	display: grid;
	place-items: center;
	font-size: 1.1rem;
	font-weight: 600;
	transition: transform .2s;
}

.faq[open] summary::after {
	content: "–";
	background: var(--c-accent);
	color: #fff;
	transform: translateY(-50%) rotate(180deg)
}

.faq[open] summary {
	border-bottom: 1px solid var(--c-line-soft)
}

.faq .faq-body {
	padding: 14px 22px 18px;
	font-size: .92rem;
	color: var(--c-ink-2);
	line-height: 1.6
}

/* ============== QUICK ACCESS ============== */
.quick-access {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
	gap: 10px;
}

.quick-access a {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 10px 14px;
	background: #fff;
	border: 1px solid #d9e5df;
	border-radius: 10px;
	font-size: .85rem;
	color: var(--t1);
	font-weight: 600;
	transition: all .2s;
	text-decoration: none;
	font-family: Montserrat-SemiBold;
   transition:
  transform .28s ease,
  box-shadow .28s ease;
}

.quick-access a:hover {
    background: var(--t6);
    border-color: var(--t4);
    color: var(--t1);
    transform:scale(1.04);

  box-shadow:
  0 12px 28px rgba(0,0,0,.08);
}

.quick-access img {
	width: 14px;
	height: 14px;
	opacity: .6
}

/* ============== REFERENCES ============== */
.refs {
	background: #fff;
	padding: 28px 32px;
	border: 1px solid var(--c-line);
	border-radius: 18px;
	font-size: .85rem;
	color: var(--c-muted);
}

.refs h3 {
	font-family: var(--fb);
	font-size: 1rem;
	color: var(--c-primary);
	margin-bottom: 14px
}

.refs ol {
	padding-left: 22px
}

.refs li {
	padding: 5px 0
}

.refs a {
	color: var(--c-primary);
	word-break: break-word
}

/* ============== PROCESS / TIMELINE ============== */
.process-timeline {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 18px;
	counter-reset: proc;
}

.process-step {
	background: #fff;
	padding: 24px;
	border: 1px solid var(--c-line);
	border-radius: 16px;
	position: relative;
	counter-increment: proc;
}

.process-step::before {
	content: counter(proc, decimal-leading-zero);
	font-family: var(--fd);
	font-size: 2.5rem;
	color: var(--c-accent);
	display: block;
	line-height: 1;
	margin-bottom: 8px;
	opacity: .85;
}

.process-step h4 {
	margin-bottom: 6px
}

.process-step p {
	margin: 0;
	font-size: .85rem;
	color: var(--c-muted);
	line-height: 1.45
}

/* ============== FINAL CTA ============== */
.final-cta {
	background: linear-gradient(160deg, var(--t1) 0%, #005e58 50%, var(--g1) 100%);
	color: var(--c-cream);
	padding: 64px 32px;
	border-radius: 24px;
	text-align: center;
}

.final-cta h2 {
	color: #fff;
	margin-bottom: 12px
}

.final-cta p {
	color: rgba(250, 246, 238, .9);
	max-width: 580px;
	margin: 0 auto 24px;
	font-size: 15px;
}

.final-cta-row {
	display: flex;
	gap: 12px;
	justify-content: center;
	flex-wrap: wrap;
	margin-bottom: 18px;
}

.final-cta .trust-pills {
	display: flex;
	gap: 14px;
	justify-content: center;
	flex-wrap: wrap;
	font-size: .85rem;
	color: rgba(250, 246, 238, .85);
}

/* ============== STICKY MOBILE CTA ============== */
.derm-mobile-cta {
	display: none;
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	background: #fff;
	padding: 10px 14px;
	box-shadow: 0 -4px 16px rgba(0, 0, 0, .10);
	z-index: 50;
	border-top: 1px solid var(--c-line);
}

.derm-mobile-cta-inner {
	display: flex;
	gap: 8px;
	max-width: 600px;
	margin: 0 auto
}

.derm-mobile-cta a {
	flex: 1
}

@media (max-width:740px) {
	.derm-mobile-cta {
		display: block
	}

	body {
		padding-bottom: 78px
	}
}

/* ============== SEGMENTS ============== */
.segments-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 18px
}

.segment-card {
	background: #fff;
	padding: 24px;
	border: 1px solid var(--c-line);
	border-radius: 16px;
	text-align: center;
	transition: transform .2s, box-shadow .2s;
}

.segment-card:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-md)
}

.segment-card .seg-icon {
	width: 54px;
	height: 54px;
	margin: 0 auto 14px;
	background: var(--c-sage-soft);
	color: var(--c-primary);
	border-radius: 14px;
	display: grid;
	place-items: center;
	font-size: 1.6rem;
}

.segment-card h4 {
	margin-bottom: 10px;
	font-size: 17px;
}

.segment-card ul {
	list-style: none;
	padding: 0;
	margin: 0;
	text-align: left
}

.segment-card li {
	padding: 4px 0;
	padding-left: 18px;
	position: relative;
	font-size: 15px;
	color: var(--muted)
}

.segment-card li::before {
	content: "·";
	position: absolute;
	left: 6px;
	color: var(--c-accent);
	font-weight: 700
}

/* ============== CASE STUDIES ============== */
.case-studies-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
	gap: 24px
}

.case-study {
	background: #fff;
	padding: 28px;
	border: 1px solid var(--c-line);
	border-radius: 20px;
}

.case-study .case-cond {
	display: inline-block;
	padding: 5px 12px;
	background: var(--c-accent);
	color: #fff;
	border-radius: 6px;
	font-size: 10px;
	font-weight: 700;
	letter-spacing: .05em;
	margin-bottom: 14px;
}

.case-study h4 {
	margin-bottom: 6px;
	font-size: 1.15rem;
	font-weight: 400
}

.case-study .case-meta {
	font-size: .78rem;
	color: var(--muted);
	margin-bottom: 14px
}

.case-study .case-bafter {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 10px;
	padding: 14px;
	background: var(--c-cream);
	border-radius: 10px;
	margin-bottom: 14px;
	font-size: .82rem;
}

.case-study .case-bafter strong {
    display: block;
    color: var(--t1);
    font-size: .7rem;
    letter-spacing: .05em;
}

.case-study .case-treatment {
    font-size: .85rem;
    color: var(--muted);
    padding-top: 12px;
    border-top: 1px solid #dadada;
}

.case-study .case-result {
    background: var(--c-sage-soft);
    color: var(--t1);
    padding: 10px 14px;
    border-radius: 10px;
    margin-top: 14px;
    font-size: 13px;
    font-weight: 600;
    font-family: Montserrat-SemiBold;
}

/* ============== CITY LANDING ============== */
.city-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
	    gap: 13px 10px;
}

.city-grid a {
    padding: 12px 16px;
    background: #fff;
    border: 1px solid #d9e5df;
    border-radius: 500px;
    font-size: .85rem;
    color: var(--t1);
    text-align: center;
    font-weight: 600;
    transition: all .2s;
    text-decoration: none;
    font-family: Montserrat-SemiBold;
    display: inline-flex;
    align-items: center;
    gap: 12px;
    transition: .3s ease;
}

.city-grid a:hover {
	background: var(--t1);
	color: #fff;
	border-color: var(--t1)
}

/* ============== EVIDENCE BADGES ============== */
.evidence-grid {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	justify-content: center;
}

.evidence-badge {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 8px 16px;
	background: #fff;
	border: 1px solid var(--c-line);
	border-radius: 10px;
	font-size: .85rem;
	font-weight: 600;
	color: var(--c-ink-2);
}

.evidence-badge .ico {
	width: 24px;
	height: 24px;
	background: var(--c-sage-soft);
	color: var(--c-primary);
	border-radius: 50%;
	display: grid;
	place-items: center;
	font-size: .78rem;
}

/* ============== UTILITIES ============== */
.text-center {
	text-align: center
}

.mt-2 {
	margin-top: 24px
}

.mt-3 {
	margin-top: 36px
}

.mb-2 {
	margin-bottom: 24px
}

.mb-3 {
	margin-bottom: 36px
}

/* legal note */
.legal-note {
	font-size: .78rem;
	color: var(--c-muted);
	text-align: center;
	margin-top: 18px
}





/* ========== OFFERS-PAGE PARITY: Book Session widget extensions ========== */
.book-session-head {
	text-align: center;
	margin-bottom: 24px
}

.book-session-head h3 {
	font-size: clamp(1.6rem, 3vw, 2rem);
	margin: 0 0 8px;
	color: var(--c-primary)
}

.book-session-head p {
	color: var(--c-muted);
	font-size: .95rem;
	margin: 0
}

.book-steps {
	display: flex;
	gap: 6px;
	padding: 0;
	margin: 0 0 28px;
	list-style: none;
	counter-reset: step
}

.book-step {
	flex: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 6px;
	padding: 10px 6px;
	border-radius: 12px;
	background: var(--c-cream);
	transition: all .25s ease;
	opacity: .55;
	min-width: 0
}

.book-step.active {
	background: var(--c-primary);
	color: #fff;
	opacity: 1;
	box-shadow: 0 4px 14px rgba(15, 76, 70, .18)
}

.book-step.complete {
	background: var(--c-sage-soft);
	opacity: .85
}

.book-step .num {
	display: inline-flex;
	width: 28px;
	height: 28px;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	background: rgba(255, 255, 255, .18);
	font-weight: 700;
	font-size: .85rem
}

.book-step.active .num {
	background: rgba(255, 255, 255, .25)
}

.book-step:not(.active) .num {
	background: var(--c-primary);
	color: #fff
}

.book-step .label {
	font-size: .78rem;
	font-weight: 600;
	letter-spacing: .02em
}

.plan-tile-row {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 12px;
	margin-bottom: 20px
}

.plan-tile {
	position: relative;
	padding: 16px 14px;
	border: 2px solid var(--c-line);
	border-radius: 14px;
	background: #fff;
	cursor: pointer;
	transition: all .2s ease;
	text-align: center
}

.plan-tile:hover {
	border-color: var(--c-accent);
	transform: translateY(-2px)
}

.plan-tile.selected {
	border-color: var(--c-primary);
	box-shadow: 0 6px 18px rgba(15, 76, 70, .14)
}

.plan-tile.popular {
	border-color: var(--c-accent)
}

.plan-popular {
	position: absolute;
	top: -10px;
	left: 50%;
	transform: translateX(-50%);
	background: var(--c-accent);
	color: #fff;
	padding: 2px 10px;
	border-radius: 999px;
	font-size: .7rem;
	font-weight: 700;
	letter-spacing: .05em;
	text-transform: uppercase
}

.plan-tile h4 {
	font-size: .92rem;
	margin: 0 0 8px;
	color: var(--c-primary);
	font-family: var(--fb)
}

.plan-price {
	display: flex;
	align-items: baseline;
	justify-content: center;
	gap: 6px;
	margin: 6px 0
}

.plan-price strong {
	font-size: 1.35rem;
	color: var(--c-ink);
	font-family: var(--fd)
}

.plan-price small {
	font-size: .78rem;
	color: var(--c-muted);
	text-decoration: line-through
}

.plan-discount {
	display: inline-block;
	background: var(--c-sage-soft);
	color: var(--c-primary);
	padding: 2px 8px;
	border-radius: 6px;
	font-size: .7rem;
	font-weight: 700;
	margin: 4px 0
}

.plan-meta {
	font-size: .78rem;
	color: var(--c-muted);
	margin: 6px 0 0;
	line-height: 1.4
}

.discount-apply-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: 12px;
	padding: 12px 16px;
	background: #fff8f0;
	border: 1px dashed var(--c-accent);
	border-radius: 12px;
	margin-bottom: 14px
}

.discount-apply-row p {
	margin: 0;
	font-size: .88rem;
	color: var(--c-ink-2)
}

.discount-applied {
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 14px 18px;
	background: linear-gradient(135deg, #FFF8E1, #E5EFEA);
	border-radius: 14px;
	margin-bottom: 14px;
	font-size: .92rem;
	color: var(--c-primary)
}

.discount-applied img {
	flex-shrink: 0
}

.slots-block {
	margin: 18px 0
}

.slots-block-head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 12px
}

.slots-block-head h4 {
	margin: 0;
	font-size: 1rem;
	color: var(--c-primary)
}

.slots-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
	gap: 8px;
	margin-bottom: 14px
}

.slot-pill {
	padding: 10px 12px;
	background: #fff;
	border: 1px solid var(--c-line);
	border-radius: 10px;
	font-size: .85rem;
	color: var(--c-ink);
	cursor: pointer;
	transition: all .15s ease;
	font-family: var(--fb)
}

.slot-pill:hover {
	border-color: var(--c-accent);
	color: var(--c-accent)
}

.slot-pill.selected {
	background: var(--c-primary);
	color: #fff;
	border-color: var(--c-primary)
}

.slot-pill[disabled] {
	opacity: .4;
	cursor: not-allowed
}

.slots-help {
	display: flex;
	gap: 18px;
	flex-wrap: wrap;
	font-size: .82rem;
	color: var(--c-muted)
}

.slots-help a {
	color: var(--c-accent);
	font-weight: 600
}

.book-pane-back-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 16px;
	flex-wrap: wrap;
	gap: 12px
}

.book-pane-summary {
	font-size: .88rem;
	color: var(--c-muted);
	display: flex;
	align-items: center;
	gap: 8px
}

.book-pane-summary strong {
	color: var(--c-primary)
}

.btn-link {
	background: none;
	border: none;
	color: var(--c-accent);
	font-weight: 600;
	cursor: pointer;
	padding: 0;
	font-family: var(--fb);
	font-size: .82rem
}

.book-pane-cta {
	margin-top: 16px
}

.book-form {
	background: #fff;
	padding: 18px;
	border-radius: 14px;
	border: 1px solid var(--c-line)
}

.book-form-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 14px
}

.book-form-grid>div,
.book-form-row {
	display: flex;
	flex-direction: column;
	gap: 6px
}

.book-form-grid label,
.book-form-row label {
	font-size: .82rem;
	font-weight: 600;
	color: var(--c-primary)
}

.book-form-grid input,
.book-form-grid select,
.book-form-row input,
.book-form-row select {
	padding: 10px 12px;
	border: 1px solid var(--c-line);
	border-radius: 10px;
	font-size: .92rem;
	font-family: var(--fb);
	background: #fff
}

.book-form-grid input:focus,
.book-form-grid select:focus {
	outline: none;
	border-color: var(--c-accent);
	box-shadow: 0 0 0 3px rgba(217, 87, 61, .12)
}

.err-msg {
	font-size: .74rem;
	color: var(--c-accent);
	display: none
}

.book-form input:invalid:not(:focus):not(:placeholder-shown)+.err-msg,
.book-form input.invalid+.err-msg {
	display: block
}

.book-form-row {
	margin-top: 14px
}

.book-confirm-card,
.book-payment-card {
	text-align: center;
	padding: 22px;
	background: #fff;
	border-radius: 14px;
	border: 1px solid var(--c-line)
}

.book-confirm-icon {
	font-size: 2.2rem;
	display: block;
	margin-bottom: 8px
}

.book-confirm-card h4,
.book-payment-card h4 {
	font-size: 1.4rem;
	margin: 0 0 6px;
	color: var(--c-primary);
	font-family: var(--fd)
}

.book-confirm-card p,
.book-payment-card p {
	color: var(--c-muted);
	font-size: .92rem;
	margin: 0 0 14px
}

.book-confirm-slot {
	display: inline-block;
	background: var(--c-sage-soft);
	padding: 6px 14px;
	border-radius: 999px;
	font-size: .85rem;
	color: var(--c-primary);
	font-weight: 600
}

.book-summary-table {
	width: 100%;
	max-width: 480px;
	margin: 18px auto;
	border-collapse: collapse;
	text-align: left
}

.book-summary-table th {
	padding: 8px 12px;
	font-size: .82rem;
	color: var(--c-muted);
	font-weight: 600;
	width: 40%;
	border-bottom: 1px solid var(--c-line-soft)
}

.book-summary-table td {
	padding: 8px 12px;
	font-size: .92rem;
	color: var(--c-ink);
	font-weight: 600;
	border-bottom: 1px solid var(--c-line-soft)
}

.book-summary-table tr.totalrow th,
.book-summary-table tr.totalrow td {
	font-size: 1.1rem;
	color: var(--c-primary);
	border-top: 2px solid var(--c-primary);
	border-bottom: none;
	padding-top: 12px
}

.book-payment-status {
	margin-top: 14px;
	padding: 10px;
	border-radius: 10px;
	background: var(--c-sage-soft);
	color: var(--c-primary);
	font-weight: 600;
	font-size: .88rem
}

.book-payment-status.error {
	background: #FCE8E2;
	color: #7A2C18
}

.book-trust-line {
	margin-top: 14px;
	font-size: .78rem;
	color: var(--c-muted);
	text-align: center
}

.book-stats-band {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
	gap: 14px;
	padding: 24px 20px;
	background: #fff;
	border-radius: 18px;
	margin-top: 24px;
	box-shadow: var(--shadow)
}

.book-stats-band>div {
	text-align: center
}

.book-stats-band strong {
	display: block;
	font-family: var(--fd);
	font-size: 1.5rem;
	color: var(--c-primary)
}

.book-stats-band span {
	font-size: .78rem;
	color: var(--c-muted);
	display: block;
	margin-top: 4px
}

/* ========== CONCERN MATRIX — concern doctor card (offers-page parity) ========== */
.concern-doctor-card {
	padding: 18px;
	background: #fff;
	border-radius: 18px;
	box-shadow: var(--shadow);
	text-align: center;
	border: 1px solid var(--c-line)
}

.concern-doctor-card img {
	width: 88px;
	height: 88px;
	border-radius: 50%;
	object-fit: cover;
	margin: 0 auto 12px;
	border: 3px solid var(--c-sage-soft);
	display: block
}

.concern-doctor-card h4 {
	margin: 0 0 4px;
	font-size: 1.05rem;
	font-family: var(--fb);
	color: var(--c-primary)
}

.concern-doc-meta {
	font-size: .82rem;
	color: var(--c-muted);
	margin: 0 0 10px
}

.concern-doc-price {
	display: flex;
	align-items: baseline;
	justify-content: center;
	gap: 6px;
	margin: 8px 0 4px
}

.concern-doc-price strong {
	font-size: 1.3rem;
	font-family: var(--fd);
	color: var(--c-ink)
}

.concern-doc-price small {
	font-size: .82rem;
	color: var(--c-muted);
	text-decoration: line-through
}

.badge-discount {
	background: var(--c-sage-soft);
	color: var(--c-primary);
	padding: 2px 8px;
	border-radius: 6px;
	font-size: .7rem;
	font-weight: 700
}

.concern-doctor-card .btn {
	margin-top: 8px
}

@media (max-width:720px) {
	.book-steps {
		gap: 4px
	}

	.book-step .label {
		font-size: .7rem
	}

	.plan-tile-row {
		grid-template-columns: 1fr 1fr
	}

	.book-form-grid {
		grid-template-columns: 1fr
	}
}

/* ========== Free Callback modal (matches offers-page pattern) ========== */
.callback-modal-bg {
	display: none;
	position: fixed;
	inset: 0;
	background: rgba(14, 45, 42, .55);
	z-index: 9000;
	align-items: center;
	justify-content: center;
	padding: 20px
}

.callback-modal-bg.open {
	display: flex
}

.callback-modal {
	background: #fff;
	max-width: 480px;
	width: 100%;
	padding: 28px;
	border-radius: 18px;
	position: relative;
	max-height: 90vh;
	overflow-y: auto
}

.callback-modal-close {
	position: absolute;
	top: 14px;
	right: 18px;
	background: none;
	border: none;
	font-size: 1.4rem;
	color: var(--c-muted);
	cursor: pointer
}

.callback-modal h3 {
	margin: 0 0 6px;
	font-family: var(--fd);
	color: var(--c-primary)
}

.callback-modal p {
	color: var(--c-muted);
	margin: 0 0 18px;
	font-size: .92rem
}


/* second css */



        /* ═══ STEP FLOW ═══ */
.step{display:none;animation:stepUp .3s ease;}
.step.active{display:block;}
@keyframes stepUp{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);}}

.prog-bar{display:flex;align-items:center;margin-bottom:18px;}
.prog-step{flex:1;text-align:center;position:relative;}
.prog-step::after{content:'';position:absolute;top:14px;left:50%;width:100%;height:2px;background:var(--t5);z-index:0;}
.prog-step:last-child::after{display:none;}
.prog-dot{width:28px;height:28px;border-radius:50%;border:2px solid var(--t5);background:#fff;
  display:flex;align-items:center;justify-content:center;margin:0 auto 4px;
  font-size:11px;font-weight:800;color:var(--muted);position:relative;z-index:1;transition:all .25s;}
.prog-lbl{font-size:10px;color:var(--muted);font-weight:700;}
.prog-step.done .prog-dot{background:var(--t2);border-color:var(--t2);color:#fff;}
.prog-step.done::after{background:var(--t2);}
.prog-step.curr .prog-dot{background:var(--t1);border-color:var(--t1);color:#fff;box-shadow:0 0 0 4px rgba(0,158,150,.15);}
.prog-step.curr .prog-lbl{color:var(--t1);font-weight:800;}

.ftier-radio{position:absolute;top:8px;right:8px;width:16px;height:16px;border-radius:50%;
  border:2px solid var(--t4);background:#fff;display:flex;align-items:center;justify-content:center;transition:all .18s;}
.ftier.sel .ftier-radio{background:var(--t2);border-color:var(--t2);}
.ftier.sel .ftier-radio::after{content:'';width:6px;height:6px;border-radius:50%;background:#fff;}
.ftier-badge{font-size:8px;font-weight:800;text-transform:uppercase;letter-spacing:.3px;
  padding:2px 7px;border-radius:8px;display:inline-block;margin-bottom:5px;}
.badge-pop{background:var(--o5);color:var(--o1);}
.badge-rec{background:var(--t6);color:var(--t1);}

.btn-step-back{background:none;border:1.5px solid var(--t5);border-radius:8px;
  padding:6px 13px;font-size:12px;font-weight:800;color:var(--muted);cursor:pointer;
  font-family:var(--fb);transition:all .15s;margin-bottom:12px;display:inline-flex;align-items:center;gap:4px;}
.btn-step-back:hover{background:var(--t6);color:var(--t1);}

.f-err{font-size:11px;color:#e85678;font-weight:700;margin-top:3px;display:none;}
.f-err.show{display:block;}

/* Slot Picker */
.slot-plan-summary{background:var(--t6);border:1.5px solid var(--t5);border-radius:10px;
  padding:10px 14px;margin-bottom:12px;display:flex;align-items:center;
  justify-content:space-between;flex-wrap:wrap;gap:6px;}
.sps-left strong{color:var(--t1);font-size:13px;font-weight:800;display:block;margin-bottom:1px;}
.sps-left span{font-size:11px;color:var(--muted);}
.sps-price{font-family:var(--fh);font-size:20px;color:var(--t2);font-weight:700;}

.slot-label-row{display:flex;align-items:center;gap:8px;margin-bottom:10px;}

.slot-refresh{font-size:11px;color:var(--t2);font-weight:700;cursor:pointer;
  text-decoration:underline;margin-left:auto;font-family:var(--fb);border:none;background:none;}

.slot-days{display:flex;flex-direction:column;gap:8px;max-height:260px;overflow-y:auto;padding-right:2px;}
.slot-days::-webkit-scrollbar{width:3px;}
.slot-days::-webkit-scrollbar-thumb{background:var(--t4);border-radius:2px;}

.slot-day-block{background:var(--t7);border:1.5px solid var(--t5);border-radius:10px;overflow:hidden;}
.slot-day-hdr{padding:6px 12px;background:var(--t6);border-bottom:1px solid var(--t5);
  display:flex;align-items:center;gap:6px;}
.slot-day-hdr .sdh-label{font-size:11px;font-weight:800;color:var(--t1);}
.slot-day-hdr .sdh-date{font-size:10px;color:var(--muted);margin-left:auto;}
.slot-chips{display:flex;flex-wrap:wrap;gap:5px;padding:8px 10px;}
.slot-chip{padding:5px 10px;border-radius:7px;border:1.5px solid var(--t4);background:#fff;
  font-size:11px;font-weight:800;color:var(--t1);cursor:pointer;transition:all .15s;
  white-space:nowrap;}
.slot-chip:hover{background:var(--t5);border-color:var(--t2);}
.slot-chip.sel{background:var(--t2);color:#fff;border-color:var(--t1);box-shadow:0 0 0 3px rgba(0,158,150,.15);}

.slot-confirm-bar{margin-top:10px;background:var(--t6);border:2px solid var(--t4);
  border-radius:10px;padding:10px 14px;display:none;align-items:center;
  justify-content:space-between;gap:10px;flex-wrap:wrap;}
.slot-confirm-bar.show{display:flex;animation:stepUp .2s ease;}
.scb-txt strong{color:var(--t1);display:block;font-size:13px;font-weight:800;}
.scb-txt span{font-size:11px;color:var(--muted);}

.loading-dots{display:flex;gap:5px;justify-content:center;padding:24px;}
.dot{width:8px;height:8px;border-radius:50%;background:var(--t4);animation:dotBounce .8s infinite;}
.dot:nth-child(2){animation-delay:.15s;}
.dot:nth-child(3){animation-delay:.3s;}
@keyframes dotBounce{0%,80%,100%{transform:translateY(0);}40%{transform:translateY(-8px);background:var(--t2);}}



/* ═══ STEP FLOW ═══ */
.step{display:none;}
.step.on{display:block;animation:stepUp .3s ease;}
@keyframes stepUp{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);}}

.prog-bar{display:flex;align-items:center;margin-bottom:18px;}
.prog-step{flex:1;text-align:center;position:relative;}
.prog-step::after{content:'';position:absolute;top:14px;left:50%;width:100%;height:2px;background:var(--t5);z-index:0;}
.prog-step:last-child::after{display:none;}
.prog-dot{width:25px;height:25px;border-radius:50%;border:2px solid var(--t5);background:#fff;
  display:flex;align-items:center;justify-content:center;margin:0 auto 4px;
  font-size:11px;font-weight:800;color:var(--muted);position:relative;z-index:1;transition:all .25s;}
.prog-lbl{font-size:10px;color:var(--muted);font-weight:700;}
.prog-step.done .prog-dot{background:var(--t2);border-color:var(--t2);color:#fff;}
.prog-step.done::after{background:var(--t2);}
.prog-step.curr .prog-dot{background:var(--t1);border-color:var(--t1);color:#fff;box-shadow:0 0 0 4px rgba(0,158,150,.15);}
.prog-step.curr .prog-lbl{color:var(--t1);font-weight:800;}

.fbadge{font-size:8px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;
  padding:2px 6px;border-radius:8px;display:inline-block;margin-bottom:4px;}
.b-pop{background:var(--o5);color:var(--o1);}
.b-rec{background:#c6ecea;color:var(--t1);}
.fradio{position:absolute;top:8px;right:8px;width:15px;height:15px;border-radius:50%;
  border:2px solid var(--t4);background:#fff;display:flex;align-items:center;justify-content:center;transition:all .18s;}
.ftier.sel .fradio{background:var(--t2);border-color:var(--t2);}
.ftier.sel .fradio::after{content:'';width:5px;height:5px;border-radius:50%;background:#fff;}

.slot-label-row{display:flex;align-items:center;gap:7px;margin-bottom:10px;}
.slot-label-row span{font-size:13px;font-weight:600;color:var(--t1);}
.slot-refresh{font-size:11px;color:var(--t2);font-weight:700;cursor:pointer;
  text-decoration:underline;margin-left:auto;background:none;border:none;font-family:var(--fb);}

.slot-day-block{background:var(--t7);border:1.5px solid var(--t5);border-radius:10px;overflow:hidden;margin-bottom:8px;}
.slot-day-hdr{padding:6px 12px;background:var(--t6);border-bottom:1px solid var(--t5);display:flex;align-items:center;}
.sdh-label{font-size:11px;font-weight:800;color:var(--t1);}
.sdh-date{font-size:10px;color:var(--muted);margin-left:auto;}
.slot-chips{display:flex;flex-wrap:wrap;gap:5px;padding:8px 10px;}
.slot-chip{padding:5px 10px;border-radius:7px;border:1.5px solid var(--t4);background:#fff;
  font-size:11px;font-weight:600;color:var(--t1);cursor:pointer;transition:all .15s;
  white-space:nowrap;    font-family: Montserrat-Medium;}
.slot-chip:hover{background:var(--t5);border-color:var(--t2);}
.slot-chip.sel{background:var(--t2);color:#fff;border-color:var(--t1);box-shadow:0 0 0 3px rgba(0,158,150,.15);}

.sel-slot-bar{background:var(--t6);border:2px solid var(--t4);border-radius:10px;
  padding:10px 14px;margin-bottom:12px;display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap;}
.ssb-txt strong{display:block;font-size:13px;color:var(--t1);font-weight:800;}
.ssb-txt span{font-size:11px;color:var(--muted);}
.ssb-chg{font-size:11px;color:var(--t2);font-weight:600;cursor:pointer;
  text-decoration:underline;background:none;border:none;font-family: Montserrat-Medium;}

.f-err{font-size:11px;color:#e85678;font-weight:700;margin-top:3px;display:none;}
.f-err.show{display:block;}

.btn-step-back{background:none;border:1.5px solid var(--t5);border-radius:8px;padding:6px 13px;
  font-size:12px;font-weight:800;color:var(--muted);cursor:pointer;font-family:var(--fb);
  transition:all .15s;margin-bottom:12px;display:inline-flex;align-items:center;gap:4px;}
.btn-step-back:hover{background:var(--t6);color:var(--t1);}

.confirm-box{background:var(--t6);border:2px solid var(--t4);border-radius:12px;padding:16px;text-align:center;}
.cb-icon{font-size:32px;margin-bottom:8px;display:block;}
.cb-title{font-family:var(--fh);font-size:16px;color:var(--t1);margin-bottom:4px;}
.cb-sub{font-size:12px;color:var(--muted);margin-bottom:10px;}
.cb-slot-pill{display:inline-flex;align-items:center;gap:6px;background:#fff;
  border:1.5px solid var(--t4);border-radius:20px;padding:5px 14px;
  font-size:12px;font-weight:800;color:var(--t1);margin-bottom:12px;}
.conf-summary{background:#fff;border:1.5px solid var(--t5);border-radius:9px;padding:10px 14px;margin-bottom:12px;text-align:left;}
.cb-btns{display:flex;flex-direction:column;gap:7px;}
.btn-confirm{background:var(--t2);color:#fff;padding:11px;border-radius:10px;font-size:14px;
  font-weight:600;border:none;cursor:pointer;font-family: Montserrat-Medium;;text-decoration:none;
  display:flex;align-items:center;justify-content:center;gap:5px;transition:background .18s;}
.btn-confirm:hover{background:var(--t1);}
.btn-wa-sm{background:var(--wa);color:#fff;padding:9px;border-radius:10px;font-size:13px;
  font-weight:800;border:none;cursor:pointer;font-family:var(--fb);text-decoration:none;
  display:flex;align-items:center;justify-content:center;gap:5px;}
.btn-wa-sm:hover{background:var(--wad);}

.ldots{display:flex;gap:5px;justify-content:center;padding:24px;}
.dot{width:8px;height:8px;border-radius:50%;background:var(--t4);animation:db .8s infinite;}
.dot:nth-child(2){animation-delay:.15s;}
.dot:nth-child(3){animation-delay:.3s;}
@keyframes db{0%,80%,100%{transform:translateY(0);}40%{transform:translateY(-8px);background:var(--t2);}}
 
/* ═══ EXPERT PROFILE CARD — FINAL CLEAN VERSION ═══ */
.expert-profile-card{
  background:#fff;
  border-radius:12px;
  border:2px solid var(--t5);
  margin-bottom:12px;
  overflow:hidden;
  box-shadow:0 3px 14px rgba(0,158,150,.10);
  animation:up .3s ease;
}
.epc-top-bar{
  height:3px;
  background:linear-gradient(90deg,var(--t2),var(--g2));
}
.epc-body{
  display:flex;
  align-items:center;
  gap:10px;
  padding:11px 12px;
}
.epc-img{
  width:52px;height:52px;
  border-radius:50%;object-fit:cover;
  border:2.5px solid var(--t5);
  flex-shrink:0;
}
.epc-img-init{
  width:52px;height:52px;border-radius:50%;
  flex-shrink:0;
  background:linear-gradient(135deg,var(--t2),var(--t1));
  color:#fff;font-size:20px;font-weight:800;
  display:flex;align-items:center;justify-content:center;
  border:2.5px solid var(--t5);
}
.epc-info{flex:1;min-width:0;}
.epc-name{
  font-size:13px;font-weight:800;color:var(--t1);
  margin-bottom:1px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.epc-role{
  font-size:10px;color:var(--t2);font-weight:700;
  margin-bottom:5px;
}
.epc-stats{
  display:flex;flex-wrap:wrap;gap:4px;
}
.epc-stat{
  display:inline-flex;align-items:center;gap:3px;
  font-size:9px;font-weight:700;
  padding:2px 7px;border-radius:20px;white-space:nowrap;
}
.epc-stat-exp  {background:#E6F9F8;color:var(--t1);border:1px solid var(--t5);}
.epc-stat-deg  {background:var(--p5);color:var(--p1);border:1px solid var(--p4);}
.epc-stat-lang {background:var(--g6);color:var(--g1);border:1px solid var(--g4);}
.epc-stat-rci  {background:var(--o5);color:var(--o1);border:1px solid var(--o4);}
.epc-side{
  display:flex;flex-direction:column;align-items:flex-end;
  gap:5px;flex-shrink:0;
}
.epc-avail{
  display:inline-flex;align-items:center;gap:4px;
  font-size:9px;color:var(--g1);font-weight:800;
  background:var(--g6);border:1px solid var(--g4);
  padding:3px 8px;border-radius:20px;white-space:nowrap;
}
.epc-avail::before{
  content:'';width:6px;height:6px;border-radius:50%;
  background:var(--wa);animation:pulse 1.5s infinite;flex-shrink:0;
}
.epc-verified{
  font-size:9px;color:var(--o1);font-weight:800;
  background:var(--o5);border:1px solid var(--o4);
  padding:2px 7px;border-radius:20px;white-space:nowrap;
}
.epc-footer{
  background:var(--t6);border-top:1px solid var(--t5);
  padding:6px 12px;
  display:flex;align-items:center;justify-content:space-between;gap:8px;
}
.epc-footer-txt{font-size:9px;color:var(--muted);font-weight:700;}
.epc-book-cta{
  font-size:9px;font-weight:800;color:var(--t2);
  background:#fff;border:1.5px solid var(--t4);
  border-radius:6px;padding:3px 10px;
  cursor:pointer;font-family:var(--fb);
  text-decoration:none;white-space:nowrap;
  transition:all .15s;
}
.epc-book-cta:hover{background:var(--t6);border-color:var(--t2);}

/* skeleton */
.epc-skeleton{
  height:78px;border-radius:12px;margin-bottom:12px;
  background:linear-gradient(90deg,var(--t6) 25%,var(--t5) 50%,var(--t6) 75%);
  background-size:200% 100%;
  animation:shimmer 1.2s infinite;
}
@keyframes shimmer{
  0%{background-position:200% 0;}
  100%{background-position:-200% 0;}
}

/* expertise tags below stats */
.epc-tags{display:flex;flex-wrap:wrap;gap:3px;margin-top:5px;}
.epc-tag{
  font-size:9px;background:var(--t7);color:var(--muted);
  padding:2px 6px;border-radius:5px;font-weight:700;
  border:1px solid var(--t6);
}

/* ═══ DISCOUNT BANNER — fixed single line ═══ */
.disc-banner {
 background: linear-gradient(127deg, #f26b28a1, #ee6712e6);
  border-radius: 10px;
  padding: 7px 5px;
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.disc-banner-left {
  display: flex;
  align-items: center;
  gap: 6px;
  min-width: 0;
}
.disc-banner-left strong {
  font-size: 12px;
  font-weight: 800;
  color: #fff;
  white-space: nowrap;
}
.disc-banner-left span {
  font-size: 11px;
  color: rgba(255,255,255,.85);
  white-space: nowrap;
}
.disc-pill {
    background: rgb(255 255 255);
    border-radius: 20px;
    padding: 3px 11px;
    font-size: 11px;
    font-weight: 800;
    color: var(--color-1);
    white-space: nowrap;
    flex-shrink: 0;
    letter-spacing: 0.5px;
}

/* ═══ TIER CARDS — clean professional layout ═══ */
.form-tiers {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-bottom: 14px;
}
.ftier {
  border: 2px solid var(--border);
  border-radius: 12px;
 padding: 8px 8px 8px;
  cursor: pointer;
  transition: all .18s;
  text-align: center;
  position: relative;
  background: #fff;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
}
.ftier.sel {
  border-color: var(--t2);
  background: var(--t6);
  box-shadow: 0 0 0 3px rgba(0,158,150,.12);
}
.ftier:hover:not(.sel) {
  border-color: var(--t4);
  background: var(--t7);
}

/* badge row — top of card */
.ftier-badge-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  margin-bottom: 6px;
}
.fbadge {
  font-size: 8px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .4px;
  padding: 2px 8px;
  border-radius: 8px;
  display: inline-block;
}
.b-rec {    background: #c9eeec; color: var(--t1); }
.b-pop { background: var(--o5);  color: var(--o1); }

/* original price — small strikethrough */

.ftier .fp-orig {
    font-size: 14px;
    color: var(--muted);
    display: block;
    line-height: 1.3;
    margin-bottom: 0px;
    font-size: 20px;
    font-weight: 600;
    color: var(--t1);
}

/* discount badge inline */
.ftier .fp-disc {
    display: inline-block;
    font-size: 9px;
    font-weight: 800;
    color: #fff;
    background: var(--o2);
    padding: 1px 7px;
    border-radius: 20px;
    margin-bottom: 4px;
    font-family: Montserrat-Medium;
}

/* discounted price — big and bold */
.ftier .fp {
  font-family: var(--fh);
  font-size: 18px;
  color: var(--t1);
  font-weight: 700;
  display: block;
  line-height: 1.2;
  margin-bottom: 3px;
}
.ftier.sel .fp { color: var(--t1); }

/* duration */
.ftier .fd {
  font-size: 10px;
  color: var(--muted);
  font-weight: 700;
  display: block;
  margin-bottom: 2px;
}

/* mode */
.ftier .fm {
  font-size: 9px;
  color: var(--t2);
  font-weight: 700;
  display: block;
}

/* radio dot */
.fradio {
  position: absolute;
  top: 9px;
  right: 9px;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  border: 2px solid var(--t4);
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all .18s;
}
.ftier.sel .fradio {
  background: var(--t2);
  border-color: var(--t2);
}
.ftier.sel .fradio::after {
  content: '';
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: #fff;
}

/* Apply Discount Button Styles */
.disc-apply-btn {
    background: linear-gradient(135deg, #12d694 0%, #059669d4 100%);
    color: #ffffff;
    border: none;
    padding: 8px 8px;
    border-radius: 8px;
    font-weight: 600;
    font-size: 12px;
    cursor: pointer;
    transition: all 0.3s ease;
    box-shadow: 0 2px 8px rgba(16, 185, 129, 0.3);
    border: 1px dashed #ffffff;
    font-family: Montserrat-SemiBold;
    background: #22c55e;
}

.disc-apply-btn:hover {
  background: linear-gradient(135deg, #059669 0%, #047857 100%);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(16, 185, 129, 0.4);
}

.disc-apply-btn:active {
  transform: translateY(0);
}

.disc-apply-btn.applied {
  background: #6b7280;
  cursor: not-allowed;
  opacity: 0.7;
}

/* Congratulations Message Styles */

.congrts_bxe {
    position: relative;
}
.congrats-msg {
    background: linear-gradient(135deg, #ffffff 0%, #ffffff 100%);
    border: 2px dashed #10b981;
    border-radius: 30px;
    padding: 16px 20px;
    margin: 16px 0;
    display: block;
    align-items: center;
    gap: 12px;
    animation: slideDown 0.5s ease-out, pulse 0.6s ease-in-out;
    box-shadow: 0 4px 16px rgb(16 185 129 / 28%);
    position: absolute;
    width: 250px;
    margin: auto;
    left: 0;
    right: 0;
    top: -20px;
    text-align: center;
}

.congrats-icon_clbrtn img {
    width: 320px;
    height: 300px;
    position: absolute;
    top: -80px;
    left: 15px;
    right: 0;
    bottom: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}
.congrats-icon {
  font-size: 32px;
  animation: rotate 0.6s ease-in-out;
}

.congrats-text {
  flex: 1;
}

.congrats-text strong {
  color: #047857;
  font-size: 16px;
  display: block;
  margin-bottom: 4px;
}

.congrats-text p {
  color: #065f46;
  font-size: 13px;
  margin: 0;
  line-height: 1.4;
}

.congrats-checkmark {
  background: #10b981;
  color: white;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  font-weight: bold;
  animation: scaleIn 0.4s ease-out 0.3s both;
}

/* Price Display Animation */
#t1-disc, #t2-disc {
  animation: priceReveal 0.6s ease-out;
}

@keyframes priceReveal {
  from {
    opacity: 0;
    transform: scale(0.8);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

/* Animations */
@keyframes slideDown {
  from {
    opacity: 0;
    transform: translateY(-20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes pulse {
  0%, 100% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.02);
  }
}

@keyframes rotate {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

@keyframes scaleIn {
  from {
    transform: scale(0);
  }
  to {
    transform: scale(1);
  }
}

/* Responsive adjustments */
@media (max-width: 480px) {
  .congrats-msg {
    padding: 12px 16px;
  }
  
  .congrats-icon {
    font-size: 28px;
  }
  
  .congrats-text strong {
    font-size: 14px;
  }
  
  .congrats-text p {
    font-size: 12px;
  }
}



        /* ═══════════════════════════════════════════════════════════════════════
   HOPEQURE INLINE BOOKING SYSTEM - COMPLETE STYLES
   ═══════════════════════════════════════════════════════════════════════ */

:root {

  --mint: #00D4AA;
  --teal-bg: #E6F9F8;
  --teal-border: #C2EFED;
  --ink: #0A1E1C;
  --muted: #5A7875;
  --orange: #F26B28;
  --fb: 'Figtree', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

/* ═══════════════════════════════════════════════════════════════════════
   THERAPIST CARDS
   ═══════════════════════════════════════════════════════════════════════ */

.therapist-card-modern {
  background: #fff;
  border: 1.5px solid var(--teal-border);
  border-radius: 16px;
  overflow: hidden;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  margin-bottom: 24px;
  position: relative;
}

.therapist-card-modern:hover {
  border-color: var(--t1);
  transform: translateY(-4px);
  box-shadow: 0 12px 24px rgba(0, 158, 150, 0.15);
}

/* Header */
.tcm-header {
  background: linear-gradient(135deg, #F2FDFC 0%, #FFFFFF 100%);
  padding: 15px;
  border-bottom: 1px solid var(--teal-border);
}

.tcm-avatar-section {
  display: flex;
  gap: 10px;
  margin-bottom: 0px;
      align-items: center;
}

.tcm-avatar-wrapper {
  position: relative;
  flex-shrink: 0;
}

.tcm-avatar {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  object-fit: cover;
  border: 3px solid var(--teal-border);
}

.tcm-verified-badge {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 24px;
  height: 24px;
  background: var(--mint);
  color: white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  font-weight: 800;
  border: 2px solid white;
}

.tcm-info {
  flex: 1;
}

.tcm-name-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 4px;
}

.tcm-name {
  font-size: 18px;
  font-weight: 800;
  margin: 0;
}

.tcm-rci {
  background: #FFF4E6;
  color: #C4520A;
  font-size: 10px;
  font-weight: 800;
  padding: 2px 6px;
  border-radius: 4px;

}

.tcm-role {
  font-size: 14px;
  color: var(--t1);
  font-weight: 600;
  margin: 0 0 8px 0;

}

.tcm-meta {
  display: flex;
  gap: 5px;
  flex-wrap: wrap;
}

.tcm-meta-item {
  font-size: 11px;
  color: var(--muted);
  font-weight: 600;

}

/* Availability Badge */
.tcm-availability {
  display: flex;
  justify-content: flex-start;
}

.tcm-avail-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 4px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 700;

  transition: all 0.3s ease;
}

.tcm-avail-badge.checking {
  background: #F3F4F6;
  color: #6B7280;
}

.tcm-avail-badge.available {
  background: linear-gradient(135deg, #00D4AA 0%, #00B894 100%);
  color: white;
  animation: pulse-glow 2s ease-in-out infinite;
}

.tcm-avail-badge.soon {
  background: linear-gradient(135deg, #74b9ff 0%, #0984e3 100%);
  color: white;
}

@keyframes pulse-glow {
  0%, 100% {
    transform: scale(1);
    opacity: 1;
  }
  50% {
    transform: scale(1.02);
    opacity: 0.92;
  }
}

.avail-spinner {
  width: 12px;
  height: 12px;
  border: 2px solid #E5E7EB;
  border-top-color: var(--t1);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

/* Body */
.tcm-body {
  padding: 10px 20px 15px;
}

.tcm-languages {
    display: flex;
    gap: 5px;
    margin-bottom: 0 !important;
}

.tcm-expertise,
.tcm-languages {
  margin-bottom: 16px;
}

.tcm-label {
  font-size: 12px;
  font-weight: 700;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  display: block;
  margin-bottom: 8px;

}

.tcm-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}

.tcm-tag {
  background: var(--teal-bg);
  color: var(--t1);
  font-size: 11px;
  font-weight: 500;
  padding: 4px 4px;
  border-radius: 6px;
  font-family: Montserrat-Medium;

}

.tcm-value {
  font-size: 13px;
color: var(--color-4);
    font-family: Montserrat-Medium;

}
.tcm-mode{
 font-family: Montserrat-Medium;
 font-weight: 600;
}

.tcm-modes {
  display: flex;
  gap: 12px;
  margin-top: 6px;
}

.tcm-mode {
  font-size: 12px;
  color: var(--muted);

}

.tcm-avail-badge span {
    font-family: Montserrat-SemiBold;
    font-size: 8px;
}

/* Footer */
.tcm-footer {
      padding: 10px 16px;
  border-top: 1px solid var(--teal-border);
  display: flex;
  gap: 30px;
  background: #FAFAFA;
}

.tcm-btn-secondary,
.tcm-btn-primary {
  flex: 1;
  padding: 8px 10px;
  border-radius: 10px;
  font-size: 13px;
  font-weight: 600;
  border: none;
  cursor: pointer;
  transition: all 0.2s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  text-decoration: none;
}

.tcm-btn-secondary {
  background: white;
  color: var(--t1);
  border: 1.5px solid var(--teal-border);
}

.tcm-btn-secondary:hover {
  background: var(--teal-bg);
  border-color: var(--t1);
}

.tcm-btn-primary {
  background: linear-gradient(135deg, var(--t1) 0%, var(--t2) 100%);
  color: white;
  box-shadow: 0 4px 12px rgba(0, 158, 150, 0.2);
}

.tcm-btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(0, 158, 150, 0.3);
}

.tcm-btn-primary.active {
  background: linear-gradient(135deg, var(--t2) 0%, var(--t1) 100%);
}

/* ═══════════════════════════════════════════════════════════════════════
   INLINE BOOKING PANEL
   ═══════════════════════════════════════════════════════════════════════ */

.inline-booking-panel {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  background: white;
}

.inline-booking-panel.active {
  max-height: 4000px;
  border-top: 1px solid var(--teal-border);
  animation: slideDown 0.4s ease-out;
}

@keyframes slideDown {
  from {
    opacity: 0;
    transform: translateY(-20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.inline-booking-content {
      padding: 15px 10px;
}

/* Header */
.inline-booking-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 15px;
}

.inline-booking-title {
  display: flex;
  align-items: center;
  gap: 2px;
}

.inline-booking-title h4 {
    font-size: 15px;
    font-weight: 800;
    color: var(--color-3);
    margin: 0;
}

.inline-close-btn {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: #F3F4F6;
  border: none;
  color: var(--muted);
  font-size: 24px;
  cursor: pointer;
  transition: all 0.2s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  line-height: 1;
  display:none;
}

.inline-close-btn:hover {
  background: var(--orange);
  color: white;
  transform: rotate(90deg);
}

/* Progress Bar */
.inline-prog-bar {
  display: flex;
  justify-content: space-between;
 gap: 10px;
  position: relative;
}

.inline-prog-bar::before {
  content: '';
  position: absolute;
  top: 14px;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--teal-border) 0%, var(--teal-border) 100%);
  z-index: 0;
}

.inline-prog-step {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  position: relative;
  z-index: 1;
}

.inline-prog-dot {
    width: 28px;
    height: 28px;
    border-radius: 100%;
    background: white;
    border: 2px solid var(--teal-border);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 800;
    color: var(--muted);
    transition: all 0.3s ease;
}

.inline-prog-lbl {
  font-size: 11px;
  color: var(--muted);
  font-weight: 600;
 font-family: Montserrat-SemiBold;
  text-align: center;
}

.inline-prog-step.curr .inline-prog-dot {
  background: linear-gradient(135deg, var(--t1) 0%, var(--t2) 100%);
  border-color: var(--t1);
  color: white;
  transform: scale(1.1);
  box-shadow: 0 4px 12px rgba(0, 158, 150, 0.3);
}

.inline-prog-step.curr .inline-prog-lbl {
  color: var(--t1);
  font-weight: 800;
}

.inline-prog-step.done .inline-prog-dot {
  background: var(--mint);
  border-color: var(--mint);
  color: white;
}

.inline-prog-step.done .inline-prog-dot::after {
  content: '✓';
  font-size: 16px;
}

.inline-prog-step.done .inline-prog-lbl {
  color: var(--mint);
}

/* Steps */
.inline-step {
  display: none;
  animation: fadeInStep 0.3s ease-out;
}

.inline-step.on {
  display: block;
}

@keyframes fadeInStep {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Slots */
.inline-slots-container {
  max-height: 400px;
  overflow-y: auto;
  margin-bottom: 10px;
  padding-right: 8px;
}

.inline-slots-container::-webkit-scrollbar {
  width: 6px;
}

.inline-slots-container::-webkit-scrollbar-track {
  background: var(--teal-bg);
  border-radius: 3px;
}

.inline-slots-container::-webkit-scrollbar-thumb {
  background: var(--t1);
  border-radius: 3px;
}

.inline-slot-day {
  margin-bottom: 10px;
}

.inline-slot-day-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
  padding-bottom: 8px;
  border-bottom: 2px solid var(--teal-border);
}

.inline-slot-day-label {
  font-size: 14px;
  font-weight: 800;
  color: var(--color-3);
 
}

.inline-slot-day-date {
  font-size: 13px;
  color: var(--muted);
  font-family: var(--fb);
}

.inline-slot-chips {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(90px, 1fr));
    gap: 7px;
}

.inline-slot-chip {
    padding: 10px 3px;
    background: white;
    border: 1.5px solid var(--teal-border);
    border-radius: 8px;
    font-size: 11px;
    font-weight: 600;
    color: var(--color-4);
    cursor: pointer;
    transition: all 0.2s ease;
    text-align: center;
    font-family: Montserrat-Medium;
}

.inline-slot-chip:hover {
  border-color: var(--t1);
  background: var(--teal-bg);
  transform: translateY(-2px);
  box-shadow: 0 4px 8px rgba(0, 158, 150, 0.15);
}

.inline-slot-chip.sel {
  background: linear-gradient(135deg, var(--t1) 0%, var(--t2) 100%);
  border-color: var(--t1);
  color: white;
  transform: scale(1.05);
  box-shadow: 0 6px 16px rgba(0, 158, 150, 0.3);
  background: var(--t1);
}

/* Forms */
.inline-selected-pill {
  background: var(--teal-bg);
  border: 1px solid var(--teal-border);
  border-radius: 12px;
  padding: 12px 16px;
  font-size: 13px;
  color: var(--t1);
  font-weight: 600;
  margin-bottom: 12px;
  text-align: center;
 font-family: Montserrat-Medium;
}

.inline-form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  
}

.inline-form-group {
  margin-bottom: 10px;
}

.inline-form-label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: var(--color-4);
  margin-bottom: 5px;
 font-family: Montserrat-Medium;
}

.inline-form-input,
.inline-form-select {
  width: 100%;
  padding: 10px 10px;
  border: 1.5px solid var(--teal-border);
  border-radius: 8px;
  font-size: 12px;
  color: var(--ink);
  font-family: Montserrat-Medium;
  transition: all 0.2s ease;
  background: white;
    font-weight: 500;
}

.inline-form-input:focus,
.inline-form-select:focus {
  outline: none;
  border-color: var(--t1);
  box-shadow: 0 0 0 3px rgba(0, 158, 150, 0.1);
}

.inline-form-error {
  display: none;
  font-size: 12px;
  color: var(--orange);
  margin-top: 6px;
  font-family: var(--fb);
}

.inline-form-group.error .inline-form-input,
.inline-form-group.error .inline-form-select {
  border-color: var(--orange);
}

.inline-form-group.error .inline-form-error {
  display: block;
}

.inline-info-box {
  background: #EFF6FF;
  border: 1px solid #BFDBFE;
  border-radius: 10px;
  padding: 12px 16px;
  font-size: 13px;
  color: #1E40AF;
  margin: 16px 0;
   font-family: Montserrat-Medium;
}

/* Summary Box */
.inline-summary-box {
    background: var(--teal-bg);
    border: 1px solid var(--teal-border);
    border-radius: 12px;
    padding: 5px 10px 10px;
    margin-bottom: 15px;
}

.inline-summary-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: 6px 0;
}

.inline-summary-label {
  font-size: 13px;
  color: var(--muted);
  font-weight: 600;
  font-family: Montserrat-Medium;
}

.inline-summary-value {
  font-size: 12px;
  color: var(--color-4);
  font-weight: 600;
  text-align: right;
  font-family: Montserrat-Medium;
}

.inline-summary-divider {
  height: 1px;
  background: var(--teal-border);
  margin: 8px 0;
}

.inline-summary-total {
    background: white;
    border-radius: 8px;
    padding: 5px 10px;
    margin-top: 12px;
}

/* Buttons */
.inline-btn-group {
  display: flex;
  gap: 12px;
  margin-top: 10px;
}

.inline-btn-secondary,
.inline-btn-primary {
  flex: 1;
  padding: 14px 20px;
  border-radius: 10px;
  font-size: 13px;
  font-weight: 600;
  font-family: Montserrat-Medium;
  border: none;
  cursor: pointer;
  transition: all 0.2s ease;
  text-align: center;
}

.inline-btn-secondary {
  background: white;
  color: var(--t1);
  border: 1.5px solid var(--teal-border);
}

.inline-btn-secondary:hover {
  background: var(--teal-bg);
  border-color: var(--t1);
}

.inline-btn-primary {
  background: linear-gradient(135deg, var(--t1) 0%, var(--t2) 100%);
  color: white;
  box-shadow: 0 4px 12px rgba(0, 158, 150, 0.2);
}

.inline-btn-primary:hover:not(:disabled) {
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(0, 158, 150, 0.3);
}

.inline-btn-primary:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.inline-btn-back {
  background: transparent;
  border: none;
  color: var(--t1);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  margin-bottom: 10px;

    font-family: Montserrat-Medium;
}

.inline-btn-back:hover {
  color: var(--t2);
}

.inline-btn-group button {
    padding: 10px;
    font-family: Montserrat-SemiBold;
}

/* Loading */
.inline-loading {
  text-align: center;
  padding: 40px 20px;
}

.inline-spinner {
  width: 40px;
  height: 40px;
  border: 4px solid var(--teal-border);
  border-top-color: var(--t1);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
  margin: 0 auto;
}
.tcm-avail-badge {
  position: absolute;
    right: 7px;
    top: 6px;
}
/* Success */
.inline-success {
  text-align: center;
}

.inline-success-icon {
  font-size: 72px;
  margin-bottom: 16px;
  animation: successBounce 0.6s ease-out;
}

@keyframes successBounce {
  0% { transform: scale(0); }
  50% { transform: scale(1.1); }
  100% { transform: scale(1); }
}

.inline-success-title {
  font-size: 24px;
  font-weight: 600;
  color: var(--ink);
  margin: 0 0 8px 0;
      font-family: Montserrat-Medium;
}

.inline-success-subtitle {
  font-size: 14px;
  color: var(--muted);
  margin: 0 0 24px 0;
    font-family: Montserrat-Medium;
}

.inline-success-details {
  margin-bottom: 24px;
}

/* ═══════════════════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════════════════ */

@media (max-width: 768px) {


  .inline-form-row {
    grid-template-columns: 1fr;
  }



  .inline-slot-chips {
    grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
  }

  .inline-prog-lbl {
    font-size: 10px;
  }

  .inline-prog-dot {
    width: 22px;
    height: 22px;
    font-size: 12px;
  }
  .inline-prog-bar::before{
      top: 10px;
  }
  .inline-prog-bar {
  
    gap: 6px;
   
}
.inline-slot-chip{
    padding: 6px 3px;
}
.inline-selected-pill {
   
    padding: 8px 6px;
    font-size: 12px;
  
}
.inline-form-row {
   
    gap: 5px;
}
.inline-summary-row {
   
    padding: 4px 0;
}
}





.cf-booking-panel {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  background: linear-gradient(135deg, #f8f9fa 0%, #ffffff 100%);
  border-radius: 16px;
  margin-top: 20px;
}

.cf-booking-panel.active {
  max-height: 1200px;
  border: 2px solid #E0F2F1;
  padding: 24px;
}

.cf-booking-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 5px;
  padding-bottom: 16px;
  border-bottom: 2px solid #E0F2F1;
}

.cf-booking-title {
  display: flex;
  align-items: center;
  gap: 12px;
}

.cf-booking-title h4 {
  font-size: 20px;
  font-weight: 800;
  color: var(--t1);
  margin: 0;
}

.cf-close-btn {
  background: #f5f5f5;
  border: none;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  font-size: 24px;
  cursor: pointer;
  transition: all 0.2s;
  color: #666;
}

.cf-close-btn:hover {
  background: #e0e0e0;
  transform: rotate(90deg);
}

.cf-prog-bar {
  display: flex;
  justify-content: space-between;
  margin-bottom: 30px;
  position: relative;
}

.cf-prog-bar::before {
  content: '';
  position: absolute;
  top: 20px;
  left: 0;
  right: 0;
  height: 2px;
  background: #e0e0e0;
  z-index: 0;
}

.cf-prog-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  flex: 1;
  position: relative;
  z-index: 1;
}

.cf-prog-dot {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: #f5f5f5;
  border: 2px solid #e0e0e0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  color: #999;
  transition: all 0.3s;
}

.cf-prog-step.curr .cf-prog-dot {
  background: var(--t1);
  border-color: var(--t1);
  color: white;
  box-shadow: 0 4px 12px rgba(0, 158, 150, 0.3);
}

.cf-prog-step.done .cf-prog-dot {
  background: #4CAF50;
  border-color: #4CAF50;
  color: white;
}

.cf-prog-step.done .cf-prog-dot::after {
  content: '✓';
  font-size: 18px;
}

.cf-prog-lbl {
  font-size: 12px;
  font-weight: 600;
  color: #999;
  text-align: center;
}

.cf-prog-step.curr .cf-prog-lbl {
  color: var(--t1);
}

.cf-step {
  display: none;
}

.cf-step.on {
  display: block;
  animation: cfFadeIn 0.3s ease-out;
}

@keyframes cfFadeIn {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}

.cf-slot-container {
    margin-bottom: 24px;
    /* min-height: 200px; */
}



.cf-slot-day-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
  padding-bottom: 8px;
  border-bottom: 2px solid #E0F2F1;
}

.cf-slot-day-label {
  font-weight: 700;
  color: var(--t1);
  font-size: 14px;
}

.cf-slot-day-date {
  font-size: 13px;
  color: var(--muted);
  font-weight: 600;
}

.cf-slot-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.cf-slot-chip {
    padding: 8px 10px;
    background: white;
    border: 2px solid #E0F2F1;
    border-radius: 8px;
    font-size: 12px;
    font-weight: 600;
    color: var(--t1);
    cursor: pointer;
    transition: all 0.2s;
    font-family: Montserrat-Medium;
}

.cf-slot-chip:hover {
  background: #E0F2F1;
  border-color: var(--t1);
  transform: translateY(-2px);
}

.cf-slot-chip.sel {
  background: var(--t1);
  color: white;
  border-color: var(--t1);
  box-shadow: 0 4px 12px rgba(0, 158, 150, 0.3);
}

.cf-selected-pill {
  background: linear-gradient(135deg, #E0F2F1 0%, #B2DFDB 100%);
  padding: 12px 16px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 700;
  color: var(--t1);
  margin-bottom: 20px;
  text-align: center;
}

.cf-form-group {
  margin-bottom: 16px;
}

.cf-form-label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: #333;
  margin-bottom: 6px;
}

.cf-form-input,
.cf-form-select {
  width: 100%;
  padding: 12px;
  border: 2px solid #e0e0e0;
  border-radius: 8px;
  font-size: 14px;
  transition: all 0.2s;
  font-family: Montserrat-Medium;
}

.cf-form-input:focus,
.cf-form-select:focus {
  outline: none;
  border-color: var(--t1);
  box-shadow: 0 0 0 3px rgba(0, 158, 150, 0.1);
}

.cf-form-group.error .cf-form-input,
.cf-form-group.error .cf-form-select {
  border-color: #f44336;
}

.cf-form-error {
  display: none;
  color: #f44336;
  font-size: 12px;
  margin-top: 4px;
}

.cf-form-group.error .cf-form-error {
  display: block;
}

.cf-form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

.cf-btn-group {
  display: flex;
  gap: 12px;
  margin-top: 24px;
}

.cf-btn-primary,
.cf-btn-secondary {
  flex: 1;
  padding: 14px;
  border-radius: 8px;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.2s;
  border: none;
}

.cf-btn-primary {
  background: var(--t1);
  color: white;
}

.cf-btn-primary:hover:not(:disabled) {
  background: #007d76;
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0, 158, 150, 0.3);
}

.cf-btn-primary:disabled {
  background: #ccc;
  cursor: not-allowed;
}

.cf-btn-secondary {
  background: white;
  color: var(--t1);
  border: 2px solid var(--t1);
}

.cf-btn-secondary:hover {
  background: #E0F2F1;
}

.cf-btn-back {
  background: none;
  border: none;
  color: var(--muted);
  font-size: 13px;
  cursor: pointer;

  padding: 8px 0;
  font-weight: 600;
}

.cf-btn-back:hover {
  color: var(--t1);
}

.cf-summary-box {
    background: white;
    border: 2px solid #E0F2F1;
    border-radius: 12px;
    padding: 10px 20px;
    margin-bottom: 10px;
    width: 100%;
}

.cf-summary-row {
  display: flex;
  justify-content: space-between;
  padding: 7px 0;
  border-bottom: 1px solid #f5f5f5;
}

.cf-summary-row:last-child {
  border-bottom: none;
}

.cf-summary-label {
  font-size: 13px;
  color: var(--muted);
  font-weight: 600;
}

.cf-summary-value {
  font-size: 13px;
  font-weight: 700;
  color: #333;
}

.cf-summary-total {
  margin-top: 5px;
  padding-top: 5px;
  border-top: 2px solid #E0F2F1;
}

.cf-summary-total .cf-summary-value {
  font-size: 18px;
  color: var(--t1);
}

.cf-loading {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 40px;
}

.cf-spinner {
  width: 40px;
  height: 40px;
  border: 4px solid #f3f3f3;
  border-top: 4px solid var(--t1);
  border-radius: 50%;
  animation: cfSpin 1s linear infinite;
}

@keyframes cfSpin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

.cf-success {
  text-align: center;
  padding: 40px 20px;
}

.cf-success-icon {
  font-size: 64px;
  margin-bottom: 16px;
}

.cf-success-title {
  font-size: 24px;
  font-weight: 800;
  color: var(--t1);
  margin-bottom: 20px;
}

.hero-stat {
    background: #fff;
   padding: 15px 10px;
    text-align: center;
    border-bottom: 2px solid var(--t1);
    border-radius: 10px;
}

.tcm-price-badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    background: linear-gradient(135deg, #00b09b 0%, #00897b 100%);
    color: #fff;
    font-size: 13px;
    font-weight: 700;
    padding: 5px 11px;
    border-radius: 20px;
    margin-top: 6px;
    box-shadow: 0 2px 8px rgba(0, 176, 155, 0.28);
    transition: opacity 0.2s;
}

.cond-card h4 {
    font-family: Montserrat-Medium;
    font-size: 15px;
}

.para_scn {
    color: var(--color-4) !important;
}

.para_scn a{

    text-decoration: none;
    font-size: 14px;
}

/* ================= BASE ================= */
.psych-section {
  background: #fff;
  padding: 60px 20px;
}

.container {
width: 100%;
    padding-right: .75rem;
    padding-left: .75rem;
    margin: 0 auto;
}

/* ================= GRID ================= */
.top-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}

/* ================= CARD ================= */
.card {
  background: #ffffff;
  border-radius: 18px;
  padding: 26px;
  border: 1px solid #e6f0ef;
  box-shadow: 0 10px 30px rgba(0,0,0,0.05);
  transition: all 0.3s ease;
}

.card:hover {
  transform: translateY(-5px);
  box-shadow: 0 18px 45px rgba(0,0,0,0.08);
}

/* ================= TLDR ================= */
.tldr-card h3 {
  font-size: 1.3rem;
  margin-bottom: 16px;
  color: var(--t1);
}

.tldr-card ul {
  margin: 0;
  padding: 0;
}

.tldr-card li {
  list-style: none;
  position: relative;
  padding-left: 32px;
  margin-bottom: 12px;
  font-size: 14px;
  line-height: 1.6;
  color: var(--color-4);
}

.tldr-card li::before {
  content: "✔";
  position: absolute;
  left: 0;
  top: 2px;
  width: 22px;
  height: 22px;
  font-size: 12px;
  background: rgba(0,150,136,0.1);
  color: var(--c-accent);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* ================= ANSWER ================= */
.answer-card {
  background: linear-gradient(135deg, var(--c-cream), #ffffff);
  border-left: 5px solid var(--c-accent);
  position: relative;
  overflow: hidden;
}

.answer-card::after {
  content: "";
  position: absolute;
  right: -60px;
  top: -60px;
  width: 180px;
  height: 180px;
  background: radial-gradient(circle, rgba(0,150,136,0.12), transparent);
}

.answer-card h3 {
  font-size: 1.2rem;
  margin-bottom: 10px;
  color: var(--t1);
}

.answer-card p {
  font-size: 14px;
  color: var(--muted);
  line-height: 1.6;
  margin-bottom: 18px;
}

/* ================= CTA ================= */
.cta-wrap {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.btn-primary {
  display: inline-block;
  background: var(--c-accent);
  color: #fff;
  padding: 11px 18px;
  border-radius: 10px;
  text-decoration: none;
  font-size: 0.9rem;
  font-weight: 500;
  transition: 0.3s;
  width: fit-content;
}

.btn-primary:hover {
  background: #00796b;
  transform: translateY(-2px);
}

.cta-note {
  font-size: 0.8rem;
  color: var(--muted);
}

/* ================= EMERGENCY ================= */
.emergency-card {
  margin-top: 28px;
  background: #fff5f5;
  border: 1px solid #ffd6d6;
  border-left: 5px solid #e53935;
  padding: 22px 24px;
  border-radius: 16px;
}

.emergency-card strong {
  display: block;
  font-size: 1.05rem;
  margin-bottom: 6px;
  color: #b71c1c;
}

.emergency-card p {
  font-size: 0.92rem;
  color: #5c1c1c;
  margin-bottom: 14px;
}

/* helpline buttons */
.helpline-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.helpline-grid a {
  text-decoration: none;
  background: #ffecec;
  color: #c62828;
  padding: 8px 12px;
  border-radius: 8px;
  font-size: 0.85rem;
  transition: 0.25s;
}

.helpline-grid a:hover {
  background: #e53935;
  color: #fff;
}

/* support note */
.support-note {
  margin-top: 10px;
  font-size: 0.8rem;
  color: #7a2e2e;
}

/* ================= TOC ================= */
.toc-card {
  margin-top: 30px;
  background: #ffffff;
  padding: 24px 26px;
  border-radius: 16px;
  border: 1px solid #e6f0ef;
  box-shadow: 0 8px 25px rgba(0,0,0,0.05);
}

.toc-card h4 {
  margin-bottom: 14px;
  font-size: 1.1rem;
  color: var(--t1);
}

.toc-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}

.toc-grid a {
    display: block;
    text-decoration: none;
    font-size: 13px;
    color: var(--muted);
    background: #f1f7f6;
    padding: 10px 10px;
    border-radius: 10px;
    transition: all 0.25s ease;
    font-weight: 600;
    border-left: 2px solid var(--muted);
}

.toc-grid a:hover {
  background: var(--t2);
  color: #ffffff;
  transform: translateY(-2px);
}

.trmnt_prgrm .cond-card ol li {
    list-style: auto;
    color: var(--color-4);
    font-size: 14px;
    margin-bottom: 10px;
}

.trmnt_prgrm .cond-grid {
	grid-template-columns: repeat(auto-fit, minmax(440px, 1fr));
}

/* ================= RESPONSIVE ================= */
@media (max-width: 768px) {
  .top-grid {
    grid-template-columns: 1fr;
  }

  .toc-grid {
    grid-template-columns: 1fr 1fr;
  }

  .card,
  .toc-card,
  .emergency-card {
    padding: 20px;
  }
}


.why_onlne_pysc .hero-features {
    display: block;
    margin-bottom: 10px;
}

.why_onlne_pysc .hero-features li {
    align-items: flex-start;
}

.why_onlne_pysc .hero-features li svg {
    margin-top: 6px;
}

.why_onlne_pysc .hero-features li p {
    font-size: 15px;
    line-height: 22px;
    margin-bottom: 12px;
}

.jornl_pysc {
    font-family: Montserrat-Medium;
    color: var(--color-4);
    font-size: 14px !important;
    line-height: 21px;
}

.jornl_pysc strong{
	color: var(--o2);
}


/* ===== ROOT ===== */
.hqhw-section{
  background: #f5f7f6;
  padding: 70px 0;
  position: relative;
  overflow: hidden;
}

.hqhw-section{
  position: relative;
  overflow: hidden;
  background: linear-gradient(135deg, #f3f8f7, #ffffff);
}

/* animated gradient layers */
.hqhw-section::before,
.hqhw-section::after{
  content:"";
  position:absolute;
  width:600px;
  height:600px;
  border-radius:50%;
  filter: blur(100px);
  opacity:0.6;
  animation: floatMove 12s ease-in-out infinite alternate;
}

/* teal blob */
.hqhw-section::before{
 background: rgb(1 171 155 / 30%);
  top:-100px;
  left:-100px;
}

/* orange blob */
.hqhw-section::after{
  background: rgba(242,106,75,0.35);
  bottom:-120px;
  right:-120px;
  animation-delay: 3s;
}

/* extra floating layer (optional but sexy) */
.hqhw-section .hqhw-bg{
  position:absolute;
  width:500px;
  height:500px;
  background: rgba(15,76,70,0.2);
  filter: blur(120px);
  top:40%;
  left:60%;
  transform: translate(-50%, -50%);
  animation: floatMove2 14s ease-in-out infinite alternate;
}

/* animation */
@keyframes floatMove{
  0%{
    transform: translate(0,0) scale(1);
  }
  100%{
    transform: translate(80px, 60px) scale(1.2);
  }
}

@keyframes floatMove2{
  0%{
    transform: translate(-50%, -50%) scale(1);
  }
  100%{
    transform: translate(-60%, -40%) scale(1.3);
  }
}




/* ===== HEADER ===== */
.hqhw-head {
    text-align: center;
    max-width: 750px;
    margin: 0 auto 80px;
    margin-bottom: 60px;
}
.hqhw-eyebrow {
    display: inline-block;
    background: #fde7e1;
    color: var(--o2);
    padding: 6px 16px;
    border-radius: 30px;
    font-size: 12px;
    letter-spacing: 1px;
    font-weight: 600;
    text-transform: uppercase;
}

.hqhw-head h2{
 color: var(--t1);
  margin: 20px 0 10px;
  line-height:1.25;
  font-weight:700;
}

.hqhw-head p{
  color:var(--muted);
  font-size:16px;
}

/* ===== TIMELINE ===== */
.hqhw-grid{
  display:flex;
  flex-direction:column;
  gap:50px;
  position:relative;
  max-width:950px;
  margin:auto;
}

/* center line */
.hqhw-grid::before{
  content:"";
  position:absolute;
  left:50%;
  top:0;
  width:3px;
  height:100%;
  background: linear-gradient(to bottom, #e2e7e6, #0f4c46);
  transform:translateX(-50%);
  opacity:0.4;
}

/* ===== CARD ===== */
.hqhw-card {
    width: 46%;
    padding: 20px 25px;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.75);
    backdrop-filter: blur(14px);
    border: 1px solid rgba(255, 255, 255, 0.5);
    box-shadow: 0 15px 40px rgba(0, 0, 0, 0.08);
    position: relative;
    transition: all 0.4s ease;
    border-bottom: 3px solid var(--o3);
    border-top: 3px solid var(--o3);
	    z-index: 11;
}

.hqhw-card:hover{
  transform: translateY(-10px) scale(1.03);
  box-shadow:0 30px 70px rgba(0,0,0,0.15);
}

/* zig-zag */
.hqhw-card:nth-child(odd){
  align-self:flex-start;
}

.hqhw-card:nth-child(even){
  align-self:flex-end;
}

/* ===== STEP ===== */
.hqhw-step{
  position:absolute;
  top:20px;
  width:54px;
  height:54px;
  background: linear-gradient(135deg, #F26A4B, #ff8a6d);
  color:#fff;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:700;
  font-size:16px;
  box-shadow:0 10px 25px rgba(0,0,0,0.25);
  border:4px solid #fff;
}

/* step positions */
.hqhw-card:nth-child(odd) .hqhw-step{
  right:-90px;
}

.hqhw-card:nth-child(even) .hqhw-step{
  left:-90px;
}

/* ===== ICON ===== */
.hqhw-icon{
  font-size:30px;
  margin-bottom:5px;
  transition:0.3s;
}

.hqhw-card:hover .hqhw-icon{
  transform: scale(1.2) rotate(8deg);
}

/* ===== TEXT ===== */
.hqhw-card h4{
  font-size:19px;
color: var(--t1);
  margin-bottom:6px;
  font-weight:600;
}

.hqhw-card p {
    font-size: 14px;
    color: var(--color-4);
    line-height: 1.6;
    margin-bottom: 0;
}


/* hidden state */
.cvr_mntl_hlth .more {
  display: none;
  opacity: 0;
  transform: translateY(10px);
}

/* visible state */
.cvr_mntl_hlth .cond-grid.show-all .more {
  display: block;
  animation: fadeSlide 0.4s ease forwards;
}

/* animation */
@keyframes fadeSlide {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* button */
.btn-show {
  background: var(--t2);
  color: #fff;
  padding: 10px 18px;
  border: none;
  border-radius: 8px;
  cursor: pointer;
  transition: 0.3s;
font-family: Montserrat-SemiBold;
  font-weight: 600;
  font-size: 14px;
}

.btn-show:hover {
  background: var(--t1);
  transform: translateY(-2px);

}
.section-head {
 
    margin-bottom: 30px;
}

.frm_teen .section-head {
    margin-bottom: 40px;
}

.frm_teen .segments-grid {
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	width: 90%;
    margin: auto;
}
.personl_pysctry {
    background: #fff;
    padding: 60px 0;
}
.cmn_helth .hero-features li {
    align-items: self-start;
}
.cmn_helth .hero-features li svg {
    margin-top: 3px;
}

.cmn_helth .hero-features {
    margin-bottom: 20px;
}

.physc_scn h2 {
    font-size: 36px;
    margin-bottom: 8px;
}

.pscy_phclgs ul {
    margin-top: 0;
}

.pscy_phclgs ul li {
    font-size: 15px;
	padding: 0;
	padding-left: 25px;
	margin-bottom: 18px;
}

.case-study .case-bafter{
	color: var(--muted);
	    font-family: Montserrat-Medium;
}
.case-study .case-bafter {
    font-size: 12px;
    font-weight: 500;
    line-height: 15px;
    display: none;
}

.case-study .case-bafter small {
    color: var(--color-4);
    line-height: 14px;
    display: block;
    margin-top: 3px;
    font-size: 10px;
}

.case-study .case-bafter strong {
  
    margin-bottom: 2px;
}

.review_bxe {
    background: #fff;
}

/* hide answer */
.phys_faq .fi .fa {
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transition: all 0.3s ease;
}

/* show answer */
.fi.active .fa {
  max-height: 300px;
  opacity: 1;
      font-family: Montserrat-Medium;
	  padding-top: 8px;
}

/* toggle icon rotate */
.phys_faq .ftog {
  transition: transform 0.3s ease;
}

.fi.active .ftog {
  transform: rotate(45deg); /* + → × */
}


/* COLORS */

.mint{
  background:linear-gradient(135deg,#eefaf7,#dff6ef);
}

.purple{
 background: linear-gradient(135deg, #f5ebff70, #ead8ff);
}

.peach{
  background: linear-gradient(135deg, #fff0e4a3, #ffe3d2);
}

.blue {
    background: linear-gradient(135deg, #eef4ffa3, #dfe8ffdb);
}

.cream{
  background: linear-gradient(135deg, #fff7db80, #fff0c7);
}

.green{
  background:linear-gradient(135deg,#eef9e8,#e0f2d8);
}

/* LINK COLORS */

.mint h4,
.mint a{
  color:#00a89d;
}

.purple h4,
.purple a{
  color: #4c05c9;
}

.peach h4,
.peach a{
  color:#ff7a00;
}

.blue h4,
.blue a{
      color: #003e9f;
}

.cream h4,
.cream a{
  color:#f0a000;
}

.green h4,
.green a{
  color:#2e9f3e;
}

.cond-card a {
    background: #fff;
    padding: 8px 10px;
    border-radius: 5px;
    text-decoration: none;
    margin-top: 10px;
    display: inline-block;
    font-family: Montserrat-SemiBold;
}

.hlstc_cre .cond-card .ico {
    background: #fff;
}

/* =========================
   HQ TOC SECTION
========================= */

html{
  scroll-behavior:smooth;
}

/* TOC CARD */

.hq-toc-card{
 background: var(--c-cream);
  padding:40px;
  border-radius:32px;
}

/* HEADING */

.hq-toc-card h4{
  font-size:32px;
  line-height:1.1;
  color:#005f5b;
  font-weight:800;
  margin-bottom:28px;
}

/* GRID */

.hq-toc-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}

/* ITEM */

.hq-toc-item{
  position:relative;
  display:flex;
  flex-direction:column;
  justify-content:center;
  min-height: 95px;
  padding: 12px 20px;
  border-radius:24px;
  background:#fff;
  text-decoration:none;
  border:1px solid rgba(0,0,0,.04);
  box-shadow: 0 8px 24px rgba(0,0,0,.03);
  overflow:hidden;
  transition:.3s ease;
}

/* NUMBER */

.hq-toc-num{
  font-size:12px;
  font-weight:700;
  color:#8fa7a4;
  margin-bottom:5px;
}

/* TITLE */

.hq-toc-title {
    font-size: 14px;
    line-height: 19px;
    font-weight: 700;
    color: #005f5b;
    max-width: 82%;
}

/* ARROW */

.hq-toc-arrow{
  position:absolute;

  right:18px;
  bottom:18px;

  width:34px;
  height:34px;

  border-radius:50%;

  display:flex;
  align-items:center;
  justify-content:center;

  background:#edf5f2;

  color:#005f5b;

  font-size:14px;

  transition:.3s ease;
}

/* WATERMARK */

.hq-toc-item::before {
    content: "";
    position: absolute;
    width: 125px;
    height: 125px;
    border-radius: 50%;
    background: rgba(0, 95, 91, .03);
    right: -50px;
    bottom: -50px;
}

/* HOVER */

.hq-toc-item:hover{
  transform:translateY(-5px);

  box-shadow:
  0 16px 34px rgba(0,95,91,.10);
}

.hq-toc-item:hover .hq-toc-arrow{
  transform:translate(3px,-3px);

  background:#005f5b;
  color:#fff;
}


/* =========================
   HQ MODERN JOURNAL REFERENCES
========================= */

.hq-journal-sec{
  position:relative;
  overflow:hidden;
  padding:70px 0;
  background:
  radial-gradient(circle at top right,#dff7f2 0,#f6f4ef 40%);
}

/* BACKGROUND GLOW */

.hq-journal-sec::before{
  content:"";

  position:absolute;

  top:-220px;
  right:-120px;

  width:520px;
  height:520px;

  border-radius:50%;

  background:
  radial-gradient(circle,rgba(0,134,118,.12) 0%,transparent 72%);
}



/* HEADING */

.hq-journal-head{

  margin-bottom:50px;
}

.hq-journal-tag{
  display:inline-flex;
  align-items:center;
  gap:8px;

  padding:10px 18px;

  border-radius:999px;

  background:rgba(255,255,255,.75);

  backdrop-filter:blur(10px);

  border:1px solid rgba(0,134,118,.08);

  color:#008676;

  font-size:12px;
  font-weight:700;
  letter-spacing:1px;

  margin-bottom:22px;
}

.hq-journal-head h2{
  margin-bottom:10px;
}

.hq-journal-head p{
  font-size:17px;
  line-height:1.9;

  color:#5f6d6b;
}

/* TIMELINE */

.hq-journal-timeline{
  position:relative;

  padding-left:54px;
}

.hq-journal-timeline::before{
  content:"";

  position:absolute;

  left:18px;
  top:0;

  width:2px;
  height:100%;

  background:
  linear-gradient(
    to bottom,
    rgba(0,134,118,.15),
    rgba(0,134,118,.45),
    rgba(0,134,118,.1)
  );
}

/* CATEGORY */

.hq-journal-category{
  position:relative;

    margin: 30px 0 20px;

  font-size:12px;
  font-weight:800;

  letter-spacing:2px;

  color:#00a08d;

  text-transform:uppercase;
}

/* ITEM */

.hq-journal-item{
  position:relative;

  margin-bottom:34px;

  padding:26px 28px;

  border-radius:26px;

  background:
  rgba(255,255,255,.6);

  backdrop-filter:blur(16px);

  border:1px solid rgba(255,255,255,.55);

  box-shadow:
  0 8px 30px rgba(0,0,0,.03);

  transition:.35s ease;
}

/* DOT */

.hq-journal-dot{
  position:absolute;

  left:-44px;
  top:34px;

  width:16px;
  height:16px;

  border-radius:50%;

  background:#00a08d;

  border:4px solid #f6f4ef;

  z-index:2;

  transition:.35s ease;
}

/* YEAR */

.hq-journal-year{
  display:inline-flex;
  align-items:center;

  padding:7px 12px;

  border-radius:999px;

  background:#edf8f5;

  color:#008676;

  font-size:11px;
  font-weight:800;
  letter-spacing:1px;
    margin-bottom: 6px;
}

/* TITLE */

.hq-journal-content h3 {
    font-size: 24px;
    color: var(--t1);
    margin-bottom: 5px;
    transition: .3s ease;
}

/* TEXT */

.hq-journal-content p {
    font-size: 15px;
    margin-bottom: 0;
    line-height: 21px;
}

/* HOVER */

.hq-journal-item:hover{
  transform:
  translateY(-6px)
  translateX(4px);

  box-shadow:
  0 18px 40px rgba(0,95,91,.08);
}

.hq-journal-item:hover .hq-journal-dot{
  transform:scale(1.35);

  box-shadow:
  0 0 0 12px rgba(0,160,141,.08);
}

.hq-journal-item:hover h3{
  color:#008676;
}

/* DISCLAIMER */

.hq-journal-note {
    position: relative;
    margin-top: 60px;
    padding: 20px 30px;
    border-radius: 20px;
    background: linear-gradient(135deg, rgba(255, 248, 232, .9), rgba(255, 255, 255, .8));
    backdrop-filter: blur(14px);
    border: 1px solid rgba(255, 219, 138, .4);
    box-shadow: 0 10px 28px rgba(0, 0, 0, .03);
    font-size: 14px;
    line-height: 25px;
    color: #6d624d;
    font-family: Montserrat-Medium;
}

/* SMALL ACCENT */

.hq-journal-note::before{
  content:"";
  position:absolute;
  left:0;
  top:21px;
  width:4px;
  height:52px;
  border-radius:10px;
  background:#ffbf47;
}

.hq-journal-note p {
    font-size: 15px;
    margin-top: 12px;
    margin-bottom: 0;
}
.hq-journal-note a {
    font-weight: 700;
    text-decoration: none;
    color: var(--o2);
}

.hq-journal-note a:hover{
  text-decoration:underline;
}

.city_icon{
  width:40px;
  height:40px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#edf8f5;
  font-size:18px;
  transition:.3s ease;
}
.city-grid a{
  position: relative;
}

.city-grid a span:last-child {
    position: absolute;
    top: 30px;
    right: 9px;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #00a08d, #008676);
    
    color: #fff;
    font-size: 13px;
    font-weight: 700;
    opacity: 0;
    transform: translateY(6px) scale(.85) rotate(-8deg);
    transition: opacity .28s ease, transform .32s cubic-bezier(.22, 1, .36, 1), background .3s ease;
    box-shadow: 0 10px 24px rgba(0, 134, 118, .22);
}


/* GLOW */

.city-grid a span:last-child::before{
  content:"";
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
  border-radius:50%;
  background:
  radial-gradient(circle at center,
  rgba(255,255,255,.45),
  transparent 70%);
}

.city-grid a:hover span:last-child{
  opacity:1;

  transform:
  translateY(-50%)
  scale(1);
}

.pysctry_img{
  position:relative;

  display:inline-block;
}

/* IMAGE */

.pysctry_img img{
  width:100%;

  border-radius:
  34% 66% 58% 42% /
  42% 38% 62% 58%;

  animation:hqMorph 8s ease-in-out infinite;

  box-shadow:
  0 20px 50px rgba(0,95,91,.18);

  transition:.4s ease;

  object-fit:cover;
}

/* FLOATING GLOW */

.pysctry_img::before{
  content:"";

  position:absolute;

  inset:-14px;

  border-radius:
  46% 54% 39% 61% /
  58% 42% 58% 42%;

  background:
  linear-gradient(
    135deg,
    rgba(0,160,141,.18),
    rgba(0,160,141,.04)
  );

  z-index:-1;

  animation:hqMorph2 8s ease-in-out infinite;
}

/* FLOAT EFFECT */

.pysctry_img{
  animation:hqFloat 5s ease-in-out infinite;
}

/* MORPH */

@keyframes hqMorph{

  0%{
    border-radius:
    34% 66% 58% 42% /
    42% 38% 62% 58%;
  }

  50%{
    border-radius:
    58% 42% 34% 66% /
    52% 60% 40% 48%;
  }

  100%{
    border-radius:
    34% 66% 58% 42% /
    42% 38% 62% 58%;
  }
}

/* BG MORPH */

@keyframes hqMorph2{

  0%{
    border-radius:
    46% 54% 39% 61% /
    58% 42% 58% 42%;
  }

  50%{
    border-radius:
    62% 38% 58% 42% /
    38% 62% 38% 62%;
  }

  100%{
    border-radius:
    46% 54% 39% 61% /
    58% 42% 58% 42%;
  }
}

/* FLOAT */

@keyframes hqFloat{

  0%{
    transform:translateY(0px);
  }

  50%{
    transform:translateY(-10px);
  }

  100%{
    transform:translateY(0px);
  }
}

.segment-card{
  position:relative;

  background:#fff;

  padding:24px;

  border:1px solid var(--c-line);

  border-radius:16px;

  text-align:center;

  overflow:hidden;

  transition:
  transform .28s ease,
  box-shadow .28s ease,
  border-color .28s ease;
}

/* BOTTOM LINE */

.segment-card::after{
  content:"";

  position:absolute;

  left:50%;
  bottom:0;

  width:0;
  height:4px;

  border-radius:20px;

  background:
  linear-gradient(90deg,#00a08d,#008676);

  transform:translateX(-50%);

  transition:.35s ease;
}

/* HOVER */

.segment-card:hover{
  transform:translateY(-6px);

  box-shadow:
  0 16px 34px rgba(0,95,91,.08);

  border-color:#c7dfd8;
}

.segment-card:hover::after{
  width:100%;
}


/* IMAGE WRAP */

.why_cnslt_img{
  position:relative;
  display:inline-block;
  animation:hqFloatImg 6s ease-in-out infinite;
  margin-top: 30px;
}

/* IMAGE */

.why_cnslt_img img{
  width:100%;

  border-radius:
  28px 60px 28px 60px;

  position:relative;

  z-index:2;

  object-fit:cover;

  transition:
  transform .5s ease,
  border-radius .5s ease;

  box-shadow:
  0 24px 60px rgba(0,95,91,.18);
}

/* GRADIENT GLOW */

.why_cnslt_img::before{
  content:"";

  position:absolute;

  inset:-14px;

  border-radius:
  60px 28px 60px 28px;

  background:
  linear-gradient(
    135deg,
    rgba(0,160,141,.22),
    rgba(0,95,91,.08)
  );

  z-index:1;

  animation:hqGlowMorph 7s ease-in-out infinite;
}

/* FLOATING RING */

.why_cnslt_img::after{
  content:"";

  position:absolute;

  width:120px;
  height:120px;

  border-radius:50%;

  border:2px dashed rgba(0,134,118,.22);

  top:-30px;
  right:-30px;

  animation:hqRotate 16s linear infinite;
}

/* HOVER */

.why_cnslt_img:hover img{
  transform:scale(1.03);

  border-radius:
  60px 28px 60px 28px;
}

/* FLOAT */

@keyframes hqFloatImg{

  0%{
    transform:translateY(0px);
  }

  50%{
    transform:translateY(-10px);
  }

  100%{
    transform:translateY(0px);
  }
}

/* MORPH */

@keyframes hqGlowMorph{

  0%{
    border-radius:
    60px 28px 60px 28px;
  }

  50%{
    border-radius:
    28px 60px 28px 60px;
  }

  100%{
    border-radius:
    60px 28px 60px 28px;
  }
}

/* ROTATE */

@keyframes hqRotate{

  from{
    transform:rotate(0deg);
  }

  to{
    transform:rotate(360deg);
  }
}


.mntl_iner {
    text-align: center;
    margin-bottom: 40px;
}
/* =========================
   TRENDING FLOATING IMAGE
========================= */

.cmn_hlth_img{
  position:relative;

  display:inline-block;

  isolation:isolate;

  perspective:1200px;
}

/* IMAGE */

.cmn_hlth_img img{
  width:100%;

  position:relative;
  z-index:3;

  object-fit:cover;

  border-radius:32px;

  transition:
  transform .6s cubic-bezier(.22,1,.36,1),
  filter .5s ease;

  box-shadow:
  0 30px 80px rgba(0,95,91,.16);

  animation:hqLevitate 6s ease-in-out infinite;
}

/* AURORA GLOW */

.cmn_hlth_img::before{
  content:"";

  position:absolute;

  inset:-18px;

  border-radius:40px;

  background:
  conic-gradient(
    from 180deg,
    rgba(0,160,141,.22),
    rgba(0,95,91,.08),
    rgba(0,160,141,.18),
    rgba(0,95,91,.06)
  );

  filter:blur(22px);

  opacity:.85;

  z-index:1;

  animation:hqRotateGlow 12s linear infinite;
}

/* FLOATING GLASS BADGE */

.cmn_hlth_img::after{
  content:"Trusted Mental Health Care";

  position:absolute;

  left:24px;
  bottom:24px;

  z-index:4;

  padding:14px 20px;

  border-radius:999px;

  background:
  rgba(255,255,255,.18);

  backdrop-filter:blur(16px);

  border:1px solid rgba(255,255,255,.28);

  color:#fff;

  font-size:13px;
  font-weight:700;

  letter-spacing:.4px;

  box-shadow:
  0 12px 30px rgba(0,0,0,.14);
}

/* HOVER */

.cmn_hlth_img:hover img{
  transform:
  rotateY(-8deg)
  rotateX(4deg)
  scale(1.04);

  filter:
  brightness(1.04)
  contrast(1.03);
}

/* FLOAT */

@keyframes hqLevitate{

  0%{
    transform:translateY(0px);
  }

  50%{
    transform:translateY(-12px);
  }

  100%{
    transform:translateY(0px);
  }
}

/* GLOW ROTATION */

@keyframes hqRotateGlow{

  from{
    transform:rotate(0deg);
  }

  to{
    transform:rotate(360deg);
  }
}

.cmn_helth{
  
  overflow: hidden;
}


.why_onlne_pysc{
  overflow: hidden;
}

.pfeats {
  
    padding-left: 0;
}

.fi.open .fa {
    max-height: 240px;
    padding-top: 8px;
    font-family: Montserrat-Medium;
    opacity: initial !important;
}


.new_conde{
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
}

.activity-toast span{
	font-family: Montserrat-Medium;
	line-height: 17px;
    display: block;
}

.diet-page .float-call {
    background: #d8d8d8;
}


.selected-price-box {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: linear-gradient(135deg, #e6f9f8, #f0fffe);
    border: 1.5px solid #009e96;
    border-radius: 12px;
    padding: 12px 16px;
    margin: 10px 0 14px;
}
.spb-label {
    font-size: 13px;
    font-weight: 700;
    color: #007d76;
}

.spb-type {
    font-size: 11px;
    color: var(--color-4);
    font-weight: 500;
    font-family: Montserrat-Medium;
}
.spb-amount {
    font-size: 22px;
    font-weight: 800;
    color: #009e96;
}

.spb-left {
    width: 70%;
}
.spb-left {
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.spb-right {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 2px;
}

.selected-price-box .form_ttl_pricee {
    display: flex;
    gap: 6px;
}

.spb-orig {
    font-size: 12px;
    color: #999;
    text-decoration: line-through;
}

.spb-badge {
    font-size: 10px;
    background: #ff6b35;
    color: #fff;
    padding: 2px 8px;
    border-radius: 20px;
    font-weight: 700;
}
.spb-right .form_pricee {
    display: block;
}


.hq-price-wrap {
    background: #f0fafa;
    border: 1px solid #b2dfdb;
    border-radius: 10px;
    padding: 12px 14px;
    margin-bottom: 14px;
}

.hqpw-tabs {
    display: flex;
    background: #fff;
    border: 1px solid #b2dfdb;
    border-radius: 8px;
    padding: 3px;
    gap: 3px;
    margin-bottom: 10px;
}

.hqpw-price-row {
    display: flex;
    align-items: baseline;
    gap: 6px;
    margin-bottom: 10px;
    flex-wrap: wrap;
}

.hqpw-per {
    font-size: 12px;
    color: #888;
}

.hqpw-lbl {
    font-size: 11px;
    background: #e0f2f1;
    color: #00695c;
    padding: 2px 8px;
    border-radius: 20px;
    font-weight: 500;
	box-shadow: 0px 1px 1px 0px #ccc;
}

.hqpw-tab {
    flex: 1;
    padding: 7px 10px;
    border: none;
    background: transparent;
    border-radius: 6px;
    font-size: 12px;
    font-weight: 500;
    cursor: pointer;
    color: #555;
    transition: all 0.15s;
	font-family: var(--fh);
}
.hqpw-tab.active {
    background: #009e96;
    color: #fff;
}
.hqpw-amount {
    font-size: 26px;
    font-weight: 800;
    color: #009e96;
}

.hqpw-price-pill{
	display: none;
}

.cfpw{
	
	background: #e6f9f8;
    border: 1.5px solid #c2efed;
    border-radius: 10px;
    padding: 10px 14px;
    margin-bottom: 12px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 8px;
}

.cfpw-type-tag {
    font-family: var(--fh);
}

span.cfpw-amount {
    font-weight: 600;
    color: var(--muted);
}
.float-call {
    background: #fff;
}

/* RESPONSIVE */

@media(max-width:768px){

  .hq-journal-sec{
    padding:75px 0;
  }

  .hq-journal-head{
    margin-bottom:55px;
  }

  .hq-journal-head h2{
    font-size:36px;
    line-height:1.12;
  }

  .hq-journal-head p{
    font-size:15px;
  }

  .hq-journal-timeline{
    padding-left:34px;
  }

  .hq-journal-dot{
    left:-24px;
    top:30px;
  }

  .hq-journal-item{
    padding:15px;
    border-radius:22px;
        margin-bottom: 24px;
  }

  .hq-journal-content h3{
    font-size:19px;
  }

  .hq-journal-content p{
    font-size:14px;
  }

  .hq-journal-note{
    padding:24px;
    border-radius:22px;

    font-size:13px;
    line-height:1.9;
  }
}

/* RESPONSIVE */

@media(max-width:1200px){

  .hq-toc-grid{
    grid-template-columns:repeat(2,1fr);
  }
}

@media(max-width:768px){

  .hq-toc-card{
    padding:24px;
    border-radius:24px;
  }

  .hq-toc-grid{
    grid-template-columns:1fr;
    gap:16px;
  }

  .hq-toc-card h4{
    font-size:26px;
    margin-bottom:22px;
  }

  .hq-toc-item{
    min-height:95px;
    border-radius:20px;
    padding:18px;
  }

  .hq-toc-title{
    font-size:14px;
  }
}




/* ===== MOBILE ===== */
@media(max-width:768px){
  .hqhw-grid::before{
    left:25px;
  }

  .hqhw-card{
    width:100%;
    align-self:flex-start !important;
    padding-left:70px;
  }

  .hqhw-step{
    left:0 !important;
    right:auto;
  }
}



@media (max-width: 768px) {
  .cf-form-row {
    grid-template-columns: 1fr;
  }
  
  .cf-prog-lbl {
    font-size: 10px;
  }
  
  .cf-prog-dot {
    width: 32px;
    height: 32px;
    font-size: 13px;
  }
  
  .tcm-avatar-section {
   
    gap: 8px;
    margin-bottom: 10px;
}
.tcm-header {
   
    padding: 15px 10px;
  
}
.tcm-name {
    font-size: 16px;
 
}
.tcm-avail-badge span {
   
    font-size: 8px;
}
.tcm-avail-badge {
   
    top: 94px;
}
.tcm-btn-secondary, .tcm-btn-primary {

    padding: 8px 6px;
    font-size: 12px;
  
}
.tcm-body {
    padding: 10px 10px 10px;
}
.tcm-footer {
    padding: 10px 10px;
   
}
.inline-booking-title h4 {
    font-size: 14px;
    font-weight: 600;
   
}
.ftier .fp-orig {
        font-size: 16px;
    }
	.hform {
        padding: 20px 10px 14px;
    }
	    .form_disc_pricee .fp {
        font-size: 16px !important;
    }
	.cf-booking-header {
    display: block;
   
}

    .tcm-avail-badge {
        top: 4px;
    }
	    .tcm-avail-badge span {
        font-size: 6px;
    }
	.cf-booking-title h4 {
    font-size: 15px;
   
}
.cf-btn-primary, .cf-btn-secondary {
        padding: 10px;
    }
	.cf-slot-container {
        margin-bottom: 16px;
    }
	.cf-form-row {
        gap: 0px;
    }
	.cf-form-input, .cf-form-select {
        padding: 10px;
        font-size: 13px;
    }
	    .cf-form-group {
        margin-bottom: 10px;
    }
	    .tcm-header {
        padding: 15px 10px 2px;
    }
	    .cf-selected-pill {
        margin-bottom: 10px;
			padding: 10px 6px;
        font-size: 12px;
    }

		
		.cf-summary-row {
  
    padding: 5px 0;
  
}
.cf-summary-box {
        padding: 10px 10px;
        margin-bottom: 14px;
    }

    .trmnt_prgrm .cond-grid {
    grid-template-columns: initial;
}
h2 {
        font-size: 28px;
        line-height: 1.2;
    }
    .physc_scn h2 {
    font-size: 28px;

}

.psycho-band {
  
    padding: 30px 20px;
   
}
.derm-hero h1 em {
    font-style: italic;
    color: var(--t2);
    font-size: 30px;
}

.derm-hero h1 {
    font-size: 30px;
    line-height: 40px;
    margin-bottom: 25px;
}

.hb-ind {
    margin-bottom: 12px;
}

.hero-stat span{
  line-height: 15px;
  margin-top: 3px;
}

.hero-stat strong {
        font-size: 18px;
    }

    .hero-stat {
    padding: 8px 5px;
}
.psych-section {
   
    padding: 40px 0px;
}
.hq-toc-card {
        padding: 20px 10px;
        border-radius: 20px;
    }

    .hq-toc-arrow {
   
    right: 8px;
    bottom: 8px;
    width: 30px;
    height: 30px;
  
}
.hq-toc-item {
        padding: 10px;
    }
    .hq-toc-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 8px;
    }

    .hq-toc-item::before {
  
    width: 105px;
    height: 105px;
   
}
.section {
    padding: 40px 0;
}

.eyebrow {
  
    font-size: 10px;
    letter-spacing: 0.5px;
    padding: 6px 10px;
    margin-bottom: 10px;
}
.section-head {
    margin-bottom: 15px;
}
.cond-grid {
  
    gap: 10px;
}

.derm-symptom-table th {
    padding: 10px 10px;
    font-size: 15px;
   
}

    .derm-symptom-table td {
        padding: 6px 5px;
      
    }

        

    .hqhw-section{

          padding: 40px 0;
    }

    .hqhw-head {
    max-width: 100%;
    margin-bottom: 30px;
}

.hqhw-grid {
  
    gap: 30px;
   
}

.cond-card a {
    
    margin-top: 5px;
   
}

.derm-symptom-table{
  width:100%;

  overflow-x:auto;

  -webkit-overflow-scrolling:touch;
}

.derm-symptom-table table{
  min-width:600px;

  border-collapse:collapse;
}

.personl_pysctry {
    padding: 30px 0;
}

.app-band {
   
    padding: 0;
 
}
.faq-foot{
  gap: 2px;
}
.quick-access {
  
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  
}

.hq-journal-sec {
        padding: 40px 0;
        overflow: hidden;
    }
    .hq-journal-head h2 {
        font-size: 28px;
       
    }

    .hq-journal-category {
  
    margin: 28px 0 20px;
    
}
.final-cta {
   
    padding: 30px 18px;

   
}
.personl_pysctry {
    
        overflow: hidden;
    }
    .derm-mobile-cta a {
   
    text-align: center;
}

.derm-hero {
 
    padding: 110px 0 40px;
  
}
.hero-features{
	    grid-template-columns: repeat(2, 1fr);
}

.cmn_hlth_img::after {
   
    left: 15px;
    bottom: 20px;
    padding: 10px 14px;
    font-size: 12px;
  
}
.cmn_helth .hero-features {
 
    grid: initial;
}

.case-study { 
    padding: 20px 16px;
}
.case-study .case-cond {
  
    margin-bottom: 10px;
}
.case-study .case-meta {
    
    margin-bottom: 10px;
}

.case-study .case-treatment {
    padding-top: 10px;

}

.case-studies-grid {
   
    gap: 15px;
}
.compare-table td {
    padding: 10px 12px;
  
}
.compare-table th {
    padding: 12px;
   
}
.testimonial {

    padding: 20px 15px;
   
}

.faq-foot {
    padding: 18px 15px;
}

.hq-journal-content h3 {
    margin-bottom: 6px;

}
.hq-journal-year {
    margin-bottom: 12px;
}
    .hq-journal-head {
        margin-bottom: 40px;
    }
	.segment-card {
  
    padding: 18px;
  
}

.hero-features li {
   
    font-size: 12.5px;
}

body {
        padding-bottom: 0px;
    }
}

