/* 16/07 */

*, *:after, *:before { 
	box-sizing: border-box; 
	margin: 0;
    padding: 0;
}

.clearfix:before, .clearfix:after { 
	content: ''; 
	display: table; 
}
.clearfix:after { 
	clear: both; 
}

.blueText{
	color: #34495e;
}
.pinkText {
	color: #E07D8A;
}
.pinkText a{
	color: #fff;	
	font-weight: 600;
	text-decoration: none;
}
.pinkText a:hover{
	color: #E07D8A;	
}

.whiteText {
	color: #fff;	
}
.whiteText a{
	color: #E07D8A;	
	font-weight: 600;
	text-decoration: none;
}
.whiteText a:hover{
	color: #fff;	
}


.blueBG {
	 background-color: #34495e;
}
.pinkBG {
	 background-color: #E07D8A;
}
.whiteBG {
	 background-color: #fff;
}
.darkpinkBG {
background-color: #b96a74;	
}
.smallText {
	font-size: unset;
font-size: 0.6em;
	line-height: 1.7em;
}
.WO {
	width: 60%; 
	margin: 0 auto;
}
body, html {
    height: auto;
     font-family: "Poppins", sans-serif;
  font-weight: 300;
  font-style: normal;
	background-color: #2c3135;
	scroll-behavior: smooth;
	color: #fff;
	font-size: calc(14px + 0.390625vw);
}
br {
	content: "";
	display: block;
	clear: both;
	padding-bottom: 10px;
	line-height: 3;
	
}
strong {
	font-weight: 700;
}

h1, 
.content-section h2, 
.content-section h3 {
  font-family: "Praise", cursive;
  font-weight: 400;
  font-style: normal;
}
sup {
	line-height: 0.4em;
	font-size: 0.7em;
}


.content-section h3 {
margin-top: 20px;	
}

.mainWrap {
	width: 70%;
	max-width: 900px;
	margin:  0 auto;
	opacity: 1;
	position: relative; /* Make the child element position: relative */
  z-index: 1;
	
}

.logo {
    width: 90%;
	margin: 10px auto 50px auto;
	display: flex;
  justify-content: center;
}

h1 {
	font-size: calc(80px + 0.390625vw);
	line-height: 1;
	position: relative;
	width: 100%;
	color: #fff;
	text-shadow: 8px 8px 8px rgba(0, 0, 0, 0.5);
	text-align: center
}

.hero-section p {
    font-size: 1.3rem;
	color: #fff;
	display: block;
 font-family: "Poppins", sans-serif;
  font-weight: 200;
  font-style: normal;
text-align: center;
	margin-top: 40px;
	z-index: +1;
}

p.frontpagetext b{
	font-weight: 500;
	color:#E07D8A;
}

a.button.content-switch {
	border: 2px solid #fff;
	width: auto;
	overflow:visible;
	white-space: wrap;
	background: rgba(255, 255, 255, 0.2);
	color: #fff;
	font-family: "Poppins", sans-serif;
	display: block;
	margin: 50px auto;
	cursor: pointer;
 	text-align: center;
	padding: 1em;
	font-size: 0.9rem;
	line-height: 1.2;
	letter-spacing: 1px;
	font-weight: 400;
	outline: none;
	z-index: 1000;
	opacity: 0.7;
	text-transform: uppercase;
	text-indent: 200%;
	text-decoration: none;
	transition: 0.5s ease-in-out;
}
a.button.content-switch:hover{
	background-color: #E07D8A;
	color: #2c3135;
	text-decoration: none;
}


/* ------------------------------------------------------------------*/


.content-section {
    padding: 2rem 0 1px;
	box-shadow: inset 0 17px 19px -17px rgba(0,0,0,0.7);
	text-align: center;
}
.silent {
	padding:1px 0;
	box-shadow: none;
	margin: 0;
}
.content-section h2 {
  font-size: 4rem;
  padding: 0.5em 0;

	line-height: 1;
	position: relative;
}	
.content-section h2.menuH2 {
	padding-bottom: 0;
}

.content-section h2 span,
.content-section h3,
.content-section h3.TherapyTitle,
.content-section h4{
  display: block;
  font-size: 1.3rem;
    font-family: "Poppins", sans-serif;
  font-weight: 800;
  font-style: normal;	
}

.content-section h4 {
padding: 10px;
	border: 1px solid #fff;
	width: 50%;
	margin:30px auto 0 auto;
	font-size: 1.0rem;
	font-weight: 400;
}

.content-section h2 span{
margin-top: 20px;
	font-weight: 400;
	line-height: 1.2;
}
.content-section h3.TherapyTitle {
	font-size: 1.5rem;
	padding-bottom: 5px;
	font-weight: 800;
	margin-bottom: 10px;
}

.content-section p {
	font-family: "Poppins", sans-serif;
	font-style: normal;
	font-weight: 400;
	line-height: 1.5;
	padding-bottom: 0.8em;
}
p.paraEnd {
	padding-bottom: 3em;
}

img.bymiki {
	width:50%;
	margin: 0 auto;
	display: block;
}
img.mikipic {
		
	max-width: 300px;
		border: 1px solid #fff;
		display: block;
		background-color: #E07D8A;
		margin: 20px auto 30px;
	object-fit: contain;
	}	

