/*
 Theme Name:   BBC Cleaning
 Theme URI:    https://bbc.diginess.cloud
 Description:  BBC Cleaning child theme based on Hello Elementor.
 Author:       BBC Cleaning
 Author URI:   https://bbc.diginess.cloud
 Template:     hello-elementor
 Version:      1.1.0
 Text Domain:  bbc-cleaning
*/

/* ══════════════════════════════════════════════
   DESIGN TOKENS
   ══════════════════════════════════════════════ */

:root {
	/* Colour palette */
	--bbc-primary:       #1a3a6b;
	--bbc-primary-light: #2a5091;
	--bbc-primary-dark:  #0f2647;
	--bbc-accent:        #c8a94e;          /* warm gold for premium accents */
	--bbc-accent-light:  #dfc06a;
	--bbc-white:         #ffffff;
	--bbc-off-white:     #f7f8fa;
	--bbc-grey-100:      #eef0f4;
	--bbc-grey-200:      #d5d9e0;
	--bbc-grey-500:      #6b7280;
	--bbc-grey-800:      #1f2937;
	--bbc-text:          #2d3340;
	--bbc-text-light:    #5a6070;

	/* Typography */
	--bbc-font-body:    'DM Sans', sans-serif;
	--bbc-font-heading: 'Playfair Display', serif;

	/* Spacing scale */
	--bbc-space-xs:  4px;
	--bbc-space-sm:  8px;
	--bbc-space-md:  16px;
	--bbc-space-lg:  32px;
	--bbc-space-xl:  48px;
	--bbc-space-2xl: 80px;

	/* Shape */
	--bbc-radius:    9px;
	--bbc-radius-lg: 16px;

	/* Shadows — layered for depth */
	--bbc-shadow-sm:  0 1px 3px rgba(26,58,107,.08);
	--bbc-shadow-md:  0 4px 12px rgba(26,58,107,.10);
	--bbc-shadow-lg:  0 8px 30px rgba(26,58,107,.12);
	--bbc-shadow-xl:  0 16px 48px rgba(26,58,107,.14);

	/* Transitions */
	--bbc-ease: cubic-bezier(.25,.46,.45,.94);
}

/* ══════════════════════════════════════════════
   GLOBAL RESET & BASE
   ══════════════════════════════════════════════ */

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

body {
	font-family: var(--bbc-font-body);
	color: var(--bbc-text);
	line-height: 1.7;
	font-weight: 400;
	font-size: 16px;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	overflow-x: hidden;
}

.elementor-widget-text-editor,
.elementor-widget-theme-post-content {
	font-family: var(--bbc-font-body);
	color: var(--bbc-text);
	line-height: 1.7;
}

::selection {
	background: var(--bbc-primary);
	color: var(--bbc-white);
}

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

/* ══════════════════════════════════════════════
   TYPOGRAPHY
   ══════════════════════════════════════════════ */

h1, h2, h3, h4, h5, h6,
.elementor-heading-title {
	font-family: var(--bbc-font-heading);
	color: var(--bbc-primary);
	font-weight: 700;
	line-height: 1.2;
	letter-spacing: -0.02em;
}

h1, .elementor-widget-heading h1.elementor-heading-title { font-size: clamp(2.2rem, 4vw, 3.5rem); }
h2, .elementor-widget-heading h2.elementor-heading-title { font-size: clamp(1.8rem, 3vw, 2.8rem); }
h3, .elementor-widget-heading h3.elementor-heading-title { font-size: clamp(1.4rem, 2.5vw, 2rem); }

p {
	margin-bottom: 1.25em;
	color: var(--bbc-text-light);
}

/* Gold accent underline for section headings */
.elementor-widget-heading .elementor-heading-title {
	position: relative;
	display: inline-block;
}

/* ══════════════════════════════════════════════
   LINKS
   ══════════════════════════════════════════════ */

a {
	color: var(--bbc-primary);
	text-decoration: none;
	transition: color 0.3s var(--bbc-ease);
}

