@charset "UTF-8";
:root {
  /*Hauptfarben*/
  --teal-deep: #0e4b5a;
  --teal-dark: #0a3640;
  --teal-medium: #1a6b7a;
  --mint-bright: #3fbfad;
  --mint-light: #7dd4c8;
  --mint-pale: #e8f7f5;
  --mint-paler: #F6F9F7;
  --mint-pale-accent: #daeeeb;
  /* Fühlfarben */
  --orange: #EE9047;
  --orange-pale: #F9DAC2;
  --cream: #fdfbf7;
  --cream-dark: #f5f0e8;
  --sand: #e8e2d9;
  /* Grau */
  --gray-50: #fafaf9;
  --gray-100: #f5f5f4;
  --gray-200: #e7e5e4;
  --gray-300: #d6d3d1;
  --gray-400: #a8a29e;
  --gray-500: #78716c;
  --gray-600: #57534e;
  --gray-700: #44403c;
  --gray-800: #292524;
  --gray-900: #1c1917;
  /* Accent Colors */
  --coral: #f4d761;
  --coral-light: #d6d681;
  /** Alert Colors **/
  --alert-error: #8f1919;
  --alert-success: #06bb2d;
  --error-highlight: var(--alert-error);
  --error-highlight-bg: #fae5e5;
  /*Schriftfarben*/
  --text-color: var(--gray-900);
  --text-color-invert: #fff;
  --heading-color: var(--teal-dark);
  /* Legacy-Color-Aliases als RGB-Tripel fuer rgb(var(--color-*)) in _chat.scss u.a. */
  --color-primary: 14 75 90; /* teal-deep #0e4b5a */
  --color-secondary: 240 244 248; /* hellgrau */
  --color-accent: 63 191 173; /* mint-bright #3fbfad */
  --color-text-main: 28 25 23; /* gray-900 */
  --color-text-muted: 120 113 108; /* gray-500 */
  --color-bg-light: 253 251 247; /* cream */
  /* Spacing */
  --space-xs: 0.25rem;
  --space-sm: 0.5rem;
  --space-md: 1rem;
  --space-lg: 1.5rem;
  --space-xl: 2rem;
  --space-2xl: 3rem;
  --space-3xl: 4rem;
  --space-4xl: 6rem;
  --space-clamp: calc(clamp(1.5rem, 3vw + 0.375rem, 3rem));
  /* Radius */
  --radius-sm: 0.25rem;
  --radius-md: 0.5rem;
  --radius-lg: 1rem;
  --radius-xl: 1.5rem;
  --radius-full: 100vw;
  /* Shadows - Warm & Soft */
  --shadow-sm: 0 1px 2px rgba(28, 25, 23, 0.05);
  --shadow-md: 0 4px 6px -1px rgba(28, 25, 23, 0.07), 0 2px 4px -1px rgba(28, 25, 23, 0.04);
  --shadow-lg: 0 10px 15px -3px rgba(28, 25, 23, 0.08), 0 4px 6px -2px rgba(28, 25, 23, 0.04);
  --shadow-xl: 0 20px 25px -5px rgba(28, 25, 23, 0.1), 0 10px 10px -5px rgba(28, 25, 23, 0.04);
  --shadow-glow-mint: 0 0 30px rgba(63, 191, 173, 0.25);
  --shadow-glow-teal: 0 0 30px rgba(14, 75, 90, 0.15);
  --shadow-card-stack: 0 2px 4px rgba(14, 75, 90, 0.02), 0 8px 16px rgba(14, 75, 90, 0.04), 0 16px 32px rgba(14, 75, 90, 0.06);
  --shadow-dramatic: 0 4px 8px rgba(14, 75, 90, 0.06), 0 12px 24px rgba(14, 75, 90, 0.08), 0 24px 48px rgba(14, 75, 90, 0.1);
  /* Gradients */
  --gradient-hero: linear-gradient(135deg, var(--teal-deep) 0%, var(--teal-medium) 100%);
  --gradient-mint: linear-gradient(135deg, var(--mint-bright) 0%, var(--mint-light) 100%);
  --gradient-warm: linear-gradient(135deg, var(--cream) 0%, var(--cream-dark) 100%);
  --gradient-text: linear-gradient(135deg, var(--teal-deep) 0%, var(--mint-bright) 100%);
  /*Typo*/
  --fw-s: 200;
  --fw-n: 400;
  --fw-sb: 600;
  --fw-b: 900;
  --font-family-default: "Nunito Sans", system-ui, sans-serif;
  /*Layout*/
  --content-width: 1200px;
}

/*Breakpoints*/
/* nunito-sans-300 - latin */
@font-face {
  font-display: swap;
  font-family: "Nunito Sans";
  font-style: normal;
  font-weight: 300;
  src: url("/static/fonts/nunito-sans-v18-latin-300.7ed7c8897239.woff2") format("woff2");
}
/* nunito-sans-regular - latin */
@font-face {
  font-display: swap;
  font-family: "Nunito Sans";
  font-style: normal;
  font-weight: 400;
  src: url("/static/fonts/nunito-sans-v18-latin-regular.11c5e49cedca.woff2") format("woff2");
}
/* nunito-sans-italic - latin */
@font-face {
  font-display: swap;
  font-family: "Nunito Sans";
  font-style: italic;
  font-weight: 400;
  src: url("/static/fonts/nunito-sans-v18-latin-italic.6be963f7f0ba.woff2") format("woff2");
}
/* nunito-sans-600 - latin */
@font-face {
  font-display: swap;
  font-family: "Nunito Sans";
  font-style: normal;
  font-weight: 600;
  src: url("/static/fonts/nunito-sans-v18-latin-600.c4fb6b970265.woff2") format("woff2");
}
/* nunito-sans-700 - latin */
@font-face {
  font-display: swap;
  font-family: "Nunito Sans";
  font-style: normal;
  font-weight: 700;
  src: url("/static/fonts/nunito-sans-v18-latin-700.28dd13528d7a.woff2") format("woff2");
}
/* nunito-sans-800 - latin */
@font-face {
  font-display: swap;
  font-family: "Nunito Sans";
  font-style: normal;
  font-weight: 800;
  src: url("/static/fonts/nunito-sans-v18-latin-800.d91b2e485c8d.woff2") format("woff2");
}
/* nunito-sans-900 - latin */
@font-face {
  font-display: swap;
  font-family: "Nunito Sans";
  font-style: normal;
  font-weight: 900;
  src: url("/static/fonts/nunito-sans-v18-latin-900.3ef43e100b03.woff2") format("woff2");
}
/* Box sizing rules */
*,
*::before,
*::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

/* Prevent font size inflation */
html {
  -moz-text-size-adjust: none;
  -webkit-text-size-adjust: none;
  -ms-text-size-adjust: none;
      text-size-adjust: none;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

/* Remove default margin in favour of better control in authored CSS */
body,
h1,
h2,
h3,
h4,
.pd-card-title,
p,
figure,
blockquote,
dl,
dd {
  margin: 0;
}

/* Remove list styles on ul, ol elements with a list role, which suggests default styling will be removed */
ul[class],
ol[class] {
  margin: 0;
  padding: 0;
  list-style: none;
}

/* Set core body defaults */
body {
  min-height: 100dvh;
  line-height: 1.5;
}

/* Set shorter line heights on headings and interactive elements */
h1,
h2,
h3,
h4,
.pd-card-title,
button,
input,
label {
  line-height: 1.1;
}

/* Balance text wrapping on headings */
h1,
h2,
h3,
h4,
.pd-card-title {
  text-wrap: balance;
}

/* A elements that don't have a class get default styles */
a:not([class]) {
  -webkit-text-decoration-skip: ink;
          text-decoration-skip-ink: auto;
  color: currentColor;
}

/* Make images easier to work with */
img,
picture {
  display: block;
}

/* Inherit fonts for inputs and buttons */
input,
button,
textarea,
select {
  font: inherit;
}

/* Make sure textareas without a rows attribute are not tiny */
textarea:not([rows]) {
  min-height: 10em;
}

/* Anything that has been anchored to should have extra scroll margin */
:target {
  scroll-margin-block: 5ex;
}

html {
  font-size: 100%;
  font-family: var(--font-family-default);
}

html,
body {
  font-family: var(--font-family-default);
  font-weight: var(--fw-n);
  line-height: 1.5;
  color: var(--text-color);
  overflow-x: hidden;
}

@media (prefers-reduced-motion: no-preference) {
  html {
    scroll-behavior: smooth;
  }
}
img {
  max-width: 100%;
  height: auto;
}

.invisible {
  border: 0 none;
  clip: rect(0px, 0px, 0px, 0px);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}

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

.text-balance {
  text-wrap: balance;
}

.visually-hidden:not(:focus):not(:active) {
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  height: 1px;
  overflow: hidden;
  position: absolute;
  white-space: nowrap;
  width: 1px;
}

[id] {
  scroll-margin-top: 5rem;
}

a:not(.btn)[href*=http]::after {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' viewBox='0 0 16 16'%3E%3Cpath stroke='%2378716c' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.667' d='M8 4H4.667A.667.667 0 0 0 4 4.667v6.666a.667.667 0 0 0 .667.667h6.666a.666.666 0 0 0 .667-.667V8M8 8l5-5m-3-1h4v4'/%3E%3C/svg%3E");
}

.fw-n {
  font-weight: var(--fw-n);
}

.mtop-md {
  margin-top: var(--space-md);
}

.mtop-xl {
  margin-top: var(--space-xl);
}

body {
  margin: 0 auto;
  background-color: var(--cream);
}

.wrapper {
  min-height: 100dvh;
  display: -ms-grid;
  display: grid;
  -ms-grid-rows: -webkit-min-content 1fr -webkit-min-content;
  grid-template-rows: -webkit-min-content 1fr -webkit-min-content;
  -ms-grid-rows: min-content 1fr min-content;
  grid-template-rows: min-content 1fr min-content;
          grid-template-areas: "header" "container" "footer";
}

#container {
  -ms-grid-row: 2;
  -ms-grid-column: 1;
  -ms-grid-row: 2;
  -ms-grid-column: 1;
  grid-area: container;
}

main > .inside {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: minmax(0.5rem, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0.5rem, 1fr);
  grid-template-columns: minmax(0.5rem, 1fr) repeat(12, minmax(0, 1fr)) minmax(0.5rem, 1fr);
  -webkit-column-gap: var(--space-default);
     -moz-column-gap: var(--space-default);
          column-gap: var(--space-default);
  position: relative;
}
main section {
  grid-column: 1/-1;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: subgrid;
  grid-template-columns: subgrid;
  padding-bottom: var(--space-4xl);
}
main section .inner {
  grid-column: 2/-2;
  -ms-grid-row: 1;
  grid-row: 1;
}
@media screen and (min-width: 1800px) {
  main section .inner {
    grid-column: 3/-3;
  }
}

.container:has(.alert) {
  grid-column: 2/-2;
  -ms-grid-row: 1;
  grid-row: 1;
}
@media screen and (min-width: 1800px) {
  .container:has(.alert) {
    grid-column: 3/-3;
  }
}

#site-header {
  -ms-grid-row: 1;
  -ms-grid-column: 1;
  -ms-grid-row: 1;
  -ms-grid-column: 1;
  grid-area: header;
}
#site-header + #container {
  margin-top: 6rem;
}
#site-header > .inside {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: minmax(0.5rem, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0.5rem, 1fr);
  grid-template-columns: minmax(0.5rem, 1fr) repeat(12, minmax(0, 1fr)) minmax(0.5rem, 1fr);
  -webkit-column-gap: var(--space-default);
     -moz-column-gap: var(--space-default);
          column-gap: var(--space-default);
}

