﻿@import url("fonts.css");

:root {
	--color-bg-stefanie: 	#E6F7EC;
	--color-bg-green-light: #F1FBF3;
	--color-bg-green-dark:  #DCEDE0;
	
	--color-h2-stefanie:  #2f7966;
	--color-h3-stefanie:  #144d3f;
	--color-p-stefanie:   #3d6157;
	
	--color-bg-michael: 	#EFFBFF;
	--color-bg-blue-light:  #F5FDFF;
	--color-bg-blue-dark:   #DDEFF2;
	
	--color-h2-michael:  #2F5A79;
	--color-h3-michael:  #14405A;
	--color-p-michael:   #3d5061;

  --color-bullet: #333;
	
	--color-button-bg:          #4CAF50;   /* Primary */
	--color-button-bg-hover:    #43A047;   /* Darken by ~10% for hover */
	--color-button-bg-focus:    #81C784;   /* Lighten by ~20% for focus outline */
	--color-button-bg-disabled: #C8E6C9;   /* Lighten by ~60% for disabled */
	--color-button-focus: 		#88ee88;
		
	--color-text: 			 #333; /* #4B5563; /* #333; */
	--color-text-accent: 	#2f7966;
	--color-h:				#1F2937; /*#144d3f;*/
	--fs-h1:      			2.3rem;
	--fs-footer:  			0.9rem;
	--lh-footer:  			1.5;
}

body {
  font-family: 'Nunito', sans-serif;
  background: var(--color-gray-50);
  color: var(--color-text);
  font-size: clamp(16px, 1.2vw, 20px);
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}

a:hover,
a:focus { 
  color: var(--color-button-bg-hover); 
}

.stefanie {
	background-color: var(--color-bg-stefanie);
}

.col-section.stefanie {
	background-image: linear-gradient(
		135deg,
		var(--color-bg-green-light) 0%,
		var(--color-bg-green-dark)  100%
	);
}

.col-section.stefanie h2 {
  color: var(--color-h2-stefanie); 
}

.col-section.stefanie h3 {
  color: var(--color-h3-stefanie); 
}

.col-section.stefanie p {
  color: var(--color-p-stefanie);
}

.michael {
	background-color: var(--color-bg-michael);
	
}

.col-section.michael {
	background-image: linear-gradient(
		135deg,
		var(--color-bg-blue-light) 0%,
		var(--color-bg-blue-dark)  100%
	);
}

.col-section.michael h2 {
  color: var(--color-h2-michael); 
}

.col-section.michael h3 {
  color: var(--color-h3-michael); 
}

.col-section.michael p {
  color: var(--color-p-michael);
}


#page-wrapper {
	max-width: 800px;
	margin: 0 auto;
	padding: var(--space-sm);
	display: flex;
	flex: 1;
	flex-direction: column;
	min-height: calc(var(--vh, 1vh) * 100);
	min-height: 100dvh;
}

#main-wrapper {
  flex: 1;
  padding: var(--space-sm);
}

.hero-image {
  max-width: 100%;
  height: auto;
  border-radius: var(--radius-lg);
  display: block;
  margin: var(--space-lg) auto 0 auto;
}

#contact-page {
	padding: var(--space-sm);
  background-color: white;
  margin-bottom: 2rem;
}

.xsubmit-button {
	all: unset; 
}

.btn-action {
	margin: var(--space-md) 0 var(--space-md);
	background-color: var(--color-button-bg);
	    padding: var(--space-md) var(--space-lg);
		font-weight: 600;
    font-size: var(--fs-button);
	border-radius: var(--radius-md);
}

.btn-action:focus-visible {
	/* Replace the default outline */
  outline: none;

    /* Optional glow to make it pop */
  box-shadow: 0 0 0 4px rgba(136, 238, 136, 0.5);
}

.btn-action:hover {
background-color: var(--color-button-bg-hover);
  color: white;
}

.btn-action:focus {
	background-color: var(--color-button-bg-hover);
  color: white;
}

h1, h2:not(.plain), h3:not(.plain) {
    font-family: 'Marck Script', cursive;
    font-weight: 600;
}



h2:not(.plain), h3:not(.plain) {
  font-size: 2.1rem;
  font-weight: var(--fw-normal);
  color: var(--color-h); /*var(--color-text-accent);*/
  margin-bottom: var(--space-md);
  display: block;
  letter-spacing: 0.5px;
  text-shadow: var(--shadow-sm);
}

h2.plain, h3.plain {
    font-size: var(--fs-h3);
    line-height: var(--lh-heading);
	margin-top: 1em;
    margin-bottom: var(--space-sm);
}

 

h2.hidden {
	display: none;
}

.section {
	padding: var(--space-lg);
}

.col-section {
	padding: var(--space-lg);
    border-radius: var(--radius-lg);
    margin: 1rem 0;
    box-shadow: var(--shadow-md);
}

.col-section h4, h3.fs-h2 {
	margin-top: var(--space-xs);
	margin-bottom: var(--space-sm);
	font-size: 1.45rem;
	line-height: 1.6;
	color: var(--color-h);
}

