@import url('https://fonts.googleapis.com/css2?family=Amatic+SC&family=Raleway:wght@100&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Roboto&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,800;1,400&display=swap');

/* Removed redundant @font-face block (Google Fonts imports handle it) */

body {
	font-family: 'Amatic SC', cursive;
	font-size: 1rem;
	font-weight: 300;
	color: #222222;
}
strong{font-weight: 900;}
.mt-90 {margin-top:  90px !important;}
/*
.carwrap {overflow: hidden;}
.carousel {transform: translateY(100%);}
*/

a {
	color: #000;
    text-decoration: underline;
    font-size: 1rem;
    font-weight: 900;
}
p {
    font-family: 'Roboto';
	color: #444;
	line-height: 28px;
}

.h2, h2 {font-size: 500%; font-weight: 200; margin-bottom: 0.5rem; margin-top: 2.5rem;}
.h3, h3 {font-size: 400%; font-weight: 100; margin-bottom: 0.5rem; margin-top: 2.5rem;} 
.h4, h4 {font-size: 300%; font-weight: 100; margin-bottom: 0.5rem; margin-top: 2.5rem;}
.h5, h5 {font-size: 200%; font-weight: 100; margin-bottom: 0.5rem; margin-top: 2.5rem;}
.h6, h6 {font-size: 100%; font-weight: 100; margin-bottom: 0.5rem; margin-top: 2.5rem;}

li {font-family: 'Roboto';
	color: #444;
	line-height: 28px;
}
li a{font-family: 'Roboto';
    font-size: 300%;
	color: #444;
	line-height: 28px;
}

.smallH1 {font-size:1rem; line-height: 1.2rem!important;}
.bannerText {font-size:3rem; line-height: 3.4rem!important;}
.font2 {font-family: 'Roboto';}