a:hover,
a:focus {
	color: var(--bbc-accent);
}

/* ══════════════════════════════════════════════
   BUTTONS — Premium feel
   ══════════════════════════════════════════════ */

button,
input[type="button"],
input[type="submit"],
.elementor-button,
.elementor-button-wrapper .elementor-button {
	background-color: var(--bbc-primary);
	color: var(--bbc-white);
	border: 2px solid transparent;
	border-radius: var(--bbc-radius);
	font-family: var(--bbc-font-body);
	font-weight: 700;
	font-size: 15px;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	padding: 14px 36px;
	cursor: pointer;
	box-shadow: var(--bbc-shadow-sm);
	transition:
		background-color 0.35s var(--bbc-ease),
		box-shadow 0.35s var(--bbc-ease),
		transform 0.25s var(--bbc-ease),
		border-color 0.35s var(--bbc-ease);
}

button:hover,
input[type="button"]:hover,
input[type="submit"]:hover,
.elementor-button:hover,
.elementor-button-wrapper .elementor-button:hover {
	background-color: var(--bbc-primary-dark);
	color: var(--bbc-white);
	box-shadow: var(--bbc-shadow-md);
	transform: translateY(-2px);
}

button:active,
.elementor-button:active {
	transform: translateY(0);
	box-shadow: var(--bbc-shadow-sm);
}

/* Ghost / outline button */
.elementor-button.elementor-button--outline,
.elementor-button[style*="background-color: transparent"] {
	background-color: transparent;
	color: var(--bbc-primary);
	border: 2px solid var(--bbc-primary);
	border-radius: var(--bbc-radius);
}

.elementor-button.elementor-button--outline:hover {
	background-color: var(--bbc-primary);
	color: var(--bbc-white);
	border-color: var(--bbc-primary);
}

/* Gold accent button */
.bbc-btn-gold,
.elementor-button.bbc-btn-gold {
	background-color: var(--bbc-accent);
	color: var(--bbc-primary-dark);
}

.bbc-btn-gold:hover,
.elementor-button.bbc-btn-gold:hover {
	background-color: var(--bbc-accent-light);
	color: var(--bbc-primary-dark);
}

/* ══════════════════════════════════════════════
   HEADER & NAVIGATION — Corporate
   ══════════════════════════════════════════════ */

.site-header,
.elementor-location-header {
	background: var(--bbc-white);
	box-shadow: 0 1px 0 var(--bbc-grey-200);
	transition: box-shadow 0.3s var(--bbc-ease), background 0.3s var(--bbc-ease);
}

/* Force header columns on one row */
.elementor-location-header .elementor-container,
.elementor-location-header .elementor-row {
	display: flex !important;
	flex-wrap: nowrap !important;
	align-items: center !important;
}

.elementor-location-header .elementor-column {
	flex-shrink: 0 !important;
}

.elementor-location-header .e-con {
	flex-wrap: nowrap !important;
	align-items: center !important;
}

/* Sticky header enhancement */
.elementor-sticky--effects {
	box-shadow: var(--bbc-shadow-md) !important;
	background: rgba(255,255,255,.98) !important;
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
}

/* Nav links */
.elementor-nav-menu a,
.elementor-nav-menu .elementor-item {
	font-family: var(--bbc-font-body);
	font-weight: 500;
	font-size: 15px;
	color: var(--bbc-grey-800);
	letter-spacing: 0.02em;
	text-transform: uppercase;
	padding: 8px 0;
	position: relative;
	transition: color 0.3s var(--bbc-ease);
}

.elementor-nav-menu a:hover,
.elementor-nav-menu .elementor-item:hover,
.elementor-nav-menu .elementor-item.elementor-item-active {
	color: var(--bbc-primary);
}

/* Underline animation on nav items */
.elementor-nav-menu .elementor-item::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 0;
	height: 2px;
	background: var(--bbc-accent);
	transition: width 0.35s var(--bbc-ease);
}