.col-section h5 {
	margin-top: var(--space-md);
	    font-size: 1.2rem;
}

#cta-heading, #section-offer-heading, #praxis-heading {
	    color: var(--color-text);
    margin-top: var(--space-lg);
}


.contact-person {
  padding: 1.2em;
  border-radius: 10px;
  margin: 1em 0;
  box-shadow: 0 1px 4px rgba(0,0,0,0.05);
}

.contact-address {
  line-height: 1.5rem;
  font-style: normal;
}

.section h3 {
  color: var(--color-text);
  margin-top: var(--space-lg);
}

.section h4 {
	    margin-top: 1em;
    _margin-bottom: var(--space-sm);
}

.section h5 {
    margin-top: var(--space-lg);
}

ul {
	padding-left: var(--space-xl);
}

header {
	padding: var(--space-md) var(--space-lg);
}

h1 {
	padding-top: var(--space-md);
	padding-bottom: var(--space-xs);
}

section + p {
  margin: 3.5rem 0 1.5rem;
}

/* --- a, button --- */

/* 1) Ensure theyâ€™re animatable */
a,
btn-action {
  display: inline-block;            /* so transform only affects the element, not the whole line */
  transition: transform 0.15s ease; /* smooth, quick zoom */
  color: var(--color-text);
}

/* 2) On focus (and for good measure, hover) slightly enlarge */
a:focus,
a:hover,
btn-action:focus,
btn-action:hover {
  _transform: scale(1.05);           /* 5% larger */
 
}

/* 3) If you only want keyboard focus (and not hover) */
a:focus-visible,
btn-action:focus-visible {
  _transform: scale(1.05);
  outline: none;
}

/* 4) Optional: restore back when focus is lost */
a:focus:not(:focus-visible),
btn-actionfocus:not(:focus-visible),
a:active,
btn-action:active {
  transform: none;
}

/* 1) Make sure the SVG scales around its center: */
.btn-action svg {
  display: inline-block;            /* allow transform */
  transform-origin: center center;  /* pivot point */
  transition: transform 0.2s ease-in-out;
}

/* 2) On hover or keyboardâ€focus, bump the scale up: */
.btn-action:hover svg,
.btn-action:focus svg {
  transform: scale(3.6); 
}

/* 3) If you use focusâ€visible specifically: */
.btn-action:focus-visible svg {
  transform: scale(3.6);
}

/* --- footer --- */

footer a:hover {
  _text-decoration: underline;
	color: var(--color-button-bg-hover);
}

footer {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  column-gap: var(--space-sm);
  font-size: 14px;
}

footer a {
  position: relative;
  display: inline-flex;
  align-items: center;
  vertical-align: middle;
  padding: 0;                    
}

footer a + a::before {
  content: "";
  display: inline-block;
  width: 0.2em;
  height: 0.2em;
  background: var(--color-bullet, #333);
  border-radius: 50%;
  margin-right: var(--space-sm);
  vertical-align: middle;
}

footer a.special {
  --bullet-color: crimson;
  color: rebeccapurple;
}

footer nav {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  column-gap: var(--space-sm);
  row-gap: 0;
}

footer nav .flex-break {
  flex: 0 0 100%;
  height: 0;
  margin: 0;
  padding: 0;
}

.mail-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  vertical-align: middle;
  line-height: 0;
}

.mail-icon svg {
  display: block;
  width: 1em;
  height: 1em;
  transform-origin: center;  
  transform-box: fill-box;
  transition: transform 0.2s ease-in-out;
}

.mail-icon:hover svg,
.mail-icon:focus svg,
.mail-icon:focus-visible svg {
  _transform: scale(1.5);
}


/*========================================
  7) Form-Blocker
========================================*/
.form-blocker {
  position: absolute;
  inset:    0;
  background: rgba(255,255,255,0.6);
  z-index:   1010;
  pointer-events: auto;
}
.form-blocker.hidden {
  display: none;
}

#btn-close {
  width: 100%;
  margin-top: 1.5rem;
}

/*========================================
  8) Status Overlay
========================================*/
.status-overlay {
  position:     absolute;
  inset:        0;
  padding:      var(--space-md);
  background:   var(--color-overlay);
  opacity:      0;
  visibility:   hidden;
  display:      flex;
  justify-content: center;
  align-items: center;
  transition:   opacity 0.3s ease, visibility 0.3s ease;
  z-index:      1020;
}
.status-overlay.visible {
  opacity:    1 !important;
  visibility: visible !important;
}

.status-overlay[data-status="sending"] {
  background: var(--color-overlay);
}
.status-overlay[data-status="success"] {
  background: rgba(40,167,69,1);
}
.status-overlay[data-status="error"] {
  background: rgba(220,53,69,1);
}

.status-text {
  flex:       1;
  font-size:  0.9rem;
  color:      var(--color-modal-bg);
}