#site-footer {
  -ms-grid-row: 3;
  -ms-grid-column: 1;
  -ms-grid-row: 3;
  -ms-grid-column: 1;
  grid-area: footer;
}
#site-footer > .inside {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: minmax(0.5rem, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0.5rem, 1fr);
  grid-template-columns: minmax(0.5rem, 1fr) repeat(12, minmax(0, 1fr)) minmax(0.5rem, 1fr);
  -webkit-column-gap: var(--space-default);
     -moz-column-gap: var(--space-default);
          column-gap: var(--space-default);
}

.hero {
  position: relative;
  padding: calc(80px + var(--space-4xl)) 0 var(--space-4xl);
  overflow: hidden;
}

.login-section,
.registration-section {
  min-height: 70vh;
}
.login-section .inner,
.registration-section .inner {
  -ms-flex-item-align: center;
      -ms-grid-row-align: center;
      align-self: center;
}

.login-page-card {
  max-width: 440px;
  margin: 0 auto;
}

.login-title {
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--teal-deep);
  margin-bottom: var(--space-sm);
  text-align: center;
}

.login-subtitle {
  color: var(--gray-600);
  text-align: center;
}

.login-footer {
  margin-top: var(--space-xl);
  padding-top: var(--space-lg);
  border-top: 1px solid var(--gray-200);
  text-align: center;
  color: var(--gray-600);
}

.registration-card,
.profile-edit-card {
  max-width: 800px;
  margin: 0 auto;
}

.registration-title,
.profile-title {
  font-size: clamp(1.75rem, 4vw, 2.25rem);
  font-weight: 700;
  color: var(--teal-deep);
  margin-bottom: var(--space-sm);
  margin-top: 0;
}

.profile-overview {
  margin-block: var(--space-xl) var(--space-2xl);
}

.alert {
  border-radius: var(--radius-md);
  background-color: var(--gray-300);
  padding: 0.5rem 1rem;
}
.alert.alert-error {
  background-color: var(--alert-error);
}
.alert.alert-success {
  background-color: var(--alert-success);
}

:root {
  --heading-m-top: var(--space-2xl);
  --heading-m-bottom: var(--space-md);
}

body {
  font-family: var(--font-family-default);
  font-weight: var(--fw-n);
  font-size: 1rem;
  line-height: 1.6;
  color: var(--text-color);
  margin: 0;
  padding: 0;
}

h1,
h2,
h3,
h4,
.pd-card-title,
h5,
.pd-card-chat .pd-chat-title,
h6,
.pd-order-section .pd-order-form .pd-order-address .pd-address-title {
  font-family: var(--font-family-default);
  font-weight: var(--fw-b);
  color: var(--heading-color);
  line-height: 1.2;
  margin-top: var(--heading-m-top);
  margin-bottom: var(--heading-m-bottom);
}

h1 {
  font-size: clamp(2rem, 5vw, 3rem);
}

h2 {
  font-size: clamp(1.75rem, 4.5vw, 2.5rem);
  font-weight: 300;
}

h3 {
  font-size: clamp(1.5rem, 3.5vw, 2rem);
  font-weight: var(--fw-sb);
}

h4, .pd-card-title {
  font-size: clamp(1.25rem, 3vw, 1.5rem);
  font-weight: var(--fw-sb);
}

h5, .pd-card-chat .pd-chat-title {
  font-size: clamp(1.125rem, 2.5vw, 1.25rem);
}

h6, .pd-order-section .pd-order-form .pd-order-address .pd-address-title {
  font-size: clamp(1rem, 2vw, 1.125rem);
}

p {
  margin-top: 0;
  margin-bottom: var(--space-md);
  color: var(--text-color);
}

ul,
ol {
  padding-left: var(--space-lg);
  margin-top: 0;
  margin-bottom: var(--space-md);
}
ul li,
ol li {
  margin-bottom: var(--space-xs);
  color: var(--text-color);
}

a {
  color: var(--teal-dark);
  text-decoration: none;
  font-weight: var(--fw-sb);
}
a:hover, a:focus {
  color: var(--teal-medium);
  text-decoration: underline;
}

blockquote {
  border-left: 4px solid var(--mint-bright);
  padding-left: var(--space-md);
  margin: var(--space-md) 0;
  font-style: italic;
  color: var(--gray-700);
}

small {
  font-size: 0.875rem;
  color: var(--gray-600);
}

hr {
  border: none;
  height: 1px;
  background-color: var(--gray-200);
  margin: var(--space-xl) 0;
}

body {
  margin: 0 auto;
  background-color: var(--cream);
}

.wrapper {
  min-height: 100dvh;
  display: -ms-grid;
  display: grid;
  -ms-grid-rows: -webkit-min-content 1fr -webkit-min-content;
  grid-template-rows: -webkit-min-content 1fr -webkit-min-content;
  -ms-grid-rows: min-content 1fr min-content;
  grid-template-rows: min-content 1fr min-content;
          grid-template-areas: "header" "container" "footer";
}

#container {
  -ms-grid-row: 2;
  -ms-grid-column: 1;
  -ms-grid-row: 2;
  -ms-grid-column: 1;
  grid-area: container;
}

main > .inside {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: minmax(0.5rem, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0.5rem, 1fr);
  grid-template-columns: minmax(0.5rem, 1fr) repeat(12, minmax(0, 1fr)) minmax(0.5rem, 1fr);
  -webkit-column-gap: var(--space-default);
     -moz-column-gap: var(--space-default);
          column-gap: var(--space-default);
  position: relative;
}
main section {
  grid-column: 1/-1;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: subgrid;
  grid-template-columns: subgrid;
  padding-bottom: var(--space-4xl);
}
main section .inner {
  grid-column: 2/-2;
  -ms-grid-row: 1;
  grid-row: 1;
}
@media screen and (min-width: 1800px) {
  main section .inner {
    grid-column: 3/-3;
  }
}

.container:has(.alert) {
  grid-column: 2/-2;
  -ms-grid-row: 1;
  grid-row: 1;
}
@media screen and (min-width: 1800px) {
  .container:has(.alert) {
    grid-column: 3/-3;
  }
}

#site-header {
  -ms-grid-row: 1;
  -ms-grid-column: 1;
  -ms-grid-row: 1;
  -ms-grid-column: 1;
  grid-area: header;
}
#site-header + #container {
  margin-top: 6rem;
}
#site-header > .inside {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: minmax(0.5rem, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0.5rem, 1fr);
  grid-template-columns: minmax(0.5rem, 1fr) repeat(12, minmax(0, 1fr)) minmax(0.5rem, 1fr);
  -webkit-column-gap: var(--space-default);
     -moz-column-gap: var(--space-default);
          column-gap: var(--space-default);
}

#site-footer {
  -ms-grid-row: 3;
  -ms-grid-column: 1;
  -ms-grid-row: 3;
  -ms-grid-column: 1;
  grid-area: footer;
}
#site-footer > .inside {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: minmax(0.5rem, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0, 1fr) var(--space-default) minmax(0.5rem, 1fr);
  grid-template-columns: minmax(0.5rem, 1fr) repeat(12, minmax(0, 1fr)) minmax(0.5rem, 1fr);
  -webkit-column-gap: var(--space-default);
     -moz-column-gap: var(--space-default);
          column-gap: var(--space-default);
}

.hero {
  position: relative;
  padding: calc(80px + var(--space-4xl)) 0 var(--space-4xl);
  overflow: hidden;
}

.login-section,
.registration-section {
  min-height: 70vh;
}
.login-section .inner,
.registration-section .inner {
  -ms-flex-item-align: center;
      -ms-grid-row-align: center;
      align-self: center;
}

.login-page-card {
  max-width: 440px;
  margin: 0 auto;
}

.login-title {
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--teal-deep);
  margin-bottom: var(--space-sm);
  text-align: center;
}

.login-subtitle {
  color: var(--gray-600);
  text-align: center;
}

.login-footer {
  margin-top: var(--space-xl);
  padding-top: var(--space-lg);
  border-top: 1px solid var(--gray-200);
  text-align: center;
  color: var(--gray-600);
}

.registration-card,
.profile-edit-card {
  max-width: 800px;
  margin: 0 auto;
}

.registration-title,
.profile-title {
  font-size: clamp(1.75rem, 4vw, 2.25rem);
  font-weight: 700;
  color: var(--teal-deep);
  margin-bottom: var(--space-sm);
  margin-top: 0;
}

.profile-overview {
  margin-block: var(--space-xl) var(--space-2xl);
}

.alert {
  border-radius: var(--radius-md);
  background-color: var(--gray-300);
  padding: 0.5rem 1rem;
}
.alert.alert-error {
  background-color: var(--alert-error);
}
.alert.alert-success {
  background-color: var(--alert-success);
}

:root {
  --dl-table-gap: 1rem;
  --dl-table-label-color: #555;
  --dl-table-value-color: #000;
  --dl-table-font-size: 1rem;
  --dl-table-label-weight: 600;
  --dl-table-border: 1px solid #ddd;
  --dl-table-border-radius: 0.5rem;
  --dl-table-padding: 0.5rem 1rem;
}

.dl-table {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: -webkit-max-content var(--dl-table-gap) 1fr;
  -ms-grid-columns: max-content var(--dl-table-gap) 1fr;
  grid-template-columns: -webkit-max-content 1fr;
  grid-template-columns: max-content 1fr;
  gap: var(--dl-table-gap);
  border: var(--dl-table-border);
  border-radius: var(--dl-table-border-radius);
  overflow: hidden;
  font-size: var(--dl-table-font-size);
}
.dl-table dt,
.dl-table dd {
  padding: var(--dl-table-padding);
  margin: 0;
}
.dl-table dt {
  font-weight: var(--dl-table-label-weight);
  color: var(--dl-table-label-color);
  background-color: #f9f9f9;
  border-bottom: var(--dl-table-border);
}
.dl-table dd {
  color: var(--dl-table-value-color);
  border-bottom: var(--dl-table-border);
}
.dl-table dt:last-child,
.dl-table dd:last-child {
  border-bottom: none;
}
@media (max-width: 600px) {
  .dl-table {
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
  }
  .dl-table dt {
    background-color: transparent;
    border-bottom: none;
  }
  .dl-table dd {
    border-bottom: var(--dl-table-border);
    margin-bottom: var(--dl-table-gap);
  }
}

.checklist {
  list-style: none;
  margin: 0;
  padding: 0;
}
.checklist li {
  position: relative;
  padding-left: 1.6rem;
  margin-bottom: 0.5em;
}
.checklist li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.25em;
  width: 1em;
  height: 1em;
  background-color: currentColor;
  -webkit-mask-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M19.47 4.118a1 1 0 0 1 .412 1.353l-8 15a1 1 0 0 1-1.59.236l-6-6a1 1 0 1 1 1.415-1.414l5.046 5.046l7.365-13.81a1 1 0 0 1 1.353-.411'/></svg>");
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-position: center;
  -webkit-mask-size: contain;
  mask-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M19.47 4.118a1 1 0 0 1 .412 1.353l-8 15a1 1 0 0 1-1.59.236l-6-6a1 1 0 1 1 1.415-1.414l5.046 5.046l7.365-13.81a1 1 0 0 1 1.353-.411'/></svg>");
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
}

