/**
 * ChiroCare Navigation v0.4.1
 *
 * Universelles Hamburger-/Drawer-Konzept für ALLE Viewport-Größen.
 *
 * Designentscheidung (v0.4.1):
 *   Statt klassischer Desktop-Navi-Bar verwenden wir auf allen Bildschirm-
 *   größen denselben Offcanvas-Drawer. Gründe:
 *     - viele Menüpunkte (11+) – horizontal wirkt das gequetscht
 *     - Editorial-Brand-Wirkung à la Aesop, Maude, Hims
 *     - identische Mobile/Desktop-UX, keine Modus-Wechsel
 *     - Fokus auf Logo + primären CTA im Header
 *
 * Wenn klassische Desktop-Navi später wieder gewünscht ist, einfach diese
 * Datei gegen die v0.4.0-Variante zurücktauschen.
 *
 * Regelt:
 *   1) Kadences eingebaute Navigation komplett unterdrücken
 *   2) Hamburger-Toggle (immer sichtbar)
 *   3) Drawer-Panel + Backdrop + Animations
 */

/* ============================================================
 * 1. KADENCE-NAV KOMPLETT UNTERDRÜCKEN (alle Breiten)
 * ============================================================ */

.site-header .main-navigation,
.site-header .primary-navigation,
.site-header .header-navigation,
.site-header .site-header-item .navigation:not(.mobile-navigation),
.site-header .mobile-toggle-open-container,
.site-header .menu-toggle-open,
.site-header .mobile-nav-toggle,
.site-header .drawer-toggle,
.site-header [data-toggle-target*="mobile"],
.site-header .mobile-navigation,
.site-header .site-header-item-mobile-navigation {
	display: none !important;
}

/* Falls Kadence sein eigenes Drawer irgendwo am Body anhängt */
#mobile-drawer,
.mobile-drawer,
.drawer-content-wrap,
.drawer-overlay {
	display: none !important;
}

.site-header .site-main-header-inner-wrap,
.site-header .site-header-row,
.site-header .header-row-layout-standard {
	min-height: var(--cc-header-h);
}

/* ============================================================
 * 2. HAMBURGER TOGGLE (immer sichtbar, fixed oben rechts)
 * ============================================================ */

.cc-nav-toggle {
	position: fixed;
	top: calc((var(--cc-header-h) - 44px) / 2);
	right: var(--cc-gutter);
	z-index: var(--cc-z-toggle);
	display: inline-flex;
	align-items: center;
	gap: 0.55rem;
	padding: 0.55rem 0.95rem 0.55rem 0.8rem;
	min-height: 44px;
	background: rgba(255, 255, 255, 0.96);
	border: 1px solid rgba(20, 19, 22, 0.12);
	border-radius: var(--cc-radius-pill);
	color: var(--cc-text-primary);
	font-family: var(--cc-font-sans);
	font-size: 0.875rem;
	font-weight: 700;
	letter-spacing: 0.02em;
	cursor: pointer;
	box-shadow:
		0 10px 28px rgba(18, 16, 20, 0.10),
		0 2px 6px rgba(18, 16, 20, 0.06);
	backdrop-filter: blur(12px);
	transition:
		background var(--cc-trans-fast),
		transform var(--cc-trans-base),
		box-shadow var(--cc-trans-base),
		border-color var(--cc-trans-fast);
}

.cc-nav-toggle:hover,
.cc-nav-toggle:focus-visible {
	background: #fff;
	border-color: rgba(20, 19, 22, 0.22);
	transform: translateY(-1px);
	box-shadow:
		0 14px 34px rgba(18, 16, 20, 0.14),
		0 4px 10px rgba(18, 16, 20, 0.06);
}

.cc-nav-toggle__bars {
	position: relative;
	width: 20px;
	height: 14px;
	display: inline-block;
	flex-shrink: 0;
}

.cc-nav-toggle__bars span {
	position: absolute;
	left: 0;
	right: 0;
	height: 2px;
	background: currentColor;
	border-radius: 2px;
	transition:
		transform var(--cc-trans-base),
		opacity var(--cc-trans-fast),
		top var(--cc-trans-base);
}

.cc-nav-toggle__bars span:nth-child(1) { top: 0; }
.cc-nav-toggle__bars span:nth-child(2) { top: 6px; }
.cc-nav-toggle__bars span:nth-child(3) { top: 12px; }

