/* ========================================
   PsychCast mit Jan – Custom CSS
   Stand: April 2026 (bereinigt)
   ======================================== */
/* === 1. Schriften === */
.site-title,
.site-title a,
.site-description {
	display: none !important;
}

h1, h2, h3, h4, h5, h6,
.entry-title,
.entry-title a,
.page-title,
.widget-title,
.wp-block-heading {
	font-family: 'Rajdhani', sans-serif !important;
}

h1.wp-block-heading {
	line-height: 1.2;
}

.main-navigation,
.main-navigation a,
.menu-item a,
nav a {
	font-family: 'Rajdhani', sans-serif !important;
	font-weight: 600;
	font-size: 25px !important;
	letter-spacing: .04em;
	text-transform: none !important;
}

/* === 2. Farben & Links === */
a {
	color: #4BB3F9;
}

a:hover {
	color: #2a9de8;
}

/* === 3. Buttons === */
/* Content-Buttons: PsychCast-Blau */
.wp-block-button__link,
.wp-element-button {
	background-color: #4BB3F9 !important;
	border-color: #4BB3F9 !important;
	color: #ffffff !important;
	font-family: 'Rajdhani', sans-serif !important;
	font-weight: 700;
	border-radius: 8px !important;
	padding: 14px 28px !important;
}

.wp-block-button__link:hover {
	background-color: #2196F3 !important;
	border-color: #2196F3 !important;
}

.wp-block-buttons {
	margin-top: 24px !important;
	margin-bottom: 8px !important;
}

/* Suche & Formulare: Akzent-Rot */
.search-submit,
input[type="submit"] {
	background-color: #F40808 !important;
	border-color: #F40808 !important;
	color: #ffffff !important;
	font-family: 'Rajdhani', sans-serif !important;
	font-weight: 700;
	border-radius: 8px !important;
}

/* === 4. Layout === */
.site-content {
	max-width: 1080px !important;
	margin-left: auto !important;
	margin-right: auto !important;
}

.content-area {
	width: 100% !important;
	max-width: 1000px !important;
	margin: 0 auto !important;
	float: none !important;
}

body.page .site-content {
	padding-left: 20px !important;
}

/* Sidebar: Flexbox auf Desktop (Blog/Archiv) */
@media (min-width: 1000px) {
	.site-content {
		display: flex !important;
		flex-wrap: nowrap !important;
		overflow: hidden !important;
	}
	
	.content-area {
		flex: 1 1 0 !important;
		min-width: 0 !important;
		overflow: hidden !important;
	}
	
	.site-main {
		margin-right: 0 !important;
		width: auto !important;
	}
	
	.widget-area {
		flex: 0 0 250px !important;
		width: 250px !important;
		float: none !important;
		margin-left: 20px !important;
	}
}

/* Seiten: Sidebar ausblenden, volle Breite */
body.page .widget-area {
	display: none !important;
}

body.page .content-area {
	width: 100% !important;
	max-width: 100% !important;
	flex: 1 1 100% !important;
}

/* === 5. Navigation: Hover-Effekte === */
.main-navigation a,
.main-navigation .menu-item a {
	position: relative;
	transition: color .3s ease !important;
}

.main-navigation a::after {
	content: '';
	position: absolute;
	bottom: -2px;
	left: 50%;
	width: 0;
	height: 2px;
	background: #4BB3F9;
	transition: width .3s ease, left .3s ease;
}

.main-navigation a:hover::after,
.main-navigation .current-menu-item > a::after {
	width: 100%;
	left: 0;
}

.main-navigation a:hover {
	color: #4BB3F9 !important;
}

.main-navigation a:hover,
.main-navigation .current-menu-item > a {
	border-radius: 8px !important;
}

/* === 6. Header === */
.site-header {
	background-position: 75% center !important;
}

@media (max-width: 768px) {
	.site-header {
		background-position: 36% 50% !important;
	}
	
	.entry-content h1.wp-block-heading {
		font-size: 36px !important;
		line-height: 1.2 !important;
	}
}