.elementor-nav-menu .elementor-item:hover::after,
.elementor-nav-menu .elementor-item.elementor-item-active::after {
	width: 100%;
}

/* Dropdown menus */
.elementor-nav-menu--dropdown {
	background: var(--bbc-white);
	border: none;
	border-radius: var(--bbc-radius);
	box-shadow: var(--bbc-shadow-lg);
	padding: var(--bbc-space-sm) 0;
}

.elementor-nav-menu--dropdown a {
	text-transform: none;
	padding: 10px 24px;
}

/* ══════════════════════════════════════════════
   HERO SECTIONS
   ══════════════════════════════════════════════ */

.bbc-hero,
.elementor-section.bbc-hero {
	position: relative;
	overflow: hidden;
}

.bbc-hero .elementor-background-overlay {
	background: linear-gradient(
		135deg,
		rgba(15,38,71,.85) 0%,
		rgba(26,58,107,.7) 100%
	);
}

.bbc-hero h1,
.bbc-hero .elementor-heading-title {
	color: var(--bbc-white);
	text-shadow: 0 2px 20px rgba(0,0,0,.15);
}

.bbc-hero p {
	color: rgba(255,255,255,.85);
	font-size: 1.15rem;
}

/* ══════════════════════════════════════════════
   CARDS & SERVICE BOXES — Elevated
   ══════════════════════════════════════════════ */

/* Service grid: equal height columns */
.elementor-section .elementor-row,
.elementor-section .e-con {
	display: flex;
	flex-wrap: wrap;
}

.elementor-section .elementor-column {
	display: flex;
	flex-direction: column;
}

.elementor-section .elementor-widget-wrap {
	flex: 1;
	display: flex;
	flex-direction: column;
}

.elementor-widget-icon-box,
.elementor-widget-image-box {
	background: var(--bbc-white);
	border-radius: var(--bbc-radius-lg);
	padding: var(--bbc-space-lg);
	box-shadow: var(--bbc-shadow-sm);
	border: 1px solid var(--bbc-grey-100);
	text-align: center;
	flex: 1;
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	align-items: center;
	transition:
		box-shadow 0.4s var(--bbc-ease),
		transform 0.4s var(--bbc-ease),
		border-color 0.4s var(--bbc-ease);
}

.elementor-widget-icon-box .elementor-icon-box-wrapper {
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	width: 100%;
}

.elementor-widget-icon-box .elementor-icon-box-title {
	text-align: center;
	width: 100%;
}

.elementor-widget-icon-box .elementor-icon-box-description {
	text-align: center;
	width: 100%;
}

.elementor-widget-icon-box:hover,
.elementor-widget-image-box:hover {
	box-shadow: var(--bbc-shadow-lg);
	transform: translateY(-4px);
	border-color: var(--bbc-accent);
}

/* Icon accent colour */
.elementor-widget-icon-box .elementor-icon {
	color: var(--bbc-accent);
	border-color: var(--bbc-accent);
	margin: 0 auto var(--bbc-space-md);
	transition: transform 0.3s var(--bbc-ease);
}

.elementor-widget-icon-box:hover .elementor-icon {
	transform: scale(1.08);
}

/* ══════════════════════════════════════════════
   SECTIONS — Alternating backgrounds
   ══════════════════════════════════════════════ */

.bbc-section-light {
	background-color: var(--bbc-off-white);
}

.bbc-section-dark {
	background-color: var(--bbc-primary);
	color: var(--bbc-white);
}

.bbc-section-dark h1,
.bbc-section-dark h2,
.bbc-section-dark h3,
.bbc-section-dark .elementor-heading-title {
	color: var(--bbc-white);
}

.bbc-section-dark p {
	color: rgba(255,255,255,.8);
}

/* Gold top border accent for sections */
.bbc-accent-top {
	border-top: 3px solid var(--bbc-accent);
}

/* ══════════════════════════════════════════════
   TESTIMONIALS & QUOTES
   ══════════════════════════════════════════════ */