.qualWrap {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 2vw;;
	margin-bottom: 40px;

}
.qualWrap a {
	flex: 1 1 calc(25% - 2vw); /* 4 columns with spacing */
  max-width: calc(25% - 2vw);
  box-sizing: border-box;

  
	
}
.qualpics {
	width: 100%;
  height: auto;
  object-fit: contain;
  display: block;
border: 2px solid #E07D8A;
	background-color: #fff;
	padding: 2px
	}



	
	/* -------Benefits --------- */


button.sideToggleBens {
	position: sticky;
	float: right;
	right: 0;
	top: 35vh;
	background-color: #2c3135;
	color: #fff;
	rotate: 270deg;
	padding: 10px;
	border: 0;
		transform-origin: right bottom;
	border-radius: 10px 10px 0 0;
margin-top: -80px;
}
.bensLine {
	border-top:1px solid #fff;

}
.bensTitle{
    display: none;
}





span.opened::before{
  content: "Hide "; /* Create a pseudo-element */
  position: relative; /* Position the pseudo-element absolutely */
}
span.closed::before {
  content: "Show "; /* Create a pseudo-element */
  position: relative; /* Position the pseudo-element absolutely */
}
.bensBox {
	width: 100%;
	overflow: hidden; position: relative; 
	
	padding-top: 10px;
}

.bensWrap{
	width:96%;
	margin: 10px auto ;
	padding: 10px;
}
.bensBoxItem, .bensBox p {
	padding: 5px 2vh ;
	margin-bottom: 10px;
	display: block;
	overflow:auto;
}
.bensBoxItem {
	border-top: 1px solid rgba(255, 255, 255, 0.3);

	}
.bensBoxItem:first-child {
	border-width: 0;
}
.bensWrap.bensBoxItem:last-child {
	border-width: 0;
	padding-bottom: 15px;
}
.bensBoxItem b {
 display: block;
	margin-bottom: 5px;
	padding-top: 8px;
}

.bensHideMob {
	display: none
}

/* ---------------------- book new table -------*/
.responsive-table {
	width: 50%;
	margin:30px auto 40px;

	
  li {
    display: flex;
    justify-content: space-between;
    margin-bottom: 0;
	  
  }
  .table-header {
    background-color: #34495e;
    font-weight: 700;
	  height: 50px;
	  
  }
	.table-row .footer {
     height: 60px
  }
	

	
 .col {
    flex-basis: 50%;
  	border: 1px solid #fff;
display: flex;
	  justify-content: center;
    align-items: center;
	  flex-grow: 1;
	  	
	}

.col a{
	text-decoration: none;
	justify-content: center;
    align-items: center;
	color: #fff;
	display: flex;
	height: 100%;
	width: 100%;
    line-height: 1.2;
	font-weight: 600;
	padding: 10px 5px;
	}
.col a:hover{
	background-color:rgba(255,255,255, 1) ;
	color: #34495e ;
}
	
.col-img {
	flex-basis: 10%;
}
	
	.bookNow {
height: 60px;
	}

}
.price { 
	font-weight: 800;
	padding:0;}

.warning {
	width: 75%;
	margin: 20px auto 50px;
	}
.footer-table {
	display: flex;
  justify-content: space-between;
  align-items: center; /* Align items at the top to allow fluid height adjustment */
  width: 100%;
  box-sizing: border-box;
  flex-wrap: wrap; /* Allows wrapping for responsive behavior */

	border: 1px solid #34495e;
	padding: 10px;

.cell {
display: flex;
  justify-content: center;
  align-items: center;
  box-sizing: border-box;


}
.cell img {
  max-height: 100px;
  min-height: 100px;
  object-fit: contain; /* Ensures no distortion */
  max-width: 100%; /* Prevents exceeding container width */
}
.cell.blueText {
  flex: 1; /* Allows it to take up remaining space */
  padding: 10px;
  box-sizing: border-box;
  text-align: left;
  word-wrap: break-word; /* Ensures long words don't overflow */
}
.cell a {
  display: inline-block;
  max-width: 100%;
  height: 100%;
}

.cell a img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
  max-height: 100px;
  min-height: 100px;
}

p {
	padding-left: 20px;	
	font-size: 0.8em;
	 margin: 0; /* Removes default margin to prevent unnecessary spacing */
  line-height: 1.5; /* Adjust line height for better readability */
padding-bottom: 0;
	}

}

	.wide {
		width: 100%;
	}
.copyright {
  display: flex;
  justify-content: space-between; /* Ensures divs stay apart */
  align-items: center; /* Aligns content vertically (optional) */
  width: 100%; /* Full-width container */
	font-size: 0.7em;
	margin-top: 25px;
	flex-wrap: wrap;
img {
		display: block;
	max-height: 80px;
	object-fit: contain; /* Ensures no distortion */
	width: 100%
	}
	div:first-child{
		width: 100%
	}
}
.left {
  flex: 0 0 auto; /* Prevents resizing */
}

.right {
  flex: 0 0 auto; /* Prevents resizing */
}

