/*
Theme Name: AXIS PRO
Theme URI: https://axispro.com
Author: AXIS Team
Author URI: https://axispro.com
Description: Modern Block Theme with Shopify-level UX for high-converting WooCommerce stores. Built for speed, performance, and resale.
Version: 1.2.0
Tested up to: 6.6
Requires PHP: 7.4
License: GPL v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: axis-pro
Tags: e-commerce, woocommerce, block-theme, full-site-editing, responsive, fast, modern, luxury, black, white, gold

AXIS PRO is a premium WordPress block theme designed for modern e-commerce with Shopify-level user experience.
Built from scratch for maximum performance, conversion optimization, and resale value.
*/

/* Dromeas Brand Fonts */
@import url('https://fonts.googleapis.com/css2?family=Instrument+Sans:ital,wght@0,400;0,500;0,600;0,700;1,400&family=Instrument+Serif:ital@0;1&display=swap');

/* Hidden logo source for JS copying */
.dn-logo-wp-source { display: none !important; }

/* Reset & Base Styles */
:root {
	--wp--preset--color--black: #000000;
	--wp--preset--color--white: #FFFFFF;
	--wp--preset--color--gold: #c3cca6;
	--wp--preset--color--dark-gray: #1A1A1A;
	--wp--preset--color--light-gray: #F5F5F5;
	--wp--preset--font-family--inter: 'Instrument Sans', system-ui, -apple-system, sans-serif;
	--wp--preset--font-family--serif: 'Instrument Serif', Georgia, serif;
	--wp--preset--font-size--small: 0.875rem;
	--wp--preset--font-size--medium: 1rem;
	--wp--preset--font-size--large: 1.25rem;
	--wp--preset--font-size--extra-large: 1.5rem;
	--wp--preset--font-size--heading-3: 2rem;
	--wp--preset--font-size--heading-2: 2.5rem;
	--wp--preset--font-size--heading-1: 3rem;
	
	/* Header Variables */
	--layer-sticky: 1100;
	--layer-lowest: 0;
	--layer-menu-drawer: 1050;
	--layer-heightened: 1000;
	--animation-speed: 0.25s;
	--animation-easing: cubic-bezier(0.25, 0.1, 0.25, 1.0);
	--animation-speed-slow: 0.5s;
	--ease-out-cubic: cubic-bezier(0.215, 0.61, 0.355, 1);
	--submenu-animation-speed: 0.3s;
	--header-height: 60px;
	--top-row-height: 30px;
	--border-bottom-width: 1px;
	--border-bottom-width-mobile: 1px;
	--gap-xl: 2rem;
	--drawer-height: 100vh;
	--drawer-width: 280px;
	--drawer-max-width: 90vw;
	--style-border-drawer: 1px solid;
	--shadow-drawer: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
	--drawer-animation-speed: 0.3s;
	--drawer-padding: 1.5rem;
	--padding-sm: 0.5rem;
	--padding-lg: 1.5rem;
	--padding-xs: 0.75rem;
	--padding-3xs: 0.25rem;
	--margin-xs: 0.5rem;
	--margin-md: 1rem;
	--margin-lg: 1.5rem;
	--icon-size-xs: 20px;
	--button-size: 24px;
	--icon-size-md: 20px;
	
	/* Use theme.json colors for background, foreground, border */
	--color-scheme-top-row: var(--wp--preset--color--white);
	--color-scheme-bottom-row: var(--wp--preset--color--white);
	--color-submenu: var(--wp--preset--color--white);
	--color-border: var(--wp--preset--color--light-gray);
	--shadow-popover: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
	--color-background: var(--wp--preset--color--white);
	--color-foreground: var(--wp--preset--color--black);
}