.cc-nav-toggle[aria-expanded="true"] .cc-nav-toggle__bars span:nth-child(1) {
	top: 6px;
	transform: rotate(45deg);
}
.cc-nav-toggle[aria-expanded="true"] .cc-nav-toggle__bars span:nth-child(2) {
	opacity: 0;
}
.cc-nav-toggle[aria-expanded="true"] .cc-nav-toggle__bars span:nth-child(3) {
	top: 6px;
	transform: rotate(-45deg);
}

.cc-nav-toggle__label {
	line-height: 1;
}

/* Auf sehr kleinen Screens Label ausblenden, nur Bars zeigen */
@media (max-width: 479px) {
	.cc-nav-toggle__label { display: none; }
	.cc-nav-toggle { padding-inline: 0.7rem; }
}

/* Wenn Drawer offen: Body-Scroll sperren */
body.cc-drawer-open {
	overflow: hidden;
}

/* ============================================================
 * 3. DRAWER PANEL & BACKDROP
 * ============================================================ */

.cc-drawer-backdrop {
	position: fixed;
	inset: 0;
	background: rgba(18, 16, 20, 0.52);
	backdrop-filter: blur(6px);
	opacity: 0;
	z-index: var(--cc-z-backdrop);
	transition: opacity var(--cc-trans-base);
	cursor: pointer;
}

.cc-drawer-backdrop[data-open="true"] {
	opacity: 1;
}

.cc-drawer {
	position: fixed;
	top: 0;
	right: 0;
	bottom: 0;
	/* Auf Desktop spürbar breiter, damit lange Menüpunkte Platz haben */
	width: min(94vw, 460px);
	z-index: var(--cc-z-drawer);
	background:
		radial-gradient(circle at 80% 0%, rgba(200, 167, 158, 0.18), transparent 50%),
		linear-gradient(180deg, #fbf8f3 0%, #f5eee4 100%);
	box-shadow: -24px 0 70px rgba(18, 16, 20, 0.25);
	transform: translateX(100%);
	transition: transform var(--cc-trans-base);
	display: flex;
	flex-direction: column;
	overflow: hidden;
}

.cc-drawer[data-open="true"] {
	transform: translateX(0);
}

.cc-drawer__inner {
	display: flex;
	flex-direction: column;
	height: 100%;
	padding: 1.5rem 1.5rem 1.75rem;
	overflow-y: auto;
	overscroll-behavior: contain;
	-webkit-overflow-scrolling: touch;
}

.cc-drawer__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	padding-bottom: 1.25rem;
	border-bottom: 1px solid rgba(20, 19, 22, 0.08);
	margin-bottom: 1.5rem;
}

.cc-drawer__eyebrow {
	font-family: var(--cc-font-sans);
	font-size: var(--cc-fs-eyebrow);
	font-weight: 700;
	letter-spacing: var(--cc-tracking-eyebrow);
	text-transform: uppercase;
	color: var(--cc-accent);
}

.cc-drawer__brand-link {
	display: inline-flex;
	align-items: center;
	text-decoration: none;
	flex-shrink: 1;
	min-width: 0;
	max-width: calc(100% - 60px);
}

.cc-drawer__brand-link:hover,
.cc-drawer__brand-link:focus-visible {
	text-decoration: none;
	opacity: 0.85;
}

.cc-drawer__logo {
	display: block;
	max-width: 100%;
	height: auto;
	width: auto;
}

.cc-drawer__close {
	-webkit-appearance: none;
	appearance: none;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	flex-shrink: 0;
	margin: 0;
	padding: 0;
	background: rgba(255, 255, 255, 0.96) !important;
	border: 1px solid rgba(20, 19, 22, 0.14) !important;
	border-radius: 50% !important;
	color: var(--cc-text-primary) !important;
	cursor: pointer;
	line-height: 1;
	font: inherit;
	box-shadow: 0 4px 12px rgba(18, 16, 20, 0.08);
	-webkit-tap-highlight-color: transparent;
	transition:
		background var(--cc-trans-fast),
		border-color var(--cc-trans-fast),
		color var(--cc-trans-fast),
		transform var(--cc-trans-fast),
		box-shadow var(--cc-trans-fast);
}

/* SVG explizit auf currentColor, damit Parent-Theme-Regeln nicht
   reinfunken (Kadence setzt auf Buttons gerne eigene Farben). */
.cc-drawer__close svg {
	display: block;
	width: 22px;
	height: 22px;
	color: var(--cc-text-primary);
	stroke: currentColor !important;
	fill: none !important;
	pointer-events: none;
}

