/*
 * BSG2 Layout CSS
 * Provides header/nav/footer/grid styles that were previously inherited
 * from the businessfinder2 parent theme's compiled LESS stylesheet.
 *
 * NOTE: Rules scoped to #page use ID specificity to override TT25's
 * inline global-styles-inline-css which is injected after our stylesheet.
 */

/* ── Base resets ─────────────────────────────────────────────────────────── */

*, *::before, *::after { box-sizing: border-box; }

body {
	margin: 0;
	padding: 0;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	font-size: 14px;
	color: #444;
	background: #f5f5f5;
}

/* Scoped to #page so we beat TT25 inline global styles (same selector without ID = lower specificity) */
#page a             { color: #2877d1; text-decoration: none; }
#page a:hover       { color: #1a5ba8; text-decoration: underline; }

#page h1, #page h2, #page h3,
#page h4, #page h5, #page h6 { color: #333; margin: 0 0 15px; line-height: 1.3; }

p { margin: 0 0 10px; }

ul, ol { margin: 0; padding: 0; list-style: none; }

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


/* ── Page wrapper ────────────────────────────────────────────────────────── */

#page.page-container {
	background: #fff;
}

/* Suppress any TT25 block template parts that may render outside our PHP footer */
.wp-site-blocks { display: none !important; }

/* ── Grid container ──────────────────────────────────────────────────────── */

.grid-main {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 20px;
	box-sizing: border-box;
}

.grid-main::after {
	content: "";
	display: table;
	clear: both;
}

/* ── Top bar ─────────────────────────────────────────────────────────────── */

.top-bar {
	background: #f7f7f7;
	padding: 6px 0;
	border-bottom: 1px solid #e0e0e0;
	font-size: 13px;
	color: #777;
}

.top-bar a          { color: #666; }
.top-bar a:hover    { color: #333; }
.top-bar p          { margin: 0; line-height: 1.6; }

.top-bar-tools {
	float: right;
}

.top-bar-tools::after { content: ""; display: table; clear: both; }

.header-salon-count {
	color: #777;
	font-size: 13px;
}

/* ── Site header ─────────────────────────────────────────────────────────── */

#masthead.site-header {
	background: #fff;
	position: relative;
	border-bottom: 1px solid #e0e0e0;
}

.header-container {
	position: relative;
	width: 100%;
	font-size: 0; /* eliminates inline-block whitespace gap between logo and nav */
}

/* ── Site logo ───────────────────────────────────────────────────────────── */

.header-container .site-logo {
	/* display/width/background/text-align handled by custom.css (.site-logo rule) */
	vertical-align: top;
}

.header-container .site-logo a,
.header-container .site-logo a:hover {
	display: inline-block;
	text-decoration: none;
	color: #333;
}

.header-container .site-logo img {
	/* display/width/float handled by custom.css (.site-logo img rule) */
	max-width: 100%;
	height: auto;
}

.header-container .site-title {
	font-size: 22px;
	font-weight: 700;
	line-height: 1.2;
	color: #333;
}

/* ── Navigation ──────────────────────────────────────────────────────────── */

.header-container .menu-container {
	/* display/width handled by custom.css (.header-container .menu-container rule) */
	vertical-align: bottom; /* aligns nav to the bottom of the header logo area */
	font-size: 14px; /* reset from parent .header-container font-size:0 */
}

.main-nav-wrap {
	text-align: right;
}

.main-nav-wrap::after { content: ""; display: table; clear: both; }

.main-nav.menu-hidden { display: block !important; visibility: visible !important; }

/* Use #masthead scope to beat TT25 inline styles on nav/ul/li */
#masthead .nav-menu,
#masthead .nav-menu > li {
	display: inline-block !important;
	margin: 0;
	padding: 0;
	list-style: none;
}

#masthead .nav-menu > li > a {
	display: inline-block !important;
	padding: 10px 15px;
	color: #666;
	font-size: 14px;
	font-weight: 400;
	text-decoration: none;
	background: rgba(0, 0, 0, 0.03);
	transition: background 0.2s, color 0.2s;
	margin-bottom: 5px;
}