* {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

html {
	scroll-behavior: smooth;
}

body {
	font-family: var(--wp--preset--font-family--inter);
	font-size: var(--wp--preset--font-size--medium);
	line-height: 1.6;
	color: var(--wp--preset--color--black);
	background-color: var(--wp--preset--color--white);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

img {
	max-width: 100%;
	height: auto;
	display: block;
}

a {
	color: var(--wp--preset--color--gold);
	text-decoration: none;
	transition: color 0.2s ease;
}

a:hover {
	color: var(--wp--preset--color--black);
}

/* WordPress Core Alignment */
.alignwide {
	max-width: 1400px;
	margin-left: auto;
	margin-right: auto;
}

.alignfull {
	max-width: 100%;
	width: 100%;
}

/* Basic WooCommerce Styles */
.woocommerce .woocommerce-breadcrumb {
	margin-bottom: 2rem;
	font-size: var(--wp--preset--font-size--small);
	color: var(--wp--preset--color--dark-gray);
}

.woocommerce .price {
	color: var(--wp--preset--color--gold);
	font-weight: 700;
}

/* Utility Classes */
.text-center {
	text-align: center;
}

.container {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 1rem;
}

/* Header Sticky Behavior */
.header-section:has(> #header-component[sticky='always']),
.header-section:has(> #header-component[sticky='scroll-up'][data-sticky-state='active']) {
	position: sticky;
	top: -1px;
	z-index: var(--layer-sticky);
}

.header[data-sticky-state] {
	transition: opacity var(--animation-speed) var(--animation-easing);
	opacity: 1;
}

.header[data-sticky-state='active'] {
	view-transition-name: sticky-header;
}

.header[data-sticky-state='idle'] {
	opacity: 0;
}

/* Header Underlays */
.header__underlay {
	position: absolute;
	inset: 0;
}

.header__underlay-closed {
	height: var(--closed-underlay-height, 100%);
	z-index: var(--layer-lowest);
	background: linear-gradient(
		var(--color-scheme-top-row) 0 var(--top-row-height),
		var(--color-scheme-bottom-row) var(--top-row-height) var(--header-height)
	);
	transition: height var(--animation-speed-slow) var(--ease-out-cubic);
}

.header__underlay-open {
	height: var(--full-open-header-height);
	background: linear-gradient(
		var(--color-scheme-top-row) 0 var(--top-row-height),
		var(--color-scheme-bottom-row) var(--top-row-height) var(--header-height),
		var(--color-submenu) var(--header-height) 100%
	);
	transition: height var(--submenu-animation-speed) var(--ease-out-cubic);
}

.header__underlay-open::after {
	content: '';
	position: absolute;
	inset: 0;
	box-shadow: var(--shadow-popover);
	clip-path: inset(var(--header-height) 0 -100px 0);
	transition: height var(--submenu-animation-speed) var(--ease-out-cubic);
}

/* Header Row Styles */
.header__row {
	position: relative;
	background-color: transparent;
}

.header__row--top:not(.divider--page-width),
.header__row--top.divider--page-width .header__columns,
.header__row--bottom {
	border-bottom: var(--border-bottom-width) solid var(--color-border);
}

@media screen and (max-width: 749px) {
	.header__row--top:not(.divider--page-width),
	.header__row--top.divider--page-width .header__columns {
		border-bottom-width: var(--border-bottom-width-mobile);
	}
}

#header-component[data-menu-style='drawer'] .header__row--top:not(.divider--page-width),
#header-component[data-menu-style='drawer'] .header__row--top.divider--page-width .header__columns {
	border-bottom-width: var(--border-bottom-width-mobile);
}

/* Header Column Layout */
.header__column {
	display: flex;
	align-items: center;
}

@media screen and (max-width: 749px) {
	.header__column {
		display: contents;
	}
}

.header__column--left,
.header__column--center {
	gap: var(--gap-xl);
	grid-area: left;
}

.header__column--center {
	justify-content: center;
	grid-area: center;
}

.header__column--right {
	gap: var(--gap-xl);
	justify-content: flex-end;
	grid-area: right;
}

.header__columns {
	/* Three column layout */
	--header-left: 1fr;
	--header-center: auto;
	--header-right: 1fr;
	--header-template-columns: var(--header-left) var(--header-center) var(--header-right);

	/* Mobile layout */
	--header-mobile-bookend: 44px;

	display: grid;
	grid-template-areas: 'left center right';
	grid-gap: var(--gap-xl);
	grid-template-columns: var(--header-template-columns);

	/* If menu is in center column */
	&:has(.header__column--center header-menu) {
		--header-center: auto;
		--header-left: minmax(max-content, 1fr);
		--header-right: minmax(max-content, 1fr);
	}

	/* If there is no center column, make the column the menu is in grow eagerly */
	&:where(:not(:has(.header__column--center))) {
		@media screen and (min-width: 750px) {
			--header-template-columns: var(--header-left) var(--header-right);
			grid-template-areas: 'left right';
		}

		/* If the header-menu is in the right column */
		&:has(.header__column--right header-menu) {
			--header-right: auto;
			--header-left: minmax(max-content, 1fr);
		}

		/* If the header-menu is in the left column */
		&:has(.header__column--left header-menu) {
			--header-left: auto;
			--header-right: minmax(max-content, 1fr);
		}
	}

	@media screen and (max-width: 749px) {
		--header-template-columns: var(--header-mobile-bookend) var(--header-mobile-bookend) 1fr
			var(--header-mobile-bookend) var(--header-mobile-bookend);

		grid-template-areas: 'leftA leftB center rightA rightB';
		grid-column: span 3;
		column-gap: 0;
		align-items: center;
		padding-block: 0;
		padding-inline: 0 var(--padding-3xs);

		.header-logo {
			grid-area: center;
		}

		&:not(:has(header-actions)) .search-action {
			grid-area: leftB;
		}

		&:not(:has(shopify-account)) .search-action {
			grid-area: rightA;
		}

		.search-action {
			grid-area: leftB;
		}

		header-actions {
			grid-area: rightB;
		}
	}
}

/* Mobile Drawer Styles */
.menu-drawer {
	position: fixed;
	transform: translateX(-100%);
	visibility: hidden;
	height: var(--drawer-height);
	width: var(--drawer-width);
	max-width: var(--drawer-max-width);
	z-index: var(--layer-menu-drawer);
	left: 0;
	top: 0;
	padding: 0;
	background-color: var(--color-background);
	overflow: auto;
	display: flex;
	border-right: var(--style-border-drawer);
	box-shadow: var(--shadow-drawer);
	flex-direction: column;

	@media screen and (min-width: 750px) {
		width: 25rem;
	}
}

.menu-drawer.menu-drawer--has-submenu-opened {
	overflow: initial;
}

.menu-drawer__backdrop {
	position: fixed;
	top: 0;
	left: 0;
	width: 100vw;
	height: 100dvh;
	backdrop-filter: brightness(0.75);
	z-index: var(--layer-heightened);
	opacity: 0;
	transition: opacity var(--drawer-animation-speed) ease;

	.menu-open & {
		opacity: 1;
	}
}

.menu-drawer,
.menu-drawer__submenu {
	transition: transform var(--drawer-animation-speed) ease, visibility var(--drawer-animation-speed) ease,
		opacity var(--drawer-animation-speed) ease;
}

.menu-open > .menu-drawer,
.menu-open > .menu-drawer__submenu:not(.menu-drawer__menu--childlist) {
	transform: translateX(0);
	visibility: visible;
	opacity: 1;
	display: flex;
	flex-direction: column;
}

/* Drawer Menu Styles */
.menu-drawer__menu {
	--menu-drawer-inline-padding: calc(var(--padding-sm) + 7px);

	list-style: none;
	padding-inline: var(--drawer-padding);
	margin-inline: 0;
	margin-block-start: 0;
}

.menu-drawer__menu--grid {
	display: grid;
	width: 100%;
	grid-template-columns: 1fr 1fr;
	gap: var(--padding-sm);
	padding-inline-end: var(--menu-drawer-inline-padding);
	padding-block-start: var(--padding-xs);
}

.menu-drawer__menu--childlist:not(.menu-drawer__menu--grid) {
	flex-grow: 1;
}

.menu-drawer__menu.has-submenu,
.menu-drawer__menu--childlist:not(:has(.menu-drawer__animated-element)) {
	margin-block-end: var(--margin-xs);

	@media screen and (min-width: 750px) {
		margin-block-end: 2.5rem;
	}
}

.menu-drawer__list-item--divider {
	border-block-end: 1px solid var(--color-border);
}

.menu-drawer__list-item--deep:not(.menu-drawer__list-item--divider) .menu-drawer__menu {
	margin-block-start: -0.3rem;
}

.menu-drawer__list-item--flat.menu-drawer__list-item--divider .menu-drawer__menu {
	margin-block-start: -0.4rem;
}

.menu-drawer__menu-container--divider {
	border-block-end: 1px solid var(--color-border);
}

.menu-drawer__menu > .menu-drawer__list-item {
	display: flex;
	min-height: calc(2 * var(--padding-lg) + var(--icon-size-xs));
}

.menu-drawer__list-item--deep .menu-drawer__list-item,
.menu-drawer__list-item--flat .menu-drawer__list-item {
	min-height: auto;
}

.menu-drawer__menu .menu-drawer__list-item--flat {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	margin-block-end: var(--margin-md);
}

.menu-drawer__menu--childlist .menu-drawer__list-item--flat {
	margin-block-end: var(--margin-sm);

	@media screen and (min-width: 750px) {
		margin-block-end: var(--margin-lg);
	}
}

.menu-drawer__menu--childlist .menu-drawer__list-item--flat.menu-drawer__list-item--divider {
	margin-block-end: 0;
}

.menu-drawer__list-item--flat .menu-drawer__menu--childlist {
	width: 100%;
	padding-inline: 0;
}

.menu-drawer__menu-item {
	display: flex;
	padding: var(--padding-2xs) 0;
	position: relative;
	text-decoration: none;
	justify-content: space-between;
	align-items: center;
}

.menu-drawer__menu-item-text {
	overflow: hidden;
	text-overflow: ellipsis;
}

/* Drawer Animation */
.menu-drawer-container[open] .menu-drawer__animated-element {
	animation: menu-drawer-nav-open var(--drawer-animation-speed) ease-in-out;
	animation-delay: calc(var(--drawer-animation-speed) + (var(--menu-drawer-animation-index) - 1) * 0.1s);
	animation-fill-mode: backwards;
}

@keyframes menu-drawer-nav-open {
	0% {
		visibility: hidden;
		opacity: 0;
		transform: translateX(-0.5rem);
	}
	100% {
		visibility: visible;
		opacity: 1;
		transform: translateX(0);
	}
}

/* Header Action Button Styles */
.header-actions__action {
	--button-color: var(--color-foreground);
	color: var(--button-color);
	cursor: pointer;
	display: flex;
	justify-content: center;

	&:hover {
		--button-color: var(--color-foreground);
	}
}

.header-actions__action:not(.account-button) .svg-wrapper {
	height: var(--button-size);
	width: var(--button-size);
}

.header-actions__action:not(.account-button) svg {
	width: var(--icon-size-md);
	height: var(--icon-size-md);
}

/* Main Content Padding */
.main-content {
	padding-top: var(--header-height);
	min-height: calc(100vh - var(--header-height));
}

/* Responsive */
@media (max-width: 768px) {
	.container {
		padding: 0 0.75rem;
	}
}

/* =========================================
   ADDITIONAL HEADER ENHANCEMENTS
   ========================================= */

/* Transparent Header Color Inheritance */
[data-transparent-color-scheme='top']:hover,
[data-transparent-color-scheme='top']:focus-within,
[data-transparent-color-scheme='both']:hover,
[data-transparent-color-scheme='both']:focus-within {
	:is(.header__underlay-open, .header__underlay-closed) {
		--color-scheme-top-row: var(--color-background);
	}
}

[data-transparent-color-scheme='bottom']:hover,
[data-transparent-color-scheme='bottom']:focus-within,
[data-transparent-color-scheme='both']:hover,
[data-transparent-color-scheme='both']:focus-within {
	:is(.header__underlay-open, .header__underlay-closed) {
		--color-scheme-bottom-row: var(--color-background);
	}
}

/* Submenu Overlap Handling */
[data-submenu-overlap-bottom-row] {
	.header__underlay-open {
		background: linear-gradient(
			var(--color-scheme-top-row) 0 var(--top-row-height),
			var(--color-submenu) var(--top-row-height) 100%
		);
	}

	.header__row--bottom {
		z-index: var(--layer-lowest);
	}
}

/* Header Row Hover Effects */
@media (hover: hover) {
	.header__column:has(header-menu:hover),
	.header__column:has(.header-actions__action:hover),
	.header__column:has(.header__icon--menu:hover) {
		header-menu:not(:hover),
		.header-actions__action:not(:hover),
		.header__icon--menu:not(:hover) {
			opacity: var(--opacity-subdued-text);
			transition: opacity var(--animation-speed) var(--animation-easing);
		}
	}
}

/* Ensure smooth transitions for interactive elements */
header-menu,
.header-actions__action,
.header__icon--menu {
	transition: opacity var(--animation-speed) var(--animation-easing);
}

/* wp-block-navigation specific styles */
.wp-block-navigation {
	display: flex;
	gap: var(--gap-xl);
	align-items: center;
}

.wp-block-navigation__container {
	display: flex;
	gap: var(--gap-xl);
	align-items: center;
}

.wp-block-navigation__responsive-container-open {
	display: none;
}

.wp-block-navigation-item {
	display: flex;
	align-items: center;
}

.wp-block-navigation-item a {
	color: var(--color-foreground);
	text-decoration: none;
	transition: color var(--animation-speed) var(--animation-easing);
}

.wp-block-navigation-item a:hover {
	color: var(--color-primary);
}

.wp-block-navigation-submenu {
	background-color: var(--color-background);
	border: var(--style-border-width) solid var(--color-border);
	box-shadow: var(--shadow-popover);
	border-radius: var(--style-border-radius);
}

.wp-block-navigation__responsive-container-close {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background-color: var(--color-background);
	z-index: var(--layer-menu-drawer);
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
}

/* Mobile menu toggle button */
.menu-drawer-button {
	display: flex;
	align-items: center;
	justify-content: center;
}

.header__icon--menu {
	--button-color: var(--color-foreground);
	color: var(--button-color);
	cursor: pointer;
	display: flex;
	justify-content: center;
	background: none;
	border: none;
	padding: 0;
}

.header__icon--menu:hover {
	--button-color: var(--color-foreground);
}

/* Site Logo */
.wp-block-site-logo {
	display: flex;
	align-items: center;
	justify-content: center;
}

.wp-block-site-logo img {
	max-height: 40px;
	width: auto;
}

/* Sticky header underlay animation */
body:has(.header[transparent]) .content-for-layout > .shopify-section:first-child {
	margin-top: calc(var(--header-group-height) * -1);
}

body:has(.header[transparent]) #header-group > .header-section {
	z-index: var(--layer-sticky);
}

body:has(.header[transparent]) #header-group > *:not(.header-section) {
	z-index: calc(var(--layer-sticky) - 1);
}