.floating-list li {
  display: inline-block;
}

.site-footer {
  --text-color: var(--text-color-invert);
  background-color: var(--teal-deep);
  color: var(--text-color-invert);
  padding: var(--space-4xl) 0 0 0;
}

.footer-logo {
  color: var(--text-color-invert);
  margin-bottom: var(--space-sm);
  display: inline-block;
}
.footer-logo:hover {
  color: inherit;
}
.footer-logo svg {
  max-width: 250px;
  max-height: 40px;
}

.footer-grid,
.footer-bottom {
  grid-column: 2/-2;
}

@media screen and (min-width: 1200px) {
  .footer-grid,
  .footer-bottom {
    grid-column: 3/-3;
  }
}
.footer-grid {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr;
  grid-template-columns: 1fr;
  gap: var(--space-2xl);
}

@media screen and (min-width: 768px) {
  .footer-grid {
    -ms-grid-columns: 2fr 1fr 1fr;
    grid-template-columns: 2fr 1fr 1fr;
  }
}
.footer-nav h4, .footer-nav .pd-card-title {
  color: var(--text-color-invert);
  font-size: 0.875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: var(--space-md);
}

.footer-links a:hover {
  color: var(--mint-bright);
}

.footer-bottom {
  margin-top: var(--space-3xl);
  padding-block: var(--space-xl) var(--space-xl);
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: var(--space-md);
}

.footer-badges {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: var(--space-sm);
}

.footer-badge {
  padding: var(--space-xs) var(--space-sm);
  background: rgba(255, 255, 255, 0.1);
  border-radius: var(--radius-sm);
  font-size: 0.75rem;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.7);
}

.partners-section {
  background: var(--teal-dark);
  padding: var(--space-lg) 0;
}

.partners-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: var(--space-xl);
  color: var(--text-color-invert);
}

.partners-label {
  color: rgba(255, 255, 255, 0.5);
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

.partners-logos {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: var(--space-xl);
}

.a.partners-label:hover,
.a.partners-label:focus {
  color: var(--mint-bright);
}

.partners-label.partners-label[href*=http]::after {
  content: unset;
}

.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  padding: var(--space-md) 0;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.site-header.scrolled {
  background: rgba(253, 251, 247, 0.9);
  backdrop-filter: blur(12px);
  -webkit-box-shadow: var(--shadow-md);
          box-shadow: var(--shadow-md);
}
.site-header .inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 1rem;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.site-header .site-logo {
  grid-column: 2/-2;
  -ms-grid-column-align: center;
      justify-self: center;
}
.site-header .header-nav {
  grid-column: 2/-2;
  -ms-grid-column-align: center;
      justify-self: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (min-width: 768px) {
  .site-header .site-logo {
    -ms-grid-column: 2;
    -ms-grid-column-span: 3;
    grid-column: 2/span 3;
    -ms-grid-column-align: start;
        justify-self: start;
  }
  .site-header .header-nav {
    -ms-grid-column-align: end;
        justify-self: end;
    -ms-grid-column: 6;
    -ms-grid-column-span: 8;
    grid-column: 6/span 8;
  }
}
@media screen and (min-width: 1800px) {
  .site-header .site-logo {
    -ms-grid-column: 3;
    -ms-grid-column-span: 3;
    grid-column: 3/span 3;
  }
  .site-header .header-nav {
    -ms-grid-column: 6;
    -ms-grid-column-span: 7;
    grid-column: 6/span 7;
  }
}
.site-header .site-logo svg {
  max-width: 250px;
  max-height: 40px;
}

nav ul {
  margin: 0;
  padding: 0;
  list-style: none;
}
nav li {
  position: relative;
}
nav a {
  display: block;
  text-decoration: none;
  white-space: nowrap;
}

.header-nav ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.5rem;
}
.header-nav .nav-link {
  padding: var(--space-sm) var(--space-md);
  color: var(--gray-600);
  font-weight: 500;
  font-size: 0.9375rem;
  border-radius: var(--radius-full);
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease;
}
.header-nav .nav-link:hover {
  color: var(--text-color-invert);
  background: var(--teal-medium);
  text-decoration: none;
}
.header-nav .nav-link-highlight {
  color: var(--text-color-invert);
  background: var(--teal-medium);
  text-decoration: none;
}

.breadcrumb {
  grid-column: 2/-2;
  padding: 1.5rem 0;
}
@media screen and (min-width: 1200px) {
  .breadcrumb {
    grid-column: 3/-3;
  }
}
.breadcrumb ol {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.5rem;
  list-style: none;
  margin: 0;
  padding: 0;
  font-size: 0.875rem;
}
.breadcrumb li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.breadcrumb li:not(:last-child)::after {
  content: "/";
  margin-left: 0.5rem;
  color: rgb(var(--color-text-muted));
}
.breadcrumb a {
  text-decoration: none;
  -webkit-transition: color 0.2s ease;
  transition: color 0.2s ease;
}

.content-section {
  padding-block: var(--space-4xl);
}

.centered-90 {
  max-width: 90ch;
  margin: 0 auto;
}

.hero .hero-eyebrow {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: var(--space-sm);
  padding: var(--space-xs) var(--space-md);
  background: var(--mint-pale);
  color: var(--teal-deep);
  font-size: 0.8125rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  border-radius: var(--radius-full);
  margin-bottom: var(--space-lg);
}
.hero .hero-description {
  margin-bottom: var(--space-clamp);
}
.hero .hero-cta {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.5rem;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.abschluss-cta {
  --heading-color: #fff;
  --text-color: #fff;
  background: radial-gradient(ellipse, rgba(63, 191, 173, 0.1) 0%, transparent 80%), linear-gradient(135deg, var(--teal-deep), var(--teal-dark));
  background-position: right bottom, left top;
  padding: var(--space-4xl) 0;
  position: relative;
  overflow: hidden;
}
.abschluss-cta .btn-primary {
  --button-border: var(--cream);
}
.abschluss-cta .section-heading {
  --text-color: #fff;
}

.section-dark {
  --heading-color: #fff;
  --text-color: #fff;
  color: var(--text-color);
  background: radial-gradient(ellipse, rgba(63, 191, 173, 0.1) 0%, transparent 80%), linear-gradient(135deg, var(--teal-deep), var(--teal-dark));
  background-position: right bottom, left top;
  padding: var(--space-4xl) 0;
  position: relative;
  overflow: hidden;
}
.section-dark * {
  color: inherit;
}
.section-dark .card * {
  --heading-color: var(--gray-900);
  --text-color: var(--gray-900);
  color: var(--text-color);
}
.section-dark .btn-primary {
  --button-border: var(--cream);
}

.card {
  --heading-m-top: var(--space-m);
}

.card--feature {
  --container-background: #ffffff;
  --container-shadow: var(--shadow-md);
}
.card--feature.featured {
  --container-background: var(--gradient-hero);
  --heading-color: #fff;
  --text-color: #fff;
  color: #fff;
  border: none;
}
.card--feature.featured .feature-icon {
  background: rgba(255, 255, 255, 0.15);
  color: #fff;
}
.card--feature h3 {
  font-size: 1.125rem;
  margin-bottom: var(--space-sm);
}

.card:has(.card-header) {
  padding: 0;
  overflow: hidden;
}

.card-header {
  aspect-ratio: 16/9;
  background-color: #F2F5FA;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.card-header img + * {
  margin-top: 1rem;
}
.card-header .card-slogan {
  font-size: clamp(1.25rem, 1cqw + 0.5rem, 1.5rem);
  font-weight: 600;
}
.card-header p:last-child {
  margin-bottom: 0;
}

.card.grid-mobile-col-12:not(.grid-tablet-col-6) .card-header {
  aspect-ratio: unset;
}

.card-header-inner {
  padding: var(--space-lg) 1rem;
  text-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.card-content {
  padding: var(--space-clamp);
}
.card-content ul.article-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 0.5rem;
  list-style: initial;
}
.card-content ul.article-list a {
  text-decoration: underline;
}
.card-content .btn {
  margin-block: 0.25rem;
}

.card--trust {
  --container-background: #ffffff;
  --container-shadow: var(--shadow-md);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 1rem;
  text-align: center;
}
.card--trust svg {
  color: var(--teal-dark);
  width: 8rem;
  height: 8rem;
}
.card--trust .siegeltag {
  font-weight: 600;
  color: var(--teal-deep);
  font-size: 1rem;
}
.card--trust .siegeltag2 {
  font-size: 0.875rem;
  color: var(--gray-500);
}

.section-heading {
  --text-color: var(--gray-500);
  margin-bottom: calc(2 * var(--space-clamp));
}
.section-heading h2 {
  font-weight: 300;
  margin-bottom: var(--space-md);
}
.section-heading p {
  color: var(--text-color);
  font-size: 1.125rem;
  margin-bottom: var(--space-2xl);
}

.section-content p, .section-content ul {
  margin-bottom: var(--space-lg);
}

#nav-internal {
  background-color: var(--mint-pale);
  padding: 1rem;
  margin-bottom: var(--space-clamp);
  border-radius: var(--radius-md);
}

nav.navigation-internal ul {
  list-style: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.5rem;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin-bottom: 0;
}
nav.navigation-internal li {
  margin: 0;
}
nav.navigation-internal a {
  padding: 0.5em 1em;
  text-decoration: none;
  background-color: var(--teal-deep);
  color: #fff;
  border-radius: var(--radius-sm);
  -webkit-transition: background-color 0.2s linear;
  transition: background-color 0.2s linear;
}
nav.navigation-internal a:hover, nav.navigation-internal a:focus {
  background-color: var(--teal-dark);
}

#weitereinformationen section:not(#nav-internal) {
  padding-bottom: var(--space-2xl);
}

#gebrauchsinformationen a {
  text-decoration: underline;
}

.card section:not(#nav-internal) {
  padding-bottom: var(--space-2xl);
}
.card details {
  margin: 0;
}
.card details p {
  padding: 0.75rem 1.5rem;
  margin: 0;
}
.card summary {
  background: var(--mint-pale);
  padding: 0.5em;
  cursor: pointer;
  border-block: 1px solid var(--mint-light);
  -webkit-transition: background 0.25s ease, color 0.25s ease;
  transition: background 0.25s ease, color 0.25s ease;
}
.card summary:hover {
  background: var(--teal-medium);
  color: #fff;
}
.card summary:last-of-type {
  border-bottom: 1px solid var(--mint-light);
}
.card .details-content {
  padding-block: var(--space-lg);
}

.cta-notification {
  background-color: rgba(14, 75, 90, 0.05);
  padding: var(--space-clamp);
  margin-block: var(--space-clamp);
  border-radius: var(--radius-md);
  text-align: center;
}

.flex-content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 1rem;
}

.flexgrid {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: space-evenly;
      -ms-flex-pack: space-evenly;
          justify-content: space-evenly;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 1rem;
}

.feature-icon {
  width: 3rem;
  height: 3rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  background: var(--mint-pale);
  color: var(--teal-deep);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-md);
}

.feature-icon svg {
  width: 1.5rem;
  height: 1.5rem;
}