/* === 7. Kacheln (Startseite & Unterseiten) === */
.wp-block-group.has-very-light-gray-background-color.has-background {
	padding: 14px 16px !important;
	min-height: 0 !important;
	background-color: #e8f2fa !important;
	border: 5px solid #fff !important;
	border-left: 15px solid #4BB3F9 !important;
	border-radius: 6px !important;
	box-shadow: 2px 4px 6px rgba(0,0,0,0.08), 6px 12px 24px rgba(0,0,0,0.12), 0 0 0 1px rgba(0,0,0,0.05) !important;
	transition: all .2s ease !important;
	position: relative !important;
	cursor: pointer !important;
}

.wp-block-group.has-very-light-gray-background-color.has-background:hover,
.wp-block-group.has-very-light-gray-background-color.has-background:active {
	transform: translateY(-3px) !important;
	border-color: #4BB3F9 !important;
	box-shadow: 0 12px 24px rgba(75,179,249,0.2), 0 24px 48px rgba(0,0,0,0.14), 0 0 0 1px rgba(75,179,249,0.15) !important;
}

body .entry-content .wp-block-group.has-very-light-gray-background-color h3.wp-block-heading {
	font-size: 17px !important;
	font-weight: 600 !important;
	margin-bottom: 4px !important;
	margin-top: 0 !important;
	color: #2c3e50 !important;
}

.wp-block-group.has-very-light-gray-background-color .wp-block-paragraph {
	font-size: 19.5px !important;
	line-height: 1.6 !important;
	margin-bottom: 5px !important;
	color: #444 !important;
}

.wp-block-group.has-very-light-gray-background-color .wp-block-paragraph:last-child {
	margin-bottom: 0 !important;
}

.wp-block-group.has-very-light-gray-background-color a {
	color: #4BB3F9 !important;
	font-weight: 600 !important;
	text-decoration: none !important;
	font-family: 'Rajdhani', sans-serif !important;
	letter-spacing: .03em !important;
}

.wp-block-group.has-very-light-gray-background-color a:hover {
	color: #F40808 !important;
}

/* Kacheln komplett klickbar */
.wp-block-group.has-very-light-gray-background-color .wp-block-paragraph:last-child a::after {
	content: '' !important;
	position: absolute !important;
	top: 0 !important;
	left: 0 !important;
	right: 0 !important;
	bottom: 0 !important;
	z-index: 1 !important;
}

/* Kacheln-Abstand zwischen Reihen */
.entry-content .wp-block-columns + .wp-block-columns {
	margin-top: 20px !important;
}

/* Kacheln am Handy einspaltig */
@media (max-width: 768px) {
	.page-id-218057 .entry-content .wp-block-columns {
		flex-direction: column !important;
	}
	
	.page-id-218057 .entry-content .wp-block-column {
		flex-basis: 100% !important;
		width: 100% !important;
	}
}

/* === 8. Bilder: 3D-Rahmen & Hover === */
.wp-block-image img,
.entry-content figure.wp-block-image img,
.entry-content .wp-block-image img,
.widget_media_image img,
.widget_media_gallery img {
	border: 5px solid #ffffff;
	border-radius: 10px;
	box-shadow: 2px 4px 6px rgba(0,0,0,0.08), 6px 12px 24px rgba(0,0,0,0.12), 0 0 0 1px rgba(0,0,0,0.05);
	transform: none;
	transition: transform .35s ease, box-shadow .35s ease, border-color .35s ease;
	display: block;
}

.wp-block-image img:hover,
.entry-content figure.wp-block-image img:hover,
.entry-content .wp-block-image img:hover,
.widget_media_image img:hover,
.widget_media_gallery img:hover {
	transform: translateY(-6px) scale(1.02);
	box-shadow: 0 12px 24px rgba(75,179,249,0.20), 0 24px 48px rgba(0,0,0,0.14), 0 0 0 1px rgba(75,179,249,0.15);
	border-color: #4BB3F9;
}