/* View transition support */
@view-transition {
	navigation: auto;
}

::view-transition {
	pointer-events: none;
}

html:active-view-transition-type(page-navigation) main[data-page-transition-enabled='true'] {
	view-transition-name: main-content;
}

::view-transition-old(main-content) {
	animation: var(--view-transition-old-main-content);
}

::view-transition-new(main-content) {
	animation: var(--view-transition-new-main-content);
}

/* Icon rotation for open/close */
.icon-plus {
	transition: transform var(--animation-speed) var(--animation-easing);
}

details[open] .icon-plus {
	transform: rotate(45deg);
}

/* =========================================
   FOOTER STYLES (from Shopify reference)
   ========================================= */

/* Footer Reset */
.dr-footer *,
.dr-footer *::before,
.dr-footer *::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

/* Footer Main */
.dr-footer {
	font-family: var(--wp--preset--font-family--inter);
	background: #0b0c10;
	color: #fff;
	position: relative;
	overflow: hidden;
}

/* Top gradient line */
.dr-footer::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 1px;
	background: linear-gradient(90deg, transparent 0%, #38e8f5 30%, #1a8ef0 55%, #0a2fb8 80%, transparent 100%);
}

/* Subtle radial glow */
.dr-footer::after {
	content: '';
	position: absolute;
	top: -120px;
	left: 50%;
	transform: translateX(-50%);
	width: 700px;
	height: 300px;
	background: radial-gradient(ellipse, rgba(26, 142, 240, 0.12) 0%, transparent 70%);
	pointer-events: none;
}

/* Footer Body */
.dr-footer__body {
	position: relative;
	z-index: 1;
	max-width: 1200px;
	margin: 0 auto;
	padding: 64px 40px 48px;
	display: grid;
	grid-template-columns: 280px 1fr;
	gap: 64px;
}

/* Brand Block */
.dr-footer__brand {
	display: flex;
	flex-direction: column;
	gap: 0;
}

.dr-footer__logo {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 16px;
	text-decoration: none;
}

.dr-footer__logo-mark {
	width: 8px;
	height: 8px;
	background: #c0392b;
	border-radius: 2px;
	flex-shrink: 0;
}

.dr-footer__logo-name {
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: #fff;
}

.dr-footer__logo-sub {
	font-size: 10px;
	font-weight: 300;
	letter-spacing: 0.28em;
	text-transform: uppercase;
	color: #555;
	margin-left: 4px;
}

.dr-footer__tagline {
	font-size: 13px;
	font-weight: 300;
	color: #666;
	line-height: 1.7;
	margin-bottom: 28px;
	max-width: 220px;
}

/* Newsletter */
.dr-footer__nl-label {
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: #444;
	margin-bottom: 10px;
}

.dr-footer__nl-form {
	display: flex;
	gap: 0;
	margin-bottom: 10px;
}

.dr-footer__nl-form input[type="email"] {
	flex: 1;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.1);
	border-right: none;
	border-radius: 10px 0 0 10px;
	padding: 10px 14px;
	font-family: var(--wp--preset--font-family--inter);
	font-size: 12.5px;
	color: #fff;
	outline: none;
	transition: border-color 0.2s, background 0.2s;
}

.dr-footer__nl-form input[type="email"]::placeholder {
	color: #444;
}

.dr-footer__nl-form input[type="email"]:focus {
	background: rgba(255, 255, 255, 0.09);
	border-color: rgba(56, 232, 245, 0.4);
}

.dr-footer__nl-form button {
	background: linear-gradient(135deg, #1a8ef0, #0a2fb8);
	border: none;
	border-radius: 0 10px 10px 0;
	padding: 10px 16px;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: opacity 0.2s;
}

.dr-footer__nl-form button:hover {
	opacity: 0.85;
}

.dr-footer__nl-form button svg {
	width: 15px;
	height: 15px;
	stroke: #fff;
	fill: none;
	stroke-width: 2;
	stroke-linecap: round;
	stroke-linejoin: round;
}

.dr-footer__nl-success {
	font-size: 12px;
	color: #38e8f5;
	margin-bottom: 10px;
}

.dr-footer__nl-error {
	font-size: 12px;
	color: #f06;
	margin-top: 4px;
}

.dr-footer__nl-wrap {
	margin-bottom: 32px;
}

/* Socials */
.dr-footer__socials {
	display: flex;
	gap: 8px;
}

.dr-footer__social-btn {
	width: 36px;
	height: 36px;
	border-radius: 10px;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.08);
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transition: background 0.2s, border-color 0.2s, transform 0.2s;
	text-decoration: none;
	color: #888;
}

.dr-footer__social-btn:hover {
	background: rgba(255, 255, 255, 0.12);
	border-color: rgba(255, 255, 255, 0.18);
	color: #fff;
	transform: translateY(-2px);
}

.dr-footer__social-btn svg {
	width: 16px;
	height: 16px;
	fill: currentColor;
}

/* Link Columns */
.dr-footer__links {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 32px;
}

.dr-footer__col-title {
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: #fff;
	margin-bottom: 18px;
	padding-bottom: 10px;
	border-bottom: 1px solid rgba(255, 255, 255, 0.07);
}

.dr-footer__col ul {
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: 9px;
}

.dr-footer__col ul li a {
	font-size: 13px;
	font-weight: 300;
	color: #555;
	text-decoration: none;
	transition: color 0.18s;
	display: flex;
	align-items: center;
	gap: 6px;
}

.dr-footer__col ul li a:hover {
	color: #d0d8ff;
}

.dr-footer__col ul li a::before {
	content: '';
	width: 3px;
	height: 3px;
	background: #2a6ef0;
	border-radius: 50%;
	flex-shrink: 0;
	opacity: 0;
	transition: opacity 0.18s;
}

.dr-footer__col ul li a:hover::before {
	opacity: 1;
}

/* Bottom Bar */
.dr-footer__bottom {
	position: relative;
	z-index: 1;
	border-top: 1px solid rgba(255, 255, 255, 0.06);
	max-width: 1200px;
	margin: 0 auto;
	padding: 20px 40px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
	flex-wrap: wrap;
}

.dr-footer__copy {
	font-size: 12px;
	font-weight: 300;
	color: #3a3a3a;
}

.dr-footer__copy span {
	color: #555;
}

.dr-footer__legal {
	display: flex;
	gap: 20px;
}

.dr-footer__legal a {
	font-size: 12px;
	font-weight: 300;
	color: #3a3a3a;
	text-decoration: none;
	transition: color 0.18s;
}

.dr-footer__legal a:hover {
	color: #888;
}

.dr-footer__badge {
	display: flex;
	align-items: center;
	gap: 6px;
	font-size: 11px;
	font-weight: 300;
	color: #2e2e2e;
}