.cc-drawer__close:hover,
.cc-drawer__close:focus-visible {
	background: #fff !important;
	border-color: var(--cc-accent) !important;
	color: var(--cc-accent) !important;
	transform: rotate(90deg);
	box-shadow: 0 6px 18px rgba(138, 27, 40, 0.18);
}

.cc-drawer__close:hover svg,
.cc-drawer__close:focus-visible svg {
	color: var(--cc-accent);
}

.cc-drawer__close:active {
	background: #fff !important;
	color: var(--cc-accent-dark) !important;
}

/* Menü im Drawer */
.cc-drawer__nav {
	flex: 1 1 auto;
}

.cc-drawer__menu {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 0.15rem;
}

.cc-drawer__menu li {
	margin: 0;
}

/* ============================================================
 * DRAWER MENU LINKS – Multi-Strategie
 *
 * Wenn diese Regeln nach v0.4.6 IMMER NOCH nicht greifen, ist es
 * zu 99% ein Cache-Problem. Diagnose-Test:
 *   - Im Drawer hat JEDER Menü-Eintrag im Ruhezustand jetzt einen
 *     dünnen 3px transparenten linken Rand. Auf Hover/Focus wird
 *     dieser Rand zu Oxblood-Akzent.
 *   - Wenn der linke Rand (auch transparent) zur Folge hat, dass der
 *     Text leicht eingerückt erscheint, ist die neue CSS aktiv.
 *   - Wenn nicht, ist es Browser- oder Plugin-Cache.
 *
 * Selektor-Strategie: mehrere Selektor-Ketten mit unterschiedlicher
 * Spezifität targeten dasselbe Element. Eine davon MUSS gewinnen.
 * ============================================================ */

/* Tap-Highlight global ausschalten – auf html/body/drawer/menu/item.
   Verschiedene Browser greifen verschiedene Ebenen aus, deshalb alle. */
html,
body,
.cc-drawer,
.cc-drawer__menu,
.cc-drawer__menu li,
.cc-drawer__menu a {
	-webkit-tap-highlight-color: rgba(0, 0, 0, 0) !important;
	-webkit-touch-callout: none;
}

/* === Basis-Styling der Menü-Items === */
.cc-drawer__menu a,
.cc-drawer .cc-drawer__menu a,
aside.cc-drawer .cc-drawer__menu a,
body.cc-theme aside.cc-drawer ul.cc-drawer__menu li a {
	display: flex !important;
	align-items: center !important;
	padding: 1rem 1.1rem !important;
	min-height: var(--cc-touch-target) !important;
	border-radius: var(--cc-radius-md) !important;
	font-family: var(--cc-font-display) !important;
	font-size: 1.15rem !important;
	font-weight: 700 !important;
	line-height: 1.25 !important;
	color: var(--cc-text-primary) !important;
	background: transparent !important;
	background-color: transparent !important;
	text-decoration: none !important;
	border: 1px solid transparent !important;
	border-left: 3px solid transparent !important;
	outline: none !important;
	box-shadow: none !important;
	-webkit-tap-highlight-color: transparent !important;
	cursor: pointer !important;
	transition:
		background-color 200ms ease,
		color 200ms ease,
		border-left-color 200ms ease,
		border-color 200ms ease,
		transform 200ms ease,
		padding-left 200ms ease !important;
}

/* Visited niemals blau */
.cc-drawer__menu a:visited,
aside.cc-drawer .cc-drawer__menu a:visited,
body.cc-theme aside.cc-drawer ul.cc-drawer__menu li a:visited {
	color: var(--cc-text-primary) !important;
}

/* === Hover (Maus + Stift) === */
@media (hover: hover) and (pointer: fine) {
	.cc-drawer__menu a:hover,
	.cc-drawer .cc-drawer__menu a:hover,
	aside.cc-drawer .cc-drawer__menu a:hover,
	body.cc-theme aside.cc-drawer ul.cc-drawer__menu li a:hover {
		background: rgba(138, 27, 40, 0.18) !important;
		background-color: rgba(138, 27, 40, 0.18) !important;
		color: #8A1B28 !important;
		color: var(--cc-accent) !important;
		border-left-color: #8A1B28 !important;
		border-left-color: var(--cc-accent) !important;
		border-left-width: 3px !important;
		padding-left: calc(1.1rem - 0px) !important;
		text-decoration: none !important;
		transform: translateX(3px) !important;
	}
}