.logo {padding:0px!important;}
.logo:hover {background-color: #fff!important;}
i { color: #000; }
.galleryItem {margin-bottom: 30px;}

.topnav i { color: #000; }
a:hover i {color:white;}
.sticky a:hover i {color:white;}

.btn { font-family: 'Roboto', sans-serif; }

.smallGold { font-family: 'Roboto', sans-serif; color: #D4B254; }

.container { max-width: 1300px; }

.btn { border-radius: 0; padding: 15px 35px; }

.gold { color: #D4B254; }

.goldBtn { background-color: #000; color: #fff; margin-top: 15px; }
.goldBtn:hover { background-color: #D4B254; color: #fff; }

.transparentBtn { background-color: transparent; color: #fff; border: solid 1px #fff; }
.topnav a.transparentBtn { background-color: #000; color: #fff; }
.topnav a.transparentBtn i { background-color: #000; color: #fff; margin-left: 15px; }
.topnav a.transparentBtn:hover { background-color: #000; color: #fff; }

.carousel-indicators li { opacity: 1!important; }
.carousel-indicators .active { background-color: #D4B254; }

.textOver {
	position: absolute;
	text-align: center;
	width:90%;
	max-width: 1200px;
	color: #fff;
	top: 55%;
	left: 50%;
	z-index: 9996;
	transform: translate(-50%, -55%);
}
.textOver p {
	text-shadow: 2px 2px 5px rgba(0, 0, 0, 0.6);
	color: #fff;
	letter-spacing: 4px;
	font-weight: 600;
}
.textOver h1 {
	text-shadow: 2px 2px 5px rgba(0, 0, 0, 0.25);
	margin: 0 0 15px 0;
	color: #fff;
}

.topnav {
	overflow: hidden;
	background-color: #fff;
	position: fixed;
	top: 0px;
	width: 100%;
	z-index: 9998;
	margin: auto;
	color:black;
	padding:10px 0;
}

.nopad { padding: 0px; }
.pad30 { background-size:30%; padding: 100px; }
.lightGrey { background-color: #eee; }

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

.contactimg { background-size: contain; background-repeat: no-repeat; }

.borderTopBottom { border-top: solid 1px #707070; border-bottom: solid 1px 707070; }

.paddingTopBottom60 { padding: 60px 0px 60px 0px; }
.paddingTopBottom100 { padding: 100px 0px 100px 0px; }
.paddingTopBottom117 { padding-top: 117px; padding-bottom: 117px; }
.paddingTopBottom100 { padding-top: 117px; padding-bottom: 117px; }
.paddingTopBottom30 { padding-top: 30px; padding-bottom: 30px; }
.paddingTop100 { padding: 120px 0px 0px 0px; }

.testimonials {
	text-align: center;
	position: relative;
	width: 80%;
	max-width: 600px;
	margin: auto;
	margin-bottom: 30px;
}
.by { padding-bottom: 0px; padding-top: 30px; }
.testimonial { margin: auto; }
.testimonials h4 { margin-bottom: 35px; }

.topnav ul { list-style: none; }

.imageCover {
	background: url(img/verticallady.jpg) no-repeat center center;
	-webkit-background-size: cover!important;
	-moz-background-size: cover!important;
	-o-background-size: cover!important;
	background-size: cover!important;
}
.imageCover2 {
	background: url(img/verticalladypink.jpg) no-repeat top center;
	-webkit-background-size: cover!important;
	-moz-background-size: cover!important;
	-o-background-size: cover!important;
	background-size: cover!important;
}
.cover {
	-webkit-background-size: cover!important;
	-moz-background-size: cover!important;
	-o-background-size: cover!important;
	background-size: cover!important;
}

footer {
	background: url(img/footerbg.jpg) no-repeat center center;
	-webkit-background-size: cover;
	-moz-background-size: cover;
	-o-background-size: cover;
	background-size: cover;
	background-color: #000;
	padding: 60px 0px 60px 0px;
}
.socialBottom li { float: left; margin-right: 15px; }
.logoBit { position: relative; top: 10px; }

/* Global border styling (legacy tables) */
tbody, td, tfoot, th, thead, tr {
    border-color: inherit;
    border-style: solid;
    border-width: 1px;
    border-color: #ccc;
}

table {width: 100%; margin-top:25px; margin-bottom: 25px; border: solid 1px black;}
table tr:nth-of-type(even) { background: #eeeeee; }

/* NOTE: This forces all table headers to black. Kept for legacy tables.
   Bootstrap tables are neutralised later in the file. */
thead { background-color: black; color:white; font-size: 2rem; }

table th {padding:10px; font-size: 1.5rem;}
table td {padding:3px; font-size: 1rem;}

.sturdy td:nth-child(1) { width: 50%; }

.logoBit img {
	background-color: #121212;
	max-width: 250px;
	width: auto;
	border: solid 1px #707070;
}

.copy { margin-top: 60px; font-size: .8rem; color:#eeeeee; }
#footer{margin-top:100px;}
footer h4 { color: #fff; margin-bottom: 45px; }
.bannertop {margin-top:100px}

footer ul { padding-left: 0px; list-style: none; color: #fff; }
footer a {
	color: #fff;
	text-transform: uppercase;
	text-decoration: none;
	letter-spacing: 8px;
	font-size: .8rem;
	margin-bottom: 10px;
	display: inline-block;
}
footer li {
	color: #fff;
	text-transform: uppercase;
	text-decoration: none;
	letter-spacing: 8px;
	font-size: .8rem;
	margin-bottom: 10px;
}
footer a:hover { text-decoration: underline; color: #fff; }

.textArea { padding: 100px 15% ; }

[data-controls~=prev] {
	width: 71px;
	height: 71px;
	float: left;
	border: none;
	background-image: url(img/left.png);
	position: absolute;
	top: 50%;
	left: -170px;
	z-index: 2;
	transform: translate(-50%, );
}
[data-controls~=next] {
	width: 71px;
	height: 71px;
	float: right;
	border: none;
	position: absolute;
	top: 50%;
	right: -170px;
	z-index: 2;
	background-image: url("img/right.png");
	transform: translate(-50%, );
}

.sticky {
	position: fixed;
	top: 0;
	width: 100%;
	background-color: #fff;
	padding-top: 20px;
	padding-bottom: 20px;
	color: #444;
	-webkit-box-shadow: 2px 2px 10px 0px rgba(0, 0, 0, 0.2);
	-moz-box-shadow: 2px 2px 10px 0px rgba(0, 0, 0, 0.2);
	box-shadow: 2px 2px 10px 0px rgba(0, 0, 0, 0.2);
}

.logoTopwrap {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 100%;
	width: 100%;
}
.logoTopwrap:hover {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 100%;
	width: 100%;
}
.logoTopwrap img {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 100%;
	width: 100%;
}

.logoTopwrap a {padding: 0!important; margin: 0!important;}

.mobileLogo { display: none; padding: 0px; top:15px; left: 0px; }

.topLeft { width: 12%; float: left; text-align: left; }
.leftNav { width: 30%; float: left; text-align: right; }
.logoTop { width: 16%; float: left; text-align: center; padding: 0!important; margin: 0!important; }
.logoTop img { width: 100%!important; max-width: unset; }
.rightNav { width: 30%; float: left; text-align: left; }
.topRight { width: 12%; float: left; text-align: right; }
.topRight a {float: right!important;}

.leftNav ul { float: right; margin: 0px; padding: 0px; }
rightNav ul { float: left; margin: 0px; padding: 0px; }
.leftNav ul li { display: inline; }
.rightNav ul li { display: inline; }

.topnav a {
	float: left;
	display: block;
	color: #000;
	text-align: center;
	padding: 10px 16px;
	text-decoration: none;
	font-size: 20px;
	margin-top:10px;
	margin-bottom:10px;
}
.topnav a.goldBtn {color:white;}
.topnav a.goldBtn i {color:white; padding-left: 15px;}
.sticky a { color: #444; }

.topnav a:hover { background-color: #000; color: white; }
.topnav .logoTopwrap a:hover { background-color: #fff; }
.topnav a.active { color: white; }
topnav .icon { display: none; }

#team img {
	-webkit-filter: grayscale(100%);
	filter: grayscale(100%);
}
.h1, h1 { font-size: 3.4rem; margin-bottom: 30px; }

table h2 {margin-top: 1.5rem;}
.mobileButton { display: none; }

.slider { height: 100vh; min-height: 600px; }
.carousel { height: 100vh; min-height: 600px; }
.carousel-item { height: 100vh; min-height: 600px; }

.leftNav ul{ padding-right: 80px; }
.rightNav ul { padding-left: 80px; }

@media screen and (min-width: 1360px) {
  .showOnsmaller {display: none; width: 100%;}
}
@media screen and (max-width: 1360px) {
	.textOver h1 {font-size: 6rem;}
	.leftNav ul { padding-right: 40px; }
	.rightNav ul { padding-left: 40px; }
	.showOnLarge {display: none}
	.showOnsmaller {display: block!important;}
}
@media screen and (max-width: 1199.98px) {
	.textArea { padding: 100px 10% 100px 10%; }
}
@media screen and (min-width: 991.98px) {
  .carwrap {margin-top:90px;}
}
@media screen and (max-width: 991.98px) {
	.galleryItem { margin-bottom: 15px; }
	.textArea { padding: 0px 10% 100px 10%; }
	.textOver h1 {font-size: 6rem;}
	.mobileLogo { display: block; position: fixed; z-index: 9999; }
	.mobileLogo img { width: 160px; border: solid 5px white; background: white; }
	.imageCover { height: 600px; }
	[data-controls~=prev] { left: -50px; width: 50px; height: 50px; background-size: 50px 50px; }
	[data-controls~=next] { right: -50px; width: 50px; height: 50px; background-size: 50px 50px; }
	.makeBlack { background-color: #fff; padding: 10px; }
	.topnav a:hover { background-color: #C8A74B; color: #fff; }
	.topLeft { padding-left: 0px; padding-right: 0px; }
	.leftNav ul{ padding-left: 0px; padding-right: 0px; }
	.rightNav ul { padding-left: 0px; padding-right: 0px; }
	.topRight { padding-left: 0px; padding-right: 0px; }
	.topRight .btn { border-radius: 0px; }
	.slider { height: 100vh; }
	.carousel { height: 100vh; }
	.carousel-item { height: 100vh; }
	.sticky a { color: #fff; }
	.sticky i { color: #fff; }
	.mobileButton .fa-bars { display: block; }
	.mobileButton .fa-times { display: none; }
	.mobileButton.changeX .fa-bars { display: none; }
	.mobileButton.changeX .fa-times { display: block; }
	.topLeft { width: 100%; float: left; text-align: center; }
	.leftNav { width: 100%; float: left; text-align: left; padding: 0; margin:0; }
	.logoTop { display: none!important; }
	.rightNav { width: 100%; float: left; text-align: left; padding: 0; margin:0; }
	.topRight { top: 0px; left: 0px; width: 100%; }
	.paddingTopBottom100 {padding: 100px 15px 100px 15px}
	.leftNav ul, .rightNav ul { width: 100%; }
	.leftNav ul li, .rightNav ul li { display: block; width: 100%; float: left; }
	.mobileButton { display: block; position: fixed; top: 15px; right: 0px; z-index: 9999; text-decoration: none!important; font-size: 1.45rem; padding: 18px; background-color: white; }
	.mobileButton:hover i {color:black;}
	.topnav { display: none; background-color: #fff; padding-top: 100px; padding-bottom: 100px; }
	.showNav { display: block; height: 100vh; z-index: 9998; }
	.topLeft {display:none;}
	.topnav a { width: 100%; text-align: left; padding: 15px; margin: 0; }
	.topLeft a { width: auto; display: inline-block; }
	.topnav a.transparentBtn { box-shadow: none!important; border: none!important; }
}
@media screen and (max-width: 767.98px) {
	[data-controls~=prev] { left: -30px; width: 30px; height: 30px; background-size: 30px 30px; }
  	.textOver h1 {font-size: 4rem; }
  	.smallH1 {font-size:1rem; line-height: 1.2rem!important;}
	.bannerText {font-size:1.4rem; line-height: 1.8rem!important;}
  	.textOver {width:90%;}
	[data-controls~=next] { right: -30px; width: 30px; height: 30px; background-size: 30px 30px; }
}

/* ====== Head Spa + Bootstrap Table Fixes ====== */

/* Match site font for tables used inside content areas */
.textArea .table,
.textArea .table th,
.textArea .table td {
  font-family: 'Roboto', sans-serif;
  font-size: 1rem;
  color: #444;
}
.textArea .table thead th {
  font-weight: 600;
  font-size: 1.25rem;
  letter-spacing: 0.5px;
}

/* Let Bootstrap manage header backgrounds for .table components */
.table thead { 
  background: inherit; 
  color: inherit; 
  font-size: inherit; 
}
.table thead.table-light th {
  background-color: #f8f9fa; /* Bootstrap light header */
}

/* Keep Bootstrap table borders tidy (avoid double borders from global rule) */
.table,
.table td,
.table th {
  border-width: 1px;
  border-style: solid;
  border-color: #ccc; /* or #dee2e6 if you prefer Bootstrap default */
}

/* Enso symbol beside paragraph */
.enso-figure {
  max-width: 250px;
  margin-top: 10px;
}
@media (max-width: 575.98px) {
  .enso-figure {
    max-width: 180px;
    margin: 15px auto 0;   /* centers on phones */
    display: block;
  }
}

/* ------------------------------
   Booksy Booking Button Styles
   ------------------------------ */
.book-now-btn {
  background-color: #b79a75; /* main brand tone */
  color: #ffffff;
  padding: 12px 28px;
  border-radius: 6px;
  font-family: 'Raleway', sans-serif;
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: 0.5px;
  text-decoration: none;
  display: inline-block;
  transition: all 0.3s ease;
  text-align: center;
}

.book-now-btn:hover {
  background-color: #a78b64; /* slightly darker on hover */
  color: #ffffff;
  transform: translateY(-2px);
  box-shadow: 0 3px 8px rgba(0, 0, 0, 0.15);
}

.book-now-btn:active {
  transform: translateY(0);
  box-shadow: none;
}

/* Optional mobile adjustment */
@media (max-width: 768px) {
  .book-now-btn {
    display: block;
    width: 100%;
    text-align: center;
    padding: 14px;
  }
}
/* Keep the header row on one line */
.topnav .container-fluid .row {
  display: flex;                 /* ensure flex (Bootstrap .row already is, but be explicit) */
  align-items: center;
  justify-content: space-between;
  flex-wrap: nowrap;             /* <— key: no wrapping */
}

/* Let side sections grow/shrink; keep logo at its natural width */
.leftNav, .rightNav { flex: 1 1 0; min-width: 0; }
.logoTop { flex: 0 0 auto; }

/* Make menus flex so items don’t wrap */
.leftNav ul,
.rightNav ul {
  display: flex;
  align-items: center;
  gap: 18px;                     /* space between buttons */
  margin: 0;
  padding: 0;
  list-style: none;
  flex-wrap: nowrap;             /* <— prevent “CONTACT” wrapping */
}

.leftNav li, .rightNav li { white-space: nowrap; }

/* optional: reduce horizontal padding if still tight on some screens */
.leftNav ul a, .rightNav ul a { padding: 6px 8px; }

/* ---------- Desktop (≥992px) ---------- */
@media (min-width: 992px) {
  .topnav .container-fluid .row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: nowrap;                 /* keep one line on desktop only */
  }

  .leftNav, .rightNav { flex: 1 1 0; min-width: 0; }
  .logoTop { flex: 0 0 auto; }

  .leftNav ul,
  .rightNav ul {
    display: flex;
    align-items: center;
    gap: 18px;                         /* nice spacing */
    margin: 0;
    padding: 0;
    list-style: none;
    flex-wrap: nowrap;
  }

  .leftNav ul { justify-content: flex-start; }
  .rightNav ul { justify-content: flex-end; }
  .leftNav li, .rightNav li { white-space: nowrap; }
}

/* ---------- Mobile (<992px) ---------- */
@media (max-width: 991.98px) {
  /* Allow the header row to wrap naturally */
  .topnav .container-fluid .row { display: block; }

  /* Hide the nav lists by default; show when menu is open */
  .leftNav, .rightNav { display: none; }

  .topnav.is-open .leftNav,
  .topnav.is-open .rightNav {
    display: block;
  }

  /* Mobile dropdown list style */
  .leftNav ul,
  .rightNav ul {
    display: block;
    margin: 0;
    padding: 0;
    list-style: none;
  }

  .leftNav li,
  .rightNav li {
    border-top: 1px solid rgba(0,0,0,.08);
  }

  .leftNav a,
  .rightNav a {
    display: block;
    padding: 12px 16px;                /* comfortable tap targets */
  }

  /* Keep logo centered on mobile */
  .logoTop { text-align: center; margin: 10px 0; }
  .logoTopwrap img { max-height: 56px; height: auto; }
}

/* ----- DESKTOP HEADER ALIGNMENT FIX ----- */
@media (min-width: 992px) {
  .topnav .container-fluid .row {
    display: flex;
    align-items: center;
    justify-content: space-between;  /* evenly space left–logo–right */
    flex-wrap: nowrap;
  }

  /* left and right navs grow equally */
  .leftNav, .rightNav {
    flex: 1 1 0;
    min-width: 0;
  }

  /* logo stays in the middle */
  .logoTop {
    flex: 0 0 auto;
    text-align: center;
  }

  /* LEFT menu aligned left */
  .leftNav ul {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 18px;
    list-style: none;
    margin: 0;
    padding: 0;
  }

  /* RIGHT menu aligned right */
  .rightNav ul {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 18px;
    list-style: none;
    margin: 0;
    padding: 0;
  }

  .leftNav li, .rightNav li { white-space: nowrap; }

  /* social icons stay left */
  .topLeft {
    position: absolute;
    left: 20px;
    top: 12px;
  }

  .topLeft a {
    margin-right: 10px;
    color: inherit;
    font-size: 1.1rem;
  }
}

/* --- Quick fixes & typo corrections --- */
.borderTopBottom { border-top: solid 1px #707070; border-bottom: solid 1px #707070; }
.topnav .icon { display: none; }           /* was missing the dot */
.rightNav ul { float: left; margin: 0; padding: 0; } /* in case that earlier selector lacked the dot */

/* --- Desktop header reset (≥992px) --- */
@media (min-width: 992px) {
  /* use flex-only layout: kill legacy floats/widths */
  .leftNav, .logoTop, .rightNav {
    float: none !important;
    width: auto !important;
    text-align: initial;
  }

  /* keep the row on one line and spread sections */
  .topnav .container-fluid .row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: nowrap;
  }

  /* flex growth for side navs; logo sized naturally */
  .leftNav, .rightNav { flex: 1 1 0; min-width: 0; }
  .logoTop { flex: 0 0 auto; text-align: center; }

  /* menus as flex, no extra padding that bunches inward */
  .leftNav ul, .rightNav ul {
    display: flex;
    align-items: center;
    gap: 22px;             /* tweak spacing here */
    margin: 0;
    padding: 0;            /* overrides the earlier 80px paddings */
    list-style: none;
    flex-wrap: nowrap;
  }
  .leftNav ul { justify-content: flex-start; }
  .rightNav ul { justify-content: flex-end; }
  .leftNav li, .rightNav li { white-space: nowrap; }

  /* keep the logo from hogging width */
  .logoTopwrap img {
    max-width: 240px;      /* adjust to taste */
    width: 100%;
    height: auto;
  }
}

/* --- Mobile (<992px): keep your dropdown behaviour --- */
@media (max-width: 991.98px) {
  /* your mobile rules can stay; these ensure the burger works */
  .topnav .container-fluid .row { display: block; }
  .leftNav, .rightNav { display: none; }
  .topnav.is-open .leftNav,
  .topnav.is-open .rightNav { display: block; }
}
/* ensures image panels like on Beauty page always show */
.imageCover {
  background-size: cover !important;
  background-position: center center;
  background-repeat: no-repeat;
  min-height: 600px; /* same height as other pages */
}

/* make .imageCover fill the column height on desktop when used in a stretch row */
@media (min-width: 992px) {
  .row.align-items-stretch > [class*="col-"] > .imageCover { height: 100%; }
}

/* baseline for all image panels (you likely already have most of this) */
.imageCover {
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  min-height: 600px; /* fallback if the text column is shorter */
}

@media (max-width: 991.98px) {
  /* If showNav is used (legacy), also reveal the lists */
  .topnav.showNav .leftNav,
  .topnav.showNav .rightNav { display: block; }
}