/* Bilder: zentriert, kein Float */
.entry-content .wp-block-image,
.entry-content .alignright,
.entry-content .alignleft {
	float: none !important;
	margin-left: auto !important;
	margin-right: auto !important;
	display: block !important;
	text-align: center !important;
	max-width: 100% !important;
}

.entry-content .alignright img,
.entry-content .alignleft img {
	max-width: 100% !important;
	height: auto !important;
}

.entry-content figure {
	text-align: center !important;
}

.entry-content figure img {
	margin-left: auto !important;
	margin-right: auto !important;
}

body.page .entry-content figure {
	text-align: center !important;
}

body.page .entry-content figure img {
	margin-left: auto !important;
	margin-right: auto !important;
}

/* Links in Bildern als Block */
.wp-block-image > a,
.wp-block-image > figure > a {
	display: block !important;
}

/* Bildgrößen: ~55% Desktop, 100% Mobile */
.entry-content .wp-block-image img,
.entry-content figure.aligncenter img,
.entry-content figure.alignright img,
.entry-content figure.alignleft img,
.entry-content .wp-block-image.aligncenter img {
	max-width: 55% !important;
	width: auto !important;
	height: auto !important;
}

@media (max-width: 768px) {
	.entry-content .wp-block-image img,
							.entry-content figure.aligncenter img,
							.entry-content figure.alignright img,
							.entry-content figure.alignleft img,
							.entry-content .wp-block-image.aligncenter img {
		max-width: 100% !important;
	}
}

/* Seiten: Bilder 75% Desktop */
body.page .entry-content .wp-block-image.aligncenter img {
	width: 75% !important;
	height: auto !important;
}

@media (max-width: 767px) {
	body.page .entry-content .wp-block-image.aligncenter img {
		width: 100% !important;
	}
}

/* Abstand unter Bildern */
.entry-content .wp-block-image,
.entry-content figure.wp-block-image {
	margin-bottom: 30px !important;
}

/* === 9. Sidebar-Widgets === */
.widget_custom_html img {
	border: 5px solid #fff;
	border-radius: 10px;
	box-shadow: 2px 4px 6px rgba(0,0,0,0.08), 6px 12px 24px rgba(0,0,0,0.12), 0 0 0 1px rgba(0,0,0,0.05);
	transform: none;
	transition: transform .35s ease, box-shadow .35s ease, border-color .35s ease;
	display: block;
	margin: 0 auto 12px;
	width: 175px !important;
	height: auto;
}

.widget_custom_html img:hover {
	transform: translateY(-6px) scale(1.02);
	box-shadow: 0 12px 24px rgba(75,179,249,0.20), 0 24px 48px rgba(0,0,0,0.14), 0 0 0 1px rgba(75,179,249,0.15);
	border-color: #4BB3F9;
}

.widget_custom_html .textwidget {
	text-align: center;
}

/* Suchformular in Sidebar */
.widget_custom_html .search-form {
	display: flex !important;
	flex-direction: column !important;
	gap: 6px !important;
	position: relative !important;
}

.widget_custom_html .search-form label {
	display: block !important;
	width: 100% !important;
	position: relative !important;
}

.widget_custom_html .search-field {
	width: 100% !important;
	box-sizing: border-box !important;
	display: block !important;
	position: relative !important;
}

.widget_custom_html .search-submit {
	width: 100% !important;
	display: block !important;
	position: relative !important;
}

/* === 10. Spalten-Layout === */
/* Unterseiten (nicht Startseite): einspaltig */
body.page:not(.page-id-218057) .entry-content .wp-block-columns {
	flex-direction: column !important;
}

body.page:not(.page-id-218057) .entry-content .wp-block-column {
	flex-basis: 100% !important;
	width: 100% !important;
}