.dr-footer__badge-dot {
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: linear-gradient(135deg, #38e8f5, #1a8ef0);
	flex-shrink: 0;
}

/* Footer Responsive */
@media (max-width: 1024px) {
	.dr-footer__body {
		grid-template-columns: 1fr;
		gap: 40px;
	}
	.dr-footer__links {
		grid-template-columns: repeat(2, 1fr);
	}
	.dr-footer__tagline {
		max-width: 100%;
	}
}

@media (max-width: 600px) {
	.dr-footer__body {
		padding: 48px 20px 36px;
	}
	.dr-footer__links {
		grid-template-columns: repeat(2, 1fr);
		gap: 24px;
	}
	.dr-footer__bottom {
		padding: 16px 20px;
		flex-direction: column;
		align-items: flex-start;
		gap: 10px;
	}
	.dr-footer__badge {
		display: none;
	}
}

/* =========================================
   DYNAMIC ISLAND NAVIGATION
   ========================================= */

/* Body offset — island is fixed, not in flow */
body {
	padding-top: 82px !important;
}
@media (max-width: 1024px) {
	body { padding-top: 72px !important; }
}

/* Wipe out old header styles that conflict */
.main-content { padding-top: 0; }

/* ── Reset for all island elements ── */
.dn-island a, .dn-island a:link, .dn-island a:visited, .dn-island a:hover, .dn-island a:active,
.dn-island button,
.dn-drawer a, .dn-drawer a:link, .dn-drawer button,
.dn-call-popup a, .dn-call-popup a:link,
.dn-sr-panel a, .dn-sr-panel a:link,
.dn-mobile-bar a, .dn-mobile-bar button {
	background: transparent !important;
	color: inherit;
	text-decoration: none;
	font-family: 'Inter', system-ui, -apple-system, sans-serif;
}
/* ── Restore call popup button backgrounds (override the reset above) ── */
.dn-call-popup .dn-call-number,
.dn-call-popup .dn-call-number:link,
.dn-call-popup .dn-call-number:visited,
.dn-call-popup .dn-call-number:hover,
.dn-call-popup .dn-call-number:active {
	background: linear-gradient(135deg, #22c55e, #16a34a) !important;
	color: #fff !important;
}
.dn-call-popup .dn-viber-btn,
.dn-call-popup .dn-viber-btn:link,
.dn-call-popup .dn-viber-btn:visited,
.dn-call-popup .dn-viber-btn:hover,
.dn-call-popup .dn-viber-btn:active {
	background: linear-gradient(135deg, #7360f2, #5b4de8) !important;
	color: #fff !important;
}

/* ── Desktop Island ── */
.dn-island {
	--dn-h: 54px;
	font-family: 'Inter', system-ui, -apple-system, sans-serif;
	position: fixed;
	top: 12px; left: 50%; transform: translateX(-50%);
	width: calc(100vw - 40px); min-width: 860px; max-width: 1200px;
	height: var(--dn-h);
	background: rgba(255,255,255,0.92);
	border: 1px solid rgba(255,255,255,0.55);
	border-radius: 50px;
	box-shadow: 0 4px 28px rgba(0,0,0,0.07), 0 1px 3px rgba(0,0,0,0.04), inset 0 1px 0 rgba(255,255,255,0.7);
	z-index: 9000;
	overflow: hidden;
	transition: height 0.48s cubic-bezier(0.32,0.72,0,1),
	            border-radius 0.48s cubic-bezier(0.32,0.72,0,1),
	            width 0.35s cubic-bezier(0.32,0.72,0,1),
	            box-shadow 0.3s ease;
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
}
.dn-island.dn-scrolled {
	background: rgba(255,255,255,0.96);
	box-shadow: 0 8px 40px rgba(0,0,0,0.10), 0 2px 6px rgba(0,0,0,0.05), inset 0 1px 0 rgba(255,255,255,0.6);
}
.dn-island.dn-open {
	border-radius: 22px;
	box-shadow: 0 12px 50px rgba(0,0,0,0.13), 0 4px 12px rgba(0,0,0,0.06), inset 0 1px 0 rgba(255,255,255,0.5);
}

.dn-row {
	display: flex; align-items: center; justify-content: center;
	height: var(--dn-h);
	padding: 0 8px;
	position: relative; z-index: 2;
}
.dn-left  { display: flex; align-items: center; flex: 1; justify-content: flex-end; gap: 2px; }
.dn-right { display: flex; align-items: center; flex: 1; justify-content: flex-start; gap: 2px; }

.dn-logo {
	display: flex; align-items: center; justify-content: center;
	padding: 0 14px; flex-shrink: 0;
	text-decoration: none !important;
}
.dn-logo img { height: 30px; width: auto; display: block; transition: transform 0.2s ease; }
.dn-logo:hover img { transform: scale(1.04); }

.dn-nav-btn {
	display: flex; align-items: center; gap: 3px;
	height: 34px; padding: 0 13px;
	font-size: 13px; font-weight: 500; letter-spacing: -0.01em;
	color: #444;
	border-radius: 50px; border: none; background: transparent !important;
	cursor: pointer; white-space: nowrap;
	transition: all 0.18s ease;
	font-family: 'Inter', system-ui, sans-serif;
}
.dn-nav-btn:hover { color: #111; background: rgba(0,0,0,0.05) !important; }
.dn-nav-btn.dn-active { color: #111; background: rgba(0,0,0,0.07) !important; }
.dn-nav-btn svg {
	width: 9px; height: 9px; stroke: currentColor; fill: none; stroke-width: 2.5;
	stroke-linecap: round; stroke-linejoin: round;
	transition: transform 0.3s cubic-bezier(0.32,0.72,0,1); opacity: 0.5;
}
.dn-nav-btn.dn-active svg { transform: rotate(180deg); opacity: 0.8; }
.dn-nav-btn.dn-hot { color: #1a3a6b; font-weight: 600; }

.dn-icon {
	width: 34px; height: 34px; border-radius: 50%;
	display: flex; align-items: center; justify-content: center;
	border: none; background: transparent !important; cursor: pointer;
	color: #555; position: relative;
	transition: all 0.18s ease;
}
.dn-icon:hover { background: rgba(0,0,0,0.06) !important; color: #111; }
.dn-icon svg { width: 17px; height: 17px; stroke: currentColor; fill: none; stroke-width: 1.7; stroke-linecap: round; stroke-linejoin: round; }

.dn-badge {
	position: absolute; top: 2px; right: 2px;
	min-width: 14px; height: 14px;
	background: #1a3a6b; color: #fff;
	font-size: 8px; font-weight: 700; border-radius: 99px;
	display: flex; align-items: center; justify-content: center;
	padding: 0 3px; border: 1.5px solid #fff; line-height: 1;
}
.dn-badge:empty { display: none; }

/* ── Dropdown panel ── */
.dn-drop {
	position: relative;
	opacity: 0;
	transition: opacity 0.25s ease 0.05s;
	padding: 0 20px 18px;
}
.dn-island.dn-open .dn-drop { opacity: 1; }
.dn-drop::before {
	content: ''; display: block;
	height: 1px; background: rgba(0,0,0,0.06);
	margin: 0 4px 16px;
}
.dn-panel { display: none; }
.dn-panel.dn-visible { display: block; }

.dn-sub-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(130px, 160px));
	gap: 10px;
}
.dn-sub-card {
	display: flex; flex-direction: column; align-items: center; gap: 8px;
	padding: 8px; border-radius: 16px;
	cursor: pointer; text-decoration: none !important;
	transition: background 0.15s ease, transform 0.2s ease;
}
.dn-sub-card:hover { background: rgba(0,0,0,0.04); transform: translateY(-2px); }
.dn-sub-img {
	width: 100%; aspect-ratio: 1; border-radius: 14px; overflow: hidden;
	background: #f3f1ec;
	display: flex; align-items: center; justify-content: center;
	font-size: 32px;
}
.dn-sub-img img { width: 88%; height: 88%; object-fit: contain; filter: drop-shadow(0 3px 8px rgba(0,0,0,0.10)); transition: transform 0.3s ease; }
.dn-sub-card:hover .dn-sub-img img { transform: scale(1.06); }
.dn-sub-name { font-size: 12px; font-weight: 500; color: #333; text-align: center; line-height: 1.25; }

.dn-see-all {
	display: inline-flex; align-items: center; gap: 5px;
	margin-top: 12px;
	font-size: 12.5px; font-weight: 600; color: #1a3a6b !important;
	cursor: pointer; transition: gap 0.2s ease;
}
.dn-see-all:hover { gap: 8px; }
.dn-see-all svg { width: 14px; height: 14px; stroke: currentColor; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }

/* ── Overlay ── */
.dn-overlay { position: fixed; inset: 0; z-index: 8998; display: none; }
.dn-overlay.dn-on { display: block; }

/* ── Search Panel ── */
.dn-sr-panel {
	position: fixed;
	top: 74px; left: 50%;
	transform: translateX(-50%) translateY(-10px);
	width: 480px; max-width: calc(100vw - 32px);
	background: rgba(255,255,255,0.98);
	border: 1px solid rgba(0,0,0,0.07);
	border-radius: 20px; padding: 14px 10px 10px;
	box-shadow: 0 20px 60px rgba(0,0,0,0.13), 0 4px 14px rgba(0,0,0,0.06);
	opacity: 0; pointer-events: none;
	transition: opacity 0.18s ease, transform 0.22s cubic-bezier(0.32,0.72,0,1);
	z-index: 9100;
}
.dn-sr-panel.dn-sr-open { opacity: 1; pointer-events: all; transform: translateX(-50%) translateY(0); }
.dn-sr-input-wrap { display: flex; align-items: center; gap: 8px; padding: 0 10px; margin-bottom: 10px; }
.dn-sr-input-wrap svg { width: 15px; height: 15px; stroke: #aaa; fill: none; stroke-width: 2; stroke-linecap: round; flex-shrink: 0; }
.dn-sr-input { border: none; outline: none; background: none; width: 100%; font-family: 'Inter', sans-serif; font-size: 14px; color: #111; }
.dn-sr-input::placeholder { color: #bbb; }
.dn-sr-divider { height: 1px; background: rgba(0,0,0,0.06); margin: 6px 8px; }
.dn-sr-label { font-size: 9px; font-weight: 600; letter-spacing: 0.13em; text-transform: uppercase; color: #ccc; padding: 4px 10px 6px; }
.dn-sr-item { display: flex; align-items: center; gap: 10px; padding: 6px 10px; border-radius: 12px; text-decoration: none !important; transition: background 0.12s; cursor: pointer; }
.dn-sr-item:hover { background: rgba(0,0,0,0.04); }
.dn-sr-thumb { width: 42px; height: 42px; border-radius: 10px; background: #f3f1ec; flex-shrink: 0; display: flex; align-items: center; justify-content: center; overflow: hidden; }
.dn-sr-thumb img { width: 86%; height: 86%; object-fit: contain; }
.dn-sr-name { font-size: 13px; font-weight: 500; color: #111; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.dn-sr-empty { padding: 20px; text-align: center; font-size: 13px; color: #999; display: none; }

/* ── Mobile Bar ── */
.dn-mobile-bar {
	display: none;
	font-family: 'Inter', system-ui, sans-serif;
	position: fixed; top: 10px; left: 12px; right: 12px;
	height: 54px; z-index: 9000;
	background: rgba(255,255,255,0.96);
	border: 1px solid rgba(230,230,230,0.9);
	border-radius: 50px;
	box-shadow: 0 4px 28px rgba(0,0,0,0.07), 0 1px 3px rgba(0,0,0,0.04), inset 0 1px 0 rgba(255,255,255,0.7);
	padding: 0 8px 0 18px;
	align-items: center; justify-content: space-between;
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
}
.dn-m-logo { display: flex; align-items: center; text-decoration: none !important; }
.dn-m-logo img { height: 26px; width: auto; display: block; }
.dn-m-actions { display: flex; align-items: center; gap: 2px; }
.dn-m-btn {
	width: 38px; height: 38px; border-radius: 50%;
	display: flex; align-items: center; justify-content: center;
	border: none; background: transparent !important; cursor: pointer; color: #444;
	transition: all 0.15s ease; position: relative;
}
.dn-m-btn:hover { background: rgba(0,0,0,0.05) !important; }
.dn-m-btn svg { width: 19px; height: 19px; stroke: currentColor; fill: none; stroke-width: 1.7; stroke-linecap: round; stroke-linejoin: round; }
.dn-m-badge {
	position: absolute; top: 3px; right: 3px;
	min-width: 14px; height: 14px; background: #1a3a6b; color: #fff;
	font-size: 8px; font-weight: 700; border-radius: 99px;
	display: flex; align-items: center; justify-content: center;
	padding: 0 3px; border: 1.5px solid #fff; line-height: 1;
}
.dn-m-badge:empty { display: none; }

.dn-hamburger { flex-direction: column; gap: 0; justify-content: center; }
.dn-hamburger span { display: block; width: 18px; height: 1.8px; background: #444; border-radius: 2px; transition: all 0.3s cubic-bezier(0.32,0.72,0,1); }
.dn-hamburger span + span { margin-top: 4.5px; }
.dn-hamburger.dn-ham-open span:nth-child(1) { transform: rotate(45deg) translate(4.5px,4.5px); }
.dn-hamburger.dn-ham-open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.dn-hamburger.dn-ham-open span:nth-child(3) { transform: rotate(-45deg) translate(4.5px,-4.5px); }

/* ── Drawer ── */
.dn-drawer {
	font-family: 'Inter', system-ui, sans-serif;
	position: fixed; top: 0; left: 0; right: 0; bottom: 0;
	background: #fff; z-index: 9500;
	overflow-y: auto; overflow-x: hidden;
	transform: translateY(100%);
	transition: transform 0.4s cubic-bezier(0.32,0.72,0,1);
	padding: 0 0 100px;
}
.dn-drawer.dn-drawer-open { transform: translateY(0); }

.dn-drawer-head {
	display: flex; align-items: center; justify-content: space-between;
	padding: 16px 20px;
	border-bottom: 1px solid rgba(0,0,0,0.06);
	position: sticky; top: 0; background: #fff; z-index: 2;
}
.dn-drawer-head-logo { text-decoration: none !important; }
.dn-drawer-close {
	width: 38px; height: 38px; border-radius: 50%;
	display: flex; align-items: center; justify-content: center;
	border: none; background: rgba(0,0,0,0.04) !important; cursor: pointer;
	color: #666; transition: all 0.15s ease;
}
.dn-drawer-close:hover { background: rgba(0,0,0,0.08) !important; color: #111; }
.dn-drawer-close svg { width: 18px; height: 18px; stroke: currentColor; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }

.dn-drawer-search {
	margin: 16px 20px 8px;
	display: flex; align-items: center; gap: 10px;
	background: #f5f5f5; border-radius: 14px;
	padding: 0 14px; height: 46px;
	border: 1px solid transparent;
	transition: border-color 0.15s, background 0.15s;
}
.dn-drawer-search:focus-within { background: #fff; border-color: rgba(0,0,0,0.12); }
.dn-drawer-search svg { width: 16px; height: 16px; stroke: #999; fill: none; stroke-width: 2; stroke-linecap: round; flex-shrink: 0; }
.dn-drawer-search-input { border: none; outline: none; background: none; width: 100%; font-family: 'Inter', sans-serif; font-size: 14px; color: #111; }
.dn-drawer-search-input::placeholder { color: #bbb; }

.dn-drawer-section { border-bottom: 1px solid rgba(0,0,0,0.05); }
.dn-drawer-toggle {
	display: flex; align-items: center;
	width: 100%; padding: 15px 20px;
	font-size: 14.5px; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase;
	color: #111; border: none; background: transparent !important; cursor: pointer;
	font-family: 'Inter', sans-serif; gap: 12px;
}
.dn-drawer-arrow { width: 20px; height: 20px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; color: #1a3a6b; }
.dn-drawer-arrow svg { width: 16px; height: 16px; stroke: currentColor; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.dn-drawer-chev { margin-left: auto; width: 18px; height: 18px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; color: #bbb; transition: transform 0.3s cubic-bezier(0.32,0.72,0,1), color 0.2s; }
.dn-drawer-chev svg { width: 16px; height: 16px; stroke: currentColor; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.dn-drawer-toggle.dn-acc-open .dn-drawer-chev { transform: rotate(180deg); color: #1a3a6b; }

.dn-drawer-subs { max-height: 0; overflow: hidden; transition: max-height 0.35s cubic-bezier(0.32,0.72,0,1); background: #fafafa; }
.dn-drawer-subs.dn-acc-open { max-height: 600px; }

.dn-drawer-all { display: block; padding: 14px 20px 14px 52px; font-size: 14.5px; font-weight: 600; color: #1a3a6b !important; border-bottom: 1px solid rgba(0,0,0,0.04); }
.dn-drawer-sub { display: block; padding: 13px 20px 13px 52px; font-size: 14.5px; font-weight: 400; color: #333; border-bottom: 1px solid rgba(0,0,0,0.03); }
.dn-drawer-sub:last-child { border-bottom: none; }

.dn-drawer-bottom { padding: 12px 0; border-top: 1px solid rgba(0,0,0,0.06); margin-top: 4px; }
.dn-drawer-blink { display: flex; align-items: center; gap: 12px; padding: 14px 20px; font-size: 14.5px; font-weight: 500; color: #333; transition: background 0.12s; }
.dn-drawer-blink:hover { background: rgba(0,0,0,0.02); }
.dn-drawer-blink svg { width: 18px; height: 18px; stroke: currentColor; fill: none; stroke-width: 1.7; stroke-linecap: round; stroke-linejoin: round; opacity: 0.5; }
.dn-drawer-blink.dn-drawer-hot { color: #1a3a6b; font-weight: 600; }
.dn-drawer-blink.dn-drawer-hot svg { opacity: 0.8; stroke: #1a3a6b; }

/* ── Call FAB ── */
.dn-call-fab {
	position: fixed; bottom: 24px; right: 24px;
	height: 50px; border-radius: 50px;
	padding: 0 18px 0 14px;
	background: linear-gradient(135deg, #22c55e, #16a34a);
	color: #fff; border: none; cursor: pointer;
	display: flex; align-items: center; justify-content: center; gap: 8px;
	box-shadow: 0 4px 20px rgba(22,163,74,0.35), 0 2px 6px rgba(0,0,0,0.1);
	z-index: 8000;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
	white-space: nowrap;
}
.dn-call-fab:hover { transform: scale(1.05); box-shadow: 0 6px 28px rgba(22,163,74,0.45), 0 3px 8px rgba(0,0,0,0.12); }
.dn-call-fab svg { width: 22px; height: 22px; stroke: #fff; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; flex-shrink: 0; }
.dn-call-fab-label { font-family: 'Inter', sans-serif; font-size: 13px; font-weight: 700; letter-spacing: 0.01em; }
.dn-call-fab::before {
	content: ''; position: absolute; inset: -6px;
	border-radius: 50px; border: 2px solid rgba(34,197,94,0.4);
	animation: dn-pulse 2s ease-out infinite;
}
@keyframes dn-pulse {
	0% { transform: scale(0.97); opacity: 1; }
	100% { transform: scale(1.12); opacity: 0; }
}

.dn-call-popup {
	position: fixed; bottom: 92px; right: 24px;
	width: 300px;
	background: #fff;
	border-radius: 20px;
	border: 1px solid rgba(0,0,0,0.07);
	box-shadow: 0 16px 50px rgba(0,0,0,0.14), 0 4px 12px rgba(0,0,0,0.06);
	z-index: 8001;
	padding: 22px 20px 20px;
	text-align: center;
	font-family: 'Inter', sans-serif;
	opacity: 0; pointer-events: none;
	transform: translateY(10px) scale(0.95);
	transition: all 0.25s cubic-bezier(0.32,0.72,0,1);
}
.dn-call-popup.dn-call-open { opacity: 1; pointer-events: all; transform: translateY(0) scale(1); }
.dn-call-popup-title { font-size: 16px; font-weight: 700; color: #111; margin-bottom: 4px; }
.dn-call-sub { font-size: 12.5px; color: #888; margin-bottom: 14px; line-height: 1.4; }
.dn-call-number {
	display: flex; align-items: center; justify-content: center; gap: 8px;
	font-size: 20px; font-weight: 800; color: #fff !important;
	letter-spacing: 0.02em; margin-bottom: 6px;
	background: linear-gradient(135deg, #22c55e, #16a34a) !important;
	border-radius: 12px; padding: 12px 16px;
	transition: opacity 0.15s; text-decoration: none !important;
}
.dn-call-number:hover { opacity: 0.9; }
.dn-call-number svg { width: 18px; height: 18px; stroke: #fff; fill: none; stroke-width: 2.5; stroke-linecap: round; stroke-linejoin: round; flex-shrink: 0; }
.dn-viber-btn {
	display: flex; align-items: center; justify-content: center; gap: 8px;
	font-size: 15px; font-weight: 700; color: #fff !important;
	background: linear-gradient(135deg, #7360f2, #5b4de8) !important;
	border-radius: 12px; padding: 11px 16px; margin-bottom: 6px;
	transition: opacity 0.15s; text-decoration: none !important;
}
.dn-viber-btn:hover { opacity: 0.9; }
.dn-viber-btn svg { width: 18px; height: 18px; stroke: #fff; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; flex-shrink: 0; }
.dn-call-tap-hint { font-size: 11px; color: #16a34a; font-weight: 600; margin-bottom: 12px; letter-spacing: 0.01em; }
.dn-call-hours-title { display: flex; align-items: center; justify-content: center; gap: 5px; font-size: 12px; font-weight: 600; color: #333; margin-bottom: 6px; }
.dn-call-hours-title svg { width: 14px; height: 14px; stroke: #666; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.dn-call-hours { font-size: 12px; color: #777; line-height: 1.7; }

/* ── Responsive ── */
@media (max-width: 1024px) {
	.dn-island { display: none !important; }
	.dn-mobile-bar { display: flex; }
	.dn-sr-panel { top: 68px; }
	.dn-call-fab { left: 24px; right: auto; }
	.dn-call-popup { left: 24px; right: auto; }
	.dn-call-fab-label { display: none; }
	.dn-call-fab { width: 50px; height: 50px; padding: 0; border-radius: 50%; justify-content: center; }
}
@media (max-width: 400px) {
	.dn-call-popup { width: calc(100vw - 32px); left: 16px; right: auto; }
	.dn-call-fab { bottom: 80px; left: 16px; right: auto; }
}

/* =========================================
   HERO SECTION
   ========================================= */
.dr-hero-section {
	font-family: 'Outfit', 'Inter', sans-serif;
}
.dr-hero-section *,
.dr-hero-section *::before,
.dr-hero-section *::after { box-sizing: border-box; margin: 0; padding: 0; }

.dr-hero {
	display: grid;
	grid-template-columns: 1fr 380px;
	grid-template-rows: 1fr 210px;
	gap: 10px;
	max-width: 1440px;
	margin: 0 auto;
	padding: 10px;
	height: 560px;
}
/* Hide spurious <p>/<br> injected by wpautop inside the grid */
.dr-hero > p, .dr-hero > br { display: none !important; }
/* Explicit grid placement for hero children */
.dr-hero .carousel    { grid-column: 1; grid-row: 1 / 3; }
.dr-hero .promo-card  { grid-column: 2; grid-row: 1; }
.dr-hero .cat-strip   { grid-column: 2; grid-row: 2; }

/* ── Carousel ── */
.dr-hero .carousel {
	position: relative;
	border-radius: 20px;
	overflow: hidden;
	background: #111;
}
.dr-hero .carousel-slides { position: relative; width: 100%; height: 100%; }
.dr-hero .slide { position: absolute; inset: 0; opacity: 0; transition: opacity 0.8s ease; }
.dr-hero .slide.active { opacity: 1; }

.dr-hero .slide-bg {
	position: absolute; inset: 0;
	background-size: cover; background-position: center;
	transform: scale(1);
}
.dr-hero-section.kb-ready .slide-bg { transition: transform 7s ease; }
.dr-hero .slide.active .slide-bg { transform: scale(1.06); }

.dr-hero .slide-overlay {
	position: absolute; inset: 0;
	background:
		linear-gradient(to top, rgba(0,0,0,0.78) 0%, rgba(0,0,0,0.15) 50%, transparent 100%),
		linear-gradient(to right, rgba(0,0,0,0.2) 0%, transparent 50%);
}

.dr-hero .slide-progress {
	position: absolute; bottom: 0; left: 0;
	height: 2px; background: rgba(255,255,255,0.9); width: 0%;
	z-index: 10; transition: none;
}
.dr-hero .slide-progress.running { width: 100%; transition: width 6.1s linear; }

.dr-hero .slide-content { position: absolute; bottom: 44px; left: 40px; right: 40px; z-index: 5; }
.dr-hero .slide-counter { font-size: 11px; font-weight: 400; letter-spacing: 0.18em; color: rgba(255,255,255,0.4); margin-bottom: 14px; }
.dr-hero .slide-content h2 { font-size: clamp(24px, 2.6vw, 40px); font-weight: 700; color: #fff; line-height: 1.1; margin-bottom: 8px; letter-spacing: -0.5px; }
.dr-hero .slide-content p { font-size: 14px; font-weight: 300; color: rgba(255,255,255,0.6); margin-bottom: 22px; letter-spacing: 0.01em; }
.dr-hero .slide-btn {
	display: inline-flex; align-items: center; gap: 9px;
	background: rgba(0,0,0,0.38); border: 1px solid rgba(255,255,255,0.22);
	color: #fff; font-family: 'Outfit', sans-serif; font-size: 13px; font-weight: 500;
	padding: 11px 22px; border-radius: 99px; cursor: pointer;
	transition: background 0.22s, border-color 0.22s, transform 0.22s;
	letter-spacing: 0.02em; text-decoration: none;
}
.dr-hero .slide-btn:hover { background: rgba(255,255,255,0.22); border-color: rgba(255,255,255,0.38); transform: translateY(-1px); }
.dr-hero .slide-btn svg { width: 13px; height: 13px; stroke: currentColor; fill: none; stroke-width: 2.2; stroke-linecap: round; transition: transform 0.2s; }
.dr-hero .slide-btn:hover svg { transform: translateX(3px); }

.dr-hero .carousel-dots { position: absolute; bottom: 22px; left: 50%; transform: translateX(-50%); display: flex; gap: 8px; z-index: 10; }
.dr-hero .dot { width: 8px; height: 8px; border-radius: 99px; background: rgba(255,255,255,0.35); border: none; cursor: pointer; padding: 0; transition: background 0.25s, width 0.35s cubic-bezier(.4,0,.2,1); }
.dr-hero .dot.active { background: #fff; width: 28px; }
.dr-hero .dot:hover:not(.active) { background: rgba(255,255,255,0.6); }

.dr-hero .carousel-arrow {
	position: absolute; top: 50%; transform: translateY(-50%); z-index: 10;
	width: 48px; height: 48px; border-radius: 99px;
	background: rgba(255,255,255,0.15);
	backdrop-filter: blur(12px) saturate(160%);
	-webkit-backdrop-filter: blur(12px) saturate(160%);
	border: 1.5px solid rgba(255,255,255,0.35);
	color: #fff; display: flex; align-items: center; justify-content: center;
	cursor: pointer; transition: background 0.2s, transform 0.2s, border-color 0.2s;
	box-shadow: 0 4px 16px rgba(0,0,0,0.18);
}
.dr-hero .carousel-arrow:hover {
	background: rgba(255,255,255,0.28);
	border-color: rgba(255,255,255,0.6);
	transform: translateY(-50%) scale(1.08);
}
.dr-hero .carousel-arrow svg { width: 20px; height: 20px; stroke: currentColor; fill: none; stroke-width: 2.5; stroke-linecap: round; stroke-linejoin: round; }
.dr-hero .carousel-arrow.prev { left: 20px; }
.dr-hero .carousel-arrow.next { right: 20px; }

/* ── Promo card ── */
.dr-hero .promo-card {
	border-radius: 20px; overflow: hidden; position: relative;
	cursor: pointer; background: #1a1a2e; text-decoration: none; display: block;
	height: 100%; min-height: 0; align-self: stretch;
}
.dr-hero .promo-bg {
	position: absolute; inset: 0;
	background: linear-gradient(135deg, #1a1a2e 0%, #11366b 100%);
	transition: transform 0.55s ease;
}
.dr-hero .promo-card:hover .promo-bg { transform: scale(1.05); }
.dr-hero .promo-content {
	position: absolute; inset: 0; display: flex; flex-direction: column;
	align-items: center; justify-content: center; padding: 20px; text-align: center;
	z-index: 1;
}
.dr-hero .promo-eyebrow { font-size: 10px; font-weight: 600; letter-spacing: 0.2em; text-transform: uppercase; color: rgba(255,255,255,0.5); margin-bottom: 8px; }
.dr-hero .promo-headline { font-size: clamp(18px, 2vw, 28px); font-weight: 800; color: #fff; line-height: 1.1; margin-bottom: 12px; }
.dr-hero .promo-sub { font-size: 12px; font-weight: 400; color: rgba(255,255,255,0.55); }

/* ── Category strip ── */
.dr-hero .cat-strip {
	border-radius: 20px; background: #0d2150;
	display: grid; grid-template-columns: repeat(2, 1fr); grid-auto-rows: 1fr;
	overflow: hidden; position: relative;
	height: 100%; min-height: 0; align-self: stretch;
}
.dr-hero .cat-strip::before,
.dr-hero .cat-strip::after { display: none; }
.dr-hero .cat-btn {
	display: flex; flex-direction: row; align-items: center;
	gap: 12px; padding: 0 18px; cursor: pointer; text-decoration: none;
	position: relative; transition: background 0.18s;
	border-bottom: 1px solid rgba(255,255,255,0.07);
	border-right: 1px solid rgba(255,255,255,0.07);
}
.dr-hero .cat-btn:nth-child(2n)   { border-right: none; }
.dr-hero .cat-btn:nth-last-child(-n+2) { border-bottom: none; }
.dr-hero .cat-btn::after,
.dr-hero .cat-btn + .cat-btn::before { display: none; }
.dr-hero .cat-btn:hover { background: rgba(255,255,255,0.07); }
.dr-hero .cat-btn:hover .cat-label { color: #fff; }
.dr-hero .cat-icon {
	width: 38px; height: 38px; flex-shrink: 0;
	background: rgba(255,255,255,0.1); border-radius: 10px;
	display: inline-flex; align-items: center; justify-content: center;
	vertical-align: middle;
	transition: background 0.18s;
}
.dr-hero .cat-btn:hover .cat-icon { background: rgba(255,255,255,0.2); }
.dr-hero .cat-icon svg {
	width: 18px; height: 18px; fill: none;
	stroke: rgba(255,255,255,0.9); stroke-width: 1.7;
	stroke-linecap: round; stroke-linejoin: round;
}
.dr-hero .cat-label {
	font-size: 13px; font-weight: 600;
	color: rgba(255,255,255,0.82); letter-spacing: 0.01em;
	transition: color 0.18s; white-space: nowrap;
}

/* ── Trust bar ── */
.trust-bar {
	max-width: 1440px; margin: 0 auto; padding: 0 10px 10px;
	display: grid; grid-template-columns: repeat(5, 1fr); gap: 8px;
}
.trust-item {
	background: rgba(255,255,255,0.88); border: 1px solid rgba(255,255,255,0.9);
	border-radius: 14px; padding: 14px 18px;
	display: flex; align-items: center; gap: 13px;
}
.trust-icon {
	width: 34px; height: 34px; border-radius: 10px; background: #11366b;
	display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.trust-icon svg { width: 16px; height: 16px; stroke: #fff; fill: none; stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; }
.trust-text strong { display: block; font-size: 13px; font-weight: 600; color: #111; margin-bottom: 1px; }
.trust-text p { font-size: 11.5px; font-weight: 300; color: #666; margin: 0; }

/* ── Featured products section ── */
.featured-products-section { padding: 0 1.5rem 2rem; }
.featured-products-section .wp-block-heading { margin-top: 24px !important; margin-bottom: 4px !important; }
.featured-products-section p.has-text-align-center { margin-top: 6px !important; margin-bottom: 16px !important; }

/* ── Hero responsive ── */
@media (max-width: 960px) {
	.dr-hero { grid-template-columns: 1fr; grid-template-rows: 320px 130px; height: auto; }
	.dr-hero .carousel    { grid-column: 1; grid-row: 1; }
	.dr-hero .promo-card  { display: none; }
	.dr-hero .cat-strip   { grid-column: 1; grid-row: 2; }
	.trust-bar { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
	.dr-hero { grid-template-rows: 260px 120px; }
	.dr-hero .cat-label { font-size: 10px; }
	.dr-hero .cat-icon { width: 30px; height: 30px; border-radius: 8px; }
	.dr-hero .cat-icon svg { width: 16px; height: 16px; }
	.dr-hero .cat-btn { gap: 8px; padding: 0 12px; }
	.trust-bar { grid-template-columns: 1fr 1fr; gap: 6px; }
	.trust-item { padding: 10px 10px; gap: 8px; }
	.trust-item-title { font-size: 12px; }
	.trust-item-sub { font-size: 10px; }
	.dr-hero .slide-content { left: 20px; right: 20px; bottom: 28px; }
	.dr-hero .slide-content h2 { font-size: clamp(18px, 5vw, 28px); margin-bottom: 4px; }
	.dr-hero .slide-content p { margin-bottom: 14px; font-size: 12px; }
	.dr-hero .slide-btn { font-size: 11px; padding: 9px 16px; }
	.dr-hero .carousel-dots { right: 20px; bottom: 16px; }
	.dr-hero .carousel-arrow { width: 36px; height: 36px; }
	.dr-hero .carousel-arrow.prev { left: 10px; }
	.dr-hero .carousel-arrow.next { right: 10px; }
}

/* ── WooCommerce category page: hide sidebar on mobile, full-width products ── */
@media (max-width: 768px) {
	/* Classic WC sidebar */
	.woocommerce-sidebar,
	.widget-area,
	.woocommerce aside,
	aside.woocommerce-sidebar { display: none !important; }
	/* Block-based WC sidebar/filters */
	.wp-block-woocommerce-collection-filters-overlay-navigation,
	.wp-block-woocommerce-product-collection-filter { display: none !important; }
	/* Make product collection fill full width */
	.wp-block-woocommerce-product-collection,
	.wc-block-product-collection { width: 100% !important; max-width: 100% !important; }
	/* Featured products title on mobile */
	.featured-products-section .wp-block-heading { font-size: clamp(22px, 5vw, 32px) !important; }
	/* Reviews wall side padding on desktop/tablet */
	#dr-reviews-wall { padding-left: 20px; padding-right: 20px; }
}

/* WordPress Block Navigation Menu in Footer */
.dr-footer__menu {
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: 9px;
}

.dr-footer__menu li a {
	font-size: 13px;
	font-weight: 300;
	color: #555;
	text-decoration: none;
	transition: color 0.18s;
	display: flex;
	align-items: center;
	gap: 6px;
}

.dr-footer__menu li a:hover {
	color: #d0d8ff;
}

.dr-footer__legal-menu {
	display: flex;
	gap: 20px;
}

.dr-footer__legal-menu li a {
	font-size: 12px;
	font-weight: 300;
	color: #3a3a3a;
	text-decoration: none;
	transition: color 0.18s;
}

.dr-footer__legal-menu li a:hover {
	color: #888;
}

/* =========================================================
   CUSTOMER REVIEWS SECTION
   ========================================================= */
.dr-reviews-section {
	background: #f8f7f4;
	padding: 5rem 1.5rem;
}
.dr-reviews-inner {
	max-width: 1200px;
	margin: 0 auto;
}
.dr-reviews-header {
	text-align: center;
	margin-bottom: 3rem;
}
.dr-reviews-eyebrow {
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: #b89a6a;
	margin: 0 0 10px;
}
.dr-reviews-title {
	font-size: clamp(1.75rem, 4vw, 2.5rem);
	font-weight: 700;
	color: #111;
	margin: 0 0 16px;
	line-height: 1.15;
}
.dr-reviews-stars-summary {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	flex-wrap: wrap;
}
.dr-reviews-star-row {
	color: #f59e0b;
	font-size: 1.125rem;
	letter-spacing: 2px;
}
.dr-reviews-avg {
	font-size: 1rem;
	font-weight: 700;
	color: #111;
}
.dr-reviews-count {
	font-size: 0.875rem;
	color: #888;
}
.dr-reviews-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1.5rem;
}
.dr-review-card {
	background: #fff;
	border: 1px solid #eae8e3;
	border-radius: 16px;
	padding: 1.75rem;
	display: flex;
	flex-direction: column;
	gap: 1rem;
	transition: box-shadow 0.2s, transform 0.2s;
}
.dr-review-card:hover {
	box-shadow: 0 8px 32px rgba(0, 0, 0, 0.08);
	transform: translateY(-2px);
}
.dr-review-stars {
	color: #f59e0b;
	font-size: 1rem;
	letter-spacing: 2px;
}
.dr-review-text {
	font-size: 0.9375rem;
	color: #444;
	line-height: 1.65;
	margin: 0;
	font-style: italic;
	flex: 1;
}
.dr-review-author {
	display: flex;
	align-items: center;
	gap: 12px;
	padding-top: 1rem;
	border-top: 1px solid #f0ede8;
}
.dr-review-avatar {
	width: 42px;
	height: 42px;
	border-radius: 50%;
	background: #1a3a6b;
	color: #fff;
	font-size: 0.75rem;
	font-weight: 700;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	letter-spacing: 0.04em;
}
.dr-review-info {
	display: flex;
	flex-direction: column;
	gap: 2px;
}
.dr-review-info strong {
	font-size: 0.875rem;
	font-weight: 700;
	color: #111;
}
.dr-review-info span {
	font-size: 0.75rem;
	color: #999;
}
@media (max-width: 768px) {
	.dr-reviews-grid {
		grid-template-columns: 1fr;
	}
}
@media (min-width: 769px) and (max-width: 1024px) {
	.dr-reviews-grid {
		grid-template-columns: repeat(2, 1fr);
	}
	.dr-reviews-grid .dr-review-card:last-child {
		grid-column: 1 / -1;
		max-width: 50%;
		margin: 0 auto;
	}
}

/* =========================================================
   REVIEWS MARQUEE
   ========================================================= */
.dr-marquee-section {
	background: #f8f7f4;
	border-top: 1px solid #ede9e2;
	border-bottom: 1px solid #ede9e2;
	overflow: hidden;
	padding: 14px 0;
}
.dr-marquee-track {
	display: flex;
	align-items: center;
	gap: 0;
	animation: dr-marquee-scroll 40s linear infinite;
	white-space: nowrap;
	width: max-content;
}
.dr-marquee-track:hover { animation-play-state: paused; }
@keyframes dr-marquee-scroll {
	0%   { transform: translateX(0); }
	100% { transform: translateX(-50%); }
}
.dr-marquee-item {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 0 32px;
	flex-shrink: 0;
}
.dr-marquee-stars {
	color: #f5a623;
	font-size: 0.75rem;
	letter-spacing: 1px;
	flex-shrink: 0;
}
.dr-marquee-quote {
	font-size: 0.875rem;
	color: #3a3732;
	font-style: italic;
}
.dr-marquee-author {
	font-size: 0.75rem;
	font-weight: 600;
	color: #8a8478;
	flex-shrink: 0;
}
.dr-marquee-sep {
	font-size: 0.5rem;
	color: #c8c3bb;
	flex-shrink: 0;
	padding: 0 8px;
}
@media (prefers-reduced-motion: reduce) {
	.dr-marquee-track { animation: none; }
}

/* ── Vertical masonry scrolling reviews wall (matches scrolling-reviews.liquid) ── */
#dr-reviews-wall {
	background: #f6f7f9;
	padding: 36px 40px 40px;
	overflow: hidden;
	font-family: inherit;
}
#dr-reviews-wall .rev-label {
	text-align: center;
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.24em;
	text-transform: uppercase;
	color: #9b9b9b;
	margin: 0 0 14px;
}
#dr-reviews-wall .rev-title {
	text-align: center;
	font-family: Georgia, 'Times New Roman', serif;
	font-size: clamp(38px, 5vw, 64px);
	font-weight: 700;
	color: #1a1a1a;
	margin: 0 0 20px;
	line-height: 1.08;
}
#dr-reviews-wall .rev-outer {
	position: relative;
	max-width: 1160px;
	margin: 0 auto;
}
/* Top and bottom gradient fade — the "fade from top/bottom" effect */
#dr-reviews-wall .rev-outer::before,
#dr-reviews-wall .rev-outer::after {
	content: '';
	position: absolute;
	left: 0;
	right: 0;
	height: 130px;
	pointer-events: none;
	z-index: 2;
}
#dr-reviews-wall .rev-outer::before {
	top: 0;
	background: linear-gradient(to bottom, #f6f7f9 0%, transparent 100%);
}
#dr-reviews-wall .rev-outer::after {
	bottom: 0;
	background: linear-gradient(to top, #f6f7f9 0%, transparent 100%);
}
#dr-reviews-wall .rev-cols {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 16px;
	overflow: hidden;
	height: 680px;
}
#dr-reviews-wall .rev-col { overflow: hidden; }
#dr-reviews-wall .rev-inner {
	display: flex;
	flex-direction: column;
	gap: 16px;
	will-change: transform;
}
@keyframes drRevScroll {
	from { transform: translateY(0); }
	to   { transform: translateY(-50%); }
}
#dr-reviews-wall .rev-card {
	background: #ffffff;
	border-radius: 16px;
	padding: 20px 22px;
	flex-shrink: 0;
	box-shadow: 0 1px 4px rgba(0,0,0,0.05);
	transition: box-shadow 0.22s ease, transform 0.22s ease;
}
#dr-reviews-wall .rev-card:hover {
	box-shadow: 0 6px 20px rgba(0,0,0,0.08);
	transform: translateY(-2px);
}
#dr-reviews-wall .rev-stars {
	display: flex;
	gap: 3px;
	margin-bottom: 11px;
}
#dr-reviews-wall .star {
	font-size: 15px;
	line-height: 1;
	color: #e5e7eb;
}
#dr-reviews-wall .star.on { color: #f59e0b; }
#dr-reviews-wall .rev-text {
	font-size: 14px;
	color: #2d2d2d;
	line-height: 1.65;
	margin-bottom: 13px;
}
#dr-reviews-wall .rev-name {
	font-size: 13px;
	font-weight: 600;
	color: #1a1a1a;
	margin-bottom: 2px;
}
#dr-reviews-wall .rev-date {
	font-size: 11.5px;
	color: #9b9b9b;
}
@media (max-width: 860px) {
	#dr-reviews-wall { padding: 28px 16px 32px; }
	#dr-reviews-wall .rev-cols { grid-template-columns: repeat(2, 1fr); height: 460px; }
	#dr-reviews-wall .rev-col:last-child { display: none; }
	#dr-reviews-wall .rev-title { font-size: clamp(28px, 6vw, 42px); margin: 0 0 14px; }
}
@media (max-width: 520px) {
	#dr-reviews-wall { padding: 20px 12px 24px; }
	#dr-reviews-wall .rev-cols { grid-template-columns: 1fr; height: 380px; }
	#dr-reviews-wall .rev-col:nth-child(2) { display: none; }
	#dr-reviews-wall .rev-label { margin: 0 0 8px; }
}
@media (prefers-reduced-motion: reduce) {
	#dr-reviews-wall .rev-inner { animation: none !important; }
}

/* =========================================================
   ANNOUNCEMENT BAR
   ========================================================= */
#dr-announce-bar {
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	width: 100%;
	min-height: 40px;
	padding: 8px 48px;
	background: var(--dr-announce-bg, #1a3a6b);
	color: var(--dr-announce-color, #fff);
	font-size: 0.8125rem;
	font-weight: 500;
	letter-spacing: 0.01em;
	text-align: center;
	z-index: 10001;
	box-sizing: border-box;
}
#dr-announce-bar a {
	color: inherit;
	text-decoration: underline;
	text-underline-offset: 2px;
}
#dr-announce-bar strong { font-weight: 700; }

/* Scrolling marquee variant (when data-scroll="true") */
#dr-announce-bar[data-scroll="true"] {
	overflow: hidden;
	padding: 8px 0;
}
#dr-announce-bar[data-scroll="true"] .dr-announce-track {
	display: flex;
	animation: dr-announce-scroll 28s linear infinite;
	white-space: nowrap;
	gap: 0;
}
#dr-announce-bar[data-scroll="true"] .dr-announce-track:hover {
	animation-play-state: paused;
}
.dr-announce-item {
	flex-shrink: 0;
	padding: 0 48px;
}
.dr-announce-item::after {
	content: '✦';
	margin-left: 48px;
	opacity: 0.5;
}
@keyframes dr-announce-scroll {
	0%   { transform: translateX(0); }
	100% { transform: translateX(-50%); }
}

/* Close button */
.dr-announce-close {
	position: absolute;
	right: 12px;
	top: 50%;
	transform: translateY(-50%);
	background: none;
	border: none;
	cursor: pointer;
	color: inherit;
	opacity: 0.7;
	padding: 4px;
	line-height: 1;
	display: flex;
	align-items: center;
}
.dr-announce-close:hover { opacity: 1; }

@media (max-width: 600px) {
	#dr-announce-bar { font-size: 0.75rem; min-height: 36px; padding: 6px 40px; }
	.dr-announce-item { padding: 0 32px; }
}