/* === Focus (Tastatur) – immer aktiv, unabhängig vom Pointer-Typ === */
.cc-drawer__menu a:focus,
.cc-drawer__menu a:focus-visible,
aside.cc-drawer .cc-drawer__menu a:focus,
aside.cc-drawer .cc-drawer__menu a:focus-visible,
body.cc-theme aside.cc-drawer ul.cc-drawer__menu li a:focus,
body.cc-theme aside.cc-drawer ul.cc-drawer__menu li a:focus-visible {
	background: rgba(138, 27, 40, 0.18) !important;
	background-color: rgba(138, 27, 40, 0.18) !important;
	color: #8A1B28 !important;
	color: var(--cc-accent) !important;
	border-left-color: #8A1B28 !important;
	border-left-color: var(--cc-accent) !important;
	outline: 2px solid rgba(138, 27, 40, 0.4) !important;
	outline-offset: 2px !important;
	text-decoration: none !important;
	transform: translateX(3px) !important;
}

/* === Active (Touch-Tap & Mouse-Down) – das ist der primäre Feedback-
       Mechanismus auf mobilen Geräten === */
.cc-drawer__menu a:active,
aside.cc-drawer .cc-drawer__menu a:active,
body.cc-theme aside.cc-drawer ul.cc-drawer__menu li a:active {
	background: rgba(138, 27, 40, 0.28) !important;
	background-color: rgba(138, 27, 40, 0.28) !important;
	color: #6A1120 !important;
	color: var(--cc-accent-dark) !important;
	border-left-color: #6A1120 !important;
	border-left-color: var(--cc-accent-dark) !important;
	border-left-width: 4px !important;
	transform: translateX(4px) scale(0.98) !important;
	transition:
		background-color 80ms ease,
		color 80ms ease,
		transform 80ms ease !important;
}

/* === Aktueller Menü-Eintrag (current page) === */
.cc-drawer__menu .current-menu-item > a,
.cc-drawer__menu .current_page_item > a,
aside.cc-drawer .cc-drawer__menu .current-menu-item > a,
body.cc-theme aside.cc-drawer ul.cc-drawer__menu li.current-menu-item > a,
body.cc-theme aside.cc-drawer ul.cc-drawer__menu li.current_page_item > a {
	color: #8A1B28 !important;
	color: var(--cc-accent) !important;
	background: rgba(138, 27, 40, 0.10) !important;
	background-color: rgba(138, 27, 40, 0.10) !important;
	border-left-color: #8A1B28 !important;
	border-left-color: var(--cc-accent) !important;
}

/* Submenus als eingerückte Liste */
.cc-drawer__menu .sub-menu,
.cc-drawer__menu ul {
	list-style: none;
	margin: 0.15rem 0 0.45rem 0.85rem;
	padding: 0 0 0 0.85rem;
	border-left: 1px solid rgba(20, 19, 22, 0.10);
	display: flex;
	flex-direction: column;
	gap: 0.05rem;
}

.cc-drawer__menu .sub-menu a {
	font-size: 1rem;
	font-weight: 600;
	font-family: var(--cc-font-sans);
	padding: 0.7rem 0.9rem;
	min-height: 40px;
}

/* CTA im Drawer */
.cc-drawer__cta {
	display: flex;
	flex-direction: column;
	gap: 0.6rem;
	margin-top: 1.75rem;
	padding-top: 1.5rem;
	border-top: 1px solid rgba(20, 19, 22, 0.08);
}

.cc-drawer__cta .cc-btn {
	width: 100%;
}

/* Meta (Adresse + Öffnungszeiten) */
.cc-drawer__meta {
	margin-top: 1.5rem;
	padding-top: 1.25rem;
	border-top: 1px solid rgba(20, 19, 22, 0.08);
}

.cc-drawer__meta p {
	margin: 0 0 0.7rem;
	font-size: var(--cc-fs-small);
	line-height: 1.55;
	color: var(--cc-text-tertiary);
}

.cc-drawer__meta p:last-child { margin-bottom: 0; }

.cc-drawer__meta strong {
	color: var(--cc-text-primary);
	font-weight: 700;
}

/* Reduced Motion */
@media (prefers-reduced-motion: reduce) {
	.cc-drawer,
	.cc-drawer-backdrop,
	.cc-nav-toggle__bars span {
		transition: none !important;
	}

	.cc-drawer {
		transform: translateX(0);
		opacity: 0;
		pointer-events: none;
	}

	.cc-drawer[data-open="true"] {
		opacity: 1;
		pointer-events: auto;
	}
}