/* Media-Text-Blöcke einspaltig auf Unterseiten */
body.page:not(.page-id-218057) .entry-content .wp-block-media-text {
	grid-template-columns: 1fr !important;
}

body.page:not(.page-id-218057) .entry-content .wp-block-media-text .wp-block-media-text__media,
body.page:not(.page-id-218057) .entry-content .wp-block-media-text .wp-block-media-text__content {
	grid-column: 1 !important;
}

/* Desktop: 2 Spalten nebeneinander */
@media (min-width: 768px) {
	body.page .site-content .entry-content .wp-block-columns {
		flex-direction: row !important;
		flex-wrap: wrap !important;
		gap: 6px !important;
	}
	
	body.page .site-content .entry-content .wp-block-columns > .wp-block-column {
		flex-basis: calc(50% - 3px) !important;
		flex-grow: 0 !important;
		min-width: 0 !important;
		max-width: calc(50% - 3px) !important;
	}
}

/* Mobile: einspaltig */
@media (max-width: 767px) {
	body.page .site-content .entry-content .wp-block-columns {
		flex-direction: column !important;
		gap: 10px !important;
	}
	
	body.page .site-content .entry-content .wp-block-columns > .wp-block-column {
		flex-basis: 100% !important;
		max-width: 100% !important;
	}
}

/* === 11. Trennlinien === */
.entry-content hr,
.entry-content .wp-block-separator {
	margin-top: 40px !important;
	margin-bottom: 40px !important;
}

/* === 12. Footer === */
.site-footer {
	background: #1a1a2e !important;
	color: #e0e0e0 !important;
	padding: 40px 0 30px !important;
	text-align: center;
}

.site-footer a {
	color: #4BB3F9 !important;
	text-decoration: none !important;
	transition: color .3s ease, opacity .3s ease !important;
}

.site-footer a:hover {
	color: #fff !important;
	opacity: .9;
}

.footer-social-links {
	display: flex;
	justify-content: center;
	gap: 24px;
	margin-bottom: 16px;
	font-size: 15px;
}

.footer-social-links a {
	padding: 6px 12px;
	border: 1px solid rgba(75,179,249,0.3);
	border-radius: 6px;
	transition: all .3s ease !important;
}

.footer-social-links a:hover {
	border: 1px solid #4BB3F9 !important;
	background: rgba(75,179,249,0.1);
}

.footer-claim {
	font-style: italic;
	color: #999;
	font-size: 16px !important;
	margin-top: 12px;
}

.footer-claim a {
	color: #999 !important;
	text-decoration: none !important;
}

.footer-claim a:hover {
	color: #666 !important;
	text-decoration: underline !important;
}

.site-footer .site-info {
	display: none;
}

/* === 13. Blockquotes / Testimonials === */
.wp-block-quote {
	position: relative !important;
	background: #f0f7fd !important;
	border-left: 4px solid #4BB3F9 !important;
	border-radius: 0 12px 12px 0 !important;
	padding: 32px 32px 24px 56px !important;
	margin: 24px 0 !important;
	box-shadow: 0 2px 8px rgba(75,179,249,0.08) !important;
}

.wp-block-quote::before {
	content: "\201E" !important;
	position: absolute !important;
	top: 12px !important;
	left: 14px !important;
	font-size: 56px !important;
	line-height: 1 !important;
	color: #4BB3F9 !important;
	font-family: Georgia, serif !important;
	opacity: .6 !important;
}

.wp-block-quote p {
	font-size: 18px !important;
	line-height: 1.6 !important;
	color: #333 !important;
	font-style: italic !important;
	margin-bottom: 8px !important;
}

.wp-block-quote cite {
	display: block !important;
	font-size: 15px !important;
	color: #4BB3F9 !important;
	font-style: normal !important;
	font-weight: 600 !important;
	margin-top: 8px !important;
	font-family: Rajdhani, sans-serif !important;
}