#masthead .nav-menu > li > a:hover {
	color: #333;
	background: rgba(0, 0, 0, 0.07);
	text-decoration: none;
}

#masthead .nav-menu > li.current-menu-item > a,
#masthead .nav-menu > li.current-menu-ancestor > a {
	background: #444;
	color: #fff;
	text-decoration: none;
}

/* Dropdown sub-menus */
#masthead .nav-menu li { position: relative; }

#masthead .nav-menu .sub-menu {
	display: none;
	position: absolute;
	top: 100%;
	left: 0;
	background: #fff;
	min-width: 180px;
	box-shadow: 0 4px 10px rgba(0,0,0,0.15);
	z-index: 999;
	list-style: none;
	padding: 5px 0;
	margin: 0;
}

#masthead .nav-menu li:hover > .sub-menu { display: block; }

#masthead .nav-menu .sub-menu li { display: block !important; }

#masthead .nav-menu .sub-menu li a {
	display: block;
	padding: 8px 15px;
	color: #333;
	font-size: 13px;
	white-space: nowrap;
}

#masthead .nav-menu .sub-menu li a:hover { background: #f5f5f5; color: #fe5c04; }

/* Mobile menu toggle — hidden on desktop */
.main-nav-wrap .menu-toggle { display: none; }

/* ── Menu tools (user panel) ─────────────────────────────────────────────── */

.menu-tools {
	display: inline-block;
	vertical-align: top;
	margin-left: 15px;
}

/* User panel dropdown (was in businessfinder2 compiled LESS) */
.user-panel {
	position: relative;
	display: inline-block;
	cursor: pointer;
	vertical-align: middle;
}

.user-panel .user-info { display: inline-block; }

/* Hide actions by default — common.js calls .show() on click */
.user-panel .user-actions {
	display: none;
	position: absolute;
	right: 0;
	top: 100%;
	background: #fff;
	border: 1px solid #e0e0e0;
	box-shadow: 0 4px 10px rgba(0,0,0,0.15);
	min-width: 180px;
	z-index: 9000;
	padding: 5px 0;
	white-space: nowrap;
}

.user-panel.opened .user-actions { display: block; }

.user-panel .user-actions a {
	display: block;
	padding: 8px 15px;
	color: #333;
	font-size: 13px;
	text-decoration: none;
}