.grid {
  display: -ms-grid;
  display: grid;
}
.grid.gap-s {
  gap: var(--space-sm);
}
.grid.gap-m {
  gap: var(--space-md);
}
.grid.gap-l {
  gap: var(--space-lg);
}
.grid.gap-clamp {
  gap: var(--space-clamp);
}
.grid.justify-start {
  justify-items: start;
}
.grid.justify-center {
  justify-items: center;
}
.grid.justify-end {
  justify-items: end;
}
.grid.justify-stretch {
  justify-items: stretch;
}
.grid.align-start {
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: start;
}
.grid.align-center {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.grid.align-end {
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: end;
}
.grid.align-stretch {
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
}
@media screen and (min-width: 768px) {
  .grid.cols-50-50 {
    -ms-grid-columns: 1fr 1fr;
    grid-template-columns: 1fr 1fr;
  }
  .grid.cols-60-40 {
    -ms-grid-columns: 3fr 2fr;
    grid-template-columns: 3fr 2fr;
  }
  .grid.cols-40-60 {
    -ms-grid-columns: 2fr 3fr;
    grid-template-columns: 2fr 3fr;
  }
  .grid.cols-33-66 {
    -ms-grid-columns: 1fr 2fr;
    grid-template-columns: 1fr 2fr;
  }
  .grid.cols-66-33 {
    -ms-grid-columns: 2fr 1fr;
    grid-template-columns: 2fr 1fr;
  }
  .grid.cols-33-33-33 {
    -ms-grid-columns: 1fr 1fr;
    grid-template-columns: 1fr 1fr;
  }
  .grid.cols-25-25-25-25 {
    -ms-grid-columns: 1fr 1fr;
    grid-template-columns: 1fr 1fr;
  }
}
@media screen and (min-width: 990px) {
  .grid.cols-33-33-33 {
    -ms-grid-columns: 1fr 1fr 1fr;
    grid-template-columns: 1fr 1fr 1fr;
  }
}
@media screen and (min-width: 1200px) {
  .grid.cols-25-25-25-25 {
    -ms-grid-columns: 1fr 1fr 1fr 1fr;
    grid-template-columns: 1fr 1fr 1fr 1fr;
  }
}

.col-full {
  grid-column: 1/-1;
}

.amgrid:has(> *[class*=grid-]) {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr var(--space-clamp) 1fr var(--space-clamp) 1fr var(--space-clamp) 1fr var(--space-clamp) 1fr var(--space-clamp) 1fr var(--space-clamp) 1fr var(--space-clamp) 1fr var(--space-clamp) 1fr var(--space-clamp) 1fr var(--space-clamp) 1fr var(--space-clamp) 1fr;
  grid-template-columns: repeat(12, 1fr);
  grid-auto-rows: auto;
  gap: var(--space-clamp);
}

.amgrid + .amgrid {
  margin-top: var(--space-clamp);
}

[class*=grid-] {
  grid-column: auto/span 12;
}

.grid-mobile-col-2 {
  grid-column: auto/span 2;
}

.grid-mobile-col-3 {
  grid-column: auto/span 3;
}

.grid-mobile-col-4 {
  grid-column: auto/span 4;
}

.grid-mobile-col-6 {
  grid-column: auto/span 6;
}

.grid-mobile-col-8 {
  grid-column: auto/span 8;
}

.grid-mobile-col-12 {
  grid-column: auto/span 12;
}

@media screen and (min-width: 768px) {
  .grid-tablet-col-2 {
    grid-column: auto/span 2;
  }
  .grid-tablet-col-3 {
    grid-column: auto/span 3;
  }
  .grid-tablet-col-4 {
    grid-column: auto/span 4;
  }
  .grid-tablet-col-6 {
    grid-column: auto/span 6;
  }
  .grid-tablet-col-8 {
    grid-column: auto/span 8;
  }
  .grid-tablet-col-12 {
    grid-column: auto/span 12;
  }
}
@media screen and (min-width: 1200px) {
  .grid-desktop-col-2 {
    grid-column: auto/span 2;
  }
  .grid-desktop-col-3 {
    grid-column: auto/span 3;
  }
  .grid-desktop-col-4 {
    grid-column: auto/span 4;
  }
  .grid-desktop-col-6 {
    grid-column: auto/span 6;
  }
  .grid-desktop-col-8 {
    grid-column: auto/span 8;
  }
  .grid-desktop-col-12 {
    grid-column: auto/span 12;
  }
}
.grid-align-center {
  -ms-flex-line-pack: center;
      align-content: center;
}

.grid-align-end {
  -ms-flex-line-pack: end;
      align-content: end;
}

.grid-justify-center {
  -ms-grid-column-align: center;
      justify-self: center;
}

.grid-justify-end {
  -ms-grid-column-align: end;
      justify-self: end;
}

.productgrid {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr;
  grid-template-columns: 1fr;
  gap: var(--space-clamp);
  margin-bottom: var(--space-clamp);
}

@media screen and (min-width: 768px) {
  .productgrid {
    -ms-grid-columns: 1fr 1fr;
    grid-template-columns: 1fr 1fr;
  }
}
@media screen and (min-width: 1200px) {
  .productgrid {
    -ms-grid-columns: 2fr 1fr;
    grid-template-columns: 2fr 1fr;
  }
}
.productgrid:not(:has(#mello)) {
          grid-template-areas: "produktinfo" "bestellung" "produktdaten" "support" "downloads";
}

@media screen and (min-width: 768px) {
  .productgrid:not(:has(#mello)) {
            grid-template-areas: "produktinfo produktinfo" "bestellung bestellung" "produktdaten support" "downloads downloads";
  }
}
@media screen and (min-width: 1200px) {
  .productgrid:not(:has(#mello)) {
            grid-template-areas: "produktinfo produktinfo" "bestellung produktdaten" "downloads support";
  }
}
.productgrid:has(#mello) {
          grid-template-areas: "produktinfo" "mello" "bestellung" "produktdaten" "support" "downloads";
}

@media screen and (min-width: 768px) {
  .productgrid:has(#mello) {
            grid-template-areas: "produktinfo mello" "bestellung bestellung" "produktdaten support" "downloads downloads";
  }
}
@media screen and (min-width: 1200px) {
  .productgrid:has(#mello) {
            grid-template-areas: "produktinfo mello" "bestellung produktdaten" "downloads support";
  }
}
#productinfo {
  -ms-grid-row: 1;
  -ms-grid-column: 1;
  grid-area: produktinfo;
}
.productgrid:has(#mello) > #productinfo {
  -ms-grid-row: 1;
  -ms-grid-column: 1;
  -ms-grid-column-span: 1;
}

#mello {
  -ms-grid-row: 2;
  -ms-grid-column: 1;
  grid-area: mello;
}

#bestellen {
  -ms-grid-row: 2;
  -ms-grid-column: 1;
  grid-area: bestellung;
}

.productgrid:has(#mello) > #bestellen {
  -ms-grid-row: 3;
  -ms-grid-column: 1;
  -ms-grid-column-span: 1;
}

#productdata {
  -ms-grid-row: 3;
  -ms-grid-column: 1;
  grid-area: produktdaten;
}

.productgrid:has(#mello) > #productdata {
  -ms-grid-row: 4;
  -ms-grid-column: 1;
}

#support {
  -ms-grid-row: 4;
  -ms-grid-column: 1;
  grid-area: support;
}

.productgrid:has(#mello) > #support {
  -ms-grid-row: 5;
  -ms-grid-column: 1;
}

#dokumente {
  -ms-grid-row: 5;
  -ms-grid-column: 1;
  grid-area: downloads;
}

.productgrid:has(#mello) > #dokumente {
  -ms-grid-row: 6;
  -ms-grid-column: 1;
  -ms-grid-column-span: 1;
}

@media screen and (min-width: 768px){
  #productinfo {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
    -ms-grid-column-span: 2;
  }
  .productgrid:has(#mello) > #productinfo {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
    -ms-grid-column-span: 1;
  }
  #mello {
    -ms-grid-row: 1;
    -ms-grid-column: 2;
  }
  #bestellen {
    -ms-grid-row: 2;
    -ms-grid-column: 1;
    -ms-grid-column-span: 2;
  }
  .productgrid:has(#mello) > #bestellen {
    -ms-grid-row: 2;
    -ms-grid-column: 1;
    -ms-grid-column-span: 2;
  }
  #productdata {
    -ms-grid-row: 3;
    -ms-grid-column: 1;
  }
  .productgrid:has(#mello) > #productdata {
    -ms-grid-row: 3;
    -ms-grid-column: 1;
  }
  #support {
    -ms-grid-row: 3;
    -ms-grid-column: 2;
  }
  .productgrid:has(#mello) > #support {
    -ms-grid-row: 3;
    -ms-grid-column: 2;
  }
  #dokumente {
    -ms-grid-row: 4;
    -ms-grid-column: 1;
    -ms-grid-column-span: 2;
  }
  .productgrid:has(#mello) > #dokumente {
    -ms-grid-row: 4;
    -ms-grid-column: 1;
    -ms-grid-column-span: 2;
  }
}

@media screen and (min-width: 1200px){
  #productinfo {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
    -ms-grid-column-span: 2;
  }
  .productgrid:has(#mello) > #productinfo {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
    -ms-grid-column-span: 1;
  }
  #mello {
    -ms-grid-row: 1;
    -ms-grid-column: 2;
  }
  #bestellen {
    -ms-grid-row: 2;
    -ms-grid-column: 1;
    -ms-grid-column-span: 1;
  }
  .productgrid:has(#mello) > #bestellen {
    -ms-grid-row: 2;
    -ms-grid-column: 1;
    -ms-grid-column-span: 1;
  }
  #productdata {
    -ms-grid-row: 2;
    -ms-grid-column: 2;
  }
  .productgrid:has(#mello) > #productdata {
    -ms-grid-row: 2;
    -ms-grid-column: 2;
  }
  #support {
    -ms-grid-row: 3;
    -ms-grid-column: 2;
  }
  .productgrid:has(#mello) > #support {
    -ms-grid-row: 3;
    -ms-grid-column: 2;
  }
  #dokumente {
    -ms-grid-row: 3;
    -ms-grid-column: 1;
    -ms-grid-column-span: 1;
  }
  .productgrid:has(#mello) > #dokumente {
    -ms-grid-row: 3;
    -ms-grid-column: 1;
    -ms-grid-column-span: 1;
  }
}