@media (max-width: 480px) {
	.wp-block-quote {
		padding: 24px 20px 20px 44px !important;
	}
	
	.wp-block-quote::before {
		font-size: 44px !important;
		left: 10px !important;
		top: 8px !important;
	}
	
	.wp-block-quote p {
		font-size: 16px !important;
	}
}

/* === 14. Timeline (Berufliche Laufbahn) === */
.timeline-section .wp-block-paragraph {
	padding-left: 20px !important;
	border-left: 3px solid #4BB3F9 !important;
	margin-bottom: 8px !important;
	font-size: 17px !important;
	line-height: 1.6 !important;
	color: #444 !important;
}

.timeline-section .wp-block-paragraph strong {
	color: #2c3e50 !important;
	font-family: Rajdhani, sans-serif !important;
	font-size: 19px !important;
}

/* === 15. "Gefaellt mir" ausblenden === */
.sharedaddy,
.sd-like-enabled,
.likes-widget-placeholder,
div[class*="like"],
.wpl-likebox,
iframe[src*="like"] {
	display: none !important;
}

/* === 16. Newsletter Slide-In === */
#newsletter-slidein {
	position: fixed !important;
	bottom: 24px !important;
	right: 24px !important;
	width: 370px !important;
	background: #ffffff !important;
	border-radius: 16px !important;
	box-shadow: 0 8px 32px rgba(0,0,0,0.12), 0 2px 8px rgba(0,0,0,0.06), 0 0 0 1px rgba(75,179,249,0.15) !important;
	overflow: hidden !important;
	z-index: 99999 !important;
	animation: ns-slidein .5s cubic-bezier(0.34,1.56,0.64,1) 90s both !important;
}

.ns-accent {
	height: 5px !important;
	background: linear-gradient(90deg, #4BB3F9, #2196F3, #4BB3F9) !important;
	background-size: 200% 100% !important;
	animation: ns-shimmer 3s ease-in-out infinite !important;
}

@keyframes ns-shimmer {
	0%, 100% {
		background-position: 0 50%;
	}
	
	50% {
		background-position: 100% 50%;
	}
}

.ns-body {
	padding: 24px 24px 20px !important;
}

a.ns-close {
	position: absolute !important;
	top: 14px !important;
	right: 14px !important;
	width: 28px !important;
	height: 28px !important;
	border: none !important;
	background: rgba(0,0,0,0.05) !important;
	border-radius: 50% !important;
	cursor: pointer !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	font-size: 16px !important;
	color: #888 !important;
	line-height: 1 !important;
	padding: 0 !important;
	min-height: 0 !important;
	text-decoration: none !important;
}

a.ns-close:hover {
	background: rgba(0,0,0,0.1) !important;
	color: #555 !important;
}

.ns-icon {
	width: 44px !important;
	height: 44px !important;
	background: linear-gradient(135deg, #4BB3F9 0%, #2196F3 100%) !important;
	border-radius: 12px !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	margin-bottom: 16px !important;
	font-size: 26px !important;
	line-height: 44px !important;
	text-align: center !important;
	color: white !important;
}

.ns-icon svg {
	width: 24px !important;
	height: 24px !important;
	fill: white !important;
}

#newsletter-slidein .ns-title {
	font-family: Rajdhani, sans-serif !important;
	font-size: 22px !important;
	font-weight: 700 !important;
	color: #2c3e50 !important;
	line-height: 1.2 !important;
	margin-bottom: 8px !important;
}

#newsletter-slidein .ns-text {
	font-size: 15px !important;
	color: #666 !important;
	line-height: 1.5 !important;
	margin-bottom: 20px !important;
}