.elementor-testimonial,
.elementor-widget-testimonial {
	background: var(--bbc-white);
	border-radius: var(--bbc-radius-lg);
	padding: var(--bbc-space-lg);
	box-shadow: var(--bbc-shadow-sm);
	border-left: 4px solid var(--bbc-accent);
}

.elementor-testimonial-content {
	font-style: italic;
	font-size: 1.05rem;
	line-height: 1.8;
	color: var(--bbc-text);
}

.elementor-testimonial-name {
	font-family: var(--bbc-font-heading);
	font-weight: 700;
	color: var(--bbc-primary);
}

/* ══════════════════════════════════════════════
   COUNTERS / STATS — Corporate credibility
   ══════════════════════════════════════════════ */

.elementor-counter-number-wrapper {
	font-family: var(--bbc-font-heading);
	font-size: clamp(2rem, 4vw, 3.5rem);
	font-weight: 700;
	color: var(--bbc-accent);
}

.elementor-counter-title {
	font-family: var(--bbc-font-body);
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	font-size: 14px;
	color: var(--bbc-grey-500);
}

/* ══════════════════════════════════════════════
   FORMS — Clean & professional
   ══════════════════════════════════════════════ */

input[type="text"],
input[type="email"],
input[type="tel"],
input[type="url"],
input[type="password"],
input[type="number"],
textarea,
select,
.elementor-field-textual {
	border: 1px solid var(--bbc-grey-200);
	border-radius: var(--bbc-radius);
	padding: 14px 18px;
	font-family: var(--bbc-font-body);
	font-size: 15px;
	color: var(--bbc-text);
	background: var(--bbc-white);
	transition: border-color 0.3s var(--bbc-ease), box-shadow 0.3s var(--bbc-ease);
}

input:focus,
textarea:focus,
select:focus,
.elementor-field-textual:focus {
	border-color: var(--bbc-primary);
	box-shadow: 0 0 0 3px rgba(26,58,107,.12);
	outline: none;
}

label,
.elementor-field-label {
	font-weight: 500;
	font-size: 14px;
	color: var(--bbc-grey-800);
	margin-bottom: var(--bbc-space-xs);
}

/* ══════════════════════════════════════════════
   FOOTER — Corporate
   ══════════════════════════════════════════════ */

.site-footer,
.elementor-location-footer {
	background: var(--bbc-primary-dark);
	color: rgba(255,255,255,.7);
}