.flexit {
  --flexit-gap: 0.5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: start;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: var(--flexit-gap);
}
.flexit.align-start {
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}
.flexit.align-end {
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}
.flexit.align-center {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.flexit.gap-0 {
  --flexit-gap: 0;
}
.flexit.gap-1 {
  --flexit-gap: 1rem;
}
.flexit.gap-2 {
  --flexit-gap: 2rem;
}
.flexit.gap-3 {
  --flexit-gap: 3rem;
}
.flexit.flex-gap {
  --flexit-gap: 0 calc(clamp(1rem, 2.667vw + 0rem, 2rem));
}
.flexit.valign-center {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.flexit.valign-end {
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: end;
}
.flexit.valign-baseline {
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
}

.form-grid {
  display: -ms-grid;
  display: grid;
  gap: var(--space-lg);
}

@media (min-width: 640px) {
  .form-grid {
    -ms-grid-columns: (1fr)[2];
    grid-template-columns: repeat(2, 1fr);
  }
}
.form-group {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: var(--space-xs);
  margin-bottom: var(--space-lg);
}

.form-group-full {
  grid-column: 1/-1;
}

fieldset {
  margin: 0;
}

.form-section {
  margin-bottom: var(--space-2xl);
  border: none;
  padding: 0;
}
.form-section legend {
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--teal-deep);
  margin-bottom: var(--space-lg);
  padding: 0;
  width: 100%;
}

.form-label,
.form-label-ci {
  display: block;
  font-size: 0.9375rem;
  font-weight: 500;
  color: var(--gray-700);
  margin-bottom: var(--space-xs);
}

.form-input,
.form-select {
  width: 100%;
  min-height: 48px;
  padding: 0.75rem 1rem;
  border: 2px solid var(--gray-200);
  border-radius: var(--radius-md);
  background: white;
  font-size: 1rem;
  color: var(--gray-800);
  -webkit-transition: border-color 0.2s ease, -webkit-box-shadow 0.2s ease;
  transition: border-color 0.2s ease, -webkit-box-shadow 0.2s ease;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  transition: border-color 0.2s ease, box-shadow 0.2s ease, -webkit-box-shadow 0.2s ease;
}

.form-actions {
  margin-top: var(--space-xl);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: var(--space-lg);
}
.form-actions button {
  display: block;
}

.form-helptext {
  font-size: 0.8125rem;
  color: var(--gray-500);
}

.mandatory-star {
  color: #dc2626;
  font-weight: 600;
}

.form-checkbox-group {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: var(--space-sm);
}

.form-checkbox-group input[type=checkbox] {
  width: 1.25rem;
  height: 1.25rem;
  min-width: 1.25rem;
  margin-top: 0.125rem;
  accent-color: var(--mint-bright);
  cursor: pointer;
}

.checkbox-label {
  font-size: 0.9375rem;
  color: var(--gray-700);
  line-height: 1.5;
  cursor: pointer;
}

.consent-group {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: var(--space-md);
}

.form-login-hint {
  color: var(--gray-600);
  font-size: 0.9375rem;
}

.form-error {
  color: var(--error-highlight);
}

input:has(+ .form-error) {
  border: 2px solid var(--alert-error);
  background-color: var(--error-highlight-bg);
}

.form-label.pd-checkbox {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.5rem;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-bottom: 1rem;
}
.form-label.pd-checkbox input {
  width: 1.5rem;
  height: 1.5rem;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 1.5rem;
          flex: 0 0 1.5rem;
}
.form-label.pd-checkbox .pd-checkbox-label {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}

/**
 * Chat Widget Styles
 *
 * Plain CSS compatible with Tailwind CLI (no SCSS nesting)
 * npm run build:css
 */
/* ==========================================================================
   Chat Widget Container
   ========================================================================== */
.chat-widget {
  position: fixed;
  bottom: 1.5rem;
  right: 1.5rem;
  z-index: 1000;
  font-family: var(--font-sans, system-ui, sans-serif);
}

/* ==========================================================================
   Toggle Button
   ========================================================================== */
.chat-toggle {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 3.5rem;
  width: 3.5rem;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  border-radius: 9999px;
  --tw-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
  --tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);
  -webkit-box-shadow: var(--tw-ring-offset-shadow, 0 0 rgba(0, 0, 0, 0)), var(--tw-ring-shadow, 0 0 rgba(0, 0, 0, 0)), var(--tw-shadow);
          box-shadow: var(--tw-ring-offset-shadow, 0 0 rgba(0, 0, 0, 0)), var(--tw-ring-shadow, 0 0 rgba(0, 0, 0, 0)), var(--tw-shadow);
  background: rgb(var(--color-accent));
  color: white;
  border: none;
  cursor: pointer;
  -webkit-transition: -webkit-transform 0.2s ease, -webkit-box-shadow 0.2s ease;
  transition: -webkit-transform 0.2s ease, -webkit-box-shadow 0.2s ease;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  transition: transform 0.2s ease, box-shadow 0.2s ease, -webkit-transform 0.2s ease, -webkit-box-shadow 0.2s ease;
  position: relative;
}

.chat-toggle:hover {
  -webkit-transform: scale(1.05);
          transform: scale(1.05);
  -webkit-box-shadow: 0 8px 25px rgba(63, 191, 173, 0.4);
          box-shadow: 0 8px 25px rgba(63, 191, 173, 0.4);
}

.chat-toggle:focus-visible {
  outline: 2px solid rgb(var(--color-accent));
  outline-offset: 2px;
}

.chat-badge {
  position: absolute;
  top: -0.25rem;
  right: -0.25rem;
  height: 1.25rem;
  width: 1.25rem;
  border-radius: 9999px;
  font-size: 0.75rem;
  line-height: 1rem;
  font-weight: 700;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  background: #ef4444;
  color: white;
}

/* ==========================================================================
   Chat Panel
   ========================================================================== */
.chat-panel {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  position: absolute;
  bottom: 0;
  right: 0;
  width: 380px;
  height: 560px;
  max-height: 80vh;
  background: white;
  border-radius: 1rem;
  -webkit-box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15);
          box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15);
  overflow: hidden;
  -webkit-animation: slideUp 0.2s ease-out;
          animation: slideUp 0.2s ease-out;
}