.status-close {
  position: absolute;
  top:      var(--space-sm);
  right:    var(--space-sm);
  display:  none;
}
.status-overlay[data-status="error"] .status-close {
  display:        inline-flex;
  background:     #fff;
  color:          #dc3545;
  border:         1px solid #dc3545;
  border-radius:  var(--radius-sm);
  padding:        var(--space-xs) var(--space-sm);
  cursor:         pointer;
}
.status-overlay[data-status="error"] .status-close:hover,
.status-overlay[data-status="error"] .status-close:focus {
  background: #dc3545;
  color:      #fff;
  outline:    none;
}

@media (min-width: 768px) {
  #btn-close {
	min-width: 16rem;
	width: auto;
	display: inline-block;
  }
}



/* Datenschutz page typography tweaks */

/* Headings: plain h2 should have no margin after it */
/* Paragraphs: create spacing similar to two <br><br> */
/* only on Impressum + Datenschutz 
#main-wrapper[data-page="impressum"] :is(h2.plain, h3.plain) + p,
#main-wrapper[data-page="datenschutz"] :is(h2.plain, h3.plain) + p {
  margin-top: 0.6rem;
}
*/

/* ===== Headings (only on Impressum + Datenschutz) ===== */
#main-wrapper[data-page="impressum"] h2.plain,
#main-wrapper[data-page="datenschutz"] h2.plain {
  margin-top: 2rem;
  margin-bottom: 0;
  font-weight: 600;
}

#main-wrapper[data-page="impressum"] h3.plain,
#main-wrapper[data-page="datenschutz"] h3.plain {
  margin-top: 1.2rem;   /* a bit tighter than h2 */
  margin-bottom: 0;
  font-weight: 600;
}

/* First paragraph after a heading (only on these pages) */
#main-wrapper[data-page="impressum"] h2.plain + p,
#main-wrapper[data-page="impressum"] h3.plain + p,
#main-wrapper[data-page="datenschutz"] h2.plain + p,
#main-wrapper[data-page="datenschutz"] h3.plain + p {
  margin-top: 0.6rem;
}

/* Paragraph rhythm (only on these pages) */
#main-wrapper[data-page="impressum"] p,
#main-wrapper[data-page="datenschutz"] p {
  margin-top: 1.1rem;   /* like <br><br> visually */
  margin-bottom: 0;
  line-height: 1.6;
}

/* Address block (only on these pages, if desired) */
#main-wrapper[data-page="impressum"] address,
#main-wrapper[data-page="datenschutz"] address {
  font-style: normal;
  line-height: 1.6;
  margin: 0 0 2.5rem 0;
}





/* ==================================================
   iOS 26.0–26.2 consent gate popup
   ================================================== */

.ios26-consent-toast{
  position: fixed;
  inset: 0;
  z-index: 9999;

  /* Centered message box (not fullscreen UI; overlay itself is transparent)
     with safe-area padding so it stays inside the visible viewport on iOS. */
  padding:
    calc(16px + env(safe-area-inset-top, 0px))
    16px
    calc(16px + env(safe-area-inset-bottom, 0px))
    16px;

  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;

  /* Helps some iOS Safari builds that misplace fixed elements during viewport
     recalculations */
  transform: translateZ(0);
}

.ios26-consent-toast .ios26-consent-box{
  pointer-events: auto;
}

.ios26-consent-box{
  width: min(560px, 100%);
  background: var(--color-form-bg, #fff);
  color: var(--color-text, #333);
  border-radius: 14px;
  box-shadow: 0 12px 36px rgba(0, 0, 0, 0.25);
  padding: 18px 16px;
  box-sizing: border-box;
  max-height: calc(100vh - 32px - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px));
  overflow: auto;
}

.ios26-consent-message{
  margin: 0 0 14px 0;
  line-height: 1.35;
}

.ios26-consent-message a{
  color: inherit;
  text-decoration: none;
}

.ios26-consent-message a:visited,
.ios26-consent-message a:hover,
.ios26-consent-message a:active,
.ios26-consent-message a:focus{
  color: inherit;
  text-decoration: none;
}

.ios26-consent-actions{
  display: flex;
  gap: 12px;
  width: 100%;
}

.ios26-consent-btn{
  appearance: none;
  border: 1px solid var(--color-border, #ccc);
  border-radius: 10px;
  padding: 12px 0;
  font: inherit;
  cursor: pointer;
  flex: 1 1 0;
  width: 50%;
  text-align: center;
}

.ios26-consent-btn:focus{
  outline: none;
  box-shadow: 0 0 0 2px rgba(0,122,204,0.25);
  border-color: var(--color-primary, #007acc);
}

.ios26-consent-yes{
  background: var(--color-primary, #007acc);
  border-color: var(--color-primary, #007acc);
  color: #fff;
}

.ios26-consent-no{
  background: transparent;
  color: var(--color-text, #333);
}


.ios26-consent-debug{
  margin: 0 0 14px 0;
  font-size: 12px;
  line-height: 1.25;
  white-space: pre-wrap;
  word-break: break-word;
  opacity: 0.75;
}