/* ------------------------------------- 




@media screen and (min-aspect-ratio: 1280/850) {
	nav ul li i {
	display: none;
font-size: calc(11px + 0.390625vw);
}
}
@media screen and (max-width: 63.125em) {

}
*/

.sale-container {
      position: relative;
	 background-color: #fff;
	width: 50vw;
	max-width: 300px;
		display: grid;
		margin: 20px auto 30px;
	
    }

.sale-container a img {
	object-fit: cover;
	max-width:100%
}

p.finalFoot {
		display: block;
		font-size: 0.6em;
		padding-top: 10px;
	}
iframe.map {
	border:1px solid #fff;
}







@media screen and (max-width: 800px) {

	img.mikipic {
		width: 60vw;
		border: 1px solid #fff;
		display: block;
		background-color: #E07D8A;
		margin: 20px auto 30px;
		object-fit: contain;
	}	
	
.qualWrap a {
    flex: 1 1 calc(50% - 1rem);
    max-width: calc(50% - 1rem);

  }
.qualWrap {
    gap: 2rem;
  }
.WO {
	width: 90%; 
	margin: 0 auto;
}
	
.content-section h3 { 
display: flex; /* Makes the heading a flex container */
  align-items: center; /* Aligns text and button vertically */
  gap: 0.5em; /* Adds spacing between title text and button */
	justify-content: center; /* Centers the content horizontally */
}
h3 button.bensHideMob {
	font-size: 0.7em;
	background: none;
  	border: none;
  	padding: 0;
  	margin: 0;
	vertical-align:bottom;
  	cursor: pointer;
	color: #fff;
	display: flex;
	}	
	
.mainWrap.bensLine {
		border-top: 0;
	}	

span.opened::before{
  content: "[Hide]"; /* Create a pseudo-element */
  position: relative; /* Position the pseudo-element absolutely */
}
span.closed::before {
  content: "[Show]"; /* Create a pseudo-element */
  position: relative; /* Position the pseudo-element absolutely */
}	
	
.bensTitle{
	
	border-style: solid;
	border-color: #E07D8A;
	background-color: #34495e;
	border-width: 1px;
	width: 100%;
	margin: 20px 0;
overflow: hidden;
	padding: 10px 0;
	position: relative;
    min-height: 100%;
    /* Flex for centering */ 
    display: flex;
    justify-content: center;
    align-items: center;
}
button.bensTitle,
button.bensTitle.BTPink {
	font-size: 0.9REM;
	display: block;
	width: 100%;
	font-family: "Poppins", sans-serif;
	padding-top: 10px;
	font-weight: 600;
	
}	
	.bensTitle.BTPink {
	border-style: solid;
	border-color: #34495e;
	background-color: #E07D8A;
	border-width: 1px;
	width: 100%;
	margin: 20px 0;
overflow: hidden;
	padding: 10px 0;
	position: relative;
    min-height: 100%;
    /* Flex for centering */
    display: flex;
    justify-content: center;
    align-items: center;
}


h4.price {
	width: 100%;
	}
	
.responsive-table {
	width: 100%;
	margin:10px auto 30px;
	
}
	button.sideToggleBens {
		display: none;
	}	
	
/* NAV */	

.content-section h2 {
	padding-top: 10px;
	}
.content-section h3 {
margin-top: 10px;		
	}	
	
label {
  background: none transparent;
  border: 4px solid #E07D8A;
  border-left: 0 solid transparent;
  border-right: 0 solid transparent;
  cursor: pointer;
  display: block;
  height: 24px;
  position: absolute;
  top: 18px;
  left: 20px;
  width: 24px;
  transition: all 0.2s;
}
label::before {
  background: #E07D8A;
  content: "";
  height: 4px;
  left: 0;
  position: absolute;
  top: 6px;
  width: 24px;
  transition: all 0.2s;
}
label::after {
  background: #E07D8A;
  content: "";
  height: 4px;
  left: 0;
  position: absolute;
  top: 6px;
  opacity: 0;
  visibility: hidden;
  width: 100%;
  transform: rotate(90deg);
  transition: all 0.2s;
}
	
	
.logo {
    width: 100%;
	margin-top:20px;

}

a.button.content-switch b {
 margin: 5px 0;		
	font-size: 0.7em;
	line-height: 1em;
	white-space: normal;
	}
	
h1 {
	font-size: calc(48px - 0.1vw);
		
	}
nav.mainnav {
	display: none;
		width: 0;
		height: 0;
}
.footer-table {
    display: grid; /* Switch to grid layout for better control */
    grid-template-columns: auto auto; /* Two columns for the image divs */
    grid-template-rows: auto auto; /* Text div moves to the next row */
    justify-content: center; /* Centers the grid items */
    gap: 10px; /* Adds spacing between rows and columns */
  
	
  .cell {
    grid-column: span 1; /* Ensure image cells stay in their columns */
    flex: 0 0 auto; /* Prevent shrinking */
  }

  .cell.blueText {
    grid-column: span 2; /* Make the text div span the full width */
	  
  }
	p {
		text-align: center;
	  padding: 0;
	}
}

	
}