.elementor-location-footer h1,
.elementor-location-footer h2,
.elementor-location-footer h3,
.elementor-location-footer h4,
.elementor-location-footer h5,
.elementor-location-footer h6,
.elementor-location-footer .elementor-heading-title {
	color: var(--bbc-white);
	font-size: 1.1rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.elementor-location-footer a {
	color: rgba(255,255,255,.7);
	transition: color 0.3s var(--bbc-ease);
}

.elementor-location-footer a:hover {
	color: var(--bbc-accent);
}

/* Footer divider */
.elementor-location-footer .elementor-divider-separator {
	border-color: rgba(255,255,255,.1);
}

/* ══════════════════════════════════════════════
   IMAGES & MEDIA
   ══════════════════════════════════════════════ */

.elementor-widget-image img {
	border-radius: var(--bbc-radius);
}

/* ══════════════════════════════════════════════
   DIVIDERS & SEPARATORS
   ══════════════════════════════════════════════ */

.elementor-divider-separator {
	border-color: var(--bbc-grey-200);
}

/* Gold accent divider */
.bbc-divider-gold .elementor-divider-separator {
	border-color: var(--bbc-accent);
	border-width: 2px;
}

/* ══════════════════════════════════════════════
   SCROLL TO TOP
   ══════════════════════════════════════════════ */

.bbc-scroll-top {
	position: fixed;
	bottom: 30px;
	right: 30px;
	width: 48px;
	height: 48px;
	background: var(--bbc-primary);
	color: var(--bbc-white);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: var(--bbc-shadow-md);
	z-index: 999;
	opacity: 0;
	transform: translateY(10px);
	transition: opacity 0.3s, transform 0.3s;
}

.bbc-scroll-top.visible {
	opacity: 1;
	transform: translateY(0);
}

.bbc-scroll-top:hover {
	background: var(--bbc-accent);
	color: var(--bbc-primary-dark);
}

/* ══════════════════════════════════════════════
   FLOATING PHONE BUTTON
   ══════════════════════════════════════════════ */

.bbc-phone-float {
	position: fixed;
	bottom: 30px;
	left: 30px;
	width: 56px;
	height: 56px;
	background: var(--bbc-accent);
	color: var(--bbc-primary-dark);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 24px;
	box-shadow: var(--bbc-shadow-lg);
	z-index: 998;
	text-decoration: none;
	transition: transform 0.3s var(--bbc-ease), box-shadow 0.3s var(--bbc-ease);
	animation: bbcPulseRing 2s ease-out infinite;
}

.bbc-phone-float:hover {
	transform: scale(1.1);
	box-shadow: var(--bbc-shadow-xl);
	color: var(--bbc-primary-dark);
}

@keyframes bbcPulseRing {
	0%   { box-shadow: 0 0 0 0 rgba(200,169,78,0.5); }
	70%  { box-shadow: 0 0 0 15px rgba(200,169,78,0); }
	100% { box-shadow: 0 0 0 0 rgba(200,169,78,0); }
}

/* ══════════════════════════════════════════════
   ANIMATIONS — Active & engaging
   ══════════════════════════════════════════════ */

@keyframes bbcFadeUp {
	from { opacity: 0; transform: translateY(30px); }
	to   { opacity: 1; transform: translateY(0); }
}

@keyframes bbcFadeIn {
	from { opacity: 0; }
	to   { opacity: 1; }
}

@keyframes bbcSlideLeft {
	from { opacity: 0; transform: translateX(40px); }
	to   { opacity: 1; transform: translateX(0); }
}

@keyframes bbcSlideRight {
	from { opacity: 0; transform: translateX(-40px); }
	to   { opacity: 1; transform: translateX(0); }
}

@keyframes bbcScaleIn {
	from { opacity: 0; transform: scale(0.9); }
	to   { opacity: 1; transform: scale(1); }
}

@keyframes bbcFloat {
	0%, 100% { transform: translateY(0); }
	50% { transform: translateY(-10px); }
}

.bbc-fade-up {
	animation: bbcFadeUp 0.7s var(--bbc-ease) both;
}

.bbc-fade-in {
	animation: bbcFadeIn 0.8s var(--bbc-ease) both;
}

.bbc-slide-left {
	animation: bbcSlideLeft 0.7s var(--bbc-ease) both;
}

.bbc-slide-right {
	animation: bbcSlideRight 0.7s var(--bbc-ease) both;
}

.bbc-scale-in {
	animation: bbcScaleIn 0.6s var(--bbc-ease) both;
}

.bbc-float {
	animation: bbcFloat 3s ease-in-out infinite;
}

/* Staggered animation delays for grid items */
.elementor-column:nth-child(1) .elementor-widget-icon-box { animation: bbcFadeUp 0.6s var(--bbc-ease) 0.1s both; }
.elementor-column:nth-child(2) .elementor-widget-icon-box { animation: bbcFadeUp 0.6s var(--bbc-ease) 0.2s both; }
.elementor-column:nth-child(3) .elementor-widget-icon-box { animation: bbcFadeUp 0.6s var(--bbc-ease) 0.3s both; }
.elementor-column:nth-child(4) .elementor-widget-icon-box { animation: bbcFadeUp 0.6s var(--bbc-ease) 0.4s both; }

/* Service card hover lift + glow */
.elementor-widget-icon-box:hover {
	box-shadow: 0 12px 40px rgba(26,58,107,0.15), 0 0 0 1px var(--bbc-accent) !important;
}

/* Image hover zoom */
.elementor-widget-image img,
.elementor-widget-image-box img {
	transition: transform 0.7s var(--bbc-ease);
}

.elementor-widget-image:hover img,
.elementor-widget-image-box:hover img {
	transform: scale(1.05);
}

/* Button hover pulse */
.elementor-button:active {
	animation: bbcScaleIn 0.15s ease both;
}

/* Counter number animation glow */
.elementor-counter-number-wrapper {
	transition: color 0.3s var(--bbc-ease);
}

.elementor-widget-counter:hover .elementor-counter-number-wrapper {
	text-shadow: 0 0 20px rgba(200,169,78,0.3);
}

/* Client logos section */
.bbc-client-logos img {
	filter: grayscale(100%);
	opacity: 0.5;
	transition: filter 0.4s var(--bbc-ease), opacity 0.4s var(--bbc-ease);
}

.bbc-client-logos img:hover {
	filter: grayscale(0%);
	opacity: 1;
}

/* ══════════════════════════════════════════════
   RESPONSIVE REFINEMENTS
   ══════════════════════════════════════════════ */

@media (max-width: 767px) {
	body {
		font-size: 15px;
	}

	.elementor-widget-icon-box,
	.elementor-widget-image-box {
		padding: var(--bbc-space-md);
	}

	button,
	.elementor-button,
	.elementor-button-wrapper .elementor-button {
		padding: 12px 24px;
		font-size: 14px;
	}

	.elementor-nav-menu a,
	.elementor-nav-menu .elementor-item {
		font-size: 14px;
	}
}

@media (min-width: 1024px) {
	body {
		font-size: 17px;
	}
}

/* ══════════════════════════════════════════════
   ICON-BOX OVERRIDES — Force center & equal height
   Works with both e-con (new) and elementor-section (legacy)
   ══════════════════════════════════════════════ */

/* Center all icon-box content */
.elementor-widget-icon-box .elementor-icon-box-wrapper {
	text-align: center !important;
	display: flex !important;
	flex-direction: column !important;
	align-items: center !important;
	height: 100% !important;
}

.elementor-widget-icon-box .elementor-icon-box-icon {
	margin: 0 auto 15px auto !important;
	text-align: center !important;
	width: auto !important;
	display: flex !important;
	justify-content: center !important;
}

.elementor-widget-icon-box .elementor-icon-box-content {
	text-align: center !important;
	flex: 1;
}

.elementor-widget-icon-box .elementor-icon-box-title,
.elementor-widget-icon-box .elementor-icon-box-title a {
	text-align: center !important;
	display: block !important;
	width: 100% !important;
}

.elementor-widget-icon-box .elementor-icon-box-description {
	text-align: center !important;
}

/* ── Equal height: e-con container system (Elementor 3.6+) ── */

.e-con {
	display: flex !important;
	flex-wrap: wrap !important;
}

.e-con > .e-con {
	display: flex !important;
	flex-direction: column !important;
}

.e-con > .e-con > .elementor-widget-icon-box,
.e-con > .e-con > .elementor-widget-image-box {
	flex: 1 !important;
	display: flex !important;
	flex-direction: column !important;
}

.e-con > .elementor-widget-icon-box,
.e-con > .elementor-widget-image-box {
	flex: 1 !important;
	display: flex !important;
	flex-direction: column !important;
}

/* ── Equal height: legacy section/column system ── */

.elementor-section > .elementor-container {
	display: flex !important;
	flex-wrap: wrap !important;
}

.elementor-section > .elementor-container > .elementor-column {
	display: flex !important;
}

.elementor-column > .elementor-widget-wrap {
	display: flex !important;
	flex-direction: column !important;
	flex: 1 !important;
	width: 100% !important;
}

.elementor-column > .elementor-widget-wrap > .elementor-widget-icon-box,
.elementor-column > .elementor-widget-wrap > .elementor-widget-image-box {
	flex: 1 !important;
	display: flex !important;
	flex-direction: column !important;
}