.user-panel .user-actions a:hover { background: #f5f5f5; color: #fe5c04; }

.user-panel .user-actions a.button-account {
	background: #82c436;
	color: #fff;
}
.user-panel .user-actions a.button-account:hover { background: #75af30; }

.user-panel .user-actions .user-items span {
	display: inline-block;
	margin-left: 8px;
	background: #fe5c04;
	color: #fff;
	border-radius: 10px;
	padding: 1px 7px;
	font-size: 11px;
	font-weight: 700;
}

/* Login button (logged-out state) */
.menu-tools a.button-login {
	display: inline-block;
	padding: 7px 14px;
	background: #fe5c04;
	color: #fff;
	border-radius: 3px;
	font-size: 13px;
	font-weight: 600;
	text-decoration: none;
}
.menu-tools a.button-login:hover { background: #d94e03; color: #fff; }

/* ── Sticky menu ─────────────────────────────────────────────────────────── */

.sticky-menu.menu-container {
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	width: 100%;
	z-index: 9999;
	background: #fff;
	box-shadow: 0 2px 10px rgba(0,0,0,0.1);
	transform: translateY(-100%);
	transition: transform 0.3s;
}

.header-scrolled .sticky-menu.menu-container {
	display: block;
	transform: translateY(0);
}

.admin-bar.header-scrolled .sticky-menu.menu-container { top: 32px; }

.sticky-menu .grid-main { display: flex; align-items: center; }

.sticky-menu .site-logo {
	flex-shrink: 0;
	padding: 8px 0;
	margin-right: 20px;
	width: auto; /* override custom.css 175px — sticky logo sizes to image only */
}

.sticky-menu .site-logo img { max-height: 30px; width: auto; }

.sticky-menu .main-nav { flex: 1; text-align: right; }

/* ── Single salon: image + map header ───────────────────────────────────── */

.single-salon .header-element-wrap {
	height: 400px;
	overflow: hidden;
	font-size: 0; /* kill inline-block gap between image and map */
}

.single-salon .header-element-wrap > img,
.single-salon .header-element-wrap > .map {
	width: 50%;
	display: inline-block;
	position: relative;
	height: 400px;
	vertical-align: top;
}

.single-salon .header-element-wrap > img {
	height: 100%;
	object-fit: cover;
}

.single-salon .header-element-wrap > .fullwidth-map {
	width: 100%;
}

/* Thumbnail only, no map */
.single-salon .header-layout:not(.element-map-enabled) .header-element-wrap > img {
	width: 100%;
}

/* ── Single salon: two-column content layout ─────────────────────────────── */

.salon-layout {
	display: flex;
	gap: 0;
	align-items: flex-start;
}

.salon-main {
	flex: 1 1 0;
	min-width: 0;
}

.salon-info-panel {
	width: 220px;
	flex-shrink: 0;
	margin-left: 20px;
}

.single-salon-inside {
	margin-bottom: 15px;
	padding-bottom: 5px;
}

/* ── Main content + WP sidebar layout ───────────────────────────────────── */

.elements-sidebar-wrap {
	display: flex;
	align-items: flex-start;
	gap: 30px;
	padding-top: 40px;
}

.elements-area {
	flex: 1 1 0;
	min-width: 0;
}

.elements-sidebar-wrap > aside.sidebar {
	width: 260px;
	flex-shrink: 0;
}

/* ── Page title bar (salon-header.php) ───────────────────────────────────── */

.page-title {
	background: #f2f2f2;
	border-bottom: 1px solid #e0e0e0;
}

/* .grid-table / .grid-row are non-semantic wrappers from the original theme */
.page-title .grid-table {
	width: 100%;
	position: relative;
}

.page-title .grid-row {
	display: flex;
	align-items: stretch;
	justify-content: space-between;
}

.page-title .entry-header {
	flex: 1 1 0;
	min-width: 0;
	padding-right: 15px;
}

.page-title .entry-title-wrap {
	padding: 20px 0;
	display: flex;
	align-items: flex-start;
	gap: 15px;
}

/* Company logo shown inline with h1 */
.page-title .logo-image {
	flex-shrink: 0;
	vertical-align: top;
}

.page-title .logo-image img {
	max-width: 130px;
	max-height: 100px;
	height: auto;
	display: block;
}

.page-title h1 {
	margin: 0;
	font-size: 24px;
	line-height: 1.3;
	color: #333;
}

/* On single-salon pages h1 is display:inline-block so the logo sits beside it */
.single-salon .page-title h1,
.single-ait-item .page-title h1 {
	display: inline-block;
}

/* Location subtitle (e.g. "Liverpool, Merseyside") rendered as block inside h1 */
.single-salon .page-title h1 span.location,
.single-ait-item .page-title h1 span.location {
	display: block;
	font-size: 16px;
	font-weight: 300;
	color: #666;
}

/* Social sharing panel — floats right of the entry-header */
.page-title .page-title-social {
	flex-shrink: 0;
	width: 110px;
	padding: 20px 0 0 15px;
	text-align: center;
}

.page-title .share-icons {
	margin: 0 0 5px;
	padding: 0;
	list-style: none;
}

.page-title .share-icons li {
	display: inline-block;
	margin: 0 2px;
	border-radius: 50px;
	background: rgba(0,0,0,0.2);
	transition: background 0.3s;
}

.page-title .share-icons li a {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 34px;
	height: 34px;
	text-decoration: none;
}

.page-title .share-icons li a i {
	font-size: 15px;
	line-height: 1;
	color: #fff;
}

.page-title .share-icons .share-facebook:hover  { background: #3b5998; }
.page-title .share-icons .share-twitter:hover    { background: #00aced; }
.page-title .share-icons .share-pinterest:hover  { background: #e60023; }

.page-title .share-text {
	font-size: 12px;
	color: #666;
	margin-top: 4px;
}

.page-title .share-text .title {
	font-weight: 700;
}

/* Breadcrumb bar — full-width bar inside .page-title, outside .grid-main */
.page-title .breadcrumb {
	background: #b8bec7;
	padding: 5px 0;
}

.page-title .breadcrumb .breadcrumbs {
	font-size: 12px;
	line-height: 1.8;
}

.page-title .breadcrumb a,
.page-title .breadcrumb .breadcrumbs-before,
.page-title .breadcrumb .breadcrumb-end {
	display: inline;
	color: #fff;
	font-weight: bold;
}

.page-title .breadcrumb .breadcrumb-sep {
	color: rgba(255,255,255,0.6);
	padding: 0 3px;
	font-weight: bold;
}

.page-title .breadcrumb a:hover {
	color: #fe5c04;
	text-decoration: none;
}

/* ── Single salon: info panel (replaces #secondary-right) ────────────────── */

.salon-info-panel hr {
	margin: 20px 0;
	padding: 0;
	border: none;
	background: #b8bfc7;
	height: 1px;
}

.salon-info-panel > div {
	background-color: #fff;
}

.salon-info-panel .review-average {
	font-size: 60px;
	display: inline-block;
	vertical-align: top;
	margin-right: 15px;
}

.salon-info-panel .review-summary {
	display: inline-block;
	vertical-align: top;
}

.salon-info-panel .review-stars {
	width: 100px;
	background-color: #eee;
	line-height: 0;
	height: 20px;
	display: block;
	position: relative;
	overflow: hidden;
}

.salon-info-panel .review-stars img {
	width: 100px;
	position: absolute;
	z-index: 3;
}

.salon-info-panel .review-gold {
	width: 100px;
	background-color: #ff9c00;
	height: 20px;
	display: block;
	position: absolute;
	z-index: 2;
	top: 0;
}

.salon-info-panel .review-count {
	width: 100px;
	display: block;
}

.salon-info-panel .salon-phone {
	font-size: 25px;
	font-weight: 700;
	margin: 10px;
}

.salon-info-panel .salon-address,
.salon-info-panel .salon-email,
.salon-info-panel .salon-phone,
.salon-info-panel .web {
	display: block;
	margin: 10px;
}

.salon-info-panel table.opening {
	width: 100%;
}

.salon-info-panel table.opening th {
	background: #b8bfc7;
	color: #fff;
	text-transform: capitalize;
}

.salon-info-panel table.opening th:nth-child(1),
.salon-info-panel table.opening td:nth-child(1) {
	text-align: left;
	padding-left: 5px;
	text-transform: capitalize;
}

.salon-info-panel table.opening th:nth-child(2),
.salon-info-panel table.opening td:nth-child(2) {
	text-align: center;
}

.salon-info-panel .book-container {
	text-align: center;
}

.salon-info-panel .book-container .button.bookonline {
	display: block;
	background: #b8bfc7;
	font-weight: 700;
	color: #fff;
	padding: 10px;
	margin: 10px 0;
	line-height: initial;
	border-radius: 10px;
	text-decoration: none;
}

.salon-info-panel .book-container .button.bookonline:hover {
	background-color: #2877d1;
	color: #fff;
}

/* ── Single salon: tab navigation ───────────────────────────────────────── */

.single-salon .headings ul {
	display: inline-block;
}

.single-salon .headings ul li {
	display: inline-block;
	background: transparent;
	color: #000;
	border: 1px solid #d8d8d8;
	border-radius: 10px 10px 0 0;
	padding: 10px;
	cursor: pointer;
}

.single-salon .headings ul li.active {
	font-weight: 700;
	border-bottom-color: #fff;
}

/* Hidden by default; shown via inline <style> injected by has_reviews / late_deals */
.single-salon .headings ul li.tab-reviews,
.single-salon .headings ul li.tab-reviews-form,
.single-salon .headings ul li.tab-deals {
	display: none;
}

/* Tab content panels */
.single-salon .content {
	padding: 10px;
	border: 1px solid #d8d8d8;
}

.single-salon .content .container > div.so-panel > div {
	display: none;
}

.single-salon .content .container > div.so-panel > div.tab-about {
	display: block;
}

/* ── Single salon: main content sections (replaces .single-ait-item) ─────── */

.single-salon .about-container h2,
.single-salon .suppliers-container h2,
.single-salon .services-container h2 {
	margin-bottom: 1px;
	padding: 15px 0;
	position: relative;
	font-size: 16px;
	line-height: 20px;
}

.single-salon .suppliers-container span.supplier-thumbnail {
	display: inline-block;
	width: calc(16.66% - 10px);
	height: auto;
	margin: 0;
	padding: 5px;
	text-align: center;
}

.single-salon .suppliers-container span.supplier-thumbnail img {
	vertical-align: middle;
}

.single-salon .services-container li.service-item {
	display: inline-block;
	width: 33%;
	min-width: 230px;
	list-style: none;
}

/* ── Main content area ───────────────────────────────────────────────────── */

.site-content {
	padding: 20px 0;
}

.entry-content {
	max-width: 100%;
}

/* Override TT25 entry-content link styles inside search results */
.entry-content .bsg-search-results a,
.entry-content .bsg-results-container a,
.bsg-search-results a,
.bsg-results-container a {
	color: inherit;
	text-decoration: none;
}

/* More info button padding */
.result-wrapper .button {
	padding: 8px 14px;
}

/* Fix h2 color inside search result cards (inherits orange from .excerpt) */
.result-wrapper .excerpt h2,
.result-wrapper h2 {
	color: #333;
}

/* ── Footer ──────────────────────────────────────────────────────────────── */

#footer.footer {
	background: #f5f5f5;
	color: #444;
	font-size: 13px;
	margin-top: 30px;
	border-top: 1px solid #e0e0e0;
}

#footer a          { color: #2877d1; }
#footer a:hover    { color: #1a5ba8; }

.footer-widgets {
	padding: 30px 0;
	border-bottom: 1px solid #e0e0e0;
}

.footer-widgets h3.widget-title,
.footer-widgets .widgettitle {
	color: #333;
	font-size: 16px;
	margin-bottom: 15px;
	border-bottom: 2px solid #fe5c04;
	padding-bottom: 8px;
}

.site-footer {
	padding: 15px 0;
}

.site-footer-wrap {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 10px;
}

.site-footer-wrap > div:last-child { margin-left: auto; }
.footer-menu { display: inline-block; }
.footer-menu li { display: inline-block; margin: 0 8px; }
.footer-menu li a { color: #666; font-size: 12px; }
.footer-menu li a:hover { color: #2877d1; }

.footer-text { color: #888; font-size: 12px; text-align: left; }


/* ── Login / register popup ──────────────────────────────────────────────── */

#login-popup,
#register-form-footer {
	display: none;
	position: fixed;
	inset: 0;
	background: rgba(255,255,255,0.85);
	z-index: 999999;
}


/* ── Responsive ──────────────────────────────────────────────────────────── */

@media (max-width: 968px) {
	.header-container {
		display: block !important;
	}
	.header-container .site-logo,
	.header-container .menu-container {
		display: block !important;
		width: 100%;
	}
	.header-container .site-logo {
		text-align: center;
		padding: 15px 0 5px;
	}
	.main-nav-wrap { text-align: center; }
	.footer-widgets .widget-area { width: 50%; }
}

@media (max-width: 640px) {
	#masthead .nav-menu > li > a { padding: 8px 10px; font-size: 13px; }
	.top-bar-tools { float: none; text-align: center; }
	.footer-widgets .widget-area { width: 100%; padding-right: 0; }
	.site-footer-wrap { flex-direction: column; text-align: center; }
}

@media (max-width: 480px) {
	.header-container .site-logo { width: 100%; text-align: center; }
}