a.ns-cta {
	display: block !important;
	width: 100% !important;
	padding: 14px 20px !important;
	background: linear-gradient(135deg, #4BB3F9 0%, #2196F3 100%) !important;
	color: white !important;
	border: none !important;
	border-radius: 10px !important;
	font-family: Rajdhani, sans-serif !important;
	font-size: 17px !important;
	font-weight: 600 !important;
	cursor: pointer !important;
	text-align: center !important;
	text-decoration: none !important;
	box-shadow: 0 4px 12px rgba(75,179,249,0.3) !important;
}

a.ns-cta:hover {
	box-shadow: 0 6px 20px rgba(75,179,249,0.4) !important;
	color: white !important;
}

a.ns-skip {
	display: block !important;
	text-align: center !important;
	margin-top: 12px !important;
	font-size: 13px !important;
	color: #aaa !important;
	cursor: pointer !important;
	background: none !important;
	border: none !important;
	font-family: Lato, sans-serif !important;
	padding: 0 !important;
	min-height: 0 !important;
	text-decoration: none !important;
}

a.ns-skip:hover {
	color: #777 !important;
}

@media (max-width: 480px) {
	#newsletter-slidein {
		right: 12px !important;
		left: 12px !important;
		bottom: 12px !important;
		width: auto !important;
	}
}

#newsletter-slidein:target {
	animation: ns-slideout .35s ease-in forwards !important;
	pointer-events: none !important;
}

@keyframes ns-slidein {
	from {
		transform: translateY(120%);
		opacity: 0;
	}
	
	to {
		transform: translateY(0);
		opacity: 1;
	}
}

@keyframes ns-slideout {
	from {
		transform: translateY(0);
		opacity: 1;
	}
	
	to {
		transform: translateY(120%);
		opacity: 0;
	}
}

/* === 17. Videokurse: Kacheln groesser === */
.page-id-249769 .entry-content .wp-block-column .wp-block-image img {
	max-width: 90% !important;
	height: auto !important;
}

.page-id-249769 .entry-content .wp-block-column .wp-block-image {
	display: flex !important;
	justify-content: center !important;
}

/* Sticky Navigation Menu */
.site-top {
	position: fixed;
	top: 32px;
/* unterhalb der WP Admin-Bar */
	left: 0;
	right: 0;
	z-index: 9999;
	background: #2c3e50;
}

/* Platzhalter damit der Content nicht hinter dem fixierten Menü verschwindet */
.site-header {
	margin-top: 100px;
}

/* Für ausgeloggte Besucher: Admin-Bar fehlt, also top: 0 */
body:not(.admin-bar) .site-top {
	top: 0;
}

body:not(.admin-bar) .site-header {
	margin-top: 100px;
}

/* === 7. MOBILE HEADER FIX ===
   Auf Mobile wird das panoramische Header-Bild (1599x219px) 
   durch HTML-Text auf blauem Hintergrund ersetzt,
   da das Bild bei kleinen Viewports stark beschnitten wird.
   Stand: April 2026
   =============================== */
@media (max-width: 768px) {
	.site-header {
		background-image: none !important;
		min-height: auto !important;
	}
	
	.site-header .site-branding {
		padding: 22px 20px !important;
	}
	
	.site-header .site-title,
	  .site-header .site-title a,
	  .site-header .site-description {
		display: block !important;
	}
	
	.site-header .site-title {
		font-size: 32px !important;
		margin: 0 !important;
		line-height: 1.2 !important;
		text-transform: none !important;
		letter-spacing: normal !important;
	}
	
	.site-header .site-title a {
		color: #ffffff !important;
		font-style: normal !important;
		font-weight: bold !important;
		text-decoration: none !important;
		text-transform: none !important;
		letter-spacing: normal !important;
		text-shadow: 1px 1px 3px rgba(0,0,0,0.3) !important;
	}
	
	.site-header .site-description {
		color: #CA281F !important;
		font-size: 16px !important;
		font-weight: bold !important;
		font-style: italic !important;
		margin-top: 4px !important;
		line-height: 1.3 !important;
		text-transform: none !important;
		letter-spacing: normal !important;
	}
}

/* Tablet: Header-Bild bleibt, aber bessere Zentrierung */
@media (min-width: 769px) and (max-width: 1024px) {
	.site-header {
		background-position: center center !important;
	}
}