@-webkit-keyframes slideUp {
  from {
    opacity: 0;
    -webkit-transform: translateY(10px);
            transform: translateY(10px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}

@keyframes slideUp {
  from {
    opacity: 0;
    -webkit-transform: translateY(10px);
            transform: translateY(10px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
/* ==========================================================================
   Header
   ========================================================================== */
.chat-header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding-left: 1rem;
  padding-right: 1rem;
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;
  background: rgb(var(--color-primary));
  color: white;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.chat-header-info {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

.chat-header-title {
  font-weight: 600;
}

.chat-header-status {
  font-size: 0.75rem;
  line-height: 1rem;
  opacity: 0.75;
}

.chat-header-actions {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.5rem;
}

.chat-header-actions button {
  border-radius: 0.25rem;
  padding: 0.375rem;
  background: transparent;
  border: none;
  color: white;
  cursor: pointer;
  -webkit-transition: background-color 0.15s ease;
  transition: background-color 0.15s ease;
}

.chat-header-actions button:hover {
  background: rgba(255, 255, 255, 0.2);
}

.chat-header-actions button:focus-visible {
  outline: 2px solid white;
  outline-offset: 2px;
}

/* Desktop: Show minimize and maximize, hide close */
.chat-minimize-desktop {
  display: block;
}

.chat-maximize-desktop {
  display: block;
}

.chat-close-mobile {
  display: none;
}

/* Maximize button icon toggle */
.chat-maximize-desktop .restore-icon {
  display: none;
}

.chat-maximize-desktop .maximize-icon {
  display: block;
}

.chat-panel.maximized .chat-maximize-desktop .restore-icon {
  display: block;
}

.chat-panel.maximized .chat-maximize-desktop .maximize-icon {
  display: none;
}

/* ==========================================================================
   Connection Banner
   ========================================================================== */
.chat-banner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding-left: 1rem;
  padding-right: 1rem;
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
  font-size: 0.875rem;
  line-height: 1.25rem;
  background: #fef3c7;
  color: #92400e;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.chat-banner.banner-error {
  background: #fee2e2;
  color: #991b1b;
}

.chat-banner button {
  border-radius: 0.25rem;
  padding-left: 0.5rem;
  padding-right: 0.5rem;
  padding-top: 0.25rem;
  padding-bottom: 0.25rem;
  font-size: 0.75rem;
  line-height: 1rem;
  font-weight: 500;
  background: rgba(0, 0, 0, 0.1);
  border: none;
  cursor: pointer;
}

.chat-banner button:hover {
  background: rgba(0, 0, 0, 0.15);
}

/* ==========================================================================
   Messages Container
   ========================================================================== */
.chat-messages {
  -webkit-box-flex: 1;
      -ms-flex: 1 1 0%;
          flex: 1 1 0%;
}

.chat-messages > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(1rem * (1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(1rem * var(--tw-space-y-reverse));
}

.chat-messages {
  overflow-y: auto;
  padding: 1rem;
  background: rgb(var(--color-secondary));
  scroll-behavior: smooth;
}

/* ==========================================================================
   Message Bubbles
   ========================================================================== */
.message {
  border-radius: 0.5rem;
  padding: 0.75rem;
  width: -moz-fit-content;
  width: -webkit-fit-content;
  width: fit-content;
  max-width: 85%;
  word-wrap: break-word;
}

.message-user {
  margin-left: auto;
  background: rgb(var(--color-primary));
  color: white;
  border-bottom-right-radius: 4px;
}

.message-assistant {
  margin-right: auto;
  background: white;
  color: rgb(var(--color-text-main));
  border-bottom-left-radius: 4px;
  -webkit-box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
          box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

/* Markdown Content Styling */
.message-content {
  line-height: 1.5;
}

.message-content p {
  margin: 0.5em 0;
}

.message-content p:first-child {
  margin-top: 0;
}

.message-content p:last-child {
  margin-bottom: 0;
}

.message-content ul,
.message-content ol {
  margin: 0.5em 0;
  padding-left: 1.5em;
}

.message-content li {
  margin: 0.25em 0;
}

.message-content code {
  border-radius: 0.25rem;
  padding-left: 0.25rem;
  padding-right: 0.25rem;
  padding-top: 0.125rem;
  padding-bottom: 0.125rem;
  font-size: 0.875rem;
  line-height: 1.25rem;
  background: rgba(0, 0, 0, 0.05);
  font-family: monospace;
}

.message-content pre {
  overflow-x: auto;
  border-radius: 0.25rem;
  padding: 0.5rem;
  background: rgba(0, 0, 0, 0.05);
}

.message-content strong {
  font-weight: 600;
}

.message-content em {
  font-style: italic;
}

.message-content a {
  color: rgb(var(--color-accent));
  text-decoration: underline;
}

.message-user .message-content code {
  background: rgba(255, 255, 255, 0.2);
}

/* Streaming Cursor */
.message-streaming .message-content::after {
  content: "▊";
  -webkit-animation: blink 1s infinite;
          animation: blink 1s infinite;
  margin-left: 2px;
}

@-webkit-keyframes blink {
  50% {
    opacity: 0;
  }
}

@keyframes blink {
  50% {
    opacity: 0;
  }
}
/* System Messages */
.message-system {
  margin-left: auto;
  margin-right: auto;
  border-radius: 0.5rem;
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
  padding-left: 1rem;
  padding-right: 1rem;
  text-align: center;
  font-size: 0.875rem;
  line-height: 1.25rem;
  background: transparent;
  color: rgb(var(--color-text-muted));
  max-width: 90%;
}

.message-system.message-error {
  background: #fee2e2;
  color: #991b1b;
}

.message-system.message-warning {
  background: #fef3c7;
  color: #92400e;
}

/* ==========================================================================
   Typing Indicator
   ========================================================================== */
.chat-typing {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.25rem;
  padding-left: 1rem;
  padding-right: 1rem;
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.typing-dot {
  height: 0.5rem;
  width: 0.5rem;
  border-radius: 9999px;
  background: rgb(var(--color-text-muted));
  -webkit-animation: typing 1.4s infinite;
          animation: typing 1.4s infinite;
}

.typing-dot:nth-child(2) {
  -webkit-animation-delay: 0.2s;
          animation-delay: 0.2s;
}

.typing-dot:nth-child(3) {
  -webkit-animation-delay: 0.4s;
          animation-delay: 0.4s;
}

@-webkit-keyframes typing {
  0%, 60%, 100% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  30% {
    -webkit-transform: translateY(-4px);
            transform: translateY(-4px);
  }
}

@keyframes typing {
  0%, 60%, 100% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  30% {
    -webkit-transform: translateY(-4px);
            transform: translateY(-4px);
  }
}
/* ==========================================================================
   Input Area
   ========================================================================== */
.chat-input-area {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  gap: 0.5rem;
  border-top-width: 1px;
  padding: 0.75rem;
  background: white;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

#chat-input {
  -webkit-box-flex: 1;
      -ms-flex: 1 1 0%;
          flex: 1 1 0%;
  resize: none;
  border-radius: 0.5rem;
  border-width: 1px;
  padding-left: 0.75rem;
  padding-right: 0.75rem;
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
  border-color: rgb(var(--color-secondary));
  max-height: 120px;
  font-size: 0.875rem;
  line-height: 1.5;
}

#chat-input:focus {
  outline: none;
  border-color: rgb(var(--color-accent));
  -webkit-box-shadow: 0 0 0 3px rgba(63, 191, 173, 0.1);
          box-shadow: 0 0 0 3px rgba(63, 191, 173, 0.1);
}

#chat-input:disabled {
  background: rgb(var(--color-secondary));
  cursor: not-allowed;
}

#chat-send {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 2.5rem;
  width: 2.5rem;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  border-radius: 9999px;
  background: rgb(var(--color-accent));
  color: white;
  border: none;
  cursor: pointer;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  -webkit-transition: opacity 0.2s, -webkit-transform 0.2s;
  transition: opacity 0.2s, -webkit-transform 0.2s;
  transition: opacity 0.2s, transform 0.2s;
  transition: opacity 0.2s, transform 0.2s, -webkit-transform 0.2s;
}

#chat-send:hover:not(:disabled) {
  -webkit-transform: scale(1.05);
          transform: scale(1.05);
}

#chat-send:focus-visible {
  outline: 2px solid rgb(var(--color-accent));
  outline-offset: 2px;
}

#chat-send:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* ==========================================================================
   Sources Panel
   ========================================================================== */
.chat-sources {
  border-top-width: 1px;
  background: rgb(var(--color-secondary));
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.sources-toggle {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding-left: 1rem;
  padding-right: 1rem;
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
  font-size: 0.875rem;
  line-height: 1.25rem;
  background: transparent;
  border: none;
  cursor: pointer;
  color: rgb(var(--color-text-muted));
}

.sources-toggle:hover {
  color: rgb(var(--color-text-main));
}

.sources-chevron {
  -webkit-transition: -webkit-transform 0.2s ease;
  transition: -webkit-transform 0.2s ease;
  transition: transform 0.2s ease;
  transition: transform 0.2s ease, -webkit-transform 0.2s ease;
}

.sources-toggle[aria-expanded=true] .sources-chevron {
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
}

.sources-list > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(0.5rem * (1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(0.5rem * var(--tw-space-y-reverse));
}

.sources-list {
  padding-left: 1rem;
  padding-right: 1rem;
  padding-bottom: 0.75rem;
}

.source-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.5rem;
  font-size: 0.75rem;
  line-height: 1rem;
  color: rgb(var(--color-text-muted));
}

.source-type {
  border-radius: 0.25rem;
  padding-left: 0.5rem;
  padding-right: 0.5rem;
  padding-top: 0.125rem;
  padding-bottom: 0.125rem;
  background: rgba(var(--color-primary), 0.1);
  color: rgb(var(--color-primary));
  font-weight: 500;
}

.source-link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.5rem;
  -webkit-transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
  -webkit-transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
          transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  -webkit-transition-duration: 150ms;
          transition-duration: 150ms;
  color: inherit;
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 0;
  font: inherit;
  text-align: left;
}
.source-link:hover {
  color: rgb(var(--color-primary));
}
.source-link:hover .source-type {
  background: rgba(var(--color-primary), 0.2);
}
.source-link:hover .source-icon {
  opacity: 1;
}
.source-link:focus-visible {
  outline: 2px solid rgb(var(--color-accent));
  outline-offset: 2px;
  border-radius: 4px;
}

.source-section {
  color: rgb(var(--color-text-muted));
}

.source-title {
  color: rgb(var(--color-text-main));
  font-weight: 500;
}

.source-download {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 0.25rem;
  color: rgb(var(--color-text-muted));
  border-radius: 4px;
  text-decoration: none;
  -webkit-transition: color 0.15s, background 0.15s;
  transition: color 0.15s, background 0.15s;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.source-download:hover, .source-download:focus-visible {
  color: rgb(var(--color-primary));
  background: rgba(var(--color-primary), 0.08);
  outline: none;
}

.source-title-btn {
  background: transparent;
  border: none;
  padding: 0;
  cursor: pointer;
  font: inherit;
  text-align: left;
  color: inherit;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.source-title-btn:hover .source-title, .source-title-btn:focus-visible .source-title {
  color: rgb(var(--color-primary));
  text-decoration: underline;
}
.source-title-btn:focus-visible {
  outline: 2px solid rgb(var(--color-accent));
  outline-offset: 2px;
  border-radius: 4px;
}

.source-icon {
  font-size: 0.75rem;
  line-height: 1rem;
  opacity: 0.7;
  -webkit-transition: opacity 0.15s;
  transition: opacity 0.15s;
}

.citation-ref {
  color: rgb(var(--color-accent));
  font-weight: 600;
  font-size: 0.8em;
  vertical-align: super;
  -webkit-transition: color 0.15s;
  transition: color 0.15s;
  cursor: pointer;
}
.citation-ref:hover, .citation-ref:focus-visible {
  color: rgb(var(--color-primary));
  text-decoration: underline;
  outline: none;
}

.citation-ref-clickable {
  cursor: pointer;
}

.source-citation-num {
  font-weight: 700;
  color: rgb(var(--color-accent));
  min-width: 1.5rem;
  font-size: 0.8rem;
}

.tool-activity {
  color: rgb(var(--color-text-muted));
  font-style: italic;
}

/* ==========================================================================
   History Panel
   ========================================================================== */
.chat-history-panel {
  position: absolute;
  inset: 0px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  background: white;
  z-index: 10;
}

.history-header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding-left: 1rem;
  padding-right: 1rem;
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;
  background: rgb(var(--color-primary));
  color: white;
}

.history-header h3 {
  margin: 0px;
  font-weight: 600;
}

.history-header button {
  border-radius: 0.25rem;
  padding: 0.25rem;
  background: transparent;
  border: none;
  color: white;
  cursor: pointer;
  font-size: 1.5rem;
  line-height: 1;
}

.history-header button:hover {
  background: rgba(255, 255, 255, 0.2);
}

.history-list {
  -webkit-box-flex: 1;
      -ms-flex: 1 1 0%;
          flex: 1 1 0%;
  overflow-y: auto;
}

.history-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  border-bottom-width: 1px;
  padding-left: 1rem;
  padding-right: 1rem;
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;
  text-align: left;
  border-color: rgb(var(--color-secondary));
  background: transparent;
  cursor: pointer;
}

.history-item:hover {
  background: rgb(var(--color-secondary));
}

.history-item:focus {
  outline: 2px solid rgb(var(--color-accent));
  outline-offset: -2px;
}

.history-item-title {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 0.875rem;
  line-height: 1.25rem;
  font-weight: 500;
  color: rgb(var(--color-text-main));
}

.history-item-meta {
  margin-top: 0.25rem;
  font-size: 0.75rem;
  line-height: 1rem;
  color: rgb(var(--color-text-muted));
}

.history-empty,
.history-loading {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 8rem;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-size: 0.875rem;
  line-height: 1.25rem;
  color: rgb(var(--color-text-muted));
}

/* ==========================================================================
   Mobile Responsive
   ========================================================================== */
/* Maximized State (Desktop) */
.chat-panel.maximized {
  position: fixed;
  top: 1.5rem;
  left: 1.5rem;
  right: 1.5rem;
  bottom: 1.5rem;
  width: auto;
  height: auto;
  max-height: none;
  border-radius: 1rem;
}

@media (max-width: 640px) {
  .chat-widget {
    bottom: 1rem;
    right: 1rem;
  }
  .chat-panel {
    position: fixed;
    inset: 0;
    width: 100%;
    height: 100%;
    max-height: 100%;
    border-radius: 0;
    -webkit-animation: slideUpMobile 0.2s ease-out;
            animation: slideUpMobile 0.2s ease-out;
  }
  /* Mobile: Show close, hide minimize and maximize */
  .chat-minimize-desktop {
    display: none;
  }
  .chat-maximize-desktop {
    display: none;
  }
  .chat-close-mobile {
    display: block;
  }
}
@-webkit-keyframes slideUpMobile {
  from {
    opacity: 0;
    -webkit-transform: translateY(100%);
            transform: translateY(100%);
  }
  to {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
@keyframes slideUpMobile {
  from {
    opacity: 0;
    -webkit-transform: translateY(100%);
            transform: translateY(100%);
  }
  to {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
/* ==========================================================================
   Scroll Lock (Mobile Fullscreen Dialog)
   ========================================================================== */
body.chat-open {
  overflow: hidden !important;
  position: fixed;
  width: 100%;
  height: 100%;
}

/* ==========================================================================
   Utility: Hidden
   ========================================================================== */
.chat-widget .hidden {
  display: none !important;
}

/* ==========================================================================
   Document Preview Modal
   ========================================================================== */
.doc-preview-modal {
  position: fixed;
  inset: 0;
  z-index: 2000;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.doc-preview-modal.hidden {
  display: none !important;
}

.doc-preview-modal .hidden {
  display: none !important;
}

.doc-preview-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(4px);
}

.doc-preview-container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  position: relative;
  width: 95vw;
  max-width: 95vw;
  height: 95vh;
  max-height: 95vh;
  background: white;
  border-radius: 1rem;
  -webkit-box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
          box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
  overflow: hidden;
  -webkit-animation: docPreviewIn 0.2s ease-out;
          animation: docPreviewIn 0.2s ease-out;
}

@-webkit-keyframes docPreviewIn {
  from {
    opacity: 0;
    -webkit-transform: scale(0.95);
            transform: scale(0.95);
  }
  to {
    opacity: 1;
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}

@keyframes docPreviewIn {
  from {
    opacity: 0;
    -webkit-transform: scale(0.95);
            transform: scale(0.95);
  }
  to {
    opacity: 1;
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}
.doc-preview-header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding-left: 1.25rem;
  padding-right: 1.25rem;
  padding-top: 1rem;
  padding-bottom: 1rem;
  background: rgb(var(--color-primary));
  color: white;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.doc-preview-info {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 0.25rem;
  min-width: 0;
}

.doc-preview-title {
  margin: 0px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 1.125rem;
  line-height: 1.75rem;
  font-weight: 600;
}

.doc-preview-type {
  font-size: 0.875rem;
  line-height: 1.25rem;
  opacity: 0.9;
}

.doc-preview-actions {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  gap: 0.25rem;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.doc-preview-action {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  border-radius: 0.5rem;
  padding: 0.5rem;
  background: transparent;
  border: none;
  color: white;
  cursor: pointer;
  text-decoration: none;
  -webkit-transition: background-color 0.15s;
  transition: background-color 0.15s;
}
.doc-preview-action:hover {
  background: rgba(255, 255, 255, 0.2);
}
.doc-preview-action:focus-visible {
  outline: 2px solid white;
  outline-offset: 2px;
}
.doc-preview-action[hidden] {
  display: none;
}

.doc-preview-body {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-flex: 1;
      -ms-flex: 1 1 0%;
          flex: 1 1 0%;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  overflow: auto;
  background: rgb(var(--color-secondary));
  position: relative;
}

.doc-preview-loading,
.doc-preview-error {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 0.75rem;
  padding: 1.5rem;
  text-align: center;
  color: rgb(var(--color-text-main));
  font-weight: 500;
}
.doc-preview-loading.hidden,
.doc-preview-error.hidden {
  display: none !important;
}

.doc-preview-error {
  color: #c53030;
}

.doc-preview-spinner {
  height: 2.5rem;
  width: 2.5rem;
  border-radius: 9999px;
  border: 3px solid rgb(var(--color-secondary));
  border-top-color: rgb(var(--color-accent));
  -webkit-animation: spin 1s linear infinite;
          animation: spin 1s linear infinite;
}

@-webkit-keyframes spin {
  to {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}

@keyframes spin {
  to {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}
.doc-preview-error {
  color: #991b1b;
}

.doc-preview-canvas {
  max-width: 100%;
  max-height: 100%;
  -o-object-fit: contain;
  object-fit: contain;
  display: block;
  margin: auto;
  -webkit-box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
          box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
}

.doc-preview-footer {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 1rem;
  border-top-width: 1px;
  padding-left: 1.25rem;
  padding-right: 1.25rem;
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;
  background: white;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.doc-preview-nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 2.5rem;
  width: 2.5rem;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  border-radius: 9999px;
  background: rgb(var(--color-secondary));
  border: none;
  cursor: pointer;
  -webkit-transition: background-color 0.15s, -webkit-transform 0.15s;
  transition: background-color 0.15s, -webkit-transform 0.15s;
  transition: background-color 0.15s, transform 0.15s;
  transition: background-color 0.15s, transform 0.15s, -webkit-transform 0.15s;
  color: rgb(var(--color-text-main));
}

.doc-preview-nav:hover:not(:disabled) {
  background: rgb(var(--color-accent));
  color: white;
  -webkit-transform: scale(1.05);
          transform: scale(1.05);
}

.doc-preview-nav:focus-visible {
  outline: 2px solid rgb(var(--color-accent));
  outline-offset: 2px;
}

.doc-preview-nav:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

.doc-preview-page-info {
  padding-left: 1rem;
  padding-right: 1rem;
  font-size: 0.875rem;
  line-height: 1.25rem;
  font-weight: 500;
  color: rgb(var(--color-text-main));
  min-width: 80px;
  text-align: center;
}

/* Body scroll lock when preview is open */
body.preview-open {
  overflow: hidden !important;
}

/* Mobile responsive */
@media (max-width: 640px) {
  .doc-preview-container {
    width: 100vw;
    height: 100vh;
    max-width: none;
    max-height: none;
    border-radius: 0;
  }
  .doc-preview-header {
    padding-left: 1rem;
    padding-right: 1rem;
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
  }
  .doc-preview-title {
    font-size: 1rem;
    line-height: 1.5rem;
  }
  .doc-preview-footer {
    padding-left: 1rem;
    padding-right: 1rem;
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
  }
}
.breadcrumb li:not(:last-child)::after {
  color: var(--gray-500);
}

.chat-widget {
  font-family: var(--font-family-default);
}

.chat-toggle {
  background: var(--mint-bright);
  -webkit-box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -4px rgba(0, 0, 0, 0.1);
          box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -4px rgba(0, 0, 0, 0.1);
}

.chat-toggle:focus-visible {
  outline-color: var(--mint-bright);
}

.chat-header {
  background: var(--teal-deep);
}

.chat-messages > :not([hidden]) ~ :not([hidden]) {
  margin-top: 1rem;
  margin-bottom: 0;
}

.chat-messages {
  background: var(--gray-100);
}

.message-user {
  background: var(--teal-deep);
}

.message-assistant {
  color: var(--text-color);
}

.message-content a {
  color: var(--mint-bright);
}

.message-system {
  color: var(--gray-500);
}

.typing-dot {
  background: var(--gray-500);
}

#chat-input {
  border-color: var(--gray-200);
}

#chat-input:focus {
  border-color: var(--mint-bright);
}

#chat-input:disabled {
  background: var(--gray-100);
}

#chat-send {
  background: var(--mint-bright);
}

#chat-send:focus-visible {
  outline-color: var(--mint-bright);
}

.chat-sources {
  background: var(--gray-100);
}

.sources-toggle {
  color: var(--gray-500);
}

.sources-toggle:hover {
  color: var(--text-color);
}

.sources-list > :not([hidden]) ~ :not([hidden]) {
  margin-top: 0.5rem;
  margin-bottom: 0;
}

.source-item {
  color: var(--gray-500);
}

.source-type {
  background: rgba(14, 75, 90, 0.1);
  color: var(--teal-deep);
}

.source-link:hover {
  color: var(--teal-deep);
}

.source-link:hover .source-type {
  background: rgba(14, 75, 90, 0.2);
}

.source-link:focus-visible {
  outline-color: var(--mint-bright);
}

.source-section {
  color: var(--gray-500);
}

.source-title {
  color: var(--text-color);
}

.history-header {
  background: var(--teal-deep);
}

.history-header h3 {
  color: var(--mint-pale);
  font-size: 1.25rem;
}

.history-item {
  border-color: var(--gray-200);
}

.history-item:hover {
  background: var(--gray-100);
}

.history-item:focus {
  outline-color: var(--mint-bright);
}

.history-item-title {
  color: var(--text-color);
}

.history-item-meta {
  color: var(--gray-500);
}

.history-empty, .history-loading {
  color: var(--gray-500);
}

.doc-preview-header {
  background: var(--teal-deep);
}

.doc-preview-body {
  background: var(--gray-100);
}

.doc-preview-loading, .doc-preview-error {
  color: var(--gray-500);
}

.doc-preview-spinner {
  border-color: var(--gray-200);
  border-top-color: var(--mint-bright);
}

.doc-preview-nav {
  background: var(--gray-100);
  color: var(--text-color);
}

.doc-preview-nav:hover:not(:disabled) {
  background: var(--mint-bright);
}

.doc-preview-nav:focus-visible {
  outline-color: var(--mint-bright);
}

.doc-preview-page-info {
  color: var(--text-color);
}

.product-image-placeholder {
  color: rgba(120, 113, 108, 0.4);
}

.product-card:hover {
  border-color: rgba(14, 75, 90, 0.3);
}

.card {
  background: var(--container-background, #ffffff);
  border-radius: var(--radius-xl);
  padding: var(--space-clamp);
  -webkit-box-shadow: var(--container-shadow, var(--shadow-dramatic));
          box-shadow: var(--container-shadow, var(--shadow-dramatic));
  -webkit-transition: all 0.5s cubic-bezier(0.34, 1.56, 0.64, 1);
  transition: all 0.5s cubic-bezier(0.34, 1.56, 0.64, 1);
  position: relative;
}

:root {
  --product-card-padding: 1.5rem;
  --product-card-gap: 0.375rem;
  --product-card-radius: 0.75rem;
  --product-card-image-radius: 0.5rem;
  --product-card-badge-radius: 1.5rem;
  --product-card-image-height: 180px;
  --product-card-badge-norm-size: 22px;
  --product-card-bg: #ffffff;
  --product-card-border: #e5e7eb;
  --product-card-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
  --product-card-shadow-hover: 0 8px 25px rgba(0, 0, 0, 0.1);
  --product-card-image-gradient-start: #f8fafc;
  --product-card-image-gradient-end: #f1f5f9;
  --product-card-font-name: 1.125rem;
  --product-card-font-meta: 0.875rem;
  --product-card-font-manufacturer: 0.8125rem;
  --product-card-font-summary: 0.875rem;
  --product-card-font-badge-size: 0.75rem;
  --product-card-font-badge-norm: 0.5625rem;
  --product-card-font-badge-pzn: 0.625rem;
  --product-card-transition-duration: 0.2s;
  --product-card-transition-timing: ease;
}

.product-card {
  background: var(--product-card-bg);
  border: 1px solid var(--product-card-border);
  border-radius: var(--product-card-radius);
  padding: var(--product-card-padding);
  -webkit-box-shadow: var(--product-card-shadow);
          box-shadow: var(--product-card-shadow);
  position: relative;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.product-card a.product-card-link::after {
  content: "";
  position: absolute;
  inset: 0;
}
.product-card h2 {
  font-size: var(--product-card-font-name);
  margin-bottom: 0.5rem;
  margin-top: var(--space-md);
  padding-bottom: 0.375rem;
  border-bottom: 1px solid var(--gray-200);
  font-weight: var(--fw-sb);
}
.product-card .product-actionbuttons {
  margin-top: auto;
}

.product-card-link {
  text-decoration: none;
  color: inherit;
  display: block;
}
.product-card-link:hover {
  text-decoration: none;
}
.product-card-link .product-card {
  height: 100%;
  -webkit-transition: -webkit-transform var(--product-card-transition-duration) var(--product-card-transition-timing), -webkit-box-shadow var(--product-card-transition-duration) var(--product-card-transition-timing);
  transition: -webkit-transform var(--product-card-transition-duration) var(--product-card-transition-timing), -webkit-box-shadow var(--product-card-transition-duration) var(--product-card-transition-timing);
  transition: transform var(--product-card-transition-duration) var(--product-card-transition-timing), box-shadow var(--product-card-transition-duration) var(--product-card-transition-timing);
  transition: transform var(--product-card-transition-duration) var(--product-card-transition-timing), box-shadow var(--product-card-transition-duration) var(--product-card-transition-timing), -webkit-transform var(--product-card-transition-duration) var(--product-card-transition-timing), -webkit-box-shadow var(--product-card-transition-duration) var(--product-card-transition-timing);
}
.product-card-link:hover .product-card {
  -webkit-transform: translateY(-2px);
          transform: translateY(-2px);
  -webkit-box-shadow: var(--product-card-shadow-hover);
          box-shadow: var(--product-card-shadow-hover);
}
.product-card-link:hover .product-pkg-badge {
  border-color: rgb(var(--color-primary)/0.3);
  -webkit-box-shadow: 0 2px 6px rgba(14, 75, 90, 0.1);
          box-shadow: 0 2px 6px rgba(14, 75, 90, 0.1);
}

.product-image {
  width: 100%;
  height: var(--product-card-image-height);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  background: linear-gradient(135deg, rgb(176, 199, 195) 0%, rgb(216, 227, 225) 100%);
  border-radius: var(--product-card-image-radius);
  margin-bottom: 1rem;
  overflow: hidden;
}
.product-image picture {
  width: 100%;
  height: 100%;
}
.product-image img {
  max-width: 100%;
  max-height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  padding: 1rem;
}

.product-image-placeholder {
  color: rgb(var(--color-text-muted)/0.4);
}
.product-image-placeholder svg {
  width: 3rem;
  height: 3rem;
}

.product-card-content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}

.product-name {
  font-size: var(--product-card-font-name);
  margin-bottom: 0.5rem;
}

.product-meta {
  color: var(--gray-400);
  font-size: var(--product-card-font-meta);
  margin-bottom: 0.5rem;
}

.product-manufacturer {
  color: var(--gray-400);
  font-size: var(--product-card-font-manufacturer);
  margin-bottom: 0.75rem;
}

.product-summary {
  color: var(--gray-700);
  font-size: var(--product-card-font-summary);
  line-height: 1.5;
  margin-block: 1rem;
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
}

.product-packages {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: var(--product-card-gap);
  margin-bottom: 0.75rem;
}

.product-pkg-badge {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: var(--product-card-gap);
  background: var(--product-card-bg);
  border: 1px solid var(--gray-300);
  border-radius: var(--product-card-badge-radius);
  padding: 0.1875rem 0.5rem 0.1875rem 0.1875rem;
  -webkit-transition: all var(--product-card-transition-duration) var(--product-card-transition-timing);
  transition: all var(--product-card-transition-duration) var(--product-card-transition-timing);
}

.product-pkg-default .product-pkg-norm {
  background: var(--mint-bright);
}

.product-pkg-norm {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: var(--product-card-badge-norm-size);
  height: var(--product-card-badge-norm-size);
  background: var(--teal-deep);
  color: var(--product-card-bg);
  border-radius: 50%;
  font-family: var(--font-mono);
  font-size: var(--product-card-font-badge-norm);
  font-weight: 700;
  letter-spacing: -0.02em;
}

.product-pkg-size {
  font-weight: 600;
  font-size: var(--product-card-font-badge-size);
  color: var(--gray-700);
}

.product-pkg-pzn {
  font-family: var(--font-mono);
  font-size: var(--product-card-font-badge-pzn);
  color: var(--gray-400);
  letter-spacing: 0.02em;
}

.product-link-indicator {
  color: var(--teal-medium);
  font-size: var(--product-card-font-meta);
  font-weight: 500;
  margin-top: auto;
}

.product-filters {
  margin-bottom: 2rem;
}

.product-filter-form {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 1rem;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
}

.product-filter-group {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 0.25rem;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  min-width: 200px;
}

.product-filter-label {
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--gray-500);
}

.product-filter-select {
  min-height: 42px;
  padding: 0.5rem 0.75rem;
  border: 2px solid var(--gray-200);
  border-radius: var(--radius-md);
  background: white;
  font-size: 0.875rem;
  color: var(--gray-800);
  -webkit-transition: border-color 0.2s ease;
  transition: border-color 0.2s ease;
}

.product-filter-select:focus {
  outline: none;
  border-color: var(--teal-deep);
}

.product-filter-actions {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.75rem;
  padding-bottom: 0.125rem;
}

.product-filter-reset {
  font-size: 0.8125rem;
  color: var(--gray-500);
  text-decoration: underline;
}
.product-filter-reset:hover {
  color: var(--teal-deep);
}

@media (max-width: 639px) {
  .product-filter-form {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .product-filter-group {
    min-width: 100%;
  }
}
.pd-hero .pd-hero-content h1 {
  margin: 0;
}

.pd-hero-pkg {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 10px;
  border-radius: var(--radius-full);
  background-color: var(--mint-pale);
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  padding-right: var(--space-sm);
  margin-bottom: var(--space-sm);
}
.pd-hero-pkg .pd-hero-pkg-norm {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 2rem;
  height: 2rem;
  padding: var(--space-sm);
  border-radius: 50%;
  background-color: var(--mint-bright);
}
.pd-hero-pkg .pd-hero-pkg-size {
  font-weight: var(--fw-sb);
}
.pd-hero-pkg .pd-hero-pkg-size::after {
  content: " |";
  font-weight: var(--fw-n);
  color: var(--mint-bright);
}
.pd-hero-pkg .pd-hero-pkg-pzn::before {
  content: "PZN ";
}

.pd-order-section {
  background-color: var(--mint-paler);
}
.pd-order-section .pd-card-title {
  margin-top: 0;
}
.pd-order-section .pd-order-form .pd-select {
  display: block;
  width: 120px;
  min-height: 48px;
  padding: 0.75rem 1rem;
  border: 2px solid var(--gray-200);
  border-radius: var(--radius-md);
  background: white;
  font-size: 1rem;
  color: var(--gray-800);
  -webkit-transition: border-color 0.2s ease, -webkit-box-shadow 0.2s ease;
  transition: border-color 0.2s ease, -webkit-box-shadow 0.2s ease;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  transition: border-color 0.2s ease, box-shadow 0.2s ease, -webkit-box-shadow 0.2s ease;
}
.pd-order-section .pd-order-form .pd-order-btn {
  margin-top: var(--space-lg);
}
.pd-order-section .pd-order-form .pd-order-address {
  background-color: rgba(14, 75, 90, 0.05);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  margin-block: var(--space-md) var(--space-lg);
}
.pd-order-section .pd-order-form .pd-order-address .pd-address-title {
  margin-top: 0;
}
.pd-order-section .pd-order-form .pd-order-address a {
  text-decoration: underline;
}

.pd-card-chat .pd-chat-title {
  margin-top: 0;
}

.pd-card-icon {
  --icon-bg: var(--mint-pale);
  --icon-color: var(--teal-dark);
  width: 3rem;
  height: 3rem;
  padding: 0.5rem;
  border-radius: var(--radius-md);
  background-color: var(--icon-bg);
  color: var(--icon-color);
  display: -ms-grid;
  display: grid;
  place-items: center;
  margin-bottom: 1.5rem;
}
.pd-card-icon svg {
  color: inherit;
}

.pd-card-icon-highlight {
  --icon-bg: var(--orange-pale);
  --icon-color: var(--orange);
}

.pd-card-title {
  margin-top: 0;
}

.pd-card-specs .pd-specs {
  margin-bottom: 2rem;
}
.pd-card-specs .pd-specs .pd-spec-row {
  padding: var(--space-sm);
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 0.5rem 2fr;
  grid-template-columns: 1fr 2fr;
  gap: 0.5rem;
}
.pd-card-specs .pd-specs .pd-spec-row:nth-child(odd) {
  background-color: var(--mint-paler);
}

.pd-support-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.5rem;
}

.pd-support-item-icon {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.pd-support-item-icon svg {
  width: 1.25rem;
  height: 1.25rem;
  color: var(--teal-dark);
}

li.pd-doc-item {
  margin-bottom: 0.5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: start;
  gap: 0.5rem;
}

.pd-doc-download {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 0.25rem;
  color: var(--teal-dark);
  border-radius: 4px;
  text-decoration: none;
  -webkit-transition: background-color 0.15s, color 0.15s;
  transition: background-color 0.15s, color 0.15s;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.pd-doc-download svg {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 18px;
          flex: 0 0 18px;
}
.pd-doc-download:hover, .pd-doc-download:focus-visible {
  background: rgba(0, 0, 0, 0.05);
  color: var(--teal-deep);
  outline: none;
}

.pd-doc-title {
  background: transparent;
  border: none;
  padding: 0;
  cursor: pointer;
  font: inherit;
  text-align: left;
  color: inherit;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  text-decoration: underline;
}
.pd-doc-title:hover, .pd-doc-title:focus-visible {
  color: var(--teal-deep);
  outline: none;
}
.pd-doc-title .pd-doc-name {
  font-weight: 500;
}

.pd-doc-title-link {
  text-decoration: underline;
}

.document-group:not(:last-child) {
  margin-bottom: var(--space-lg);
}

.product-actionbuttons {
  margin-top: var(--space-xl);
}

.pd-oem {
  background-color: var(--mint-pale);
  padding: 0.25em 1em;
  border-radius: 100vw;
}

.amgrid + #pflichtangaben {
  margin-block: var(--space-clamp);
}

.btn {
  /* Farben */
  --button-bg: var(--mint-bright);
  --button-bg-hover: var(--mint-light);
  --button-text: var(--cream);
  --button-text-hover: var(--teal-dark);
  --button-border: var(--mint-bright);
  --button-border-hover: var(--mint-bright);
  /* Layout */
  padding: var(--space-sm) var(--space-md);
  border-radius: var(--radius-full);
  font-weight: var(--fw-sb);
  cursor: pointer;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 0.5rem;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  border: 2px solid var(--button-border);
  background: var(--button-bg);
  color: var(--button-text);
  -webkit-box-shadow: var(--shadow-sm);
          box-shadow: var(--shadow-sm);
  min-height: 48px;
}
.btn:hover, .btn:focus {
  background: var(--button-bg-hover);
  color: var(--button-text-hover);
  text-decoration: none;
  border: 2px solid var(--button-border-hover);
  -webkit-transform: translateY(-2px);
          transform: translateY(-2px);
  -webkit-box-shadow: var(--shadow-lg), var(--shadow-glow-teal);
          box-shadow: var(--shadow-lg), var(--shadow-glow-teal);
}
.btn:disabled {
  background: var(--gray-200);
  color: var(--gray-500);
  cursor: not-allowed;
  -webkit-box-shadow: none;
          box-shadow: none;
  border: 2px solid var(--gray-300);
}

.btn-primary {
  --button-bg: var(--teal-deep);
  --button-bg-hover: var(--teal-medium);
  --button-text: var(--cream);
  --button-text-hover: var(--cream);
  --button-border: var(--teal-deep);
  --button-border-hover: var(--teal-medium);
}

.btn-primary-skeleton {
  --button-bg: transparent;
  --button-bg-hover: var(--teal-medium);
  --button-text: var(--teal-deep);
  --button-text-hover: var(--cream);
  --button-border: var(--teal-deep);
  --button-border-hover: var(--teal-medium);
}

.btn-secondary {
  --button-bg: var(--mint-light);
  --button-bg-hover: var(--teal-dark);
  --button-text: var(--teal-dark);
  --button-text-hover: #fff;
  --button-border: var(--mint-light);
  --button-border-hover: var(--teal-dark);
}

.btn-secondary-skeleton {
  --button-bg: transparent;
  --button-bg-hover: var(--teal-dark);
  --button-text: var(--mint-light);
  --button-text-hover: #fff;
  --button-border: var(--mint-light);
  --button-border-hover: var(--teal-dark);
}

.btn-full {
  width: 100%;
  margin-bottom: var(--space-sm);
}

.btn-lg {
  padding: 1rem 2rem;
  font-size: 1.0625rem;
}

.profile-card {
  background: white;
  border-radius: var(--radius-xl);
  padding: var(--space-2xl);
  -webkit-box-shadow: var(--shadow-lg);
          box-shadow: var(--shadow-lg);
}
.profile-card-header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-bottom: var(--space-xl);
  padding-bottom: var(--space-lg);
  border-bottom: 1px solid var(--gray-200);
}
.profile-card-header h2 {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--teal-deep);
}
.profile-card .profile-data {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: var(--space-xl);
}
.profile-card .profile-data .profile-section-block h3 {
  font-size: 0.875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--gray-500);
  margin-bottom: var(--space-md);
}
.profile-card .profile-data .profile-dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: var(--space-sm);
}
.profile-card .profile-data .profile-dl .profile-dl-row {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr var(--space-md) 1.5fr;
  grid-template-columns: 1fr 1.5fr;
  gap: var(--space-md);
  padding: var(--space-sm) 0;
  border-bottom: 1px solid var(--gray-100);
}
.profile-card .profile-data .profile-dl .profile-dl-row:last-child {
  border-bottom: none;
}
.profile-card .profile-data .profile-dl .profile-dl-row dt {
  font-size: 0.875rem;
  color: var(--gray-500);
}
.profile-card .profile-data .profile-dl .profile-dl-row dd {
  font-size: 0.9375rem;
  color: var(--gray-800);
  font-weight: 500;
}

.profile-edit-header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-bottom: var(--space-2xl);
  padding-bottom: var(--space-lg);
  border-bottom: 1px solid var(--gray-200);
}
.profile-edit-header h1 {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--teal-deep);
}

.pd-order-message {
  padding: 0.5rem 1rem;
  border-radius: var(--radius-sm);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.5rem;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.pd-order-message.pd-order-success {
  background-color: rgba(0, 255, 0, 0.15);
}
.pd-order-message.pd-order-error {
  background-color: rgba(255, 0, 0, 0.15);
}