/* =============================================================
   Art of Beauty Trier — Custom Stylesheet
   Brand Tokens: --primary #90a7ac · Black · White · Poppins
   ============================================================= */

/* Wave 87BW.49: Global iOS-Zoom-Guard auf allen <input>/<select>/<textarea>.
 * Vorher: Inputs ausserhalb von .form-group hatten Computed-Font-Size <16px,
 * iOS Safari zoomte beim Fokus rein — kaputt fuer Voucher-Form (preset-buttons),
 * Coupon-Form, inline-styled form-fields auf Public-Seiten. */
@media (max-width: 720px) {
    input, select, textarea {
        font-size: max(16px, 1em) !important;
    }
}

:root {
    /* --- Brand colors (Teal / Gold / Dark / Soft) --- */
    --primary: #90a7ac;
    --primary-dark: #7a9499;
    --primary-hover: #a1b4b8;
    --primary-soft: #adc1c5;
    --gold: #dabe92;
    --gold-dark: #b89261;
    --dark-bg: #1f2528;
    --soft-bg: #fcfaf6;
    --black: #000;
    --text: #2d2d2d;
    --text-warm: #5a4a30;
    --muted: #6e7679;
    --border: #e8eaed;
    --bg-soft: #f8f8f8;
    --bg-light: #fcfcfc;
    --white: #ffffff;
    --alert: #E3213C;
    --success: #4caf50;

    /* --- Spacing scale (4 / 8 / 12 / 16 / 24 / 32 / 48 / 64) --- */
    --sp-1: 4px;
    --sp-2: 8px;
    --sp-3: 12px;
    --sp-4: 16px;
    --sp-5: 24px;
    --sp-6: 32px;
    --sp-7: 48px;
    --sp-8: 64px;
    /* Wave 72: --space-N Aliase fuer neueren Code; Mapping 1:1 zu --sp-N. */
    --space-1: var(--sp-1);
    --space-2: var(--sp-2);
    --space-3: var(--sp-3);
    --space-4: var(--sp-4);
    --space-5: var(--sp-5);
    --space-6: var(--sp-6);

    /* --- Border radius scale --- */
    --radius-sm: 6px;
    --radius-md: 10px;
    --radius-lg: 14px;
    --radius-xl: 22px;
    --radius-pill: 999px;
    --radius: 0; /* legacy default — kept for back-compat */

    /* --- Shadow tokens --- */
    --shadow-sm: 0 2px 8px rgba(0,0,0,.04);
    --shadow-md: 0 8px 24px rgba(0,0,0,.08);
    --shadow-lg: 0 16px 48px rgba(0,0,0,.12);
    --shadow-glow: 0 8px 28px rgba(144,167,172,.28);

    /* --- Motion --- */
    --transition: 300ms cubic-bezier(.25,.46,.45,.94);
    --t-fast: 180ms cubic-bezier(.4,0,.2,1);
    --t-base: 240ms cubic-bezier(.4,0,.2,1);
    --t-slow: 420ms cubic-bezier(.16,1,.3,1);

    /* --- Layout container widths --- */
    --max-w: 1400px;
    --max-w-default: 1200px;
    --max-w-narrow: 740px;

    /* --- Touch targets --- */
    --touch-min: 44px;
}

* { box-sizing: border-box; }
html { font-size: 17px; scroll-behavior: smooth; }
@media (min-width: 941px)  { html { font-size: 18px; } }
@media (min-width: 1281px) { html { font-size: 19px; } }
@media (min-width: 1621px) { html { font-size: 20px; } }

body {
    margin: 0;
    font-family: 'Poppins', Arial, Verdana, Helvetica, sans-serif;
    font-size: .85em;
    line-height: 1.55em;
    font-weight: 400;
    color: var(--black);
    background: var(--white);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

img { max-width: 100%; height: auto; display: block; }
a { color: var(--primary); text-decoration: none; transition: color var(--transition); }
a:hover { color: var(--primary-hover); }

h1, h2, h3, h4, h5 { font-family: inherit; font-weight: 500; line-height: 1.25; margin: 0 0 .6em; }
h1 { font-size: 2.5em; color: var(--black); }
h2 { font-size: 1.25em; color: var(--primary); font-weight: 400; line-height: 1.5; margin-bottom: 1em; }
h3 { font-size: 2em; color: var(--black); font-weight: 500; margin-bottom: .65em; }
h4 { font-size: 1.4em; }
p { margin: 0 0 1em; }
ul, ol { padding-left: 1.4em; margin: 0 0 1em; }

.container { max-width: var(--max-w); margin: 0 auto; padding: 0 1.5rem; }
.container-narrow { max-width: var(--max-w-narrow); margin: 0 auto; padding: 0 1.5rem; }

/* ---------- Buttons ---------- */
.btn, button.btn, a.btn, .button, button.button, a.button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--primary);
    border: 2px solid var(--primary);
    color: var(--white) !important;
    padding: .6em 1.55em;
    font: 500 .9em/1.55em 'Poppins', sans-serif;
    text-transform: none;
    letter-spacing: 0;
    border-radius: var(--radius);
    cursor: pointer;
    text-decoration: none;
    transition: all var(--transition);
    text-align: center;
}
.btn:hover { background: var(--primary-hover); border-color: var(--primary-hover); }
.btn-outline { background: transparent; color: var(--primary) !important; }
.btn-outline:hover { background: var(--primary); color: var(--white) !important; }
.btn-dark { background: var(--black); border-color: var(--black); }
.btn-dark:hover { background: var(--primary); border-color: var(--primary); }
.btn-block { display: flex; width: 100%; }
.btn + .btn { margin-left: .6rem; }

/* ---------- HEADER (glassmorphic premium) ---------- */
.site-header {
    position: sticky; top: 0; z-index: 100;
    background: rgba(255,255,255,.55);
    backdrop-filter: saturate(180%) blur(28px);
    -webkit-backdrop-filter: saturate(180%) blur(28px);
    border-bottom: 1px solid rgba(0,0,0,.04);
    box-shadow:
        0 1px 0 rgba(255,255,255,.6) inset,
        0 8px 32px rgba(0,0,0,.04),
        0 1px 0 rgba(0,0,0,.05);
    transition: background 350ms ease, box-shadow 350ms ease, padding 350ms ease;
}
.site-header.scrolled {
    background: rgba(255,255,255,.82);
    box-shadow:
        0 1px 0 rgba(255,255,255,.7) inset,
        0 6px 28px rgba(0,0,0,.10);
}
.site-header::before {
    content: ''; position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(255,255,255,.12), transparent 60%);
    pointer-events: none;
}

/* Top utility bar - schwarzer Premium-Streifen */
.header-top {
    background: linear-gradient(180deg, #050505 0%, #1a1a1a 100%);
    color: rgba(255,255,255,.85);
    font-size: .75rem;
    border-bottom: 1px solid rgba(255,255,255,.08);
    box-shadow: 0 1px 0 rgba(255,255,255,.04) inset, 0 -1px 0 rgba(255,255,255,.02);
    position: relative;
    z-index: 2;
}
.header-top::after {
    content: ''; position: absolute;
    left: 0; right: 0; bottom: -1px;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(144,167,172,.4), transparent);
}
.header-top-inner {
    max-width: var(--max-w);
    margin: 0 auto;
    padding: .55rem 1.5rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
}
.header-top a { color: rgba(255,255,255,.85); }
.header-top a:hover { color: var(--white); }
.header-top .icon-link svg { width: 14px; height: 14px; }
.header-top .icon-link { gap: .4rem; font-size: .75rem; letter-spacing: .04em; }
.utility-divider { opacity: .25; }
.header-top-utils { display: flex; align-items: center; gap: .9rem; }
.basket-link em { font-style: normal; color: var(--primary); font-weight: 500; }

/* Main bar with logo + nav */
.header-bar {
    max-width: var(--max-w);
    margin: 0 auto;
    padding: 1.2rem 1.5rem .8rem;
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 1.5rem;
}
.brand {
    display: flex; align-items: center;
    text-decoration: none;
    grid-column: 2;
    justify-self: center;
}
.brand-logo {
    width: 220px;
    height: auto;
    fill: var(--black);
    transition: transform 500ms cubic-bezier(.34,1.56,.64,1), filter 400ms ease;
    filter: drop-shadow(0 0 0 transparent);
}
.brand:hover .brand-logo {
    transform: scale(1.04);
    filter: drop-shadow(0 4px 12px rgba(144,167,172,.25));
}

.main-nav {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 2rem;
    list-style: none;
    margin: 0; padding: 0;
    grid-column: 1 / -1;
    grid-row: 2;
    border-top: 1px solid var(--border);
    padding-top: 1rem;
    margin-top: .5rem;
}
.main-nav > li { position: relative; }
.main-nav a {
    color: var(--black);
    font-weight: 400;
    font-size: .78rem;
    letter-spacing: .14em;
    text-transform: uppercase;
    padding: .65em .25em;
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    transition: color 350ms ease, letter-spacing 350ms ease, transform 350ms cubic-bezier(.34,1.56,.64,1);
}
.main-nav > li > a::before {
    content: ''; position: absolute;
    left: 50%; top: 0;
    width: 4px; height: 4px;
    background: var(--primary);
    border-radius: 50%;
    opacity: 0;
    transform: translate(-50%, -8px) scale(0);
    transition: all 400ms cubic-bezier(.34,1.56,.64,1);
}
.main-nav > li > a::after {
    content: ''; position: absolute;
    left: 50%; right: 50%; bottom: -2px;
    height: 1.5px; background: var(--primary);
    transition: left 400ms cubic-bezier(.16,1,.3,1), right 400ms cubic-bezier(.16,1,.3,1);
}
.main-nav > li:hover > a::after,
.main-nav > li > a.active::after { left: 0; right: 0; }
.main-nav > li:hover > a::before,
.main-nav > li > a.active::before { opacity: 1; transform: translate(-50%, -2px) scale(1); }
.main-nav > li:hover > a {
    color: var(--primary);
    letter-spacing: .16em;
}
.main-nav .dropdown:hover > a span[aria-hidden] {
    transform: rotate(180deg);
}
.main-nav span[aria-hidden] {
    transition: transform 350ms ease;
    display: inline-block;
    font-size: .65em;
    opacity: .6;
}

.main-nav .dropdown-menu {
    position: absolute; top: calc(100% + 8px); left: 50%;
    transform: translateX(-50%) translateY(12px);
    background: rgba(255,255,255,.85);
    backdrop-filter: saturate(180%) blur(20px);
    -webkit-backdrop-filter: saturate(180%) blur(20px);
    box-shadow:
        0 1px 0 rgba(255,255,255,.6) inset,
        0 24px 60px rgba(0,0,0,.12),
        0 0 0 1px rgba(0,0,0,.04);
    min-width: 320px;
    padding: .75rem 0;
    opacity: 0; visibility: hidden;
    transition: opacity 400ms ease, transform 400ms cubic-bezier(.16,1,.3,1), visibility 400ms;
    border-top: 2px solid var(--primary);
    z-index: 90;
    border-radius: 0 0 8px 8px;
}
.main-nav .dropdown:hover .dropdown-menu { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); }
.main-nav .dropdown-menu a {
    display: block;
    padding: .7em 1.6em;
    text-transform: none;
    font-size: .85rem;
    letter-spacing: .01em;
    font-weight: 400;
    position: relative;
    transition: padding-left 300ms ease, color 300ms ease, background 300ms ease;
}
.main-nav .dropdown-menu a::before,
.main-nav .dropdown-menu a::after { display: none; }
.main-nav .dropdown-menu a:hover {
    background: linear-gradient(90deg, rgba(144,167,172,.12) 0%, transparent 100%);
    color: var(--primary);
    padding-left: 2.1em;
}

.icon-link { color: var(--black); display: inline-flex; align-items: center; gap: .4rem; font-size: .85rem; transition: color 300ms ease, transform 300ms ease; }
.icon-link:hover { color: var(--primary); transform: translateY(-1px); }
.icon-link svg { width: 18px; height: 18px; transition: transform 350ms cubic-bezier(.34,1.56,.64,1); }
.icon-link:hover svg { transform: scale(1.15) rotate(-4deg); }
.basket-link:hover svg { transform: scale(1.15); }

.lang-switch { display: flex; gap: .15rem; align-items: center; }
.lang-switch a {
    display: inline-flex; align-items: center; gap: .3rem;
    padding: .25rem .4rem; opacity: .5;
    transition: opacity 300ms ease, transform 300ms ease;
    font-size: .7rem; text-transform: uppercase; letter-spacing: .08em;
    border-radius: 4px;
}
.lang-switch a.active, .lang-switch a:hover {
    opacity: 1;
    background: rgba(255,255,255,.05);
}
.lang-switch a:hover { transform: translateY(-1px); }
.lang-switch img {
    width: 20px; height: 13px;
    object-fit: cover;
    border-radius: 2px;
    box-shadow: 0 1px 3px rgba(0,0,0,.3);
}

.menu-toggle {
    display: none; background: none; border: 0;
    padding: .5rem; cursor: pointer;
    width: 44px; height: 44px;
    grid-column: 1; justify-self: start;
}
.menu-toggle span {
    display: block; width: 24px; height: 2px;
    background: var(--black); margin: 5px auto;
    transition: var(--transition);
    border-radius: 1px;
}

@media (max-width: 940px) {
    .header-top { font-size: .7rem; }
    .header-top-inner { padding: .4rem 1rem; gap: .5rem; }
    .header-top .icon-link span:not(em) { display: none; }
    .lang-switch a span { display: none; }
    .lang-switch a { padding: .15rem; }

    .header-bar {
        padding: .9rem 1rem;
        grid-template-columns: 44px 1fr 44px;
        gap: .75rem;
    }
    .menu-toggle {
        display: flex; flex-direction: column;
        align-items: center; justify-content: center;
        width: 44px; height: 44px; padding: 0;
        position: relative; z-index: 210;
    }
    .menu-toggle span {
        display: block; width: 26px; height: 2.5px;
        background: var(--black); margin: 4px auto;
        border-radius: 2px;
    }
    body.menu-open .menu-toggle span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
    body.menu-open .menu-toggle span:nth-child(2) { opacity: 0; }
    body.menu-open .menu-toggle span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }
    .brand { grid-column: 2; }
    .brand-logo { width: 150px; }

    .main-nav {
        position: fixed; top: 0; right: 0;
        width: 340px; max-width: 92vw; height: 100vh;
        height: 100dvh;
        background: linear-gradient(180deg, #fff 0%, #fcfaf6 100%);
        flex-direction: column;
        align-items: stretch;
        justify-content: flex-start;
        padding: 5rem 0 2rem;
        gap: 0;
        transform: translateX(100%);
        transition: transform .3s cubic-bezier(.2,.7,.2,1);
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
        margin: 0;
        border-top: 0;
        box-shadow: -10px 0 40px rgba(0,0,0,.18);
        z-index: 200;
    }
    .main-nav.open { transform: translateX(0); }

    /* Parent-Items (Behandlungen, Preise, Sale, etc.) */
    .main-nav > li > a {
        display: flex; align-items: center; justify-content: space-between;
        padding: 1.05em 1.5rem;
        border-bottom: 1px solid #ece4d3;
        font-size: .98rem; font-weight: 500;
        color: #2a2c30;
        text-decoration: none;
        transition: .15s;
        min-height: 48px;
    }
    .main-nav > li > a:hover, .main-nav > li > a:active {
        background: linear-gradient(90deg, rgba(218,190,146,.18), rgba(218,190,146,.06));
        color: #5a4a30;
    }
    .main-nav > li > a::after { display: none; }
    .main-nav > li > a span[aria-hidden] {
        font-size: .85rem; color: #b89261; transition: transform .25s;
    }
    .main-nav .dropdown.is-open > a span[aria-hidden] { transform: rotate(180deg); }

    /* Dropdown-Menu (Sub-Items wie BioRePeel, Microneedling, etc.) */
    .main-nav .dropdown-menu {
        position: static; opacity: 1; visibility: visible; transform: none;
        box-shadow: none; padding: 0;
        border-top: 0; min-width: 0;
        background: linear-gradient(180deg, #fcfaf6 0%, #fff 100%);
        border-bottom: 1px solid #ece4d3;
        max-height: 0; overflow: hidden;
        transition: max-height .35s cubic-bezier(.2,.7,.2,1);
    }
    .main-nav .dropdown.is-open .dropdown-menu { max-height: 800px; }

    /* Sub-Item-Links — klickbar, sichtbar, gold-akzentuiert */
    .main-nav .dropdown-menu a {
        display: flex; align-items: center;
        padding: .85em 1.5rem .85em 2.5rem;
        font-size: .92rem; font-weight: 400;
        color: #3d3d3d !important;
        text-decoration: none;
        border-bottom: 1px solid #f4eedd;
        transition: .15s;
        min-height: 44px;
        position: relative;
    }
    .main-nav .dropdown-menu a::before {
        content: '›';
        position: absolute; left: 1.5rem;
        color: #dabe92; font-size: 1rem; font-weight: 500;
        opacity: 0;
        transition: .15s;
    }
    .main-nav .dropdown-menu a:hover, .main-nav .dropdown-menu a:active {
        background: linear-gradient(90deg, rgba(218,190,146,.15), transparent);
        color: #5a4a30 !important;
        padding-left: 2.8rem;
    }
    .main-nav .dropdown-menu a:hover::before, .main-nav .dropdown-menu a:active::before { opacity: 1; }
    .main-nav .dropdown-menu a:last-child { border-bottom: 0; }

    body.menu-open { overflow: hidden; }
    body.menu-open::after {
        content: ''; position: fixed; inset: 0;
        background: rgba(15,18,22,.32);   /* sanft transparent, kein gruseliger Blur */
        z-index: 150;
        pointer-events: none;
        animation: navOverlayIn .25s ease-out;
    }
    @keyframes navOverlayIn { from {opacity:0;} to {opacity:1;} }

    /* Sidebars MÜSSEN scrollbar sein und alle Items klickbar */
    .main-nav,
    .sidebar,
    .profile-sidebar,
    .dashboard .sidebar {
        overflow-y: auto !important;
        -webkit-overflow-scrolling: touch !important;
        max-height: 100vh;
        max-height: 100dvh;
        overscroll-behavior: contain;
    }
    .main-nav a,
    .sidebar a,
    .profile-sidebar a,
    .profile-action {
        pointer-events: auto !important;
        position: relative;
        z-index: 2;
        touch-action: manipulation;        /* deaktiviert iOS-Doppeltap-Zoom */
        -webkit-tap-highlight-color: rgba(218,190,146,.25);
    }

    /* Auf mobile sind ALLE Dropdown-Sub-Menüs immer offen + klickbar — kein Tap-to-Toggle nötig */
    .main-nav .dropdown-menu {
        max-height: none !important;
        overflow: visible !important;
    }
    .main-nav .dropdown-menu a,
    .main-nav > li > a {
        pointer-events: auto !important;
        position: relative;
        z-index: 1;
    }

    /* User-Profile-Card — DEAKTIVIERT (Layout-Probleme). Komplett ausgeblendet. */
    .nav-user-card {
        display: none !important;
    }
    .nav-user-card .nav-user-avatar {
        width: 44px; height: 44px; border-radius: 50%;
        background: rgba(255,255,255,.95); color: #b89261;
        display: flex; align-items: center; justify-content: center;
        font-size: 1.05rem; font-weight: 600;
        flex-shrink: 0;
        box-shadow: 0 3px 10px rgba(0,0,0,.18);
    }
    .nav-user-card .nav-user-info { flex: 1; min-width: 0; }
    .nav-user-card .nav-user-name {
        font-size: 1rem; font-weight: 600; line-height: 1.25;
        white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    }
    .nav-user-card .nav-user-mail {
        font-size: .78rem; opacity: .92; line-height: 1.3;
        white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    }
    .nav-user-card .nav-user-menu {
        background: rgba(255,255,255,.18);
        border: 0; padding: .55em .8em;
        border-radius: 8px; color: #fff;
        cursor: pointer; font-size: 1.1rem;
        line-height: 1; transition: .15s;
    }
    .nav-user-card .nav-user-menu:hover { background: rgba(255,255,255,.32); }

    /* Card sichtbar machen NUR wenn slide-out aktiv ist */
    .main-nav.open .nav-user-card,
    body.menu-open .nav-user-card,
    body.nav-open .nav-user-card { display: flex; }

    /* POS-Cart z-index (250) + Mobile-Nav (180) + Backdrop (170) → migriert nach pos-pro.css */
}

@media (max-width: 480px) {
    .header-top-inner { justify-content: center; }
    .header-top-utils { gap: .6rem; }
    .brand-logo { width: 120px; }
}

/* ---------- HERO ---------- */
.hero {
    position: relative;
    width: 100%;
    height: clamp(360px, 56vw, 680px);
    overflow: hidden;
    background: var(--bg-soft);
}
.hero-slide {
    position: absolute; inset: 0;
    opacity: 0;
    transition: opacity 1.2s ease;
}
.hero-slide.active { opacity: 1; }
.hero-slide img { width: 100%; height: 100%; object-fit: cover; }
.hero-overlay {
    position: absolute; inset: 0;
    background: linear-gradient(0deg, rgba(0,0,0,.35) 0%, rgba(0,0,0,0) 50%);
}
.hero-dots {
    position: absolute; left: 50%; bottom: 1.5rem;
    transform: translateX(-50%);
    display: flex; gap: .25rem;
}
/* Wave 72 — QW-08: Touch-Target >= 24x24px (WCAG 2.5.5 Level AAA / 2.5.8 Level AA).
   Sichtbarer Dot bleibt 12px (::before), Button selbst ist 28x28px Hit-Area
   mit transparentem Padding. Optik der Hero-Carousel unveraendert. */
.hero-dots button {
    width: 28px; height: 28px;
    background: transparent;
    border: 0; cursor: pointer; padding: 0;
    display: inline-flex; align-items: center; justify-content: center;
    transition: var(--transition);
}
.hero-dots button::before {
    content: '';
    width: 12px; height: 12px; border-radius: 50%;
    background: rgba(255,255,255,.55);
    transition: var(--transition);
}
.hero-dots button.active::before { background: var(--white); transform: scale(1.25); }

/* ---------- PAGE TITLE ---------- */
.page-title-block {
    text-align: center;
    padding: 4rem 1.5rem 2rem;
    max-width: 920px;
    margin: 0 auto;
}
.page-title-block h1 { margin-bottom: 1rem; }
.page-title-block .lead { color: var(--primary); font-size: 1.05rem; line-height: 1.6; }

/* ---------- SECTIONS ---------- */
.section { padding: 4rem 0; }
.section-soft { background: var(--bg-soft); }
.section-dark { background: var(--black); color: var(--white); }
.section-dark h1, .section-dark h3 { color: var(--white); }
.section-dark h2 { color: var(--primary-soft); }

.split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 3rem;
    align-items: center;
}
.split.reverse > :first-child,
.split.split-reverse > :first-child { order: 2; }
.split-text h3 { margin-bottom: .8rem; }
.split-text .actions { margin-top: 1.5rem; display: flex; flex-wrap: wrap; gap: .75rem; }
.split-image {
    position: relative;
    overflow: hidden;
}
.split-image img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: contain;
    transition: transform 800ms cubic-bezier(.25,.46,.45,.94);
}
.split-image:hover img { transform: scale(1.03); }
.split-image.cover img { aspect-ratio: 4 / 3; object-fit: cover; }

/* Produkt-Detail Hero-Bild: zentriert, voll sichtbar, grauer Rand + Hover */
.split-image.product-image {
    background: #f6f6f6;
    border: 1px solid #e6e6e6;
    border-radius: var(--radius-lg, 12px);
    padding: 2rem;
    aspect-ratio: 1 / 1;
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(0,0,0,0.03);
    transition: box-shadow 320ms ease, border-color 320ms ease, transform 320ms ease;
}
.split-image.product-image img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    object-position: center;
    display: block;
    transition: transform 600ms cubic-bezier(.25,.46,.45,.94);
}
.split-image.product-image:hover {
    border-color: var(--primary, #90a7ac);
    box-shadow: 0 14px 38px rgba(0,0,0,0.09);
}
.split-image.product-image:hover img {
    transform: scale(1.04);
}
@media (max-width: 940px) {
    .split-image.product-image { padding: 1.25rem; }
}
@media (max-width: 940px) {
    .split { grid-template-columns: 1fr; gap: 2rem; }
    .split.reverse > :first-child,
    .split.split-reverse > :first-child { order: 0; }
}

/* ---------- SERVICE CARDS GRID ---------- */
.services-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1.5rem;
}
.service-card {
    background: var(--white);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    transition: transform var(--transition), box-shadow var(--transition);
    display: flex; flex-direction: column;
}
.service-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.service-card-media { aspect-ratio: 4 / 3; overflow: hidden; }
.service-card-media img { width: 100%; height: 100%; object-fit: cover; transition: transform 600ms ease; }
.service-card:hover .service-card-media img { transform: scale(1.04); }
.service-card-body { padding: 1.5rem; flex: 1; display: flex; flex-direction: column; }
.service-card-body h4 { margin: 0 0 .5em; color: var(--black); font-weight: 500; }
.service-card-body p { color: var(--muted); font-size: .9rem; flex: 1; }
.service-card-body .meta { display: flex; justify-content: space-between; padding-top: 1rem; border-top: 1px solid var(--border); margin-top: 1rem; font-size: .85rem; }
.service-card-body .price { color: var(--primary); font-weight: 500; }

/* ---------- BANNERS / TEASER ---------- */
.banner-card {
    display: grid;
    grid-template-columns: 1fr 1fr;
    align-items: stretch;
    background: var(--bg-soft);
    overflow: hidden;
    margin: 2rem 0;
}
.banner-card .banner-text { padding: 3rem; display: flex; flex-direction: column; justify-content: center; }
.banner-card .banner-image { aspect-ratio: 4 / 3; }
.banner-card .banner-image img { width: 100%; height: 100%; object-fit: cover; }
@media (max-width: 940px) { .banner-card { grid-template-columns: 1fr; } }

/* ---------- FORMS ---------- */
.form-group { margin-bottom: 1.25rem; }
.form-group label { display: block; margin-bottom: .35rem; font-weight: 500; font-size: .9rem; }
.form-control, input[type=text], input[type=email], input[type=password], input[type=tel], input[type=date], input[type=number], textarea, select {
    width: 100%;
    padding: .7rem .9rem;
    font: inherit;
    color: var(--text);
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    transition: border-color var(--transition), box-shadow var(--transition);
}
.form-control:focus { outline: 0; border-color: var(--primary); box-shadow: 0 0 0 3px rgba(144,167,172,.15); }
textarea { resize: vertical; min-height: 120px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
@media (max-width: 600px) { .form-row { grid-template-columns: 1fr; } }
.field-error { color: var(--alert); font-size: .8rem; margin-top: .25rem; }

/* ---------- ALERTS / FLASH ---------- */
.alert { padding: 1rem 1.25rem; border-left: 4px solid; margin-bottom: 1.25rem; font-size: .9rem; }
.alert-success { background: #ecf7ec; border-color: var(--success); color: #2e6b30; }
.alert-error { background: #fbecee; border-color: var(--alert); color: #8b1525; }
.alert-info { background: #eef4f5; border-color: var(--primary); color: #2a5a64; }

/* ---------- NEWSLETTER ---------- */
/* Wave 72 — QW-06: dunkler Hintergrund fuer AA-Kontrast (>= 7:1 weiss/dunkel).
   Vorher: white on --primary #90a7ac ~ 2.5:1 (Fail).  Jetzt: --dark-bg #1f2528. */
.newsletter {
    background: var(--dark-bg);
    color: var(--white);
    padding: 4rem 1.5rem;
    text-align: center;
}
.newsletter h3 { color: var(--white); margin-bottom: .5em; }
.newsletter p  { max-width: 560px; margin: 0 auto 1.5rem; color: #e8eaed; opacity: 1; }
.newsletter form { max-width: 480px; margin: 0 auto; display: flex; gap: .5rem; }
.newsletter input {
    flex: 1;
    background: var(--white);
    color: var(--text);
    border: 1px solid rgba(255,255,255,.15);
}
.newsletter input::placeholder { color: #6e7679; }
/* Button auf dunklem Bg: helle Outline-Variante mit Hover-Invert. */
.newsletter .btn,
.newsletter .btn-dark {
    background: var(--gold);
    border-color: var(--gold);
    color: var(--dark-bg) !important;
}
.newsletter .btn:hover,
.newsletter .btn-dark:hover {
    background: var(--gold-dark);
    border-color: var(--gold-dark);
    color: var(--white) !important;
}

/* ---------- FOOTER ---------- */
.site-footer {
    background: var(--black);
    color: rgba(255,255,255,.7);
    padding: 3rem 1.5rem 2rem;
}
.footer-grid {
    max-width: var(--max-w);
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2rem;
}
.site-footer h5 { color: var(--white); font-size: .9rem; text-transform: uppercase; letter-spacing: .08em; margin-bottom: 1rem; }
.site-footer a { color: rgba(255,255,255,.65); display: block; padding: .25rem 0; }
.site-footer a:hover { color: var(--white); }
.footer-bottom {
    max-width: var(--max-w);
    margin: 2rem auto 0;
    padding-top: 1.5rem;
    border-top: 1px solid rgba(255,255,255,.12);
    display: flex; flex-wrap: wrap; justify-content: space-between; gap: 1rem;
    font-size: .8rem; color: rgba(255,255,255,.5);
}
.payment-icons { display: flex; gap: .5rem; align-items: center; flex-wrap: wrap; }
.payment-icons img { height: 22px; width: auto; filter: brightness(0) invert(1) opacity(.8); }
.social-icons { display: flex; gap: .8rem; }
.social-icons a { font-size: 1.2rem; }
@media (max-width: 760px) { .footer-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .footer-grid { grid-template-columns: 1fr; } }

/* ---------- ACCOUNT / ADMIN LAYOUT ---------- */
.dashboard {
    display: grid;
    grid-template-columns: 240px 1fr;
    gap: 2rem;
    max-width: var(--max-w);
    margin: 2rem auto;
    padding: 0 1.5rem;
}
.sidebar {
    background: var(--white);
    border: 1px solid var(--border);
    padding: 1.5rem 0;
    align-self: start;
    position: sticky; top: 80px;
}
.sidebar a {
    display: block;
    padding: .7em 1.5em;
    color: var(--text);
    border-left: 3px solid transparent;
    font-size: .9em;
}
.sidebar a:hover, .sidebar a.active { background: var(--bg-soft); color: var(--primary); border-left-color: var(--primary); }
.dashboard-main {
    background: var(--white);
    border: 1px solid var(--border);
    padding: 2rem;
    min-height: 60vh;
}
.dashboard-main h1 { font-size: 1.8em; }
@media (max-width: 940px) {
    .dashboard { grid-template-columns: 1fr; }
    .sidebar { position: static; }
}

/* ---------- TABLES ---------- */
.table { width: 100%; border-collapse: collapse; }
.table th, .table td { padding: .75rem 1rem; text-align: left; border-bottom: 1px solid var(--border); font-size: .9rem; }
.table th { background: var(--bg-soft); font-weight: 500; text-transform: uppercase; font-size: .75rem; letter-spacing: .04em; }
.table tbody tr:hover { background: var(--bg-light); }

.badge { display: inline-block; padding: .15em .6em; font-size: .7rem; font-weight: 500; border-radius: 12px; text-transform: uppercase; letter-spacing: .04em; }
.badge-pending { background: #fff4d6; color: #8a6d00; }
.badge-confirmed { background: #d8eed9; color: #1f6924; }
.badge-cancelled { background: #f9d7dc; color: #8b1525; }
.badge-paid { background: #e0eff7; color: #1f4a6b; }

/* ---------- BREADCRUMB ---------- */
.breadcrumb { padding: 1rem 1.5rem; max-width: var(--max-w); margin: 0 auto; font-size: .8rem; color: var(--muted); }
.breadcrumb a { color: var(--muted); }
.breadcrumb a:hover { color: var(--primary); }
.breadcrumb .sep { margin: 0 .5em; opacity: .5; }

/* ---------- PRICE TABLE ---------- */
.price-table { width: 100%; border-collapse: collapse; margin: 2rem 0; }
.price-table tr { border-bottom: 1px solid var(--border); }
.price-table td { padding: 1rem .5rem; }
.price-table td:last-child { text-align: right; color: var(--primary); font-weight: 500; white-space: nowrap; }

/* ---------- CART ---------- */
.cart-grid { display: grid; grid-template-columns: 1fr 360px; gap: 2rem; align-items: start; }
.cart-items { display: flex; flex-direction: column; gap: 1rem; }
.cart-item {
    display: grid;
    grid-template-columns: 100px 1fr auto auto auto;
    gap: 1rem;
    padding: 1rem;
    background: var(--white);
    border: 1px solid var(--border);
    align-items: center;
    transition: box-shadow var(--transition);
}
.cart-item:hover { box-shadow: var(--shadow-sm); }
.cart-thumb img { width: 100px; height: 100px; object-fit: cover; }
.cart-title { font-weight: 500; color: var(--black); display: block; }
.cart-title:hover { color: var(--primary); }
.cart-unit { font-size: .85rem; color: var(--muted); margin-top: .25rem; }
.cart-qty input { width: 70px; text-align: center; }
.cart-line { font-weight: 500; color: var(--primary); white-space: nowrap; min-width: 80px; text-align: right; }
.cart-remove {
    width: 32px; height: 32px;
    background: transparent; border: 1px solid var(--border);
    color: var(--muted); cursor: pointer;
    transition: all var(--transition);
    font-size: 1.4rem; line-height: 1;
}
.cart-remove:hover { background: var(--alert); color: var(--white); border-color: var(--alert); }
.cart-summary {
    background: var(--white); border: 1px solid var(--border);
    padding: 1.5rem;
    position: sticky; top: 180px;
}
.cart-summary h3 { font-size: 1.2rem; margin-bottom: 1rem; }
.cart-summary > div { margin-bottom: .5rem; font-size: .9rem; }
@media (max-width: 940px) {
    .cart-grid { grid-template-columns: 1fr; }
    .cart-item { grid-template-columns: 80px 1fr auto; gap: .75rem; }
    .cart-thumb img { width: 80px; height: 80px; }
    .cart-line, .cart-qty { grid-column: 2; }
    .cart-remove { grid-column: 3; grid-row: 1; }
    .cart-summary { position: static; }
}

/* ---------- CHECKOUT ---------- */
.checkout-grid { display: grid; grid-template-columns: 1fr 360px; gap: 2rem; }
.checkout-step {
    background: var(--white); border: 1px solid var(--border);
    padding: 2rem; margin-bottom: 1rem;
}
.checkout-step h3 { display: flex; align-items: center; gap: .75rem; margin-top: 0; }
.step-num {
    display: inline-flex; align-items: center; justify-content: center;
    width: 32px; height: 32px;
    background: var(--primary); color: var(--white);
    border-radius: 50%; font-size: .9rem; font-weight: 500;
}
.payment-options { display: grid; grid-template-columns: repeat(auto-fit, minmax(120px, 1fr)); gap: .5rem; }
.payment-option {
    padding: 1rem; border: 2px solid var(--border);
    text-align: center; cursor: pointer;
    transition: all var(--transition);
    background: var(--white); display: flex; align-items: center; justify-content: center; min-height: 64px;
}
.payment-option input { display: none; }
.payment-option:has(input:checked), .payment-option.checked {
    border-color: var(--primary);
    background: rgba(144,167,172,.05);
}
.payment-option img { height: 28px; }
@media (max-width: 940px) {
    .checkout-grid { grid-template-columns: 1fr; }
}

/* ---------- ORDER CONFIRMATION ---------- */
.order-success {
    text-align: center; padding: 4rem 1rem;
    max-width: 640px; margin: 0 auto;
    animation: fadeUp 700ms ease-out;
}
.order-success-icon {
    width: 80px; height: 80px;
    background: var(--success); color: var(--white);
    border-radius: 50%; display: inline-flex;
    align-items: center; justify-content: center;
    font-size: 2.4rem; margin-bottom: 1.5rem;
    animation: scaleIn 600ms cubic-bezier(.34,1.56,.64,1) both;
}

/* ---------- PRODUCT CARD (Online Shop) ---------- */
.product-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 1.5rem;
}
.product-card { display: flex; flex-direction: column; background: var(--white); }
.product-card .product-media { aspect-ratio: 1 / 1; background: var(--bg-soft); overflow: hidden; display: flex; align-items: center; justify-content: center; padding: 14px; box-sizing: border-box; }
.product-card .product-media img { width: 100%; height: 100%; object-fit: contain; object-position: center; }
.product-card .product-body { padding: 1rem 0; }
.product-card .product-brand { font-size: .75rem; text-transform: uppercase; letter-spacing: .08em; color: var(--muted); margin-bottom: .25rem; }
.product-card .product-title { font-weight: 500; margin-bottom: .5rem; color: var(--black); }
.product-card .product-price { color: var(--primary); font-weight: 500; }

/* ---------- IMAGE COLLAGE (Hauptbild + Thumbs daneben/darunter, NICHT drüber) ---------- */
.collage {
    position: relative;
    width: 100%;
    padding-bottom: 4rem;          /* Platz für überlappende Bottom-Thumbs */
    padding-right: 1rem;
}
.collage-main {
    position: relative;
    width: 100%;
    aspect-ratio: 4 / 3;
    overflow: hidden;
    box-shadow: 0 20px 60px rgba(0,0,0,.16);
    z-index: 1;
    transition: transform 600ms cubic-bezier(.16,1,.3,1);
    cursor: zoom-in;
    display: block;
}
.collage-main img {
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform 1200ms cubic-bezier(.25,.46,.45,.94);
}
.collage-main:hover { transform: translateY(-4px); box-shadow: 0 28px 80px rgba(0,0,0,.22); }
.collage-main:hover img { transform: scale(1.04); }

.collage-thumbs {
    position: absolute;
    right: -1rem;
    bottom: 0;
    display: flex;
    gap: 1.1rem;
    z-index: 3;
    pointer-events: none;          /* Container nimmt keine Klicks – nur Kinder */
}
.collage-thumb {
    position: relative;
    width: clamp(80px, 11vw, 130px);
    height: clamp(80px, 11vw, 130px);
    flex: 0 0 auto;
    border-radius: 50%;
    overflow: hidden;
    border: 5px solid var(--white);
    box-shadow: 0 16px 40px rgba(0,0,0,.18);
    cursor: zoom-in;
    transition: transform 500ms cubic-bezier(.34,1.56,.64,1),
                box-shadow 500ms ease;
    will-change: transform;
    background: var(--white);
    pointer-events: auto;
    text-decoration: none;
    box-sizing: border-box;
}
.collage-thumb img {
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform 800ms cubic-bezier(.25,.46,.45,.94);
}
/* dezente Tilts – nicht übertrieben */
.collage-thumb:nth-child(1) { transform: rotate(-6deg); }
.collage-thumb:nth-child(2) { transform: rotate(4deg);  margin-bottom: -1rem; }
.collage-thumb:nth-child(3) { transform: rotate(-3deg); }
.collage-thumb:nth-child(4) { transform: rotate(7deg);  margin-bottom: -1rem; }

.collage-thumb:hover {
    transform: rotate(0deg) scale(1.15);
    z-index: 4;
    box-shadow: 0 24px 60px rgba(144,167,172,.5);
}
.collage-thumb:hover img { transform: scale(1.08); }

/* sanfter Schwebe-Effekt */
@keyframes collageDrift {
    0%, 100% { transform: rotate(var(--tilt, 0deg)) translateY(0); }
    50%      { transform: rotate(calc(var(--tilt, 0deg) + 1deg)) translateY(-4px); }
}
.collage-thumb:nth-child(1) { --tilt: -6deg; animation: collageDrift 7s ease-in-out infinite; }
.collage-thumb:nth-child(2) { --tilt:  4deg; animation: collageDrift 8s ease-in-out -2s infinite; }
.collage-thumb:nth-child(3) { --tilt: -3deg; animation: collageDrift 9s ease-in-out -4s infinite; }
.collage-thumb:nth-child(4) { --tilt:  7deg; animation: collageDrift 7.5s ease-in-out -6s infinite; }
.collage-thumb:hover { animation-play-state: paused; }

@media (max-width: 720px) {
    .collage { padding-bottom: 0; padding-right: 0; }
    .collage-thumbs {
        position: static;
        flex-wrap: wrap;
        justify-content: center;
        margin: 1.25rem 0 0;
        right: auto; bottom: auto;
        gap: .7rem;
    }
    .collage-thumb {
        width: clamp(64px, 18vw, 90px);
    }
    .collage-thumb:nth-child(n) { margin-bottom: 0; }
}

/* ---------- LIGHTBOX (Click-to-Zoom) ---------- */
.lightbox {
    position: fixed; inset: 0;
    background: rgba(0,0,0,.92);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    display: flex; align-items: center; justify-content: center;
    z-index: 9999;
    opacity: 0; visibility: hidden;
    transition: opacity 400ms ease, visibility 400ms;
    cursor: zoom-out;
    padding: 2rem;
}
.lightbox.open { opacity: 1; visibility: visible; }
.lightbox img {
    max-width: 92vw; max-height: 88vh;
    object-fit: contain;
    box-shadow: 0 20px 80px rgba(0,0,0,.6);
    transform: scale(.85);
    transition: transform 500ms cubic-bezier(.34,1.56,.64,1);
    /* Wave 86D: Pinch-Zoom auf Touch-Devices erlauben */
    touch-action: pinch-zoom;
    cursor: zoom-out;
    user-select: none;
}
.lightbox.open img { transform: scale(1); }
.lightbox-close {
    position: absolute;
    top: 1.5rem; right: 1.5rem;
    width: 44px; height: 44px;
    background: rgba(255,255,255,.1);
    border: 1px solid rgba(255,255,255,.25);
    color: var(--white);
    font-size: 1.4rem;
    border-radius: 50%;
    cursor: pointer;
    transition: all var(--transition);
}
.lightbox-close:hover { background: rgba(255,255,255,.2); transform: rotate(90deg); }
.lightbox-prev, .lightbox-next {
    position: absolute;
    top: 50%; transform: translateY(-50%);
    width: 56px; height: 56px;
    background: rgba(255,255,255,.1);
    border: 1px solid rgba(255,255,255,.25);
    color: var(--white);
    font-size: 1.6rem;
    border-radius: 50%;
    cursor: pointer;
    transition: all var(--transition);
}
.lightbox-prev { left: 1.5rem; }
.lightbox-next { right: 1.5rem; }
.lightbox-prev:hover, .lightbox-next:hover { background: rgba(255,255,255,.2); }
.lightbox-caption {
    position: absolute;
    bottom: 1.5rem; left: 50%;
    transform: translateX(-50%);
    color: var(--white);
    font-size: .85rem;
    background: rgba(0,0,0,.5);
    padding: .5rem 1rem;
    border-radius: 4px;
    max-width: 80vw;
}

/* Generic zoomable image */
.zoomable {
    cursor: zoom-in;
    transition: transform 400ms cubic-bezier(.16,1,.3,1);
}
.zoomable:hover { transform: scale(1.02); }

/* ---------- ANIMATIONS ---------- */
@keyframes fadeUp {
    from { opacity: 0; transform: translateY(40px); }
    to   { opacity: 1; transform: translateY(0); }
}
@keyframes fadeIn {
    from { opacity: 0; }
    to   { opacity: 1; }
}
@keyframes shimmer {
    0%   { background-position: -200% 0; }
    100% { background-position: 200% 0; }
}
@keyframes float {
    0%, 100% { transform: translateY(0); }
    50%      { transform: translateY(-8px); }
}
@keyframes scaleIn {
    from { opacity: 0; transform: scale(.92); }
    to   { opacity: 1; transform: scale(1); }
}
@keyframes kenBurns {
    from { transform: scale(1) translate(0,0); }
    to   { transform: scale(1.08) translate(-1%, -1%); }
}

/* Reveal on scroll */
.reveal {
    opacity: 0;
    transform: translateY(40px);
    transition: opacity 900ms cubic-bezier(.16,1,.3,1), transform 900ms cubic-bezier(.16,1,.3,1);
    will-change: opacity, transform;
}
.reveal.in-view { opacity: 1; transform: translateY(0); }
.reveal-delay-1 { transition-delay: 80ms; }
.reveal-delay-2 { transition-delay: 160ms; }
.reveal-delay-3 { transition-delay: 240ms; }
.reveal-delay-4 { transition-delay: 320ms; }
.reveal-delay-5 { transition-delay: 400ms; }

.reveal.fade  { transform: none; }
.reveal.scale { transform: scale(.94); }
.reveal.scale.in-view { transform: scale(1); }
.reveal.left  { transform: translateX(-60px); }
.reveal.left.in-view { transform: translateX(0); }
.reveal.right { transform: translateX(60px); }
.reveal.right.in-view { transform: translateX(0); }

/* Hero Ken Burns */
.hero-slide.active img { animation: kenBurns 18s ease-out both; }

/* Service card hover glow */
.service-card { position: relative; isolation: isolate; }
.service-card::before {
    content: ''; position: absolute; inset: 0;
    background: linear-gradient(135deg, rgba(144,167,172,0) 0%, rgba(144,167,172,.12) 100%);
    opacity: 0; transition: opacity var(--transition);
    z-index: -1; pointer-events: none;
}
.service-card:hover::before { opacity: 1; }
.service-card-body h4 { transition: color var(--transition); }
.service-card:hover .service-card-body h4 { color: var(--primary); }

/* Button shine */
.btn { position: relative; overflow: hidden; }
.btn::after {
    content: ''; position: absolute;
    top: 0; left: -100%; width: 100%; height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,.3), transparent);
    transition: left 600ms;
}
.btn:hover::after { left: 100%; }

/* Section title underline */
.section-title { display: inline-block; position: relative; }
.section-title::after {
    content: ''; display: block;
    width: 60px; height: 2px;
    background: var(--primary);
    margin: .8rem auto 0;
    transform-origin: left;
    animation: shimmer 3s ease-in-out infinite;
    background-size: 200% 100%;
    background-image: linear-gradient(90deg, var(--primary), var(--primary-soft), var(--primary));
}

/* Cart badge pulse */
@keyframes pulse {
    0%, 100% { transform: scale(1); }
    50%      { transform: scale(1.15); }
}
.cart-badge {
    display: inline-flex; align-items: center; justify-content: center;
    min-width: 20px; height: 20px;
    padding: 0 6px;
    background: var(--primary);
    color: var(--white);
    border-radius: 10px;
    font-size: .68rem;
    font-weight: 600;
    margin-left: .25rem;
    animation: pulse 2s ease-in-out infinite;
}

/* Smooth page enter */
main { animation: fadeIn 600ms ease-out; }

/* Float animation for accent elements */
.float-anim { animation: float 4s ease-in-out infinite; }

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: .01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: .01ms !important;
    }
    .reveal { opacity: 1; transform: none; }
}

/* ---------- UTILITIES ---------- */
.text-center { text-align: center; }
.mt-0 { margin-top: 0 !important; }
.mt-1 { margin-top: .5rem; } .mt-2 { margin-top: 1rem; } .mt-3 { margin-top: 1.5rem; } .mt-4 { margin-top: 2.5rem; }
.mb-0 { margin-bottom: 0 !important; }
.mb-1 { margin-bottom: .5rem; } .mb-2 { margin-bottom: 1rem; } .mb-3 { margin-bottom: 1.5rem; } .mb-4 { margin-bottom: 2.5rem; }
.flex { display: flex; gap: 1rem; align-items: center; }
.flex-between { display: flex; justify-content: space-between; align-items: center; }
.hidden { display: none !important; }

/* =============================================================
   MOBILE RESPONSIVE OVERRIDES (additive — appended)
   Targets: <940px (tablet & smaller), <768px (mobile), <480px, <360px
   Fixes: sidebar drawer/scroll-bar, image cutoffs, hero height,
   header overflow, cart/checkout stacking polish
   ============================================================= */

/* ---------- DASHBOARD: Sidebar -> horizontal scroll bar at top on mobile ---------- */
@media (max-width: 940px) {
    .dashboard {
        grid-template-columns: 1fr;
        gap: 1rem;
        margin: 1rem auto;
        padding: 0 1rem;
    }
    /* Sidebar becomes a horizontal scrollable nav at top */
    .sidebar {
        position: static;
        padding: .35rem;
        display: flex;
        flex-direction: row;
        flex-wrap: nowrap;
        overflow-x: auto;
        overflow-y: hidden;
        gap: .25rem;
        white-space: nowrap;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: thin;
        scrollbar-color: var(--primary) transparent;
        background: var(--white);
        border: 1px solid var(--border);
    }
    .sidebar::-webkit-scrollbar { height: 4px; }
    .sidebar::-webkit-scrollbar-track { background: transparent; }
    .sidebar::-webkit-scrollbar-thumb { background: var(--primary); border-radius: 2px; }
    .sidebar a {
        flex: 0 0 auto;
        padding: .55em 1em;
        border-left: 0;
        border-bottom: 3px solid transparent;
        font-size: .82em;
    }
    .sidebar a:hover, .sidebar a.active {
        border-left: 0;
        border-bottom-color: var(--primary);
        background: var(--bg-soft);
    }
    /* Subtle fade-edges to hint at scroll */
    .sidebar { position: relative; }
    .dashboard-main { padding: 1.25rem; }
}

/* ---------- TIGHTER MOBILE TWEAKS ---------- */
@media (max-width: 768px) {
    /* Hero — better proportions on portrait phones */
    .hero { height: clamp(320px, 80vw, 500px); }
    .hero-dots { bottom: 1rem; }

    /* Page title trims */
    .page-title-block { padding: 2.5rem 1rem 1.25rem; }
    h1 { font-size: 2em; }
    h3 { font-size: 1.5em; }

    /* Section padding */
    .section { padding: 2.5rem 0; }
    .container, .container-narrow { padding: 0 1rem; }

    /* Service cards: switch from 4/3 to 1/1 (square) for nicer thumbnail proportions on small screens */
    .service-card-media { aspect-ratio: 1 / 1; }
    .service-card-body { padding: 1.1rem; }

    /* Banner image aspect ratio */
    .banner-card .banner-image { aspect-ratio: 16 / 10; }
    .banner-card .banner-text { padding: 1.75rem 1.25rem; }

    /* Split image — keep contain so portraits aren't cut off, but cap height */
    .split-image img { max-height: 60vh; width: 100%; }
    .split-image.cover img { aspect-ratio: 16 / 10; }

    /* Collage main keeps 4/3 but pulled down */
    .collage-main { aspect-ratio: 4 / 3; }

    /* Newsletter form stacks */
    .newsletter { padding: 2.5rem 1rem; }
    .newsletter form { flex-direction: column; gap: .6rem; }
    .newsletter form .btn { width: 100%; }

    /* Tables: see TABLE-RESPONSIVE block below — handled via .table-wrap + .responsive-cards */

    /* Cart item: tighter columns */
    .cart-item {
        grid-template-columns: 70px 1fr auto;
        gap: .6rem;
        padding: .75rem;
    }
    .cart-thumb img { width: 70px; height: 70px; }
    .cart-title { font-size: .9rem; }
    .cart-summary { padding: 1.1rem; }

    /* Checkout step padding */
    .checkout-step { padding: 1.25rem; }

    /* Buttons wider tap targets, allow wrapping */
    .btn + .btn { margin-left: 0; }
    .split-text .actions { gap: .5rem; }
    .split-text .actions .btn { flex: 1 1 auto; min-width: 140px; }

    /* Lightbox padding shrinks */
    .lightbox { padding: .75rem; }
    .lightbox-prev, .lightbox-next { width: 44px; height: 44px; font-size: 1.2rem; }
    .lightbox-prev { left: .5rem; }
    .lightbox-next { right: .5rem; }
    .lightbox-close { top: .5rem; right: .5rem; }

    /* Page-title block & breadcrumbs */
    .breadcrumb { padding: .75rem 1rem; }

    /* Header top: hide divider artefacts that may overflow */
    .header-top-inner { padding: .35rem .75rem; }
    .utility-divider { display: none; }
}

/* ---------- VERY SMALL SCREENS ---------- */
@media (max-width: 480px) {
    h1 { font-size: 1.7em; }
    h3 { font-size: 1.3em; }

    .header-bar {
        padding: .65rem .6rem;
        grid-template-columns: 40px 1fr 40px;
        gap: .4rem;
    }
    .menu-toggle { width: 40px; height: 40px; }
    .header-top-utils { gap: .4rem; }
    .header-top-utils .basket-link em { font-size: .7rem; }

    /* Service grid single column with comfy width */
    .services-grid { grid-template-columns: 1fr; gap: 1rem; }
    .product-grid { grid-template-columns: repeat(2, 1fr); gap: 1rem; }

    /* Sidebar nav text smaller */
    .sidebar a { padding: .5em .85em; font-size: .78em; }

    /* Cart price fits */
    .cart-line { min-width: 0; font-size: .85rem; }
    .cart-qty input { width: 56px; padding: .4rem .3rem; }

    /* Page title block */
    .page-title-block { padding: 2rem .75rem 1rem; }
    .page-title-block .lead { font-size: .95rem; }

    /* Footer compact */
    .site-footer { padding: 2rem 1rem 1.5rem; }
    .footer-bottom { font-size: .75rem; }
}

/* ---------- ULTRA-NARROW (<360px) ---------- */
@media (max-width: 360px) {
    .brand-logo { width: 100px; }
    .header-bar { gap: .25rem; padding: .5rem .4rem; }
    .header-top-inner { padding: .3rem .5rem; gap: .35rem; }
    .header-top-utils { gap: .3rem; }
    .icon-link svg { width: 16px; height: 16px; }
    .product-grid { grid-template-columns: 1fr; }
    .container, .container-narrow { padding: 0 .75rem; }
    .dashboard { padding: 0 .5rem; }
}

/* ---------- ORIENTATION: short landscape (e.g. phones in landscape) ---------- */
@media (max-height: 480px) and (orientation: landscape) {
    .hero { height: 80vh; min-height: 280px; }
    .main-nav { padding: 3.5rem 1.25rem 1.5rem; }
}

/* ---------- ANAMNESE COMPATIBILITY BADGES ---------- */
.product-anam-badge {
    display: block;
    margin: .35rem 0;
    line-height: 1;
    min-height: 1.6em;
}
.anam-badge {
    display: inline-block;
    padding: .25em .6em;
    font-size: .78rem;
    font-weight: 500;
    border-radius: 0;
    line-height: 1.3;
    letter-spacing: .01em;
    text-decoration: none;
    background: #f3f3f3;
    color: #444;
    border-left: 3px solid #bbb;
    cursor: default;
    position: relative;
    white-space: nowrap;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
}
.anam-badge-safe {
    background: #e8f7e8;
    color: #1a6b1a;
    border-left: 3px solid #2c8c2c;
}
.anam-badge-warn {
    background: #fff8e6;
    color: #8a6d00;
    border-left: 3px solid #d4a017;
}
.anam-badge-block {
    background: #fde8e8;
    color: #a32020;
    border-left: 3px solid #c93030;
}
.anam-badge-hint {
    background: #f1f1f4;
    color: #555;
    border-left: 3px solid #888;
    font-style: italic;
    cursor: pointer;
}
.anam-badge-hint:hover {
    background: #e8e8ee;
    color: #222;
}

/* Custom hover-tooltip for badges with reasons. Falls back gracefully to the title attribute. */
.anam-has-tooltip:hover::after {
    content: attr(data-anam-tooltip);
    position: absolute;
    left: 0;
    top: calc(100% + 6px);
    z-index: 50;
    padding: .55em .75em;
    background: #1f1f1f;
    color: #fff;
    font-size: .72rem;
    font-weight: 400;
    line-height: 1.45;
    white-space: pre-line;
    max-width: 280px;
    min-width: 160px;
    box-shadow: 0 4px 14px rgba(0,0,0,.18);
    pointer-events: none;
}

/* On product detail pages we render a slightly bigger badge */
.product-anam-badge--lg .anam-badge {
    font-size: .9rem;
    padding: .45em .85em;
    border-left-width: 4px;
}

/* ---------- Treatment / Service CTA Bar (3-button) ---------- */
.treatment-actions {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: .75rem;
    margin: 2rem 0;
}
.treatment-actions .btn {
    padding: 1rem 1.5rem;
    text-align: center;
    font-size: .95rem;
    margin-left: 0; /* override .btn + .btn margin */
    width: 100%;
}
.treatment-actions .btn-primary {
    background: var(--primary);
    color: #fff !important;
    border-color: var(--primary);
}
.treatment-actions .btn-primary:hover {
    background: var(--primary-dark, #6a8088);
    border-color: var(--primary-dark, #6a8088);
}
.treatment-actions .btn[aria-disabled="true"],
.treatment-actions .btn.is-disabled {
    background: #d8dcde;
    border-color: #d8dcde;
    color: #6a6a6a !important;
    cursor: not-allowed;
    pointer-events: none;
}
.treatment-actions .btn.is-disabled small {
    display: block;
    font-size: .7rem;
    font-weight: 400;
    opacity: .8;
}

/* Reservation form box used on api/service_action.php */
.reservation-form-box {
    background: #fff;
    border: 1px solid #ececec;
    border-radius: var(--radius);
    padding: 2rem;
    box-shadow: 0 4px 14px rgba(0,0,0,.04);
    max-width: 640px;
    margin: 2rem auto;
}
.reservation-form-box h2 { margin-bottom: .25rem; }
.reservation-form-box .field { margin-bottom: 1rem; }
.reservation-form-box .field label {
    display: block;
    font-weight: 500;
    margin-bottom: .35rem;
    font-size: .9rem;
}
.reservation-form-box .field input,
.reservation-form-box .field select,
.reservation-form-box .field textarea {
    width: 100%;
    padding: .65rem .8rem;
    border: 1px solid #d6d6d6;
    border-radius: var(--radius);
    font: inherit;
    background: #fff;
}
.reservation-form-box .field textarea { min-height: 110px; resize: vertical; }
.reservation-form-box .form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}
@media (max-width: 600px) {
    .reservation-form-box .form-row { grid-template-columns: 1fr; }
}
.reservation-form-box .alert {
    background: #f5f0e8;
    border-left: 3px solid var(--primary);
    padding: .75rem 1rem;
    margin-bottom: 1.25rem;
    font-size: .9rem;
}

/* ============================================================
   Mobile Nav Polish + Bottom Nav (PWA-feel) — appended 2026-04
   Additive only; does NOT override existing .main-nav rules.
   The existing rules slide the nav in from the RIGHT using
   transform: translateX(...) which is already smooth.
   ============================================================ */

/* Hit-area + touch-friendly tweaks for the off-canvas nav on mobile */
@media (max-width: 940px) {
    /* Body lock when nav is open (compat with new mobile-nav.js writing both classes) */
    body.nav-open { overflow: hidden; }
    body.nav-open::after {
        content: ''; position: fixed; inset: 0;
        background: rgba(0,0,0,.5);
        z-index: 150;
        animation: aob-fade-in .25s ease both;
    }

    /* Make every nav <a> a comfortable 44x44 touch target */
    .main-nav a,
    .main-nav .dropdown-menu a {
        min-height: 44px;
        display: flex; align-items: center;
        -webkit-tap-highlight-color: rgba(144,167,172,.18);
    }
    /* Keep the smooth slide via transform (not "left/width") for performance */
    .main-nav { will-change: transform; }
    .main-nav.mobile-open { transform: translateX(0); } /* compat with task spec */

    /* Don't let the bottom-nav cover the off-canvas panel content */
    .main-nav { padding-bottom: calc(2rem + 56px + env(safe-area-inset-bottom)); }
}

@keyframes aob-fade-in { from { opacity: 0; } to { opacity: 1; } }

/* Mobile-only Bottom-Nav (PWA feel) */
.mobile-bottom-nav { display: none; }

@media (max-width: 940px) {
    .mobile-bottom-nav {
        position: fixed; left: 0; right: 0; bottom: 0;
        height: calc(56px + env(safe-area-inset-bottom));
        padding-bottom: env(safe-area-inset-bottom);
        display: flex; justify-content: space-around; align-items: stretch;
        background: var(--white);
        border-top: 1px solid var(--border);
        box-shadow: 0 -2px 12px rgba(0,0,0,.06);
        z-index: 140; /* below off-canvas nav (200) and its overlay (150) */
        backdrop-filter: saturate(140%) blur(6px);
        -webkit-backdrop-filter: saturate(140%) blur(6px);
    }
    .mobile-bottom-nav a {
        flex: 1 1 0;
        display: flex; flex-direction: column; align-items: center; justify-content: center;
        gap: 2px;
        text-align: center;
        font-size: .68rem; letter-spacing: .02em;
        color: var(--muted);
        text-decoration: none;
        min-height: 56px;
        transition: color .2s ease, transform .2s ease;
    }
    .mobile-bottom-nav a:hover,
    .mobile-bottom-nav a:focus-visible { color: var(--primary); }
    .mobile-bottom-nav a.active { color: var(--primary); font-weight: 500; }
    .mobile-bottom-nav a.active .icon { transform: scale(1.06); }
    .mobile-bottom-nav .icon {
        display: block;
        font-size: 1.25rem;
        line-height: 1;
        margin-bottom: 2px;
        transition: transform .2s ease;
    }
    /* Ensure page content isn't hidden under the bottom-nav */
    body { padding-bottom: calc(56px + env(safe-area-inset-bottom)); }
    /* Nudge the site footer above the bar */
    .site-footer { margin-bottom: 0; }
}

/* On wider screens, fully hide the bottom-nav */
@media (min-width: 941px) {
    .mobile-bottom-nav { display: none !important; }
}

/* ============================================================
   Profile Personalization — Avatar, Theme Picker, About-Me
   Appended 2026-04-29. Additive only (no overrides).
   ============================================================ */

/* User-controlled accent variable (overridable per-user via inline <style>) */
:root {
    --user-accent: var(--primary);
}

/* Dark-mode variant when user picked "dark" */
.user-theme-dark {
    --bg: #1a1a1a;
    --text: #f0f0f0;
    --white: #2a2a2a;
    --border: #3a3a3a;
    --bg-soft: #222;
    --bg-light: #1f1f1f;
    --muted: #b0b0b0;
}
.user-theme-dark body { background: var(--bg, #1a1a1a); color: var(--text, #f0f0f0); }
.user-theme-dark .dashboard-main,
.user-theme-dark .sidebar { background: var(--white); color: var(--text); }
.user-theme-dark input,
.user-theme-dark textarea,
.user-theme-dark select {
    background: var(--bg-soft);
    color: var(--text);
    border-color: var(--border);
}
.user-theme-dark a { color: var(--user-accent, var(--primary)); }
.user-theme-dark hr { border-color: var(--border); }

/* Avatar */
.avatar {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    object-fit: cover;
    display: inline-block;
    background: var(--bg-soft);
    border: 2px solid var(--border);
}
.avatar-large {
    width: 140px;
    height: 140px;
}
.avatar-initials {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 2.4rem;
    font-weight: 500;
    color: #fff;
    background: var(--user-accent, var(--primary));
    text-transform: uppercase;
    letter-spacing: 1px;
    border: 2px solid var(--border);
}

/* Profile sections wrapper */
.profile-section {
    margin: 1.5rem 0 0;
}
.profile-section-desc {
    color: var(--muted);
    font-size: .85rem;
    margin-bottom: 1rem;
}

/* Avatar uploader layout */
.avatar-uploader {
    display: flex;
    gap: 1.5rem;
    align-items: flex-start;
    flex-wrap: wrap;
}
.avatar-preview {
    flex: 0 0 auto;
}
.avatar-actions {
    flex: 1 1 280px;
    min-width: 0;
}
.avatar-dropzone {
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    border: 2px dashed var(--border);
    border-radius: 6px;
    padding: 1.25rem;
    cursor: pointer;
    transition: border-color .2s, background .2s;
    background: var(--bg-soft);
}
.avatar-dropzone:hover,
.avatar-dropzone.is-drag {
    border-color: var(--user-accent, var(--primary));
    background: var(--bg-light);
}
.avatar-dropzone-text strong { display: block; margin-bottom: .25rem; }
.avatar-dropzone-text small { color: var(--muted); font-size: .78rem; }
.avatar-actions-row { margin-top: .75rem; display: flex; gap: .5rem; }
.avatar-status {
    margin-top: .5rem;
    min-height: 1.4em;
    font-size: .85rem;
}
.avatar-status.is-busy { color: var(--muted); }
.avatar-status.is-ok   { color: var(--success); }
.avatar-status.is-err  { color: var(--alert); }

/* Theme color presets */
.theme-color-presets {
    display: flex;
    gap: .5rem;
    flex-wrap: wrap;
    margin-bottom: .75rem;
}
.theme-swatch {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: 2px solid var(--border);
    cursor: pointer;
    padding: 0;
    transition: transform .15s, box-shadow .15s, border-color .15s;
}
.theme-swatch:hover { transform: scale(1.08); }
.theme-swatch.is-active {
    border-color: #000;
    box-shadow: 0 0 0 2px #fff inset, 0 0 0 4px var(--user-accent, var(--primary));
}
.theme-color-custom {
    display: flex;
    align-items: center;
    gap: .5rem;
    flex-wrap: wrap;
}
.theme-color-custom input[type="color"] {
    width: 42px;
    height: 38px;
    border: 1px solid var(--border);
    border-radius: 4px;
    padding: 2px;
    cursor: pointer;
    background: #fff;
}

/* Theme mode toggle (3-button) */
.theme-mode-toggle {
    display: inline-flex;
    border: 1px solid var(--border);
    border-radius: 6px;
    overflow: hidden;
}
.theme-mode-option {
    margin: 0;
    cursor: pointer;
}
.theme-mode-option input { display: none; }
.theme-mode-option span {
    display: block;
    padding: .5rem 1rem;
    font-size: .85rem;
    background: var(--bg-soft);
    color: var(--text);
    border-right: 1px solid var(--border);
    transition: background .2s, color .2s;
    user-select: none;
}
.theme-mode-option:last-child span { border-right: 0; }
.theme-mode-option.is-active span,
.theme-mode-option:hover span {
    background: var(--user-accent, var(--primary));
    color: #fff;
}

/* Live preview card */
.theme-preview {
    margin: 1rem 0;
    padding: 1rem;
    border: 1px solid var(--border);
    border-radius: 6px;
    background: var(--bg-light);
}
.theme-preview-card {
    background: #fff;
    border-radius: 4px;
    padding: 1rem;
    box-shadow: var(--shadow-sm);
}
.theme-preview-bar {
    display: flex;
    align-items: center;
    gap: .5rem;
    font-weight: 500;
    margin-bottom: .5rem;
    color: var(--user-accent, var(--primary));
}
.theme-preview-dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: var(--user-accent, var(--primary));
    display: inline-block;
}
.theme-preview-btn {
    background: var(--user-accent, var(--primary));
    color: #fff;
    border: 0;
    padding: .5rem 1rem;
    border-radius: 4px;
    font-size: .85rem;
    cursor: pointer;
    margin-top: .5rem;
}

/* Contact-method radio group */
.contact-radio {
    display: flex;
    gap: .5rem;
    flex-wrap: wrap;
}
.contact-radio-option {
    margin: 0;
    cursor: pointer;
    padding: .4rem .8rem;
    border: 1px solid var(--border);
    border-radius: 4px;
    font-size: .85rem;
    background: var(--white);
    transition: background .2s, border-color .2s;
}
.contact-radio-option input { margin-right: .35rem; }
.contact-radio-option:has(input:checked) {
    background: var(--user-accent, var(--primary));
    color: #fff;
    border-color: var(--user-accent, var(--primary));
}

/* ============================================================
   === Frontend Polish (Apr 2026) ============================
   - Fix für gecropptes "Schön dass du da bist"-Portrait
   - Reviews-Block (auf Startseite hochgezogen)
   - Magazin/Blog-Vorschau Cards
   ============================================================ */

/* Cropped portrait fix — face was getting clipped because the container
   used aspect-ratio: 4/3 with object-fit:cover. Override the wrapper to a
   portrait-friendly ratio and pin the focal point near the top. */
.collage .about-portrait-wrap { aspect-ratio: 4 / 5; }
.about-portrait {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
    display: block;
}
@media (max-width: 768px) {
    .collage .about-portrait-wrap { aspect-ratio: 3 / 4; }
}

/* Reviews moved-up block — soft background so it stands out without
   competing with the hero. */
.reviews-block { background: var(--bg-soft); padding-block: 4rem; }
.reviews-home-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1.25rem;
    margin: 0 auto;
}
.review-card-home {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 1.4rem 1.5rem;
    display: flex;
    flex-direction: column;
    gap: .6rem;
    box-shadow: 0 4px 18px rgba(0,0,0,.04);
    transition: transform .25s ease, box-shadow .25s ease;
}
.review-card-home:hover {
    transform: translateY(-3px);
    box-shadow: 0 14px 32px rgba(0,0,0,.08);
}
.review-card-home-top { font-size: 1.1rem; }
.review-card-home-title {
    margin: 0;
    font-size: 1.05rem;
    font-weight: 600;
    line-height: 1.35;
}
.review-card-home-body {
    margin: 0;
    color: var(--muted);
    font-size: .95rem;
    line-height: 1.55;
    flex: 1;
}
.review-card-home-foot {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    font-size: .82rem;
    color: var(--muted);
    margin-top: .25rem;
}
.review-card-home-author { font-weight: 600; color: inherit; }

/* Blog-Preview cards on home — simple, clean, matches site style */
.blog-preview-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1.5rem;
}
.blog-preview-grid .blog-card {
    display: flex;
    flex-direction: column;
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: 12px;
    overflow: hidden;
    text-decoration: none;
    color: inherit;
    transition: transform .25s ease, box-shadow .25s ease;
}
.blog-preview-grid .blog-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 14px 32px rgba(0,0,0,.08);
}
.blog-preview-grid .blog-card img {
    width: 100%;
    aspect-ratio: 16 / 10;
    object-fit: cover;
    display: block;
    transition: transform .4s ease;
}
.blog-preview-grid .blog-card:hover img { transform: scale(1.04); }
.blog-preview-grid .blog-card-body {
    padding: 1.25rem 1.4rem 1.4rem;
    display: flex;
    flex-direction: column;
    gap: .5rem;
    flex: 1;
}
.blog-preview-grid .blog-card-cat {
    font-size: .7rem;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--primary);
    font-weight: 600;
}
.blog-preview-grid .blog-card-body h3 {
    margin: 0 0 .25rem;
    font-size: 1.1rem;
    line-height: 1.35;
}
.blog-preview-grid .blog-card-body p {
    color: var(--muted);
    font-size: .92rem;
    line-height: 1.5;
    margin: 0 0 .5rem;
    flex: 1;
}
.blog-preview-grid .blog-card-link {
    margin-top: auto;
    font-weight: 600;
    color: var(--primary);
    font-size: .92rem;
}

/* ====================================================================== */
/*  REFERRAL / "Freunde werben"                                           */
/* ====================================================================== */
.referral-hero {
    display: grid;
    grid-template-columns: 1.4fr 1fr;
    gap: 1.5rem;
    padding: 1.75rem;
    background: linear-gradient(135deg, rgba(212, 160, 23, 0.08), rgba(212, 160, 23, 0.02));
    border: 1px solid var(--border);
    border-radius: 8px;
}
.referral-hero__intro small {
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: .08em;
    font-size: .72rem;
}
.referral-hero__code {
    font-family: 'SFMono-Regular', Consolas, 'Liberation Mono', Menlo, monospace;
    font-size: 2.6rem;
    font-weight: 600;
    color: var(--primary);
    letter-spacing: .15em;
    margin: .35rem 0 .8rem;
    word-break: break-all;
}
.referral-hero__url {
    display: flex;
    gap: .5rem;
    flex-wrap: wrap;
    align-items: stretch;
}
.referral-hero__url input {
    flex: 1 1 240px;
    min-width: 200px;
    padding: .55em .8em;
    border: 1px solid var(--border);
    border-radius: 4px;
    background: var(--white);
    font-size: .85rem;
    font-family: 'SFMono-Regular', Consolas, monospace;
}
.referral-hero__share {
    display: flex;
    flex-direction: column;
    gap: .55rem;
    justify-content: center;
}
.referral-share-btn {
    text-align: center;
    font-size: .9rem;
}
.referral-share-btn--wa {
    border-color: #25d366;
    color: #128c4a;
}
.referral-share-btn--wa:hover {
    background: #25d366;
    color: #fff;
}
.referral-share-btn--mail {
    border-color: #1f4a6b;
    color: #1f4a6b;
}
.referral-share-btn--mail:hover {
    background: #1f4a6b;
    color: #fff;
}
.referral-share-btn--copy {
    border-color: var(--primary);
    color: var(--primary);
}

.referral-stats-grid {
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
}
.referral-stat {
    padding: 1.25rem;
    text-align: center;
}
.referral-stat__num {
    font-size: 2rem;
    color: var(--primary);
    font-weight: 300;
    line-height: 1.05;
}
.referral-stat--accent {
    background: linear-gradient(135deg, rgba(212, 160, 23, 0.10), rgba(212, 160, 23, 0.02));
    border-color: rgba(212, 160, 23, 0.4);
}
.referral-howto {
    border-left: 4px solid var(--primary);
}
.referral-howto__list {
    margin: .55rem 0 0;
    padding-left: 1.25rem;
    line-height: 1.7;
}
.referral-howto__list li {
    margin: .25rem 0;
}

@media (max-width: 760px) {
    .referral-hero {
        grid-template-columns: 1fr;
        padding: 1.25rem;
    }
    .referral-hero__code {
        font-size: 1.9rem;
    }
    .referral-stats-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* ====================================================================
   Customer Security Hub — /account/security  (appended 2026-04-29)
   ==================================================================== */

/* Sicherheits-Checkup Score-Bar */
.sec-checkup-head {
    display: flex; gap: 1rem; align-items: center; flex-wrap: wrap; justify-content: space-between;
}
.sec-score-bar {
    display: inline-flex; gap: .35rem; align-items: center;
    padding: .35rem .55rem; background: #fff; border: 1px solid var(--border, #e0e0e0);
    border-radius: 999px;
}
.sec-score-dot {
    width: .85rem; height: .85rem; border-radius: 50%;
    background: #d6d6d6;
    box-shadow: inset 0 0 0 1px rgba(0,0,0,.04);
}
.sec-score-dot.on { background: var(--success, #188a4a); }
.sec-check-list {
    list-style: none; margin: 1rem 0 0; padding: 0;
    display: grid; grid-template-columns: 1fr 1fr; gap: .4rem .9rem;
}
.sec-check-list li {
    display: flex; gap: .5rem; align-items: center; font-size: .92rem;
}
.sec-check-list li .sec-check-icon {
    display: inline-flex; width: 1.4rem; height: 1.4rem; flex: none;
    align-items: center; justify-content: center; border-radius: 50%;
    background: #d6d6d6; color: #fff; font-size: .8rem; font-weight: 600;
}
.sec-check-list li.ok  .sec-check-icon { background: var(--success, #188a4a); }
.sec-check-list li.bad .sec-check-icon { background: var(--alert, #c0392b); }
.sec-check-list li.bad { color: var(--alert, #c0392b); }
@media (max-width: 700px) {
    .sec-check-list { grid-template-columns: 1fr; }
}

/* 2FA Setup */
.twofa-setup {
    margin-top: 1.25rem; padding: 1rem; background: #fff; border: 1px dashed var(--border, #e0e0e0);
    border-radius: 12px;
}
.twofa-setup-grid {
    display: grid; gap: 1rem; grid-template-columns: 240px 1fr; align-items: start;
}
@media (max-width: 700px) {
    .twofa-setup-grid { grid-template-columns: 1fr; }
}
.twofa-qr {
    display: inline-block; padding: .5rem; background: #fff; border: 1px solid var(--border, #e0e0e0);
    border-radius: 8px;
}
.twofa-qr img { display: block; width: 240px; height: 240px; max-width: 100%; }
.twofa-secret {
    font-family: 'Courier New', Consolas, monospace;
    font-size: 1rem; letter-spacing: .08em; word-break: break-all;
    background: #faf6ef; border: 1px dashed var(--border, #d6d6d6);
    padding: .65rem .85rem; border-radius: 8px; user-select: all;
}

/* Backup-Codes Grid */
.twofa-backup { padding-top: .5rem; }
.twofa-codes-grid {
    display: grid; gap: .5rem .75rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-top: .5rem;
}
@media (min-width: 700px) {
    .twofa-codes-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}
.twofa-backup-code,
code.twofa-backup-code {
    display: block; text-align: center;
    background: #fff; border: 1px solid var(--border, #e0e0e0);
    border-radius: 6px; padding: .55rem .65rem;
    font-family: 'Courier New', Consolas, monospace;
    font-size: .95rem; letter-spacing: .08em; user-select: all;
}

/* Tabellen */
.sec-table-wrap { overflow-x: auto; }
.sec-device-table th, .sec-device-table td,
.sec-login-table th,  .sec-login-table td {
    padding: .55rem .65rem; vertical-align: top;
}
.sec-device-table thead th, .sec-login-table thead th {
    text-align: left; font-size: .82rem; color: var(--muted, #666);
    border-bottom: 1px solid var(--border, #e0e0e0);
}
.sec-device-table tbody tr + tr,
.sec-login-table tbody tr + tr {
    border-top: 1px solid var(--border, #ececec);
}

/* Status-Badges */
.sec-badge {
    display: inline-block; padding: .15rem .55rem; border-radius: 999px;
    font-size: .75rem; font-weight: 600; letter-spacing: .02em;
}
.sec-badge-ok  { background: rgba(24,138,74,.12);  color: var(--success, #188a4a); }
.sec-badge-bad { background: rgba(192,57,43,.12);  color: var(--alert, #c0392b); }

/* Accessibility: Skip-to-content link (visually hidden until focus) */
.skip-link {
    position: absolute;
    left: -9999px;
    top: auto;
    width: 1px;
    height: 1px;
    overflow: hidden;
    z-index: 9999;
}
.skip-link:focus {
    left: 1em;
    top: 1em;
    width: auto;
    height: auto;
    background: var(--primary, #90a7ac);
    color: #fff;
    padding: .5em 1em;
    border-radius: 4px;
    text-decoration: none;
    font-weight: 600;
    box-shadow: 0 4px 12px rgba(0,0,0,.18);
}


/* =============================================================
   === Polish-Pass 2026-04-29 ===
   Site-wide polish (typography, hover, focus) + POS rebuild.
   APPEND-ONLY: no existing rule above is altered. Safe to remove
   this whole block and the page degrades gracefully.
   ============================================================= */

/* ---------- Typography polish ---------- */
body { font-feature-settings: "kern" 1, "liga" 1, "calt" 1; text-rendering: optimizeLegibility; }
h1, h2, h3, h4 { letter-spacing: -.015em; }
h1 { letter-spacing: -.02em; }
.lead, p.lead { font-weight: 300; line-height: 1.65; }

/* Decorative section-title eyebrow — opt-in via [data-eyebrow] */
.section-title[data-eyebrow]::before {
    content: attr(data-eyebrow);
    display: block;
    color: var(--primary);
    text-transform: uppercase;
    letter-spacing: .18em;
    font-size: .72rem;
    font-weight: 500;
    margin-bottom: .55rem;
    opacity: .9;
}

/* ---------- Smoother global transitions (additive) ---------- */
/* Note: .pos-tile + .pay-pick transitions sind in pos-pro.css definiert */
.btn, .button, .product-card, .service-card, .badge, .sec-badge {
    transition: background var(--transition), border-color var(--transition),
                color var(--transition), box-shadow var(--transition),
                transform var(--transition);
}

/* ---------- Buttons polish (lift on hover, no override of color rules) ---------- */
.btn:hover, .button:hover { box-shadow: 0 6px 18px rgba(144,167,172,.28); transform: translateY(-1px); }
.btn:active, .button:active { transform: translateY(0); box-shadow: 0 2px 6px rgba(144,167,172,.18); }
.btn-outline:hover { box-shadow: 0 6px 18px rgba(144,167,172,.18); }
.btn-dark:hover { box-shadow: 0 6px 18px rgba(0,0,0,.22); }
.btn:focus-visible, .button:focus-visible {
    outline: 0;
    box-shadow: 0 0 0 3px rgba(144,167,172,.35), 0 6px 18px rgba(144,167,172,.28);
}

/* ---------- Forms polish ---------- */
.form-control:focus,
input[type=text]:focus, input[type=email]:focus, input[type=password]:focus,
input[type=tel]:focus, input[type=date]:focus, input[type=number]:focus,
input[type=time]:focus, input[type=search]:focus, input[type=url]:focus,
textarea:focus, select:focus {
    outline: 0;
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(144,167,172,.18);
}
input::placeholder, textarea::placeholder { color: #aab1b3; opacity: 1; }
input[type=number]::-webkit-outer-spin-button,
input[type=number]::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

/* ---------- Customer-facing polish ---------- */
/* Product-card hover lift + image zoom — pairs with existing .product-card rules above */
.product-card { transition: transform var(--transition), box-shadow var(--transition); }
.product-card:hover { transform: translateY(-3px); box-shadow: 0 10px 28px rgba(0,0,0,.07); }
.product-card .product-media img { transition: transform 600ms ease; }
.product-card:hover .product-media img { transform: scale(1.03); }
.product-card .product-title { transition: color var(--transition); }
.product-card:hover .product-title { color: var(--primary); }

/* ---------- Modern table polish (pairs with existing .table) ---------- */
.table tbody tr { transition: background var(--transition); }
.table-striped tbody tr:nth-child(odd) { background: var(--bg-light); }
.table-compact th, .table-compact td { padding: .5rem .65rem; font-size: .85rem; }

/* ---------- Skeleton loader ---------- */
.skel { background: linear-gradient(90deg, var(--bg-soft) 0%, #efefef 50%, var(--bg-soft) 100%); background-size: 200% 100%; animation: skelShimmer 1.4s linear infinite; color: transparent !important; user-select: none; pointer-events: none; }
@keyframes skelShimmer { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }

/* =============================================================
   POS — Vor-Ort-Kasse → ALLE .pos-*-Regeln in pos-pro.css migriert
   (Konsolidierung 2026-05-01). pos-pro.css wird in admin/_pos.php
   geladen. Hier nur noch die nicht-POS-Print-Regeln.
   ============================================================= */

/* =============================================================
   Print-friendly: hide chrome on receipts, dashboards, invoices
   (Hinweis: POS-spezifische Print-Regeln sind in pos-pro.css)
   ============================================================= */
@media print {
    .site-header, .header-top, .site-footer, .sidebar, .breadcrumb,
    .mobile-bottom-nav,
    .btn, .button,
    .reveal, nav, .newsletter, .cookie-banner {
        display: none !important;
    }
    body { background: #fff !important; color: #000 !important; }
    .dashboard, .dashboard-main { display: block !important; padding: 0 !important; margin: 0 !important; box-shadow: none !important; border: 0 !important; }
    a { color: inherit !important; text-decoration: none !important; }
}

/* =============================================================
   Reduced-motion: respect user preference
   ============================================================= */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: .01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: .01ms !important;
        scroll-behavior: auto !important;
    }
    .skel { animation: none !important; }
}
/* === /Polish-Pass 2026-04-29 === */


/* =============================================================
   === TABLE-RESPONSIVE 2026-05-01 ===
   Generic mobile fix for admin tables. Two layers:
   1. .table-wrap → horizontal scroll fallback (always safe)
   2. .table.responsive-cards → cards stack on <=720px
   Each <td> needs data-label="…" for the card-mode label.
   APPEND-ONLY: existing desktop layout untouched.
   ============================================================= */

/* Wrapper for any table — gives clean horizontal scroll on overflow */
.table-wrap {
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    border-radius: 4px;
}
.table-wrap > .table { min-width: 640px; }

/* Mobile: turn flagged tables into card lists */
@media (max-width: 720px) {
    /* General safety: any .table inside .dashboard-main may overflow horizontally */
    .dashboard-main .table-wrap { border: 1px solid var(--border); }

    /* Card mode — opt-in via class="table responsive-cards" */
    .table.responsive-cards { min-width: 0; display: block; }
    .table.responsive-cards thead {
        position: absolute; left: -9999px; top: -9999px;
        width: 1px; height: 1px; overflow: hidden;
    }
    .table.responsive-cards tbody { display: block; }
    .table.responsive-cards tr {
        display: block;
        background: var(--white, #fff);
        border: 1px solid var(--border);
        border-radius: 10px;
        margin-bottom: .8rem;
        padding: .6rem .9rem;
        box-shadow: 0 1px 3px rgba(0,0,0,.04);
    }
    .table.responsive-cards tr:hover { background: var(--white, #fff); }
    .table.responsive-cards td {
        display: flex;
        justify-content: space-between;
        align-items: flex-start;
        gap: 1rem;
        padding: .45rem 0;
        border-bottom: 1px dashed #eee;
        white-space: normal;
        word-break: break-word;
        text-align: right;
    }
    .table.responsive-cards td:last-child { border-bottom: none; }
    .table.responsive-cards td::before {
        content: attr(data-label);
        font-weight: 500;
        color: var(--muted);
        font-size: .78rem;
        text-transform: uppercase;
        letter-spacing: .03em;
        flex: 0 0 auto;
        max-width: 45%;
        text-align: left;
    }
    /* Cells without data-label still align nicely (e.g. action rows) */
    .table.responsive-cards td:not([data-label])::before { content: ""; max-width: 0; }
    .table.responsive-cards td[data-label="Aktion"],
    .table.responsive-cards td[data-label="Aktionen"],
    .table.responsive-cards td[data-label="Schnell-Rabatt"] {
        flex-direction: column;
        align-items: stretch;
        text-align: left;
        padding-top: .6rem;
    }
    .table.responsive-cards td[data-label="Aktion"]::before,
    .table.responsive-cards td[data-label="Aktionen"]::before,
    .table.responsive-cards td[data-label="Schnell-Rabatt"]::before {
        max-width: 100%;
        margin-bottom: .35rem;
    }
    /* Touch-friendly buttons inside cards (min 40px tall) */
    .table.responsive-cards .btn,
    .table.responsive-cards button[type="submit"],
    .table.responsive-cards .ci-btn {
        min-height: 40px;
        padding: .55em .9em;
    }
}

/* Same logic for the bespoke .ci-table & .aob-products-grid & .datev-table —
   they don't share .table class, so add scroll wrapper rule explicitly */
.ci-table-wrap, .aob-products-wrap, .datev-table-wrap {
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}
@media (max-width: 720px) {
    .aob-products-grid { min-width: 720px; }
}
/* === /TABLE-RESPONSIVE 2026-05-01 === */


/* =============================================================
   === DASHBOARD SIDEBAR DRAWER 2026-05-01 ===
   Mobile (<940px): hamburger toggles a slide-in drawer.
   Desktop: sidebar stays static. Hamburger button hidden.
   ============================================================= */
.dashboard-sidebar-toggle { display: none; }
.dashboard-sidebar-backdrop { display: none; }

@media (max-width: 940px) {
    /* Hamburger button — fixed, gold-accent */
    .dashboard-sidebar-toggle {
        position: sticky;
        top: 60px;
        z-index: 60;
        margin: .5rem 1rem 0;
        display: inline-flex;
        align-items: center;
        gap: .55rem;
        padding: .55rem .85rem;
        background: var(--white);
        border: 1px solid var(--border);
        border-radius: 6px;
        font: inherit;
        color: var(--text);
        cursor: pointer;
        box-shadow: 0 1px 4px rgba(0,0,0,.06);
        transition: background var(--transition), border-color var(--transition);
    }
    .dashboard-sidebar-toggle .lbl { font-size: .82rem; font-weight: 500; }
    .dashboard-sidebar-toggle > span:not(.lbl) {
        display: block;
        width: 18px;
        height: 2px;
        background: #b89261;
        transition: transform .25s, opacity .25s;
        border-radius: 2px;
    }
    .dashboard-sidebar-toggle > span:not(.lbl):nth-child(1) { margin-bottom: 4px; }
    .dashboard-sidebar-toggle > span:not(.lbl):nth-child(2) { margin-bottom: 4px; }
    .dashboard-sidebar-toggle:hover { border-color: #dabe92; background: #fffaf3; }
    .dashboard-sidebar-toggle.open > span:not(.lbl):nth-child(1) {
        transform: translateY(6px) rotate(45deg);
    }
    .dashboard-sidebar-toggle.open > span:not(.lbl):nth-child(2) { opacity: 0; }
    .dashboard-sidebar-toggle.open > span:not(.lbl):nth-child(3) {
        transform: translateY(-6px) rotate(-45deg);
    }

    /* Drawer overrides: replace horizontal-scroll layout with a vertical drawer */
    .dashboard {
        grid-template-columns: 1fr;
        margin: .25rem auto 1rem;
    }
    .dashboard .sidebar {
        position: fixed;
        top: 0;
        left: 0;
        bottom: 0;
        width: min(86vw, 340px);
        max-width: 86vw;
        flex-direction: column;
        flex-wrap: nowrap;
        overflow-x: hidden;
        overflow-y: auto;
        white-space: normal;
        background: var(--white);
        border: 0;
        border-right: 1px solid var(--border);
        box-shadow: 4px 0 24px rgba(0,0,0,.08);
        padding: 4.5rem 0 1rem;
        transform: translateX(-105%);
        transition: transform .28s cubic-bezier(.25,.46,.45,.94);
        z-index: 70;
    }
    .dashboard .sidebar.open { transform: translateX(0); }
    .dashboard .sidebar a {
        flex: 0 0 auto;
        display: block;
        padding: .75em 1.25em;
        border-left: 3px solid transparent;
        border-bottom: 0;
        font-size: .92em;
    }
    .dashboard .sidebar a:hover,
    .dashboard .sidebar a.active {
        border-left-color: #dabe92;
        border-bottom: 0;
        background: var(--bg-soft);
    }
    .dashboard-sidebar-backdrop {
        display: block;
        position: fixed;
        inset: 0;
        background: rgba(0,0,0,.4);
        z-index: 65;
        animation: dashFadeIn .2s ease;
    }
    .dashboard-sidebar-backdrop[hidden] { display: none; }
    @keyframes dashFadeIn { from { opacity: 0; } to { opacity: 1; } }

    body.dashboard-sidebar-locked { overflow: hidden; }

    /* Re-tighten dashboard-main */
    .dashboard-main { padding: 1rem; }
}
/* === /DASHBOARD SIDEBAR DRAWER === */



/* ============================================================================
 * GLOBAL MOBILE-LOCK (2026-05-01)
 * Verhindert horizontales Scrollen + Layout-Shifts auf allen Mobile-Pages
 * ========================================================================== */
@media (max-width: 940px) {
    html, body {
        overflow-x: hidden;
        max-width: 100vw;
        width: 100%;
        overscroll-behavior-x: none;
    }
    body { position: relative; }
    .container, .container-narrow, .dashboard, .dashboard-main,
    main, section, header, footer, nav,
    .b-grid, .services-grid, .product-grid, .blog-grid {
        max-width: 100%;
        box-sizing: border-box;
    }
    /* Lange Wörter umbrechen statt overflowen */
    h1, h2, h3, h4, p, td, .product-card-name, .b-card-name {
        word-break: break-word;
        overflow-wrap: anywhere;
    }
    /* Breite Tabellen scrollen INNERHALB ihres Wrappers, nicht die ganze Page */
    .table-wrap, .ci-table-wrap, .datev-table-wrap, .aob-products-wrap,
    .sec-table-wrap {
        max-width: 100%;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }
    /* Bilder + Iframes responsive */
    img, video, iframe { max-width: 100%; height: auto; }
    /* Form-Elemente nehmen volle Breite (außer wenn explizit anders) */
    input:not([type=checkbox]):not([type=radio]):not([type=submit]):not([type=button]),
    textarea, select { max-width: 100%; box-sizing: border-box; }
}


/* ============================================================================
 * === FRONTEND POLISH PASS 2026-05-01 ===
 * Token-driven harmonization of buttons, forms, cards, sections and footer.
 * APPEND-ONLY: existing rules above are NOT modified. Specificity is kept
 * minimal so per-component overrides above still win where intentional.
 * ========================================================================== */

/* ---------- 1. Fluid typography --------------------------------------- */
h1 { font-size: clamp(2rem, 4.5vw, 3rem); letter-spacing: -.02em; line-height: 1.15; }
h2 { font-size: clamp(1.5rem, 3vw, 2.2rem); letter-spacing: -.015em; line-height: 1.25; }
h3 { font-size: clamp(1.2rem, 2.4vw, 1.6rem); letter-spacing: -.01em; line-height: 1.3; }
h4 { font-size: clamp(1.05rem, 1.8vw, 1.25rem); line-height: 1.35; }
body { font-size: 1rem; line-height: 1.6; }
p { line-height: 1.65; }
small, .small { font-size: .85rem; line-height: 1.5; }

/* ---------- 2. Container widths (additive) ---------------------------- */
.container-default { max-width: var(--max-w-default); margin: 0 auto; padding: 0 var(--sp-4); }
.container-wide { max-width: var(--max-w); margin: 0 auto; padding: 0 var(--sp-4); }

/* ---------- 3. Button system (unified heights, radii, focus) ---------- */
.btn, button.btn, a.btn, .button, button.button, a.button {
    min-height: var(--touch-min);
    border-radius: var(--radius-md);
    padding: .65em 1.5em;
    font-weight: 500;
    letter-spacing: .01em;
    transition:
        background var(--t-fast),
        border-color var(--t-fast),
        color var(--t-fast),
        box-shadow var(--t-fast),
        transform var(--t-fast);
}
.btn:focus-visible, .button:focus-visible {
    outline: 0;
    box-shadow:
        0 0 0 3px rgba(144,167,172,.35),
        var(--shadow-glow);
}
.btn:disabled, .btn[disabled], .btn[aria-disabled="true"],
.button:disabled, .button[disabled] {
    opacity: .45;
    cursor: not-allowed;
    transform: none !important;
    box-shadow: none !important;
}

/* New variants — Gold + Ghost (additive) */
.btn-gold {
    background: var(--gold);
    border-color: var(--gold);
    color: #fff !important;
}
.btn-gold:hover {
    background: var(--gold-dark);
    border-color: var(--gold-dark);
    box-shadow: 0 6px 18px rgba(184,146,97,.32);
}
.btn-ghost {
    background: transparent;
    border-color: transparent;
    color: var(--primary) !important;
    box-shadow: none;
}
.btn-ghost:hover {
    background: rgba(144,167,172,.10);
    color: var(--primary-dark) !important;
    border-color: transparent;
}
.btn-sm {
    min-height: 36px;
    padding: .4em 1em;
    font-size: .85rem;
    border-radius: var(--radius-sm);
}
.btn-lg {
    min-height: 52px;
    padding: .85em 1.85em;
    font-size: 1rem;
    border-radius: var(--radius-md);
}

/* ---------- 4. Forms (unified focus + touch height) -------------------- */
.form-control,
input[type=text], input[type=email], input[type=password], input[type=tel],
input[type=date], input[type=number], input[type=time], input[type=search],
input[type=url], textarea, select {
    min-height: var(--touch-min);
    border-radius: var(--radius-sm);
    transition:
        border-color var(--t-fast),
        box-shadow var(--t-fast),
        background var(--t-fast);
}
.form-control:focus,
input[type=text]:focus, input[type=email]:focus, input[type=password]:focus,
input[type=tel]:focus, input[type=date]:focus, input[type=number]:focus,
input[type=time]:focus, input[type=search]:focus, input[type=url]:focus,
textarea:focus, select:focus {
    outline: 0;
    border-color: var(--gold);
    box-shadow: 0 0 0 3px rgba(218,190,146,.22);
}
.form-control[aria-invalid="true"],
.form-control.is-error {
    border-color: var(--alert);
    box-shadow: 0 0 0 3px rgba(227,33,60,.12);
}
.form-control.is-success {
    border-color: var(--success);
    box-shadow: 0 0 0 3px rgba(76,175,80,.14);
}
.field-success { color: var(--success); font-size: .8rem; margin-top: .25rem; }
.form-group label { font-size: .9rem; font-weight: 500; margin-bottom: .4rem; color: var(--text); }

/* Checkboxes & radios — ensure adequate touch target on mobile */
input[type=checkbox], input[type=radio] {
    min-width: 18px;
    min-height: 18px;
    accent-color: var(--primary);
}

/* ---------- 5. Cards (consistent radius + soft hover) ----------------- */
.product-card,
.service-card,
.review-card-home,
.blog-preview-grid .blog-card,
.b-card,
.cart-item,
.checkout-step,
.cart-summary,
.reservation-form-box {
    border-radius: var(--radius-lg);
}
.product-card,
.service-card,
.b-card {
    transition: transform var(--t-base), box-shadow var(--t-base);
}
.product-card:hover,
.service-card:hover,
.b-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}
.review-card-home,
.blog-preview-grid .blog-card {
    transition: transform var(--t-base), box-shadow var(--t-base);
}
.review-card-home:hover,
.blog-preview-grid .blog-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}

/* ---------- 6. Section spacing (fluid) -------------------------------- */
.section { padding: clamp(2.5rem, 6vw, 5rem) 0; }
.section-narrow { padding: clamp(2rem, 4vw, 3.5rem) 0; }
.page-title-block { padding: clamp(2rem, 5vw, 4rem) var(--sp-4) var(--sp-5); }

/* ---------- 7. Section title underline polish ------------------------- */
.section-title {
    display: inline-block;
    position: relative;
}

/* ---------- 8. Newsletter (rounded form on desktop) -------------------- */
.newsletter input,
.newsletter button {
    border-radius: var(--radius-md);
    min-height: var(--touch-min);
}
.newsletter form { gap: var(--sp-2); }

/* ---------- 9. Badges & pills ----------------------------------------- */
.badge { border-radius: var(--radius-pill); padding: .2em .7em; }
.sec-badge { border-radius: var(--radius-pill); }

/* ---------- 10. Alerts (rounded) -------------------------------------- */
.alert { border-radius: var(--radius-md); }

/* ---------- 11. Anchor focus-visible ---------------------------------- */
a:focus-visible {
    outline: 2px solid var(--gold);
    outline-offset: 2px;
    border-radius: 2px;
}

/* ---------- 12. Footer polish ----------------------------------------- */
.site-footer {
    background: var(--dark-bg);
}
.site-footer h5 { color: var(--white); margin-bottom: var(--sp-3); }
.site-footer a { transition: color var(--t-fast); padding: .3rem 0; }
.social-icons a {
    width: var(--touch-min);
    height: var(--touch-min);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: rgba(255,255,255,.06);
    transition: background var(--t-fast), transform var(--t-fast);
}
.social-icons a:hover {
    background: var(--primary);
    transform: translateY(-2px);
}
@media (max-width: 760px) {
    .site-footer { padding: var(--sp-7) var(--sp-4) var(--sp-5); }
    .footer-grid { gap: var(--sp-5); }
    .footer-bottom { flex-direction: column; gap: var(--sp-3); align-items: flex-start; }
}
@media (max-width: 480px) {
    .footer-grid { grid-template-columns: 1fr; gap: var(--sp-4); }
    .site-footer h5 { font-size: .85rem; margin-bottom: var(--sp-2); }
    .footer-bottom { font-size: .72rem; }
    .payment-icons img { height: 18px; }
}

/* ---------- 13. Touch-friendly nav + pill items ------------------------ */
@media (max-width: 940px) {
    .main-nav a { min-height: var(--touch-min); }
    .icon-link, .basket-link, .lang-switch a {
        min-height: var(--touch-min);
        min-width: var(--touch-min);
        display: inline-flex; align-items: center; justify-content: center;
    }
}

/* ---------- 14. Smooth scrollable areas (touch momentum) -------------- */
.scrollable, .scroll-x, .table-wrap,
.sidebar, .sec-table-wrap,
.aob-products-wrap, .ci-table-wrap, .datev-table-wrap {
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    scrollbar-color: var(--primary) transparent;
}

/* ---------- 15. Avoid overlay artifacts on iOS -------------------------- */
@supports (-webkit-touch-callout: none) {
    .site-header { -webkit-backdrop-filter: saturate(180%) blur(28px); }
}

/* ---------- 16. Image polish ------------------------------------------ */
.product-card .product-media,
.service-card-media,
.blog-preview-grid .blog-card img,
.banner-card .banner-image {
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
    overflow: hidden;
}

/* ---------- 17. Cart / Checkout polish -------------------------------- */
.cart-item, .checkout-step, .cart-summary {
    box-shadow: var(--shadow-sm);
}
.cart-summary { box-shadow: var(--shadow-md); }

/* ---------- 18. Reduced motion (already set globally — kept compatible) */
@media (prefers-reduced-motion: reduce) {
    .product-card:hover, .service-card:hover, .b-card:hover,
    .review-card-home:hover, .blog-preview-grid .blog-card:hover {
        transform: none;
    }
}
/* === /FRONTEND POLISH PASS 2026-05-01 === */


/* ============================================================================
 * === FRONTEND POLISH PASS 2 (2026-05-01) ===
 * Page-level helpers extracted from inline styles + viz-bug fixes.
 * Replaces 70+ inline declarations across treatment / shop / basket pages.
 * ========================================================================== */

/* ---------- Steps grid (treatment detail "Was dich erwartet") ---------- */
.steps-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: var(--sp-4);
}
.steps-grid .step-card {
    padding: var(--sp-6) var(--sp-5);
    text-align: center;
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    transition: transform var(--t-base), box-shadow var(--t-base), border-color var(--t-base);
}
.steps-grid .step-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
    border-color: var(--gold);
}
.step-num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px; height: 48px;
    margin: 0 auto var(--sp-3);
    border-radius: 50%;
    background: linear-gradient(135deg, var(--gold), var(--gold-dark));
    color: var(--white);
    font-size: 1.25rem;
    font-weight: 600;
    line-height: 1;
    box-shadow: 0 4px 12px rgba(184,146,97,.3);
}
.step-card h4 { margin: 0 0 var(--sp-2); color: var(--text); font-weight: 500; }
.step-card p { margin: 0; color: var(--muted); font-size: .92rem; line-height: 1.6; }

/* ---------- Brand tile (online-shop.php) ---------- */
.brand-tile {
    padding: var(--sp-6) var(--sp-5);
    text-align: center;
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    transition: transform var(--t-base), box-shadow var(--t-base), border-color var(--t-base);
    text-decoration: none;
    color: inherit;
    display: block;
}
.brand-tile:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
    border-color: var(--gold);
    color: inherit;
}
.brand-tile h4 { margin: 0 0 var(--sp-2); color: var(--text); font-weight: 500; }
.brand-tile p  { margin: 0 0 var(--sp-3); color: var(--muted); font-size: .92rem; }
.brand-tile .brand-tile-link {
    color: var(--primary);
    font-size: .85rem;
    font-weight: 500;
    letter-spacing: .02em;
}

/* ---------- Pill toggle (Pflegeprodukte | Gutscheine) ---------- */
.pill-group { display: inline-flex; gap: var(--sp-2); flex-wrap: wrap; }
.pill-group .btn-pill {
    min-height: 38px;
    padding: .4rem 1.1rem;
    font-size: .85rem;
    border-radius: var(--radius-pill);
}

/* ---------- Coupon box (basket.php) ---------- */
.coupon-active-box {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--sp-4);
    padding: var(--sp-4) var(--sp-5);
    background: rgba(76,175,80,.08);
    border: 1px solid rgba(76,175,80,.3);
    border-radius: var(--radius-md);
    flex-wrap: wrap;
}
.coupon-active-box code {
    background: var(--white);
    color: var(--text);
    padding: .15rem .5rem;
    border-radius: 3px;
    font-size: .9rem;
}
.coupon-savings-pill {
    margin-top: var(--sp-2);
    padding: var(--sp-3) var(--sp-4);
    background: rgba(76,175,80,.1);
    border-left: 3px solid var(--success);
    border-radius: var(--radius-sm);
    font-size: .85rem;
}
.coupon-form { display: flex; gap: var(--sp-2); flex-wrap: wrap; }
.coupon-form input[type=text] {
    flex: 1; min-width: 180px;
    text-transform: uppercase;
    letter-spacing: .05em;
}

/* ---------- Sale badge on product card (online-shop.php) ---------- */
.product-card .product-media { position: relative; }
.shop-sale-badge {
    position: absolute;
    top: var(--sp-2); left: var(--sp-2);
    z-index: 2;
    background: #c93030;
    color: #fff;
    padding: .2em .55em;
    font-size: .7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .04em;
    border-radius: var(--radius-sm);
}
.product-price-sale { color: #c93030; font-weight: 600; }
.product-price-strike { text-decoration: line-through; color: var(--muted); font-size: .85em; margin-left: .35em; }

/* ---------- Auslaufprodukt Badge (Ex-Artikel mit Restbestand) ---------- */
.shop-auslauf-badge {
    position: absolute;
    top: var(--sp-2); left: var(--sp-2);
    z-index: 3;
    background: #c93030;
    color: #fff;
    padding: .28em .7em;
    font-size: .72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    border-radius: var(--radius-sm);
    box-shadow: 0 2px 6px rgba(201,48,48,0.35);
}
.product-card-auslauf {
    position: relative;
}
.product-card-auslauf::after {
    content: '';
    position: absolute;
    inset: 0;
    border: 2px solid #c93030;
    border-radius: var(--radius-md, 8px);
    pointer-events: none;
    z-index: 1;
}
.product-card-auslauf .product-title {
    color: #c93030;
}
.product-card-auslauf .product-media img {
    opacity: 0.82;
}
/* ---------- PDP Gallery (Carrousel) ---------- */
.pdp-gallery { display: flex; flex-direction: column; gap: .85rem; }
.pdp-gallery-main {
    position: relative;
    border: 1px solid var(--border, #e3e3e3);
    border-radius: var(--radius-md, 10px);
    background: #fff;
    overflow: hidden;
    cursor: zoom-in;
}
.pdp-gallery-main img {
    width: 100%; height: auto; aspect-ratio: 1/1;
    object-fit: contain; display: block; background: #fff;
    padding: .75rem;
    transition: transform 350ms ease, opacity 200ms ease;
}
.pdp-gallery-main:hover img { transform: scale(1.12); }
.pdp-gallery-thumbs {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(72px, 1fr));
    gap: .55rem;
}
.pdp-gallery-thumb {
    padding: 0;
    border: 2px solid var(--border, #e3e3e3);
    border-radius: var(--radius-sm, 8px);
    background: #fff;
    cursor: pointer;
    transition: border-color 140ms ease, transform 140ms ease, box-shadow 140ms ease;
    overflow: hidden;
    line-height: 0;
    aspect-ratio: 1/1;
}
.pdp-gallery-thumb:hover { transform: translateY(-2px); box-shadow: 0 4px 10px rgba(0,0,0,.1); }
.pdp-gallery-thumb.active {
    border-color: var(--primary, #c93030);
    box-shadow: 0 0 0 1px var(--primary, #c93030);
}
.pdp-gallery-thumb img { width: 100%; height: 100%; object-fit: contain; display: block; padding: 4px; }

/* Detail-Page Hinweisbox bei Auslaufprodukt */
.pdp-auslauf-warning {
    background: #fff4f4;
    border: 2px solid #c93030;
    border-radius: var(--radius-md, 8px);
    color: #c93030;
    padding: 1em 1.25em;
    margin: 1em 0;
    font-weight: 600;
    font-size: 1rem;
}
.pdp-auslauf-warning::before {
    content: '⚠ ';
    margin-right: .25em;
}

/* ---------- Treatment page lead paragraph polish ---------- */
.treatment-lead { font-size: 1.05rem; line-height: 1.7; color: var(--text); }

/* ---------- behandlungen.php token-aligned overrides ---------- */
.b-hero { background-color: var(--dark-bg); }
.b-hero .btn-hero {
    min-height: var(--touch-min);
    border-radius: var(--radius-pill);
    box-shadow: var(--shadow-md);
}
.b-card { border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); }
.b-card:hover { box-shadow: var(--shadow-md); border-color: var(--gold); }
.b-card-meta .price { color: var(--text-warm); }
.b-faq-item { border-radius: var(--radius-md); }
.b-cta a.btn-cta {
    min-height: var(--touch-min);
    border-radius: var(--radius-pill);
    box-shadow: var(--shadow-md);
}
.b-why-card { border-radius: var(--radius-md); }

/* ---------- Section header centered block (used a lot) ---------- */
.section-head-centered {
    text-align: center;
    max-width: 720px;
    margin: 0 auto var(--sp-7);
}
.section-head-centered.compact { margin-bottom: var(--sp-5); }

/* ---------- Banner-text on dark voucher card (index.php) ---------- */
.banner-card.is-dark { background: var(--black); color: var(--white); }
.banner-card.is-dark h2 { color: var(--primary-soft); }
.banner-card.is-dark h3 { color: var(--white); }
.banner-card.is-dark p  { color: rgba(255,255,255,.85); }

/* ---------- Empty state (basket / shop / blog) ---------- */
.empty-state { text-align: center; padding: var(--sp-7) var(--sp-4); color: var(--muted); }
.empty-state p:first-child { font-size: 1.1rem; margin-bottom: var(--sp-3); }

/* ---------- Soft horizontal divider used in summaries ---------- */
.soft-divider {
    margin: var(--sp-4) 0;
    border: 0;
    border-top: 1px solid var(--border);
}

/* ---------- Misc tiny helpers (extracted from inline) ---------- */
.text-success { color: var(--success); }
.text-alert   { color: var(--alert); }
.fw-500       { font-weight: 500; }
.fw-600       { font-weight: 600; }
.lead-lg      { font-size: 1.15rem; line-height: 1.55; opacity: .95; }
.max-w-520    { max-width: 520px; }
.max-w-720    { max-width: 720px; }
.full-w       { width: 100%; }
.mt-tight     { margin-top: var(--sp-2); }

/* ---------- Card meta total row (basket / checkout summary) ---------- */
.summary-total {
    display: flex;
    justify-content: space-between;
    font-size: 1.15rem;
    font-weight: 500;
}
.summary-total .amount { color: var(--primary); }

/* ---------- Treatment-actions touch + spacing ---------- */
.treatment-actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--sp-2);
    margin: var(--sp-4) 0;
}
.treatment-actions .btn { flex: 1 1 auto; min-width: 160px; }
@media (max-width: 480px) {
    .treatment-actions .btn { flex: 1 1 100%; }
    .treatment-actions .btn + .btn { margin-left: 0; }
}
/* === /FRONTEND POLISH PASS 2 === */


/* =============================================================
   === RIGHT-SIDE PROFILE SIDEBAR 2026-05-01 ===
   3-column dashboard: nav | content | profile
   On mobile (<940px): collapses into a right-side drawer.
   ============================================================= */

/* Avatar — Initials circle in gold gradient */
.profile-avatar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: linear-gradient(135deg, #dabe92 0%, #b89261 100%);
    color: #fff;
    font-weight: 600;
    font-size: 1.15rem;
    letter-spacing: .04em;
    text-transform: uppercase;
    box-shadow: 0 2px 8px rgba(184, 146, 97, .35), inset 0 1px 0 rgba(255,255,255,.25);
    flex: 0 0 auto;
    user-select: none;
}
.profile-avatar.size-sm { width: 36px; height: 36px; font-size: .85rem; }
.profile-avatar.size-lg { width: 72px; height: 72px; font-size: 1.45rem; }

/* Profile Sidebar wrapper */
.profile-sidebar {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: 0;
    padding: 1.25rem 0;
    align-self: start;
    position: sticky;
    top: 80px;
    display: flex;
    flex-direction: column;
    transition: all .24s cubic-bezier(.25,.46,.45,.94);
    overflow: hidden;
}

/* Profile header (avatar + name + email) */
.profile-header {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 0 1.25rem 1rem;
    border-bottom: 1px solid var(--border);
    margin-bottom: .5rem;
    position: relative;
}
.profile-header .profile-name {
    margin-top: .65rem;
    font-weight: 600;
    color: var(--text);
    font-size: .95rem;
    line-height: 1.3;
    word-break: break-word;
}
.profile-header .profile-email {
    color: var(--muted);
    font-size: .76rem;
    margin-top: .15rem;
    word-break: break-all;
}
.profile-admin-badge {
    display: inline-flex;
    align-items: center;
    gap: .3em;
    margin-top: .55rem;
    padding: .2em .6em;
    background: linear-gradient(135deg, #dabe92 0%, #b89261 100%);
    color: #fff;
    font-size: .68rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .06em;
    border-radius: 999px;
}

/* Action button list */
.profile-actions {
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding: .35rem 0;
}
.profile-action {
    display: flex;
    align-items: center;
    gap: .7rem;
    min-height: 44px;
    padding: .65rem 1.25rem;
    color: var(--text);
    font-size: .88rem;
    text-decoration: none;
    border: 0;
    border-left: 3px solid transparent;
    background: transparent;
    cursor: pointer;
    transition: background .2s, color .2s, border-color .2s;
    width: 100%;
    text-align: left;
}
.profile-action .pa-icon {
    font-size: 1.05rem;
    line-height: 1;
    width: 22px;
    text-align: center;
    flex: 0 0 22px;
}
.profile-action .pa-label {
    flex: 1 1 auto;
    line-height: 1.2;
}
.profile-action:hover,
.profile-action:focus-visible {
    background: #fcf7ee;
    color: var(--text-warm);
    border-left-color: #dabe92;
    outline: 0;
}
.profile-action.active {
    background: #fcf7ee;
    color: var(--text-warm);
    border-left-color: #b89261;
    font-weight: 500;
}
.profile-action.danger { color: var(--alert); }
.profile-action.danger:hover {
    background: #fff0f1;
    color: #b81527;
    border-left-color: var(--alert);
}
.profile-divider {
    height: 1px;
    background: var(--border);
    margin: .35rem 1.25rem;
}

/* Collapse toggle on desktop (small chevron in top-right of sidebar) */
.profile-collapse-btn {
    position: absolute;
    top: -.25rem;
    right: -.25rem;
    width: 28px;
    height: 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: 50%;
    color: var(--text-warm);
    cursor: pointer;
    font-size: .85rem;
    line-height: 1;
    transition: all .2s;
    z-index: 2;
}
.profile-collapse-btn:hover {
    background: #fcf7ee;
    border-color: #dabe92;
    color: #b89261;
}

/* Collapsed state (desktop only) — only avatar visible, narrow column */
.dashboard.profile-collapsed {
    grid-template-columns: 240px 1fr 76px;
}
.dashboard.profile-collapsed .profile-sidebar {
    padding: 1rem .25rem;
}
.dashboard.profile-collapsed .profile-header {
    padding: 0 .25rem .75rem;
}
.dashboard.profile-collapsed .profile-name,
.dashboard.profile-collapsed .profile-email,
.dashboard.profile-collapsed .profile-admin-badge,
.dashboard.profile-collapsed .pa-label {
    display: none;
}
.dashboard.profile-collapsed .profile-action {
    justify-content: center;
    padding: .65rem .25rem;
}
.dashboard.profile-collapsed .profile-action .pa-icon {
    width: auto;
    flex: 0 0 auto;
    font-size: 1.2rem;
}
.dashboard.profile-collapsed .profile-divider {
    margin: .35rem .25rem;
}
.dashboard.profile-collapsed .profile-collapse-btn {
    transform: rotate(180deg);
}

/* Profile pill in page-header (small avatar + name) — currently optional */
.profile-pill {
    display: inline-flex;
    align-items: center;
    gap: .55rem;
    padding: .35rem .7rem .35rem .35rem;
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: 999px;
    text-decoration: none;
    color: var(--text);
    font-size: .85rem;
    transition: border-color .2s, background .2s;
}
.profile-pill:hover { border-color: #dabe92; background: #fcf7ee; }
.profile-pill .profile-avatar { box-shadow: none; }

/* Mobile profile-drawer toggle — gold avatar button on the right */
.profile-drawer-toggle { display: none; }
.profile-drawer-backdrop { display: none; }

/* Desktop 3-column layout for dashboard */
@media (min-width: 941px) {
    .dashboard.has-profile-sidebar {
        grid-template-columns: 240px 1fr 280px;
    }
}

/* Mobile: profile-sidebar becomes a right-side drawer */
@media (max-width: 940px) {
    /* Hide the collapse button on mobile */
    .profile-collapse-btn { display: none; }

    /* Right-side avatar button — round gold-gradient */
    .profile-drawer-toggle {
        position: sticky;
        top: 60px;
        z-index: 60;
        margin: .5rem 1rem 0 auto;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 48px;
        height: 48px;
        padding: 0;
        background: linear-gradient(135deg, #dabe92 0%, #b89261 100%);
        border: 0;
        border-radius: 50%;
        color: #fff;
        font-weight: 600;
        font-size: .92rem;
        letter-spacing: .04em;
        text-transform: uppercase;
        cursor: pointer;
        box-shadow: 0 2px 8px rgba(184,146,97,.4), inset 0 1px 0 rgba(255,255,255,.25);
        transition: transform .24s cubic-bezier(.25,.46,.45,.94), box-shadow .24s;
        float: right;
    }
    .profile-drawer-toggle:hover,
    .profile-drawer-toggle:focus-visible {
        transform: scale(1.06);
        box-shadow: 0 4px 14px rgba(184,146,97,.5);
        outline: 0;
    }
    .profile-drawer-toggle.open {
        transform: scale(.92);
    }

    /* Toolbar that holds both hamburger + profile avatar side-by-side */
    .dashboard-toolbar {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: .5rem;
        padding: 0 1rem;
        margin-top: .5rem;
        position: sticky;
        top: 60px;
        z-index: 59;
    }
    .dashboard-toolbar .dashboard-sidebar-toggle,
    .dashboard-toolbar .profile-drawer-toggle {
        margin: 0;
        position: static;
    }

    /* Drawer panel — slides in from the right */
    .profile-sidebar {
        position: fixed;
        top: 0;
        right: 0;
        bottom: 0;
        width: min(86vw, 340px);
        max-width: 86vw;
        align-self: stretch;
        background: var(--white);
        border: 0;
        border-left: 1px solid var(--border);
        box-shadow: -4px 0 24px rgba(0,0,0,.08);
        padding: 4.5rem 0 1.5rem;
        transform: translateX(105%);
        transition: transform .28s cubic-bezier(.25,.46,.45,.94);
        z-index: 70;
        overflow-y: auto;
    }
    .profile-sidebar.open { transform: translateX(0); }

    /* Backdrop (no blur — user request) */
    .profile-drawer-backdrop {
        display: block;
        position: fixed;
        inset: 0;
        background: rgba(0,0,0,.4);
        z-index: 65;
        animation: profileDrawerFadeIn .2s ease;
    }
    .profile-drawer-backdrop[hidden] { display: none; }
    @keyframes profileDrawerFadeIn { from { opacity: 0; } to { opacity: 1; } }

    body.profile-drawer-locked { overflow: hidden; }

    /* In drawer mode, profile-sidebar action items get more breathing room */
    .profile-sidebar .profile-action {
        min-height: 48px;
        padding: .8rem 1.25rem;
    }
}

/* User-theme-dark adaption (parallel to .sidebar dark rule above) */
.user-theme-dark .profile-sidebar { background: var(--white); color: var(--text); }
/* === /RIGHT-SIDE PROFILE SIDEBAR === */

/* =================================================================
   === FRONTEND POLISH PASS 3 — Live-Layout-Fix (User-Reklamation) ===
   ================================================================= */

/* 1. Maincontent + Dashboard volle Breite, Auto-Margin */
.container,
.container-narrow,
.container-default,
.container-wide,
.dashboard,
.breadcrumb {
    max-width: min(100% - 2rem, 1680px);
    width: auto;
}

/* Desktop: Profile-Sidebar AUSBLENDEN (Duplikat der linken Nav)
 * has-profile-sidebar fällt auf 2-Col zurück (240px + 1fr).
 * Mobile (< 1100px): Profile-Sidebar wird Drawer (steuerung in mobile-block) */
.dashboard.has-profile-sidebar {
    display: grid;
    grid-template-columns: 240px minmax(0, 1fr);
    gap: 1.4rem;
    margin: 1.4rem auto;
    padding: 0 1rem;
    align-items: start;
    max-width: min(100% - 1rem, 1880px);
}
@media (min-width: 1101px) {
    .dashboard.has-profile-sidebar > .profile-sidebar,
    .dashboard.has-profile-sidebar .profile-collapse-btn {
        display: none !important;
    }
    .profile-drawer-toggle { display: none !important; }
}

/* 2-Col-Fallback (ohne Profil-Sidebar) */
.dashboard:not(.has-profile-sidebar) {
    grid-template-columns: 240px minmax(0, 1fr);
    gap: 1.4rem;
    margin: 1.4rem auto;
    padding: 0 1rem;
}

/* Dashboard-Main: kein max-width, nur padding */
.dashboard-main {
    padding: 1.4rem 1.6rem;
    min-width: 0;     /* GRID-CHILD overflow-fix */
}
.dashboard-main h1 {
    font-size: 1.6rem;
    margin: 0 0 1rem;
}

/* Header-Bar volle Breite, mit Padding-Auto */
.header-top-inner,
.header-bar,
.breadcrumb {
    max-width: min(100% - 2rem, 1680px);
}

/* Tablet (940-1100px): linke Sidebar weiter sichtbar, Profile-Sidebar als Drawer */
@media (max-width: 1100px) {
    .dashboard.has-profile-sidebar {
        grid-template-columns: 240px minmax(0, 1fr);
    }
    /* Profile-Sidebar nicht im Grid-Flow, nur als Drawer */
    .dashboard.has-profile-sidebar > .profile-sidebar { display: none; }
    .dashboard.has-profile-sidebar > .profile-sidebar.is-open { display: block; }
}
@media (max-width: 940px) {
    .dashboard,
    .dashboard.has-profile-sidebar,
    .dashboard:not(.has-profile-sidebar) {
        grid-template-columns: 1fr;
        padding: 0 .6rem;
    }
    .dashboard-main { padding: 1rem .9rem; }
}

/* 2. Cookie-FAB UNTEN-LINKS entfernen — User-Wunsch */
.aob-cc-fab,
.aob-cc-fab.show {
    display: none !important;
}
/* Footer-Link macht das stattdessen — manueller Re-Open via window.aobConsentOpen() */
.aob-cookie-link {
    display: inline-flex;
    align-items: center;
    gap: .35em;
    color: inherit;
    text-decoration: underline;
    cursor: pointer;
    font: inherit;
    background: 0;
    border: 0;
    padding: 0;
}
.aob-cookie-link:hover { opacity: .8; }

/* 3. Top-Nav bleibt wie im Original — keine Override hier */

/* 4. POS-Layout — Behandlungen-Pill darf NICHT in Cart rutschen */
.pos-shell {
    align-items: start;
    overflow: visible;
}
.pos-toolbar {
    position: relative !important;
    z-index: 5 !important;
}
.pos-tabs {
    flex-wrap: wrap;
    gap: .4rem;
}
.pos-tab,
.pos-tab.active {
    position: relative;
    z-index: 5;
}
.pos-cart {
    position: relative;
    z-index: 4;
}
@media (min-width: 720px) {
    /* Desktop: Tabs sauber als Pill-Reihe oberhalb */
    .pos-toolbar {
        background: transparent;
        border: 0;
        padding: 0 0 .8rem;
        margin: 0 0 .6rem;
    }
    .pos-tabs {
        display: flex;
        flex-wrap: wrap;
    }
}

/* 5. POS-Today-Tile: solide nicht semi-transparent */
.pos-today {
    background: linear-gradient(145deg, var(--soft-bg, #f7efe1), var(--white, #fff)) !important;
    border: 1px solid var(--border, #e7dfcf);
    color: var(--text, #2a2a2a);
    box-shadow: var(--shadow-sm, 0 1px 4px rgba(0,0,0,.08));
}
.pos-today-label,
.pos-today-value {
    color: var(--text);
}
.pos-stat {
    background: var(--white, #fff);
    border: 1px solid var(--border, #e7dfcf);
    color: var(--text);
    box-shadow: var(--shadow-sm, 0 1px 4px rgba(0,0,0,.08));
}
.pos-stat-label, .pos-stat-meta {
    color: var(--muted);
}
.pos-stat-value { color: var(--text); }

/* 6. POS-Head: dunkelgrünen Block aufbrechen */
.pos-head {
    background: linear-gradient(135deg, #1c2429 0%, #2d3942 100%);
    border-radius: var(--radius-lg, 14px);
    padding: 1.4rem 1.6rem;
    color: var(--white, #fff);
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 1.5rem;
    align-items: center;
    margin-bottom: 1rem;
}
.pos-head h1 { color: var(--white); margin: 0 0 .35rem; }

/* 7. Allgemein: Mobile-Drawer-Backdrop weniger creepy (User: nicht gruseliger) */
.dashboard-sidebar-backdrop,
.profile-drawer-backdrop {
    background: rgba(15, 18, 22, .28) !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
}

/* === /POLISH PASS 3 === */


/* =================================================================
   === ADMIN / ACCOUNT POLISH PASS 4 ===
   Append-only — keine bestehenden Regeln modifizieren.
   Tokens: --primary, --gold, --soft-bg, --bg-soft, --border, --text,
            --muted, --white, --alert, --success, --shadow-sm
   ================================================================= */

/* ----------------------------------------------------------------
 * 4.1  Stat-Tile / KPI-Card  ·  einheitliche Optik fuer Dashboard
 * ---------------------------------------------------------------- */
.dashboard-main .service-card.stat-tile,
.dashboard-main .service-card.kpi-tile {
    padding: 1.4rem 1.5rem;
    background: var(--white);
    border: 1px solid var(--border);
    border-top: 3px solid var(--gold);
    border-radius: var(--radius-lg, 14px);
    box-shadow: var(--shadow-sm);
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
    text-decoration: none;
    color: inherit;
    display: flex;
    flex-direction: column;
    min-height: 110px;
}
.dashboard-main .service-card.stat-tile:hover,
.dashboard-main .service-card.kpi-tile:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 22px rgba(0,0,0,.08);
    border-top-color: var(--primary);
}
.dashboard-main .stat-tile-label,
.dashboard-main .kpi-label {
    font-size: .72rem;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: .06em;
    font-weight: 500;
}
.dashboard-main .stat-tile-value,
.dashboard-main .kpi-value {
    font-size: 2.2rem;
    font-weight: 300;
    color: var(--primary);
    line-height: 1.05;
    margin-top: .35rem;
}
.dashboard-main .kpi-value.is-alert { color: var(--alert); }
.dashboard-main .kpi-value.is-success { color: var(--success); }
.dashboard-main .stat-tile-meta,
.dashboard-main .kpi-meta {
    font-size: .78rem;
    color: var(--muted);
    margin-top: .35rem;
}

/* Quick-Action-Bar (Buttons als Cards) */
.dashboard-main .quick-action {
    padding: 1rem 1.1rem;
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg, 14px);
    text-decoration: none;
    color: inherit;
    text-align: center;
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
    display: flex;
    flex-direction: column;
    gap: .35rem;
    align-items: center;
    cursor: pointer;
}
.dashboard-main .quick-action:hover {
    transform: translateY(-2px);
    border-color: var(--gold);
    box-shadow: 0 6px 22px rgba(0,0,0,.08);
}
.dashboard-main .quick-action.is-alert { border-color: var(--alert); }
.dashboard-main .quick-action .qa-icon {
    font-size: 1.5rem;
    line-height: 1;
}
.dashboard-main .quick-action strong {
    font-size: .92rem;
    color: var(--text);
}
.dashboard-main .quick-action p {
    font-size: .75rem;
    color: var(--muted);
    margin: 0;
}

/* ----------------------------------------------------------------
 * 4.2  Filter-Bar / Toolbar  ·  Touch-44px Inputs
 * ---------------------------------------------------------------- */
.dashboard-main .filter-bar,
.dashboard-main .aob-products-toolbar {
    background: var(--soft-bg, #fcfaf6);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg, 14px);
    padding: 1rem 1.15rem;
}
.dashboard-main .filter-bar input[type="text"],
.dashboard-main .filter-bar input[type="search"],
.dashboard-main .filter-bar input[type="date"],
.dashboard-main .filter-bar input[type="number"],
.dashboard-main .filter-bar select,
.dashboard-main .aob-products-toolbar input[type="text"],
.dashboard-main .aob-products-toolbar input[type="search"],
.dashboard-main .aob-products-toolbar select {
    min-height: 44px;
    border: 1px solid var(--border);
    background: var(--white);
    border-radius: 10px;
    padding: .55em .8em;
    font-size: .92rem;
    transition: border-color .15s ease, box-shadow .15s ease;
}
.dashboard-main .filter-bar input:focus,
.dashboard-main .filter-bar select:focus,
.dashboard-main .aob-products-toolbar input:focus,
.dashboard-main .aob-products-toolbar select:focus {
    border-color: var(--gold);
    box-shadow: 0 0 0 3px rgba(218,190,146,.18);
    outline: 0;
}

/* Filter-Pill-Buttons (Vouchers/Coupons "Alle | Aktiv | Eingeloest") */
.dashboard-main .filter-pills {
    display: flex;
    gap: .5rem;
    flex-wrap: wrap;
    margin-bottom: 1rem;
}
.dashboard-main .filter-pills .btn,
.dashboard-main .filter-pills .btn-outline {
    border-radius: 999px;
    padding: .45rem 1rem;
    font-size: .85rem;
    min-height: 36px;
}

/* ----------------------------------------------------------------
 * 4.3  Status-Badges  ·  einheitliche Farb-Sets
 * ---------------------------------------------------------------- */
.dashboard-main .badge,
.dashboard-main .table .badge {
    display: inline-block;
    padding: .25em .7em;
    font-size: .72rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .04em;
    border-radius: 999px;
    line-height: 1.4;
    border: 1px solid transparent;
}
/* Status-Mappings (additiv zu bestehenden .badge-paid etc.) */
.dashboard-main .badge.status-active,
.dashboard-main .badge.status-paid,
.dashboard-main .badge.status-success {
    background: rgba(76,175,80,.12);
    color: #2e7d32;
    border-color: rgba(76,175,80,.3);
}
.dashboard-main .badge.status-pending,
.dashboard-main .badge.status-warn {
    background: rgba(218,190,146,.18);
    color: var(--gold-dark, #8a6d12);
    border-color: rgba(218,190,146,.45);
}
.dashboard-main .badge.status-cancelled,
.dashboard-main .badge.status-expired,
.dashboard-main .badge.status-danger {
    background: rgba(227,33,60,.1);
    color: var(--alert);
    border-color: rgba(227,33,60,.3);
}
.dashboard-main .badge.status-info {
    background: rgba(144,167,172,.18);
    color: var(--primary);
    border-color: rgba(144,167,172,.4);
}
.dashboard-main .badge.status-muted,
.dashboard-main .badge.status-inactive {
    background: var(--bg-soft);
    color: var(--muted);
    border-color: var(--border);
}

/* ----------------------------------------------------------------
 * 4.4  Action-Buttons (Edit / Delete) als Pill mit Hover
 * ---------------------------------------------------------------- */
.dashboard-main .row-actions,
.dashboard-main .table .row-actions,
.dashboard-main td .row-actions {
    display: inline-flex;
    flex-wrap: wrap;
    gap: .35rem;
    align-items: center;
}
.dashboard-main .pill-btn,
.dashboard-main .row-actions > a:not(.btn):not(.aob-tr-btn-icon),
.dashboard-main .row-actions > button:not(.btn):not(.aob-tr-btn-icon),
.dashboard-main .table .row-actions a,
.dashboard-main .table .row-actions button {
    display: inline-flex;
    align-items: center;
    gap: .3em;
    padding: .35rem .8rem;
    font-size: .8rem;
    font-weight: 500;
    line-height: 1.2;
    border: 1px solid var(--border);
    background: var(--white);
    color: var(--text);
    border-radius: 999px;
    text-decoration: none;
    cursor: pointer;
    transition: background .15s, border-color .15s, color .15s, transform .12s;
    min-height: 32px;
}
.dashboard-main .pill-btn:hover,
.dashboard-main .row-actions > a:not(.btn):not(.aob-tr-btn-icon):hover,
.dashboard-main .row-actions > button:not(.btn):not(.aob-tr-btn-icon):hover,
.dashboard-main .table .row-actions a:hover,
.dashboard-main .table .row-actions button:hover {
    background: var(--soft-bg, #fcfaf6);
    border-color: var(--gold);
    color: var(--text);
    transform: translateY(-1px);
}
.dashboard-main .pill-btn.primary,
.dashboard-main .row-actions a.primary,
.dashboard-main .row-actions button.primary {
    background: var(--primary);
    border-color: var(--primary);
    color: var(--white);
}
.dashboard-main .pill-btn.primary:hover,
.dashboard-main .row-actions a.primary:hover,
.dashboard-main .row-actions button.primary:hover {
    background: var(--primary-hover);
    border-color: var(--primary-hover);
    color: var(--white);
}
.dashboard-main .pill-btn.danger,
.dashboard-main .row-actions a.danger,
.dashboard-main .row-actions button.danger {
    color: var(--alert);
    border-color: rgba(227,33,60,.35);
}
.dashboard-main .pill-btn.danger:hover,
.dashboard-main .row-actions a.danger:hover,
.dashboard-main .row-actions button.danger:hover {
    background: rgba(227,33,60,.08);
    border-color: var(--alert);
}

/* "+ Neues" Header-CTA (vereinheitlichen mit Brand-Gold) */
.dashboard-main .aob-btn-new {
    display: inline-flex;
    align-items: center;
    gap: .4em;
    padding: .65em 1.2em;
    background: var(--primary);
    color: var(--white);
    text-decoration: none;
    font-weight: 500;
    border: 1px solid var(--primary);
    border-radius: 999px;
    transition: background .15s, transform .12s, box-shadow .15s;
    min-height: 40px;
    box-shadow: var(--shadow-sm);
}
.dashboard-main .aob-btn-new:hover {
    background: var(--gold);
    border-color: var(--gold);
    color: var(--white);
    transform: translateY(-1px);
}

/* ----------------------------------------------------------------
 * 4.5  Tabellen  ·  konsistenter Card-Border + Mobile-Card-Mode
 * ---------------------------------------------------------------- */
.dashboard-main .table-wrap {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg, 14px);
    overflow: auto;
    box-shadow: var(--shadow-sm);
}
.dashboard-main .table {
    margin: 0;
    border: 0;
}
.dashboard-main .table thead th {
    background: var(--soft-bg, #fcfaf6);
    border-bottom: 1px solid var(--border);
    color: var(--muted);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .05em;
    font-size: .72rem;
    padding: .85rem .8rem;
}
.dashboard-main .table tbody td {
    padding: .85rem .8rem;
    vertical-align: middle;
    border-bottom: 1px solid var(--border);
}
.dashboard-main .table tbody tr:last-child td { border-bottom: 0; }
.dashboard-main .table tbody tr:hover {
    background: rgba(218,190,146,.05);
}

/* aob-products-grid (Produkt-Liste): selber Look */
.dashboard-main .aob-products-grid {
    background: var(--white);
    border-radius: var(--radius-lg, 14px);
}
.dashboard-main .aob-products-grid thead th {
    background: var(--soft-bg, #fcfaf6);
    border-bottom: 1px solid var(--border);
}

/* Mobile: Cards (responsive-cards bestehende Klasse) -- hervorheben */
@media (max-width: 720px) {
    .dashboard-main .table.responsive-cards thead { display: none; }
    .dashboard-main .table.responsive-cards,
    .dashboard-main .table.responsive-cards tbody,
    .dashboard-main .table.responsive-cards tr,
    .dashboard-main .table.responsive-cards td { display: block; width: 100%; }
    .dashboard-main .table.responsive-cards tr {
        background: var(--white);
        border: 1px solid var(--border);
        border-radius: var(--radius-lg, 14px);
        margin-bottom: .8rem;
        padding: .9rem 1rem;
        box-shadow: var(--shadow-sm);
    }
    .dashboard-main .table.responsive-cards tr:hover { background: var(--white); }
    .dashboard-main .table.responsive-cards td {
        border: 0;
        padding: .35rem 0;
        display: flex;
        justify-content: space-between;
        gap: 1rem;
        align-items: flex-start;
    }
    .dashboard-main .table.responsive-cards td::before {
        content: attr(data-label);
        font-size: .7rem;
        text-transform: uppercase;
        letter-spacing: .05em;
        color: var(--muted);
        font-weight: 600;
        flex-shrink: 0;
        max-width: 40%;
    }
    .dashboard-main .table.responsive-cards td:not([data-label])::before { content: ""; }
}

/* ----------------------------------------------------------------
 * 4.6  Settings-Page  ·  Tabs / Sektionen / Form-Layout
 * ---------------------------------------------------------------- */
.dashboard-main .settings-tabs,
.dashboard-main .nav-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: .35rem;
    border-bottom: 1px solid var(--border);
    margin: 0 0 1.5rem;
    padding: 0 0 .35rem;
}
.dashboard-main .settings-tabs a,
.dashboard-main .settings-tabs button,
.dashboard-main .nav-tabs a,
.dashboard-main .nav-tabs button {
    display: inline-flex;
    align-items: center;
    gap: .35em;
    padding: .55rem 1rem;
    font-size: .88rem;
    font-weight: 500;
    color: var(--muted);
    background: transparent;
    border: 1px solid transparent;
    border-radius: 999px 999px 0 0;
    text-decoration: none;
    cursor: pointer;
    transition: color .15s, background .15s, border-color .15s;
}
.dashboard-main .settings-tabs a:hover,
.dashboard-main .nav-tabs a:hover,
.dashboard-main .settings-tabs button:hover {
    color: var(--text);
    background: var(--soft-bg, #fcfaf6);
}
.dashboard-main .settings-tabs a.active,
.dashboard-main .settings-tabs button.active,
.dashboard-main .nav-tabs a.active {
    color: var(--primary);
    background: var(--white);
    border-color: var(--border);
    border-bottom-color: var(--white);
    margin-bottom: -1px;
}

.dashboard-main .settings-section,
.dashboard-main .profile-section {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg, 14px);
    padding: 1.4rem 1.5rem;
    margin-bottom: 1.4rem;
    box-shadow: var(--shadow-sm);
}
.dashboard-main .settings-section h3,
.dashboard-main .profile-section h3 {
    margin-top: 0;
    color: var(--primary);
    font-size: 1.05rem;
    border-bottom: 1px solid var(--border);
    padding-bottom: .65rem;
    margin-bottom: 1rem;
}

/* Forms: Touch-44px + sanftes Focus */
.dashboard-main .form-group input[type="text"],
.dashboard-main .form-group input[type="email"],
.dashboard-main .form-group input[type="tel"],
.dashboard-main .form-group input[type="password"],
.dashboard-main .form-group input[type="number"],
.dashboard-main .form-group input[type="date"],
.dashboard-main .form-group input[type="search"],
.dashboard-main .form-group input[type="url"],
.dashboard-main .form-group select,
.dashboard-main .form-group textarea {
    min-height: 44px;
    border-radius: 10px;
    border: 1px solid var(--border);
    transition: border-color .15s ease, box-shadow .15s ease;
}
.dashboard-main .form-group textarea { min-height: 96px; }
.dashboard-main .form-group input:focus,
.dashboard-main .form-group select:focus,
.dashboard-main .form-group textarea:focus {
    border-color: var(--gold);
    box-shadow: 0 0 0 3px rgba(218,190,146,.18);
    outline: 0;
}

/* "details > summary" Akkordeons (Voucher-Create, Coupon-Create) */
.dashboard-main details {
    border-radius: var(--radius-lg, 14px);
    border: 1px solid var(--border);
    background: var(--soft-bg, #fcfaf6) !important;
    overflow: hidden;
    transition: box-shadow .18s ease;
}
.dashboard-main details[open] { box-shadow: var(--shadow-sm); }
.dashboard-main details > summary {
    padding: .9rem 1.1rem;
    font-weight: 500;
    color: var(--primary);
    cursor: pointer;
}
.dashboard-main details > summary:hover { color: var(--text); }
.dashboard-main details[open] > summary {
    border-bottom: 1px solid var(--border);
    background: var(--white);
}

/* ----------------------------------------------------------------
 * 4.7  ACCOUNT  ·  Profil-Sektionen, Loyalty-Tier, Stat-Cards
 * ---------------------------------------------------------------- */
#accountDashboard .dashboard-main .service-card {
    border-radius: var(--radius-lg, 14px);
    border: 1px solid var(--border);
    background: var(--white);
    box-shadow: var(--shadow-sm);
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
#accountDashboard .dashboard-main .service-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 22px rgba(0,0,0,.08);
    border-color: var(--gold);
}

/* Loyalty: Tier-Karte gold akzentuiert */
#accountDashboard .dashboard-main .service-card[style*="linear-gradient"] {
    border-top: 3px solid var(--gold);
}

/* Notifications-Switches (Toggle) */
.dashboard-main .notif-toggle,
.dashboard-main .toggle-switch {
    position: relative;
    display: inline-block;
    width: 44px;
    height: 24px;
}
.dashboard-main .notif-toggle input,
.dashboard-main .toggle-switch input {
    opacity: 0;
    width: 0;
    height: 0;
}
.dashboard-main .notif-toggle .slider,
.dashboard-main .toggle-switch .slider {
    position: absolute;
    cursor: pointer;
    inset: 0;
    background: var(--border);
    border-radius: 999px;
    transition: background .2s;
}
.dashboard-main .notif-toggle .slider::before,
.dashboard-main .toggle-switch .slider::before {
    content: "";
    position: absolute;
    width: 18px;
    height: 18px;
    left: 3px;
    top: 3px;
    background: var(--white);
    border-radius: 50%;
    transition: transform .2s;
    box-shadow: 0 1px 3px rgba(0,0,0,.18);
}
.dashboard-main .notif-toggle input:checked + .slider,
.dashboard-main .toggle-switch input:checked + .slider {
    background: var(--gold);
}
.dashboard-main .notif-toggle input:checked + .slider::before,
.dashboard-main .toggle-switch input:checked + .slider::before {
    transform: translateX(20px);
}

/* ----------------------------------------------------------------
 * 4.8  POS  ·  Tile-Spacing, Tab-Hover, Cart-Items, Sticky-Cart
 * ---------------------------------------------------------------- */
.pos-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: .85rem;
    margin: .25rem 0 1.1rem;
}
.pos-stat {
    padding: 1rem 1.1rem;
    border-radius: var(--radius-lg, 14px);
    display: flex;
    flex-direction: column;
    gap: .15rem;
    transition: transform .15s ease, box-shadow .15s ease;
}
.pos-stat:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 14px rgba(0,0,0,.07);
}
.pos-stat .pos-stat-label {
    font-size: .7rem;
    text-transform: uppercase;
    letter-spacing: .06em;
    font-weight: 500;
}
.pos-stat .pos-stat-value {
    font-size: 1.4rem;
    font-weight: 400;
}
.pos-stat .pos-stat-meta {
    font-size: .72rem;
}

/* POS-Tabs: smooth Hover */
.pos-tab {
    border-radius: 999px !important;
    padding: .55rem 1.05rem !important;
    transition: background .15s ease, color .15s ease, border-color .15s ease, transform .12s !important;
    min-height: 38px;
}
.pos-tab:hover:not(.active) {
    background: var(--soft-bg, #fcfaf6) !important;
    color: var(--text) !important;
    transform: translateY(-1px);
}
.pos-tab.active {
    background: var(--primary) !important;
    color: var(--white) !important;
    border-color: var(--primary) !important;
    box-shadow: 0 2px 8px rgba(144,167,172,.3);
}

/* POS-Tile: subtileres Hover */
.pos-tile.pos-quick {
    transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.pos-tile.pos-quick:hover {
    transform: translateY(-2px);
    border-color: var(--gold);
    box-shadow: 0 6px 18px rgba(0,0,0,.08);
}
.pos-tile-tag {
    background: rgba(218,190,146,.18) !important;
    color: var(--gold-dark, #8a6d12) !important;
    border-radius: 999px;
    padding: .12em .55em;
    font-size: .65rem;
    font-weight: 600;
    letter-spacing: .04em;
    text-transform: uppercase;
}

/* POS-Cart: sticky am Desktop, Cart-Items: feinere Trenner */
@media (min-width: 1100px) {
    .pos-cart {
        position: sticky;
        top: 1rem;
        max-height: calc(100vh - 2rem);
        overflow-y: auto;
        align-self: start;
    }
}
.pos-cart-item {
    border-bottom: 1px solid var(--border);
    transition: background .12s ease;
}
.pos-cart-item:last-child { border-bottom: 0; }
.pos-cart-item:hover { background: var(--soft-bg, #fcfaf6); }

/* POS-Today (am Desktop voll sichtbar, am Mobile kompakt) */
.pos-today {
    border-radius: var(--radius-lg, 14px);
    padding: 1rem 1.2rem;
    min-width: 160px;
    text-align: right;
}
.pos-today-label {
    font-size: .7rem;
    text-transform: uppercase;
    letter-spacing: .06em;
    font-weight: 500;
    opacity: .85;
}
.pos-today-value {
    font-size: 1.6rem;
    font-weight: 400;
    margin-top: .15rem;
}

/* POS-Kopf: Mobile-Stack */
@media (max-width: 720px) {
    .pos-head {
        grid-template-columns: 1fr !important;
        text-align: left;
    }
    .pos-today { text-align: left; }
}

/* ----------------------------------------------------------------
 * 4.9  Treatments-Admin Cards (services-list)  ·  Hover smooth
 * ---------------------------------------------------------------- */
.dashboard-main .aob-tr-card {
    border-radius: var(--radius-lg, 14px);
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.dashboard-main .aob-tr-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 22px rgba(0,0,0,.08);
    border-color: var(--gold);
}
.dashboard-main .aob-tr-btn-icon {
    border-radius: 999px;
    transition: background .15s, border-color .15s, transform .12s;
}
.dashboard-main .aob-tr-btn-icon:hover {
    border-color: var(--gold);
    transform: translateY(-1px);
}
.dashboard-main .aob-tr-btn-icon.primary {
    background: var(--primary);
    border-color: var(--primary);
    color: var(--white);
}
.dashboard-main .aob-tr-btn-icon.primary:hover {
    background: var(--gold);
    border-color: var(--gold);
}

/* Treatments-Stats Strip */
.dashboard-main .aob-tr-stats {
    background: var(--soft-bg, #fcfaf6);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg, 14px);
    padding: .85rem 1rem;
}

/* ----------------------------------------------------------------
 * 4.10  Flex-between Header (Listen-Header mit Suche)
 * ---------------------------------------------------------------- */
.dashboard-main .flex-between {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
    margin-bottom: 1.1rem;
}
.dashboard-main .flex-between h1 { margin: 0; }
.dashboard-main .flex-between form input[type="search"] {
    min-height: 40px;
    border-radius: 999px;
    padding-left: 1rem;
    border: 1px solid var(--border);
    background: var(--white);
}
.dashboard-main .flex-between form input[type="search"]:focus {
    border-color: var(--gold);
    box-shadow: 0 0 0 3px rgba(218,190,146,.18);
    outline: 0;
}

/* ----------------------------------------------------------------
 * 4.11  Profile-Sidebar (rechts, im Drawer): Action-Hover
 * ---------------------------------------------------------------- */
.profile-actions .profile-action {
    border-radius: 10px;
    transition: background .15s, transform .12s, color .15s;
}
.profile-actions .profile-action:hover {
    background: var(--soft-bg, #fcfaf6);
    transform: translateX(2px);
}
.profile-actions .profile-action.active {
    background: rgba(218,190,146,.18);
    color: var(--gold-dark, #8a6d12);
}
.profile-actions .profile-action.danger:hover {
    background: rgba(227,33,60,.08);
    color: var(--alert);
}

/* === /ADMIN / ACCOUNT POLISH PASS 4 === */


/* ================================================================
 * === POLISH PASS 5 — DETAIL-PAGES (Bon, Termin, Kunde, Order) ===
 * Append-only. Hands-off zu Pass 1-4. Token-only Farben.
 * Bug-Reports: Layout verrutscht am PC + Handy in /admin/bon_view.
 * ================================================================ */

/* Header block: Titel links, Action-Buttons rechts, mobile gestapelt */
.dashboard-main .detail-head {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem 1.5rem;
    margin: 0 0 1.25rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--border);
}
.dashboard-main .detail-head-info {
    flex: 1 1 280px;
    min-width: 0; /* avoid overflow when long titles */
}
.dashboard-main .detail-head-info .detail-back {
    display: inline-block;
    font-size: .85rem;
    color: var(--muted);
    margin-bottom: .25rem;
    text-decoration: none;
}
.dashboard-main .detail-head-info .detail-back:hover { color: var(--primary); }
.dashboard-main .detail-head-info h1 {
    margin: .15rem 0 .35rem;
    font-size: 1.55rem;
    font-weight: 500;
    line-height: 1.25;
    color: var(--text);
    overflow-wrap: break-word;
}
.dashboard-main .detail-head-info .detail-meta {
    margin: 0;
    color: var(--muted);
    font-size: .9rem;
    line-height: 1.5;
}
.dashboard-main .detail-head-info .detail-meta a { color: var(--primary); }

.dashboard-main .detail-head .row-actions {
    flex: 0 0 auto;
    flex-wrap: wrap;
    justify-content: flex-end;
}

/* Status-Badges (success / paid / pending / alert / muted) */
.dashboard-main .status-badge {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: .3rem .7rem;
    border-radius: 999px;
    font-size: .8rem;
    font-weight: 500;
    line-height: 1;
    background: var(--bg-soft, #f8f8f8);
    color: var(--text);
    border: 1px solid var(--border);
    white-space: nowrap;
}
.dashboard-main .status-badge.status-paid,
.dashboard-main .status-badge.status-success,
.dashboard-main .status-badge.status-confirmed {
    background: rgba(76,175,80,.12);
    color: var(--success);
    border-color: rgba(76,175,80,.25);
}
.dashboard-main .status-badge.status-pending,
.dashboard-main .status-badge.status-warn {
    background: rgba(218,190,146,.18);
    color: var(--gold-dark, #8a6d12);
    border-color: rgba(218,190,146,.4);
}
.dashboard-main .status-badge.status-alert,
.dashboard-main .status-badge.status-cancelled,
.dashboard-main .status-badge.status-error {
    background: rgba(227,33,60,.08);
    color: var(--alert);
    border-color: rgba(227,33,60,.2);
}
.dashboard-main .status-badge.status-muted {
    background: var(--bg-soft, #f8f8f8);
    color: var(--muted);
}

/* Grid: Hauptcontent links, Sidebar rechts; mobile stackt komplett */
.dashboard-main .detail-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
    gap: 1.5rem;
    margin-top: 1rem;
    align-items: start;
}
.dashboard-main .detail-grid > .detail-main { min-width: 0; }
.dashboard-main .detail-grid > .detail-side { min-width: 0; }
.dashboard-main .detail-grid.detail-grid--equal {
    grid-template-columns: 1fr 1fr;
}
.dashboard-main .detail-grid.detail-grid--single {
    grid-template-columns: 1fr;
}
@media (max-width: 960px) {
    .dashboard-main .detail-grid {
        grid-template-columns: 1fr;
        gap: 1.25rem;
    }
}

/* Detail-Card: einheitlich, ersetzt Inline-padding/border-Spam */
.dashboard-main .detail-card {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 1.25rem 1.4rem;
    box-shadow: var(--shadow-sm, 0 1px 3px rgba(0,0,0,.04));
    overflow: hidden; /* Inhalt clippen, NIE überfließen lassen */
    min-width: 0;
}
.dashboard-main .detail-card + .detail-card { margin-top: 1rem; }
.dashboard-main .detail-card > h2,
.dashboard-main .detail-card > h3 {
    margin: 0 0 .9rem;
    font-size: 1.05rem;
    font-weight: 500;
    color: var(--text);
    line-height: 1.3;
    display: flex;
    align-items: center;
    gap: .4rem;
    flex-wrap: wrap;
}
.dashboard-main .detail-card > p { color: var(--muted); font-size: .9rem; line-height: 1.5; }
.dashboard-main .detail-card.detail-card--alert {
    border-left: 3px solid var(--alert);
    background: linear-gradient(to right, rgba(227,33,60,.04), transparent 40%);
}
.dashboard-main .detail-card.detail-card--gold {
    border-left: 3px solid var(--gold);
}
.dashboard-main .detail-card.detail-card--success {
    border-left: 3px solid var(--success);
}

/* Bon-Display (Receipt-style): font + max-width damit lange Titel umbrechen */
.dashboard-main .detail-card--receipt {
    background: var(--white);
    font-family: 'SF Mono', Menlo, Consolas, monospace;
    padding: 1.4rem 1.4rem;
}
.dashboard-main .detail-card--receipt * { word-break: break-word; }
.dashboard-main .detail-card--receipt table { width: 100%; }

/* Status-Tabellen innerhalb von detail-card */
.dashboard-main .detail-card .kv-table {
    width: 100%;
    border-collapse: collapse;
    font-size: .9rem;
}
.dashboard-main .detail-card .kv-table tr + tr td { border-top: 1px solid var(--border); }
.dashboard-main .detail-card .kv-table td {
    padding: .5rem 0;
    vertical-align: top;
}
.dashboard-main .detail-card .kv-table td:first-child {
    color: var(--muted);
    width: 45%;
    padding-right: 1rem;
}
.dashboard-main .detail-card .kv-table td:last-child {
    text-align: right;
    color: var(--text);
}

/* KPI-Stats Grid (4 Mini-Cards) */
.dashboard-main .detail-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
    gap: .85rem;
    margin: 1.25rem 0 0;
}
.dashboard-main .detail-stats .detail-stat {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: .9rem 1rem;
    min-width: 0;
}
.dashboard-main .detail-stats .detail-stat-label {
    font-size: .72rem;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: .05em;
    margin: 0 0 .2rem;
}
.dashboard-main .detail-stats .detail-stat-value {
    font-size: 1.5rem;
    font-weight: 500;
    color: var(--primary);
    line-height: 1.1;
    word-break: break-word;
}
.dashboard-main .detail-stats .detail-stat-sub {
    margin-top: .25rem;
    color: var(--muted);
    font-size: .75rem;
}

/* Form innerhalb detail-card: Inputs füllen sauber & überlaufen nicht */
.dashboard-main .detail-card form input[type="email"],
.dashboard-main .detail-card form input[type="text"],
.dashboard-main .detail-card form textarea {
    width: 100%;
    box-sizing: border-box;
    margin: 0 0 .55rem;
}
.dashboard-main .detail-card form .form-row-stack {
    display: flex;
    flex-direction: column;
    gap: .55rem;
    margin: 0;
}
.dashboard-main .detail-card form .form-row-stack .pill-btn,
.dashboard-main .detail-card form .form-row-stack .btn {
    width: 100%;
    justify-content: center;
}

/* QR-Wrapper: zentriert, nie breiter als Card */
.dashboard-main .detail-qr {
    text-align: center;
}
.dashboard-main .detail-qr img {
    max-width: 100%;
    width: 240px;
    height: auto;
    display: block;
    margin: .6rem auto;
    border-radius: 6px;
}
.dashboard-main .detail-qr small {
    color: var(--muted);
    font-size: .78rem;
    line-height: 1.4;
    display: block;
}

/* Mobile-Refinements (≤720px) */
@media (max-width: 720px) {
    .dashboard-main .detail-head {
        margin-bottom: 1rem;
        padding-bottom: .85rem;
    }
    .dashboard-main .detail-head-info h1 {
        font-size: 1.3rem;
    }
    .dashboard-main .detail-head-info .detail-meta {
        font-size: .85rem;
    }
    .dashboard-main .detail-head .row-actions {
        width: 100%;
        justify-content: flex-start;
    }
    .dashboard-main .detail-card {
        padding: 1rem 1.05rem;
        border-radius: 10px;
    }
    .dashboard-main .detail-card > h2,
    .dashboard-main .detail-card > h3 {
        font-size: 1rem;
    }
    .dashboard-main .detail-stats {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: .6rem;
    }
    .dashboard-main .detail-stats .detail-stat-value {
        font-size: 1.25rem;
    }
    .dashboard-main .detail-card .kv-table td:first-child { width: 50%; }
    .dashboard-main .detail-card--receipt {
        padding: 1.05rem 1rem;
        font-size: .9rem;
    }
}

/* === Receipt-Print-Page Polishing (pos_receipt.php) === */
.aob-receipt-page {
    font-family: 'SF Mono', Menlo, Consolas, monospace;
    font-size: 11pt;
    background: var(--bg-soft, #eee);
    margin: 0;
    padding: 20px;
    color: #000;
}
.aob-receipt-page .receipt {
    max-width: 360px;
    margin: 0 auto;
    background: #fff;
    padding: 20px 22px;
    box-shadow: 0 4px 20px rgba(0,0,0,.15);
    border-radius: 4px;
}
.aob-receipt-page .receipt * { word-break: break-word; }
.aob-receipt-page .receipt .center { text-align: center; }
.aob-receipt-page .receipt .biz { font-weight: bold; font-size: 13pt; }
.aob-receipt-page .receipt .small { font-size: 9pt; }
.aob-receipt-page .receipt hr { border: 0; border-top: 1px dashed #888; margin: 10px 0; }
.aob-receipt-page .receipt table { width: 100%; border-collapse: collapse; font-size: 10.5pt; }
.aob-receipt-page .receipt td { padding: 2px 0; vertical-align: top; }
.aob-receipt-page .receipt .right { text-align: right; }
.aob-receipt-page .receipt .total-row td {
    font-weight: bold;
    font-size: 13pt;
    padding-top: 8px;
    border-top: 2px solid #000;
}
.aob-receipt-page .receipt .voucher-card {
    border: 2px dashed var(--gold, #dabe92);
    padding: 14px;
    margin-top: 12px;
    text-align: center;
    background: #fff8e6;
    border-radius: 6px;
}
.aob-receipt-page .receipt .voucher-code {
    font-size: 14pt;
    font-weight: bold;
    letter-spacing: .15em;
    margin: 6px 0;
    word-break: break-all;
}
.aob-receipt-page .actions {
    max-width: 360px;
    margin: 14px auto;
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
}
.aob-receipt-page .actions a,
.aob-receipt-page .actions button {
    flex: 1 1 90px;
    padding: 10px 8px;
    background: var(--primary);
    color: #fff;
    border: 0;
    border-radius: 6px;
    text-decoration: none;
    text-align: center;
    cursor: pointer;
    font-family: inherit;
    font-size: 11pt;
    transition: background .15s;
}
.aob-receipt-page .actions a:hover,
.aob-receipt-page .actions button:hover { background: var(--primary-dark, #7a9499); }

@media (max-width: 480px) {
    .aob-receipt-page { padding: 10px; }
    .aob-receipt-page .receipt { padding: 16px 16px; max-width: 100%; }
    .aob-receipt-page .actions { max-width: 100%; }
}
@media print {
    .aob-receipt-page { background: #fff; padding: 0; }
    .aob-receipt-page .receipt { box-shadow: none; max-width: 80mm; padding: 4mm; border-radius: 0; }
    .aob-receipt-page .actions { display: none; }
    @page { size: 80mm auto; margin: 5mm; }
}

/* Bon-Print-Mode (within bon_view, when ?print=1) */
.aob-bon-print-mode body * { visibility: hidden !important; }
.aob-bon-print-mode .detail-card--receipt,
.aob-bon-print-mode .detail-card--receipt * { visibility: visible !important; }
.aob-bon-print-mode .detail-card--receipt {
    position: absolute !important;
    left: 0 !important;
    top: 0 !important;
    width: 100% !important;
    border: 0 !important;
    box-shadow: none !important;
}
@media print {
    .aob-bon-print-mode @page { size: 80mm auto; margin: 5mm; }
}

/* === /POLISH PASS 5 — DETAIL-PAGES === */

/* === AVATAR-IMG ===
   Render <img> inside profile-avatar and the round drawer-toggle as
   a perfect circle that covers the whole circle area. Append-only. */
.profile-avatar { overflow: hidden; }
.profile-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 50%;
    display: block;
}
.profile-drawer-toggle { overflow: hidden; padding: 0; }
.profile-drawer-toggle img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 50%;
    display: block;
}
/* === /AVATAR-IMG === */

/* =================================================================
   === POLISH PASS 6 — WhatsApp-FAB Bottom-Nav-Abstand ============
   User-Beschwerde: WhatsApp-Button liegt auf Handy unter
   Start/Buchen/Shop/Konto-Buttons. 25–50 px Abstand zur Bottom-Leiste.
   Bottom-Nav-Höhe: 56px + safe-area-inset.
   ================================================================= */
@media (max-width: 940px) {
    .aob-wa-fab {
        bottom: calc(56px + 25px + env(safe-area-inset-bottom)) !important;
        right: 14px !important;
    }
    .aob-wa-panel {
        bottom: calc(56px + 80px + env(safe-area-inset-bottom)) !important;
        max-height: calc(78vh - 56px) !important;
    }
}
@media (max-width: 480px) {
    .aob-wa-fab {
        bottom: calc(56px + 25px + env(safe-area-inset-bottom)) !important;
    }
}
/* === /POLISH PASS 6 === */

/* =================================================================
   === POLISH PASS 7 — Lesbare Errors / Login-Feedback auf Mobile ==
   User-Beschwerde: Login-Error zu klein, nicht lesbar auf Smartphone
   ================================================================= */
@media (max-width: 720px) {
    .alert {
        font-size: 1rem !important;
        padding: 1.1rem 1rem !important;
        line-height: 1.45 !important;
    }
    .alert strong { font-size: 1.05em; }

    .field-error {
        font-size: .92rem !important;
        font-weight: 500;
        margin-top: .35rem !important;
        padding: .35rem .55rem;
        background: rgba(227, 33, 60, .08);
        border-left: 3px solid var(--alert);
        border-radius: 4px;
    }

    /* Login-Form: Inputs & Labels groß genug für Phone */
    .form-group label {
        font-size: 1rem !important;
        font-weight: 500;
        margin-bottom: .35rem;
    }
    .form-group input[type="email"],
    .form-group input[type="password"],
    .form-group input[type="text"],
    .form-group input[type="tel"] {
        font-size: 16px !important;   /* iOS würde sonst Auto-Zoom auslösen bei < 16px */
        min-height: 48px;
        padding: .7rem .9rem;
    }
    .btn.btn-block { min-height: 48px; font-size: 1rem; }
}

/* Größere Tap-Targets für mobile Buttons (alle Login/Account-Forms) */
@media (max-width: 480px) {
    .alert { font-size: 1.05rem !important; }
    .field-error { font-size: 1rem !important; }
}
/* === /POLISH PASS 7 === */

/* ===================================================================
   POLISH PASS 8 — Responsive Feinschliff + Shop-Sidebar (Mobil/Tablet/PC)
   Rein additiv: verfeinert vorhandene Komponenten, bricht kein Layout.
   =================================================================== */

/* -- Shop-Sidebar: weicheres Karten-Design -- */
.shop-sidebar {
    border-radius: 14px;
    box-shadow: 0 2px 14px rgba(0,0,0,.05);
    border-color: #ececec !important;
}
.shop-sidebar h3 { letter-spacing:.06em; }

/* -- Linien-Accordion: edler -- */
.shop-linenav details {
    border-radius: 10px;
    transition: border-color .18s ease, box-shadow .18s ease;
}
.shop-linenav details[open] { box-shadow: 0 2px 10px rgba(201,48,48,.08); }
.shop-linenav summary { transition: background .15s ease; }
.shop-linenav summary:hover { background:#faf6f6; }
.shop-linenav .ln-line { transition: background .12s ease, padding-left .12s ease; }
.shop-linenav .ln-line:hover { padding-left:.85rem; }

/* -- Produktraster: flüssig responsiv -- */
.product-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
    gap: 1.4rem;
}
.product-card {
    border-radius: 12px;
    transition: transform .2s ease, box-shadow .2s ease;
}
.product-card:hover { transform: translateY(-4px); box-shadow: 0 8px 22px rgba(0,0,0,.1); }

/* -- Varianten-Auswahl: touch-freundliche Mindestgrößen -- */
.pdp-variant-opt { min-height: 44px; }
.pdp-variant-opt.shade { width: 48px; height: 48px; }

/* ---------- Tablet (bis 980px) ---------- */
@media (max-width: 980px) {
    .product-grid { grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 1.1rem; }
    .shop-layout { gap: 1.3rem; }
    .split { gap: 1.5rem; }
}

/* ---------- Mobil (bis 640px) ---------- */
@media (max-width: 640px) {
    .product-grid { grid-template-columns: repeat(2, 1fr); gap: .8rem; }
    .product-card .product-body { padding: .7rem .8rem 1rem; }
    .product-title { font-size: .92rem; line-height: 1.3; }
    .product-price { font-size: 1rem; }
    /* Shop-Sidebar wird oben gestapelt, kompakter */
    .shop-sidebar { padding: 1rem; border-radius: 12px; }
    .shop-sidebar h3 { font-size: .85rem; }
    /* PDP: Galerie + Text untereinander */
    .split { grid-template-columns: 1fr !important; }
    .pdp-gallery-thumbs { grid-template-columns: repeat(auto-fill, minmax(58px, 1fr)); }
    .pdp-variant-options { gap: .45rem; }
    /* Toolbar / Filter umbrechen */
    .shop-toolbar { flex-direction: column; align-items: stretch; gap: .6rem; }
    h1 { font-size: clamp(1.6rem, 6vw, 2.1rem); }
    /* Tabellen im Account/Admin horizontal scrollbar statt zerquetscht */
    .aob-products-wrap, .user-table-wrap, .table-responsive { overflow-x: auto; -webkit-overflow-scrolling: touch; }
}

/* ---------- Sehr klein (bis 380px) ---------- */
@media (max-width: 380px) {
    .product-grid { grid-template-columns: 1fr; }
}

/* -- Touch: größere Tap-Ziele für Buttons/Links in Navigation -- */
@media (hover: none) and (pointer: coarse) {
    .btn, .shop-cat-chip, .ln-line, .pdp-gallery-thumb { min-height: 44px; }
}
/* === /POLISH PASS 8 === */



/* ===================================================================
   RESPONSIVE FIX — BLOCK 1   (an site.css anhaengen)
   -------------------------------------------------------------------
   Rein additiv. Verfeinert das oeffentliche Frontend (Startseite,
   Behandlungs-Seiten, Blog, Ueber-mich, Termine-Kontakt, Angebote).
   Bricht keine bestehenden Layouts; nichts dupliziert, was POLISH
   PASS 8 oder mobile-enhance.css bereits abdeckt.
   Breakpoints bewusst nur bei 980px (Tablet) und 640px (Mobil) —
   passend zu POLISH PASS 8.
   =================================================================== */


/* -------------------------------------------------------------------
   1) behandlungen.php — Behandlungs-Raster (.b-grid)
   Problem: .b-grid nutzt minmax(320px,1fr). Auf schmalen Phones
   (Viewport ~320-360px) ist die 320px-Mindestbreite breiter als die
   verfuegbare Spalte -> die Karte kann horizontal ueberlaufen.
   Fix: Mindestbreite auf Mobil herabsetzen, sodass die Karte sauch
   auf 320px-Geraeten sauber in eine Spalte passt. (Die Seiten-eigene
   Inline-@media bei 600px regelt nur Padding, nicht das minmax.)
   ------------------------------------------------------------------- */
@media (max-width: 640px) {
    .b-grid {
        grid-template-columns: 1fr;
        gap: 1.1rem;
    }
}

/* -------------------------------------------------------------------
   2) behandlungen.php — Hero (.b-hero)
   Problem: padding 6rem/5rem (oben/unten) frisst auf dem Handy sehr
   viel vertikalen Platz, bevor man Inhalt sieht; min-height:54vh
   addiert sich dazu.
   Fix: vertikale Innenabstaende auf Mobil reduzieren.
   ------------------------------------------------------------------- */
@media (max-width: 640px) {
    .b-hero {
        padding: 3.5rem 1rem 3rem;
        min-height: 42vh;
    }
    .b-hero p { font-size: 1.02rem; }
}

/* -------------------------------------------------------------------
   3) behandlungen.php — Filter-Buttons (.b-filter)
   Problem: Die Filter-Pills sind nur min-height:38px (Seiten-CSS) und
   auf Mobil per Inline-@media noch kleiner -> unter dem 44px-Tap-
   Richtwert. Bei vielen Pills wird die Reihe zudem eng.
   Fix: komfortablere Tap-Hoehe auf Touch-Geraeten, ohne das
   Desktop-Aussehen zu aendern.
   ------------------------------------------------------------------- */
@media (max-width: 640px) {
    .b-filter button {
        min-height: 40px;
        padding-top: .5em;
        padding-bottom: .5em;
    }
}

/* -------------------------------------------------------------------
   4) Treatment-Seiten — Vorher/Nachher-Galerien
   (microneedling-trier.php, plasma-pen.php, biorepeel-trier.php,
   angebote-trier.php nutzen .services-grid + viele .collage-thumb)
   Problem: .collage-thumb hat in site.css :nth-child(1..4) feste
   rotate()-Transforms + Drift-Animation. Das ist fuer die 4-teilige
   About-/Service-Collage gedacht. In den grossen VN-Galerien werden
   so willkuerlich nur die ersten 4 Bilder schraeg gestellt — wirkt
   auf Mobil unruhig und kann Bilder leicht aus der Spalte kippen.
   Fix: Innerhalb von .services-grid die Rotation/Animation neutral
   stellen (gerade ausgerichtete, ruhige Galerie). Greift nur, wenn
   .collage-thumb tatsaechlich in einem .services-grid liegt — die
   echte 4er-Collage (.collage .collage-thumbs) bleibt unberuehrt.
   ------------------------------------------------------------------- */
.services-grid > .collage-thumb,
.services-grid > .collage-thumb:nth-child(1),
.services-grid > .collage-thumb:nth-child(2),
.services-grid > .collage-thumb:nth-child(3),
.services-grid > .collage-thumb:nth-child(4) {
    transform: none;
    margin-bottom: 0;
    animation: none;
}
.services-grid > .collage-thumb:hover {
    transform: translateY(-3px);
}

/* -------------------------------------------------------------------
   5) Treatment-Seiten — Galerie-Thumbnails als echte Tap-Ziele
   (biorepeel-trier.php: .gallery-thumbs Inline-Grid repeat(3,1fr))
   Problem: 3 Spalten auch auf sehr schmalen Phones -> einzelne
   Thumbnails werden < 44px Tap-Flaeche und stehen sehr eng.
   Fix: Ab 640px auf 2 Spalten umbrechen -> groessere, besser
   antippbare Vorschaubilder. Inline-3-Spalten bleibt auf groesseren
   Screens erhalten (Spezifitaet: Inline-Style gewinnt dort).
   Daher Umbruch ueber eigene Regel mit hoher Spezifitaet + Query.
   ------------------------------------------------------------------- */
@media (max-width: 640px) {
    .split-text .gallery-thumbs,
    div.gallery-thumbs {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: .55rem;
    }
}

/* -------------------------------------------------------------------
   6) index.php — Hero-Carousel auf sehr kleinen Phones
   Problem: .hero ist clamp(320px,80vw,500px) (768er-Query). Auf
   320-360px-Geraeten bleibt das Hero relativ hoch, der Intro-Text
   rutscht weit nach unten.
   Fix: leichte Reduktion der Hero-Hoehe ganz unten im Spektrum.
   ------------------------------------------------------------------- */
@media (max-width: 640px) {
    .hero { height: clamp(260px, 62vw, 420px); }
}

/* -------------------------------------------------------------------
   7) index.php — Service-/Review-/Blog-Karten: gleichmaessige
   2-Spalten auf Tablet, sauberer Umbruch
   Problem: .services-grid nutzt auto-fit minmax(280px,1fr); zwischen
   ca. 640-980px kann je nach Containerbreite eine unguenstige
   2/3-Mischung entstehen. reviews-home-grid + blog-preview-grid
   haben kein explizites Tablet-Verhalten in PASS 8.
   Fix: im Tablet-Bereich klare 2-Spalten erzwingen.
   ------------------------------------------------------------------- */
@media (max-width: 980px) and (min-width: 641px) {
    .reviews-home-grid,
    .blog-preview-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* -------------------------------------------------------------------
   8) ueber-mich.php — Studio-Impressionen-Galerie
   Problem: Inline .services-grid mit minmax(220px,1fr) und Bildern
   mit fester height:220px (Inline-Style am <img>). Auf schmalen
   Phones wirken 220px hohe Bilder in 1 Spalte sehr wuchtig.
   Fix: Bildhoehe in dieser Galerie auf Mobil reduzieren. Zielt nur
   auf Bilder, die direkt in einem .services-grid liegen und eine
   feste Inline-Hoehe haben — daher [style] als Anker + !important,
   um den Inline-Wert zu ueberschreiben.
   ------------------------------------------------------------------- */
@media (max-width: 640px) {
    .services-grid img[style*="height:220px"],
    .services-grid img[style*="height: 220px"] {
        height: 160px !important;
    }
}

/* -------------------------------------------------------------------
   9) Treatment-Seiten — Listen (ul) in .split-text
   Problem: Die langen Aufzaehlungen (Behandlungsmoeglichkeiten,
   Kontraindikationen) erben Browser-Default-Padding-left (~40px).
   Auf schmalen Phones schiebt das den Text unnoetig ein und kostet
   Lesbreite.
   Fix: linkes Listen-Padding auf Mobil dezent reduzieren.
   ------------------------------------------------------------------- */
@media (max-width: 640px) {
    .split-text ul {
        padding-left: 1.25rem;
    }
    .split-text li {
        margin-bottom: .35rem;
        line-height: 1.55;
    }
}

/* -------------------------------------------------------------------
   10) Allgemein — horizontalen Ueberlauf hart verhindern
   Schutzgurt: Falls auf einer der oeffentlichen Seiten ein einzelnes
   breites Element (Inline-Grid, langes Wort, Bild ohne max-width)
   durchrutscht, soll die Seite nicht seitlich wackeln.
   Konservativ: nur overflow-x cap, kein Layout-Eingriff.
   ------------------------------------------------------------------- */
@media (max-width: 640px) {
    html, body { overflow-x: hidden; }
}

/* -------------------------------------------------------------------
   11) termine-kontakt.php / Treatment-CTAs — Button-Reihen
   Problem: .actions enthaelt auf Mobil teils 3 Buttons nebeneinander.
   site.css gibt .btn ab 768px flex:1 1 auto + min-width:140px — bei
   3 Buttons + Gap kann das auf 320px-Geraeten knapp werden.
   Fix: in zentrierten Aktionsreihen auf sehr kleinen Screens die
   Buttons voll breit stapeln (sauberer als enges Nebeneinander).
   ------------------------------------------------------------------- */
@media (max-width: 640px) {
    .actions {
        gap: .6rem;
    }
    .container-narrow .actions .btn,
    .text-center .actions .btn {
        flex: 1 1 100%;
        min-width: 0;
    }
}

/* === /RESPONSIVE FIX — BLOCK 1 === */

/* =====================================================================
   BLOCK 2 — Shop-Bereich Responsive- & Optik-Feinschliff
   Wird additiv an site.css angehängt (NACH "POLISH PASS 8").
   Scope: /online-shop (inkl. ?cat=epoch), /product/<slug>, /basket, /checkout
   Konservativ: rein additiv, keine bestehenden Layouts werden gebrochen.
   Breakpoints: 980px (Tablet) / 640px (Mobil) — analog PASS 8.
   ===================================================================== */

/* ---------------------------------------------------------------------
   1. ONLINE-SHOP — Produktraster & Sidebar
   --------------------------------------------------------------------- */

/* Produktkarten: Bild quadratisch & gleichmäßig (verhindert ungleiche
   Kartenhöhen bei Produkten mit/ohne Hover-Bild). */
.product-card .product-media {
    aspect-ratio: 1 / 1;
}
.product-card .product-img-base {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* Sidebar-Suche: bündige Tap-Höhe. */
.shop-search { min-height: 44px; }

/* Aktive-Filter-Chips: Tap-Ziel zum Entfernen vergrößern. */
.shop-chip a { padding-top: .15em; padding-bottom: .15em; }


/* ---------------------------------------------------------------------
   2. PRODUKTSEITE (PDP) — Galerie, Varianten, Detail-Tabs
   --------------------------------------------------------------------- */

/* Detail-Tabs: statt unruhigem Mehrzeilen-Umbruch horizontal scrollen.
   Sauberer auf schmalen Viewports, alle 6 Tabs bleiben erreichbar. */
.pde-tabs {
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
}
.pde-tab {
    flex: 0 0 auto;
    white-space: nowrap;
}

/* Varianten-Pills: angenehme Mindestbreite, damit kurze Labels
   nicht zu winzigen Tap-Zielen werden. */
.pdp-variant-opt:not(.shade) {
    min-width: 52px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}


/* ---------------------------------------------------------------------
   3. WARENKORB — Tabelle / Karten
   --------------------------------------------------------------------- */

/* Entfernen-Button: vollwertiges Tap-Ziel (war 32x32). */
.cart-remove {
    min-width: 40px;
    min-height: 40px;
}


/* =====================================================================
   TABLET — bis 980px
   ===================================================================== */
@media (max-width: 980px) {

    /* PDP-Galerie-Hauptbild nicht unnötig hoch werden lassen. */
    .pdp-gallery-main { max-height: 60vh; }
}


/* =====================================================================
   MOBIL — bis 640px
   ===================================================================== */
@media (max-width: 640px) {

    /* --- Online-Shop --- */

    /* Toolbar: Sortier-Select & Such-Reset volle Breite, gut greifbar. */
    .shop-toolbar select { width: 100%; min-height: 44px; }
    .shop-toolbar .result-count { width: 100%; }

    /* Preis-Range: Inputs gleichmäßig verteilen statt fixe 5em
       (verhindert Überlauf in schmaler, oben gestapelter Sidebar). */
    .shop-price-range { flex-wrap: wrap; }
    .shop-price-range input { flex: 1 1 0; width: auto; min-width: 0; }

    /* Linien-Accordion: etwas größere Tipp-Flächen. */
    .shop-linenav summary { padding: .85rem .9rem; }
    .shop-linenav .ln-line { padding-top: .55rem; padding-bottom: .55rem; }

    /* --- Produktseite --- */

    /* Detail-Tabs kompakter, damit mehr Tabs ohne Scrollen sichtbar sind. */
    .pde-tab { padding: .6em .9em; font-size: .88rem; }

    /* Inhaltsstoffe-Liste einspaltig (auto-fit minmax 260px erzwingt
       sonst horizontalen Druck auf 375px). */
    .ing-list { grid-template-columns: 1fr; }

    /* Bewertungs-Verteilungsbalken: Labelspalten nicht zu breit. */
    .review-distribution { font-size: .8rem; }

    /* --- Warenkorb --- */

    /* Karte: Bild + Infos oben, Menge/Preis darunter — klar getrennt.
       Ergänzt den vorhandenen 940px-Umbruch in site.css feiner. */
    .cart-item {
        grid-template-columns: 72px 1fr auto;
        gap: .6rem .8rem;
        padding: .85rem;
    }
    .cart-thumb img { width: 72px; height: 72px; }
    .cart-info { grid-column: 2 / 4; }
    .cart-qty {
        grid-column: 1 / 3;
        grid-row: 2;
        display: flex;
        align-items: center;
    }
    .cart-line {
        grid-column: 3;
        grid-row: 2;
        align-self: center;
    }
    .cart-remove {
        grid-column: 3;
        grid-row: 1;
        align-self: start;
        justify-self: end;
    }
    .cart-qty input { width: 64px; min-height: 40px; }

    /* --- Checkout --- */

    /* Formular-Zeilen einspaltig: Name/E-Mail bzw. PLZ/Ort
       werden auf 375px nebeneinander zu schmal. */
    .form-row { grid-template-columns: 1fr; }
    /* Loyalty-Zeile (3-Spalten-Inline-Grid) ebenfalls stapeln. */
    .checkout-step #loyalty-step .form-row,
    #loyalty-step .form-row { grid-template-columns: 1fr; }

    /* Checkout-Step-Innenabstand etwas reduzieren. */
    .checkout-step { padding: 1.25rem; }

    /* Zahlungsarten: mind. 2 nebeneinander, aber nicht zu schmal. */
    .payment-options { grid-template-columns: repeat(2, 1fr); }
}

/* === ACCESSIBILITY PASS ===
   A11y-Verbesserungen 2026-05-22. APPEND-ONLY: ueberschreibt keine
   bestehende Regel. Kann komplett entfernt werden — die Seite degradiert
   dann sauber auf den vorherigen Stand.
   --------------------------------------------------------------------- */

/* --- 1. Skip-Link: sichtbar erst bei Fokus -----------------------------
   Bestehende .skip-link-Regel (oben in der Datei) benutzt left:-9999px.
   Wir verstaerken die Fokus-Sichtbarkeit und stellen sicher, dass der
   Link wirklich ueber allem liegt. */
.skip-link:focus,
.skip-link:focus-visible {
    position: fixed;
    left: 1rem;
    top: 1rem;
    width: auto;
    height: auto;
    overflow: visible;
    z-index: 100000;
    outline: 3px solid #fff;
    outline-offset: 2px;
}

/* Das Skip-Link-Ziel selbst soll beim Anspringen keinen Fokus-Rahmen
   zeichnen (es ist nur ein Container, kein interaktives Element). */
#content { outline: none; }
#content:focus { outline: none; }

/* --- 2. Globaler, deutlich sichtbarer Fokus-Indikator ------------------
   Greift fuer alle per Tastatur fokussierbaren Elemente. :focus-visible
   blendet den Rahmen bei reiner Maus-Nutzung aus, sodass das Design
   unveraendert bleibt. */
a:focus-visible,
button:focus-visible,
[role="button"]:focus-visible,
[role="tab"]:focus-visible,
summary:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
details:focus-visible,
[tabindex]:focus-visible {
    outline: 3px solid var(--gold, #dabe92);
    outline-offset: 2px;
    border-radius: 3px;
}

/* Fallback fuer aeltere Browser ohne :focus-visible-Unterstuetzung —
   keyboard-only ist hier nicht erkennbar, daher dezenter Rahmen. */
@supports not selector(:focus-visible) {
    a:focus, button:focus, summary:focus,
    input:focus, select:focus, textarea:focus {
        outline: 3px solid var(--gold, #dabe92);
        outline-offset: 2px;
    }
}

/* Icon-only-Buttons im Header (Menue-Toggle, Nav-Close) brauchen einen
   gut erkennbaren Fokusrahmen — die SVG-Strokes geben sonst kein Signal. */
.menu-toggle:focus-visible,
.nav-close:focus-visible,
.icon-link:focus-visible,
.hero-dots button:focus-visible {
    outline: 3px solid var(--gold, #dabe92);
    outline-offset: 3px;
    border-radius: 4px;
}

/* --- 3. Sidebar-Accordion (<details> im Shop): sichtbarer Fokus auf
   <summary>, damit per Tastatur klar ist, welche Marke aktiv ist. */
.shop-linenav summary:focus-visible,
.faq-item summary:focus-visible {
    outline: 3px solid var(--gold, #dabe92);
    outline-offset: -3px;
    border-radius: 4px;
}

/* --- 4. aria-current Hervorhebung des aktiven Navigationspunkts -------- */
.main-nav a[aria-current="page"] {
    font-weight: 600;
    text-decoration: underline;
    text-underline-offset: 4px;
}
.lang-switch a[aria-current],
.lang-switch a.active { font-weight: 600; }

/* --- 5. Kontrast-Korrekturen (klar sichere Faelle) --------------------- */
/* Platzhalter-Text war #aab1b3 auf Weiss (~2.3:1, deutlich unter WCAG AA).
   Abdunkeln auf einen Wert, der die 4.5:1-Schwelle erreicht. */
input::placeholder,
textarea::placeholder { color: #6b7173; opacity: 1; }

/* Sale-/Sonderpreis-Strike: rein dekorativ, aber als durchgestrichener
   alter Preis darf er nicht unleserlich blass sein. */
.product-price-strike { color: #6b6b6b; }

/* --- 6. Reduzierte Bewegung respektieren ------------------------------
   Nutzer mit "prefers-reduced-motion" bekommen Animationen/Transitions
   praktisch deaktiviert (Scroll-Reveal, Hover-Lift, Karussell-Fades). */
@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
    .reveal { opacity: 1 !important; transform: none !important; }
}

/* --- 7. Touch-/Klick-Ziele: Mindestgroesse fuer kleine Icon-Links ----- */
.social-icons a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 44px;
    min-height: 44px;
}
/* === /ACCESSIBILITY PASS === */


/* =====================================================================
   SEHR SCHMAL — bis 400px (Notnagel gegen Überlauf)
   ===================================================================== */
@media (max-width: 400px) {
    .payment-options { grid-template-columns: 1fr; }
    .checkout-step h3 { font-size: 1rem; }
}
/* === /BLOCK 2 === */

/* ============================================================
 * block3.css  —  Responsive + Optik-Verbesserungen Kunden-Account
 * ------------------------------------------------------------
 * Scope: /login, /register (account/registration.php) und der
 *        Account-Bereich /account/* (Bootstrap-Layout in
 *        .acc-bs-scope, siehe account/_layout.php).
 *
 * Wird ANgehaengt an assets/css/site.css. Rein additiv,
 * konservativ. Keine bestehende Regel wird ueberschrieben,
 * ausser gezielt mit erhoehter Spezifitaet / !important wo
 * Bootstrap-Inline-Defaults sonst gewinnen.
 *
 * Breakpoints: 640px (Smartphone) / 980px (Tablet).
 * Brand: --primary #90a7ac · --acc-brand #90a7ac
 * Getestet konzeptionell fuer 375 / 768 / 1280 px.
 * ============================================================ */


/* ============================================================
 * 1. LOGIN / REGISTER  (Site-Design-System, .section)
 * ============================================================ */

/* 1a. Login-/Register-Karte: dezente Karten-Optik statt nackter
 *     Formular auf grosser, leerer Section-Flaeche. Additiv —
 *     greift nur, wenn die schmale max-width-Box vorhanden ist. */
.section > div[style*="max-width:440px"],
.section > div[style*="max-width:560px"] {
    background: #fff;
    border: 1px solid var(--border);
    border-radius: var(--radius-lg, 14px);
    box-shadow: 0 6px 28px rgba(0, 0, 0, .06);
    padding: 2.25rem 2rem;
}

/* 1b. Section-Innenabstand auf Smartphone reduzieren, damit die
 *     Login-Karte nicht von 4rem Luft oben/unten erschlagen wird. */
@media (max-width: 640px) {
    .section > div[style*="max-width:440px"],
    .section > div[style*="max-width:560px"] {
        padding: 1.5rem 1.15rem;
        border-radius: var(--radius-md, 10px);
    }
}

/* 1c. Login-/Register-Buttons: abgerundet (site.css setzt --radius:0)
 *     damit sie zur Karten-Optik passen. Nur Block-Buttons im
 *     Login/Register-Kontext. */
.section .btn.btn-block {
    border-radius: var(--radius-pill, 999px);
    margin-top: .25rem;
}

/* 1d. Checkbox-Zeile (AGB akzeptieren) im Register sauber
 *     ausrichten — Touch-Target des Checkbox vergroessern. */
@media (max-width: 640px) {
    .section .form-group input[type="checkbox"] {
        width: 20px;
        height: 20px;
        flex: 0 0 auto;
    }
}


/* ============================================================
 * 2. ACCOUNT-LAYOUT  (.acc-bs-scope — Bootstrap)
 * ============================================================ */

/* 2a. Hauptinhalt nie schmaler quetschen als noetig: zwischen
 *     768 und 980px ist die docked Sidebar bereits sichtbar und
 *     die Spalte col-md-9 wird eng. Etwas Innenabstand zuruecknehmen. */
@media (min-width: 768px) and (max-width: 980px) {
    .acc-bs-scope .acc-main {
        padding-left: 1rem;
        padding-right: 1rem;
    }
}

/* 2b. Seiten-Ueberschrift (h1) im Account auf Smartphone
 *     verkleinern — die Standard-h1 ist fuer die schmale
 *     Content-Spalte zu wuchtig. */
@media (max-width: 640px) {
    .acc-bs-scope .acc-main h1 {
        font-size: clamp(1.45rem, 6vw, 1.9rem);
        line-height: 1.25;
        word-break: break-word;
    }
    .acc-bs-scope .acc-main h3 {
        font-size: 1.15rem;
    }
}

/* 2c. Mobile Top-Bar (Menue + Titel) leicht aufwerten:
 *     abgerundet, dezenter Schatten, sticky am oberen Rand,
 *     damit das Menue beim Scrollen erreichbar bleibt. */
@media (max-width: 767.98px) {
    .acc-bs-scope .acc-mobile-bar {
        border-radius: var(--radius-md, 10px);
        border: 1px solid var(--acc-border, #e6e6e6);
        box-shadow: 0 2px 8px rgba(0, 0, 0, .05);
        position: sticky;
        top: .35rem;
        z-index: 5;
    }
}

/* 2d. Offcanvas-Sidebar: aktiver Eintrag und Branding klarer.
 *     Marken-Akzentstreifen links am aktiven Eintrag. */
.acc-bs-scope .acc-sidebar .list-group-item.active {
    box-shadow: inset 3px 0 0 var(--acc-brand-hover, #7a9197);
}

/* 2e. Abmelden-Eintrag in der Sidebar optisch abgrenzen. */
.acc-bs-scope .acc-sidebar .list-group-item.text-danger {
    margin-top: .35rem;
    border-top: 1px solid var(--acc-border, #e6e6e6) !important;
}


/* ============================================================
 * 3. DASHBOARD-KACHELN  (account/_dashboard.php)
 * ============================================================ */

/* 3a. Stat-Kacheln: konsistente Optik — sanfter Rahmen,
 *     Hover-Anhebung, Marken-Akzent fuer die grosse Zahl. */
.acc-bs-scope .acc-main .card {
    border: 1px solid var(--acc-border, #e6e6e6);
    border-radius: var(--radius-lg, 14px);
    transition: transform .15s ease, box-shadow .15s ease;
}
.acc-bs-scope .acc-main .card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 22px rgba(0, 0, 0, .08);
}
.acc-bs-scope .acc-main .stat-tile-value {
    color: var(--acc-brand, #90a7ac);
    line-height: 1.05;
    font-weight: 600;
}

/* 3b. Auf sehr schmalen Schirmen (375px) ist die 2-Spalten-
 *     Kachelreihe (row-cols-sm-2 greift erst ab 576px, darunter
 *     also 1-spaltig) ok — aber die grosse 2.5rem-Zahl etwas
 *     zaehmen, damit die Kachel kompakter wirkt. */
@media (max-width: 640px) {
    .acc-bs-scope .acc-main .stat-tile-value {
        font-size: 2rem !important;
    }
    .acc-bs-scope .acc-main .card .card-body {
        padding: 1rem .85rem;
    }
    /* Schnell-Aktionen-Buttons full width gestapelt */
    .acc-bs-scope .acc-main .d-flex.flex-wrap.gap-2 .btn {
        flex: 1 1 100%;
    }
}


/* ============================================================
 * 4. TABELLEN  (Termine / Rechnungen / Bons — .responsive-cards)
 * ============================================================ */

/* site.css schaltet .table.responsive-cards erst bei <=720px in
 * den Karten-Modus. Im Account ist die Content-Spalte aber schon
 * deutlich frueher schmal. Sicherheitsnetz: horizontaler Scroll
 * ist ueber .table-responsive bereits da — hier nur Optik. */

/* 4a. Tabellen-Karten (Mobil-Modus) bekommen Marken-Akzent und
 *     etwas mehr Luft; Status-Badges duerfen nicht umbrechen. */
@media (max-width: 640px) {
    .acc-bs-scope .table.responsive-cards tr {
        border-radius: var(--radius-md, 10px);
        border-color: var(--acc-border, #e6e6e6);
    }
    .acc-bs-scope .table.responsive-cards td {
        padding-top: .5rem;
        padding-bottom: .5rem;
    }
    /* Label (data-label) konsistent klein + gedaempft */
    .acc-bs-scope .table.responsive-cards td::before {
        color: var(--acc-muted, #6c757d);
        font-weight: 600;
    }
    /* Badge im Karten-Modus nicht zerquetschen */
    .acc-bs-scope .table.responsive-cards .badge {
        white-space: nowrap;
    }
    /* Aktion/PDF-Button im Karten-Modus volle Breite + Touch-Hoehe */
    .acc-bs-scope .table.responsive-cards td[data-label="Aktion"] .btn {
        display: block;
        width: 100%;
        min-height: 42px;
        line-height: 1.4;
    }
}

/* 4b. Zwischenbereich 641-767px: Sidebar ist Offcanvas (gut),
 *     aber Tabelle noch im Spalten-Modus. table-responsive
 *     erlaubt Scroll — zusaetzlich dezenten Rahmen geben, damit
 *     der scrollbare Bereich erkennbar ist. */
@media (min-width: 641px) and (max-width: 767.98px) {
    .acc-bs-scope .table-responsive {
        border: 1px solid var(--acc-border, #e6e6e6);
        border-radius: var(--radius-md, 10px);
    }
}

/* 4c. Tabellen-Optik allgemein im Account: Kopfzeile in Markenton. */
.acc-bs-scope .acc-main .table > thead th {
    border-bottom: 2px solid var(--acc-border, #e6e6e6);
    color: var(--acc-ink, #2c2c2c);
    font-weight: 600;
}


/* ============================================================
 * 5. ANAMNESE  (account/_anamnese.php — viele Inline-Grids)
 * ============================================================ */

/* Das Template nutzt Inline-Grids mit minmax(280px,1fr) bzw.
 * minmax(220px,1fr). Auf 375px (Content-Breite ~ 330px) passt
 * 280px gerade noch, ist aber kantig nah am Rand. Zur Sicherheit
 * die Mindestbreite per Override auf 1fr ziehen. */
@media (max-width: 640px) {
    /* Vorerkrankungen-Grid (minmax 280px) + Inhaltsstoffe-Grid
     * (minmax 220px) auf eine Spalte zwingen. */
    .acc-bs-scope .acc-main fieldset .card-body div[style*="grid-template-columns"],
    .acc-bs-scope .acc-main fieldset .card-body details div[style*="grid-template-columns"] {
        grid-template-columns: 1fr !important;
    }
    /* Scroll-Boxen (Allergien/Medikamente) etwas niedriger,
     * damit sie auf dem Phone nicht den halben Screen fuellen. */
    .acc-bs-scope .acc-main fieldset .card-body div[style*="max-height:380px"] {
        max-height: 300px !important;
    }
    /* Checkbox-Touch-Target in den Listen vergroessern. */
    .acc-bs-scope .acc-main fieldset .card-body input[type="checkbox"] {
        width: 20px;
        height: 20px;
    }
}

/* 5b. Anamnese-Fieldsets (Karten) optisch glaetten: konsistenter
 *     Radius, kein harter Kasten-Look. */
.acc-bs-scope .acc-main fieldset.card {
    border-radius: var(--radius-md, 10px);
    border: 1px solid var(--acc-border, #e6e6e6);
}
.acc-bs-scope .acc-main fieldset.card legend {
    color: var(--acc-ink, #2c2c2c);
}

/* 5c. "Anamnese speichern"-Button auf Smartphone volle Breite. */
@media (max-width: 640px) {
    .acc-bs-scope .acc-main form > button[type="submit"].btn {
        width: 100%;
        min-height: 46px;
    }
}


/* ============================================================
 * 6. APP-INSTALLATION  (account/_install_app.php)
 * ============================================================ */

/* Das Template bringt eigenes <style> mit (Hero collapse @540px).
 * Ergaenzung: Plattform-Tabs auf schmalen Schirmen sauber halten. */
@media (max-width: 640px) {
    /* 4 Tabs (Mein Geraet / iOS / Android / Desktop) wuerden bei
     * 375px zerquetscht — horizontal scrollbar machen statt
     * Umbruch, Tabs behalten ihre Groesse. */
    .acc-bs-scope .platform-tabs {
        flex-wrap: nowrap;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: thin;
    }
    .acc-bs-scope .platform-tabs button {
        flex: 0 0 auto;
        white-space: nowrap;
        padding: .65rem .85rem;
    }
    /* Install-Aktionsbuttons gestapelt + volle Breite. */
    .acc-bs-scope .install-actions {
        flex-direction: column;
    }
    .acc-bs-scope .install-actions .btn {
        width: 100%;
        min-height: 46px;
    }
}

/* 6b. Benefits-Grid: minmax(220px,1fr) ist auf 375px knapp —
 *     auf eine Spalte ziehen fuer saubere Darstellung. */
@media (max-width: 640px) {
    .acc-bs-scope .benefits-grid {
        grid-template-columns: 1fr;
    }
}


/* ============================================================
 * 7. FAVORITEN  (account/_favorites.php — .product-grid)
 * ============================================================ */

/* .product-grid ist site-weit definiert. Innerhalb der schmalen
 * Account-Spalte kann es bei 768-980px zu eng werden. Mindest-
 * Kachelbreite leicht reduzieren, damit 2 Spalten sauber passen. */
@media (min-width: 768px) and (max-width: 980px) {
    .acc-bs-scope .acc-main .product-grid {
        grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    }
}


/* ============================================================
 * 8. ALLGEMEINE ACCOUNT-OPTIK / FORMULARE
 * ============================================================ */

/* 8a. Primaer-Buttons im Account einheitlich abrunden
 *     (Bootstrap-Default ist eckiger als die Karten). */
.acc-bs-scope .acc-main .btn {
    border-radius: var(--radius-pill, 999px);
}

/* 8b. Formular-Inputs im Profil/Anamnese: 16px Schriftgroesse auf
 *     Mobil verhindert iOS-Auto-Zoom; bequeme Tap-Hoehe. */
@media (max-width: 640px) {
    .acc-bs-scope .acc-main .form-control,
    .acc-bs-scope .acc-main .form-select,
    .acc-bs-scope .acc-main input[type="text"],
    .acc-bs-scope .acc-main input[type="email"],
    .acc-bs-scope .acc-main input[type="tel"],
    .acc-bs-scope .acc-main input[type="date"],
    .acc-bs-scope .acc-main input[type="search"],
    .acc-bs-scope .acc-main textarea,
    .acc-bs-scope .acc-main select {
        font-size: 16px;
        min-height: 44px;
    }
    .acc-bs-scope .acc-main textarea {
        min-height: 88px;
    }
}

/* 8c. Bootstrap-Alerts im Account auf Smartphone gut lesbar. */
@media (max-width: 640px) {
    .acc-bs-scope .acc-main .alert {
        font-size: .95rem;
        padding: .9rem 1rem;
    }
}

/* 8d. Profil: Theme-Farbfelder / Kontakt-Radios duerfen umbrechen,
 *     nicht ueberlaufen. */
@media (max-width: 640px) {
    .acc-bs-scope .acc-main .theme-color-presets,
    .acc-bs-scope .acc-main .theme-mode-toggle,
    .acc-bs-scope .acc-main .contact-radio {
        flex-wrap: wrap;
    }
}

/* 8e. Sicherheitsnetz gegen horizontalen Overflow im Account-
 *     Content (lange Tabellenzellen, Codes, E-Mails). */
.acc-bs-scope .acc-main {
    overflow-wrap: break-word;
}

/* === /block3.css === */



/* === LINIEN-DARSTELLUNG FRONTEND === */
/*
 * Additiver, optischer Feinschliff fuer die Marken-/Linien-Darstellung
 * im Online-Shop (online-shop.php).
 *
 * NUR CSS. Keine PHP-Aenderung. Alle Selektoren entsprechen exakt den
 * im Template vorhandenen Klassen. Dieser Block ist so geschrieben, dass
 * er NACH site.css und nach den <style>-Bloecken in online-shop.php
 * geladen werden kann und die bestehende Optik gezielt ueberschreibt.
 *
 * Erstellt: 2026-05-22  |  Pfad: tools/lines/frontend_lines.css
 * --------------------------------------------------------------------
 *  1. Linien-Hero / Linien-Beschreibung ueber der Produktliste
 *  2. Sidebar-Container (shop-sidebar) + Ueberschriften
 *  3. Marken->Linien-Akkordeon (shop-linenav)
 *  4. Aktive Linie / Hover / dezente Counts
 *  5. Shop-Toolbar Feinschliff
 *  6. Responsive (Tablet / Mobile)
 * ==================================================================== */


/* --------------------------------------------------------------------
 * 1. LINIEN-HERO / BESCHREIBUNG  (.page-title-block bei aktiver Linie)
 *    Edler, ruhiger Hero-Bereich mit klarer Typo-Hierarchie.
 * ------------------------------------------------------------------ */
.page-title-block {
    padding: 3.5rem 1.5rem 2.25rem;
}

/* Linien-Ueberschrift: feine Goldlinie als Akzent darunter */
.page-title-block h1 {
    position: relative;
    margin-bottom: 1.15rem;
    letter-spacing: .01em;
}
.page-title-block h1::after {
    content: "";
    display: block;
    width: 56px;
    height: 2px;
    margin: .85rem auto 0;
    background: var(--gold, #dabe92);
    border-radius: var(--radius-pill, 999px);
}

/* Linien-Beschreibung (product_categories.description) ueber der Liste */
.shop-line-desc {
    max-width: 720px;
    margin: 0 auto;
    color: var(--muted, #6e7679);
    font-size: 1.02rem;
    line-height: 1.7;
    font-weight: 300;
}

/* Pill-Gruppe (Alle Pflegeprodukte / Gutscheine) etwas mehr Luft */
.page-title-block .pill-group {
    margin-top: 1.5rem !important;
}


/* --------------------------------------------------------------------
 * 2. SIDEBAR-CONTAINER  (.shop-sidebar)
 *    Weicher, leichter Karten-Look statt harter Kante.
 * ------------------------------------------------------------------ */
.shop-sidebar {
    padding: 1.5rem 1.4rem;
    border: 1px solid var(--border, #e8eaed);
    border-radius: var(--radius-lg, 14px);
    background: var(--white, #fff);
    box-shadow: var(--shadow-sm, 0 2px 8px rgba(0,0,0,.04));
}

/* Abschnitts-Ueberschriften (Suche / Marken & Linien / Preis / ...) */
.shop-sidebar h3 {
    font-size: .8rem;
    letter-spacing: .1em;
    color: var(--primary-dark, #7a9499);
    border-bottom: 1px solid var(--border, #e8eaed);
    padding-bottom: .55rem;
    margin-bottom: .9rem;
}
.shop-sidebar h3:not(:first-child) {
    margin-top: 1.7rem;
}


/* --------------------------------------------------------------------
 * 3. MARKEN -> LINIEN-AKKORDEON  (.shop-linenav)
 *    Klare, ruhige Gliederung; aktive Marke dezent hervorgehoben.
 * ------------------------------------------------------------------ */
.shop-linenav {
    margin-bottom: 1.5rem;
}

/* Einzelne Marken-Box (<details>) */
.shop-linenav details {
    border: 1px solid var(--border, #e8eaed);
    border-radius: var(--radius-md, 10px);
    margin-bottom: .55rem;
    background: var(--white, #fff);
    overflow: hidden;
    transition: border-color .18s ease, box-shadow .18s ease;
}
.shop-linenav details:hover {
    border-color: var(--primary-soft, #adc1c5);
}
/* Geoeffnete Marke: zarter Teal-Rahmen + leichter Schatten */
.shop-linenav details[open] {
    border-color: var(--primary, #90a7ac);
    box-shadow: var(--shadow-sm, 0 2px 8px rgba(0,0,0,.04));
}

/* Marken-Kopfzeile (<summary>) */
.shop-linenav summary {
    padding: .8rem .95rem;
    font-size: .9rem;
    font-weight: 600;
    color: var(--text, #2d2d2d);
    transition: background .15s ease, color .15s ease;
}
.shop-linenav summary:hover {
    background: var(--bg-soft, #f8f8f8);
}
.shop-linenav details[open] summary {
    color: var(--primary-dark, #7a9499);
    border-bottom: 1px solid var(--border, #e8eaed);
}

/* Pfeil-Icon dezenter + weiche Drehung */
.shop-linenav summary::after {
    font-size: .65rem;
    color: var(--primary, #90a7ac);
    transition: transform .22s ease;
}

/* Marken-Count: dezenter Pill-Badge statt nackter Zahl */
.shop-linenav summary .ln-brand-count {
    min-width: 1.5em;
    padding: .12em .5em;
    font-size: .72rem;
    font-weight: 500;
    line-height: 1.4;
    text-align: center;
    color: var(--muted, #6e7679);
    background: var(--bg-soft, #f8f8f8);
    border-radius: var(--radius-pill, 999px);
}
.shop-linenav details[open] summary .ln-brand-count {
    color: var(--primary-dark, #7a9499);
    background: rgba(144,167,172,.14);
}

/* Linien-Liste innerhalb einer Marke */
.shop-linenav .ln-lines {
    padding: .35rem .45rem .5rem;
}

/* Einzelne Linie (<a class="ln-line">) */
.shop-linenav .ln-line {
    padding: .46rem .6rem;
    border-radius: var(--radius-sm, 6px);
    font-size: .86rem;
    color: var(--text, #2d2d2d);
    transition: background .14s ease, color .14s ease, padding-left .14s ease;
}
.shop-linenav .ln-line:hover {
    background: var(--bg-soft, #f8f8f8);
    color: var(--primary-dark, #7a9499);
    padding-left: .85rem;
}


/* --------------------------------------------------------------------
 * 4. AKTIVE LINIE  (.ln-line.active)  +  Counts (.ln-cnt)
 * ------------------------------------------------------------------ */
.shop-linenav .ln-line.active {
    background: var(--primary, #90a7ac);
    color: var(--white, #fff);
    font-weight: 500;
    padding-left: .6rem;
    box-shadow: var(--shadow-sm, 0 2px 8px rgba(0,0,0,.04));
}
/* Linker Akzentstreifen, der die aktive Linie markiert */
.shop-linenav .ln-line.active {
    position: relative;
}
.shop-linenav .ln-line.active::before {
    content: "";
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 3px;
    height: 62%;
    background: var(--gold, #dabe92);
    border-radius: var(--radius-pill, 999px);
}
.shop-linenav .ln-line.active:hover {
    background: var(--primary-dark, #7a9499);
    color: var(--white, #fff);
    padding-left: .6rem;
}

/* Linien-Count (Produktanzahl je Linie) — dezent */
.shop-linenav .ln-line .ln-cnt {
    font-size: .73rem;
    font-weight: 400;
    color: var(--muted, #6e7679);
    opacity: 1;
    transition: color .14s ease;
}
.shop-linenav .ln-line:hover .ln-cnt {
    color: var(--primary-dark, #7a9499);
}
.shop-linenav .ln-line.active .ln-cnt {
    color: rgba(255,255,255,.85);
}

/* "Alle Marken anzeigen"-Link oben im Akkordeon */
.shop-linenav .ln-all {
    margin-bottom: .55rem;
    padding: .5rem .6rem;
    font-size: .82rem;
    color: var(--primary-dark, #7a9499);
    text-decoration: none;
    border-radius: var(--radius-sm, 6px);
    transition: background .14s ease, color .14s ease;
}
.shop-linenav .ln-all:hover {
    background: var(--bg-soft, #f8f8f8);
    color: var(--primary, #90a7ac);
    text-decoration: underline;
}


/* --------------------------------------------------------------------
 * 5. SHOP-TOOLBAR  (.shop-toolbar)
 *    Ergebniszeile / Sortierung optisch ruhiger.
 * ------------------------------------------------------------------ */
.shop-toolbar {
    padding: .25em 0 1.35em;
    border-bottom: 1px solid var(--border, #e8eaed);
    margin-bottom: 1.75em;
}
.shop-toolbar .result-count {
    font-size: .95rem;
    color: var(--muted, #6e7679);
}
.shop-toolbar .result-count strong {
    color: var(--primary-dark, #7a9499);
    font-weight: 600;
}
.shop-toolbar select {
    border-radius: var(--radius-sm, 6px);
    transition: border-color .15s ease;
}
.shop-toolbar select:hover {
    border-color: var(--primary, #90a7ac);
}


/* --------------------------------------------------------------------
 * 6. RESPONSIVE  (Tablet / Mobile)
 *    Sidebar wird unter 900px in den Flow gesetzt (Template-Verhalten),
 *    hier nur Typo-/Abstands-Feinschliff.
 * ------------------------------------------------------------------ */
@media (max-width: 900px) {
    .shop-sidebar {
        border-radius: var(--radius-md, 10px);
        padding: 1.25rem 1.15rem;
    }
    .page-title-block {
        padding: 2.5rem 1rem 1.75rem;
    }
}

@media (max-width: 600px) {
    .shop-line-desc {
        font-size: .96rem;
        line-height: 1.65;
    }
    .page-title-block h1::after {
        width: 44px;
        margin-top: .7rem;
    }
    .shop-linenav summary {
        padding: .75rem .8rem;
    }
    .shop-linenav .ln-line {
        padding: .5rem .55rem;
        font-size: .88rem;
    }
    /* Auf Touch kein Padding-Shift beim Hover — vermeidet Verspringen */
    .shop-linenav .ln-line:hover {
        padding-left: .55rem;
    }
}

/* === ENDE LINIEN-DARSTELLUNG FRONTEND === */



/* === KAUFOPTIONEN === */
/*
 * Additiver Block fuer die variant_type='option'-Varianten der PDP
 * (product.php). Reiht sich optisch in die bestehenden .pdp-variant-opt-
 * Pills ein und hebt ADR-Abo- bzw. Set-Optionen dezent hervor.
 * Keine bestehende Regel wird ueberschrieben — nur ergaenzt.
 *
 * Markup-Hooks aus product.php:
 *   .pdp-variant-group[data-vtype="option"]   — die Kaufoptions-Gruppe
 *   .pdp-variant-opt.opt-pill                 — eine Kaufoptions-Pill
 *   button[data-opt-key="single|adr|set"]     — normalisierter Optionstyp
 */

/* Kaufoptionen duerfen volle Breite nutzen und untereinander stehen,
   damit die Labels (Einmalkauf / ADR-Abo / Im Set) gut lesbar bleiben. */
.pdp-variant-group[data-vtype="option"] .pdp-variant-options {
    flex-direction: column;
    gap: .55rem;
}

/* Grund-Pill fuer Kaufoptionen: etwas grosszuegiger, linksbuendiger Text. */
.pdp-variant-opt.opt-pill {
    width: 100%;
    justify-content: flex-start;
    text-align: left;
    padding: .7rem 1rem;
    font-weight: 500;
    line-height: 1.3;
}

/* Dezenter Hinweis-Pfeil/Marker links, nur fuer Kaufoptionen. */
.pdp-variant-opt.opt-pill::before {
    content: "";
    display: inline-block;
    flex: 0 0 auto;
    width: 14px;
    height: 14px;
    margin-right: .6rem;
    border-radius: 50%;
    border: 1.5px solid var(--border, #dcdcdc);
    background: #fff;
    transition: border-color .15s, background .15s, box-shadow .15s;
}

/* Ausgewaehlte Kaufoption: gefuellter Marker im Primaerton. */
.pdp-variant-opt.opt-pill.selected::before {
    border-color: var(--primary, #c93030);
    background: var(--primary, #c93030);
    box-shadow: inset 0 0 0 2.5px #fff;
}

/* --- Dezente Hervorhebung der ADR-Abo-Option --- */
.pdp-variant-opt.opt-pill[data-opt-key="adr"] {
    border-color: #c9a96a;
    background: #fcf8ef;
}
.pdp-variant-opt.opt-pill[data-opt-key="adr"]:hover {
    border-color: #b8923f;
}
.pdp-variant-opt.opt-pill[data-opt-key="adr"].selected {
    border-color: #b8923f;
    box-shadow: 0 0 0 1px #b8923f;
}
/* Kleiner Spar-/Abo-Badge rechts an der ADR-Pill. */
.pdp-variant-opt.opt-pill[data-opt-key="adr"]::after {
    content: "Abo";
    margin-left: auto;
    font-size: .68rem;
    font-weight: 600;
    letter-spacing: .04em;
    text-transform: uppercase;
    color: #8a6d27;
    background: #f0e4c4;
    border-radius: 4px;
    padding: .12rem .42rem;
}

/* --- Dezente Hervorhebung der Set-/Bundle-Option --- */
.pdp-variant-opt.opt-pill[data-opt-key="set"] {
    border-color: #a9c6b4;
    background: #f2f8f4;
}
.pdp-variant-opt.opt-pill[data-opt-key="set"]:hover {
    border-color: #6f9e83;
}
.pdp-variant-opt.opt-pill[data-opt-key="set"].selected {
    border-color: #6f9e83;
    box-shadow: 0 0 0 1px #6f9e83;
}
.pdp-variant-opt.opt-pill[data-opt-key="set"]::after {
    content: "Set";
    margin-left: auto;
    font-size: .68rem;
    font-weight: 600;
    letter-spacing: .04em;
    text-transform: uppercase;
    color: #3f6b51;
    background: #d9ebe0;
    border-radius: 4px;
    padding: .12rem .42rem;
}

/* Einmalkauf bleibt neutral — keine Sonderfarbe, nur die Standard-Pill. */

/* Schmale Viewports: Pills weiterhin volle Breite, Badge sauf eigener Linie
   ueber margin-left:auto bleibt rechts buendig — kein Extra noetig. */



/* === LINIEN & PRODUKTSEITE FEINSCHLIFF v4 === */
/*
 * Additiver CSS-Block — optische Verbesserung der Shop-Linien-Darstellung
 * (online-shop.php) und der Produktseite (product.php).
 *
 * Fokus: saubere Optik bei vielen Linien (~16 NuSkin-Linien + Esthevital/Rike).
 * Keine bestehende Regel wird umgeschrieben — nur ergaenzt/praezisiert.
 * Alle Selektoren treffen vorhandene Klassen aus online-shop.php / product.php
 * bzw. assets/css/site.css exakt. CSS-Variablen aus :root werden genutzt,
 * Fallbacks decken den Fall fehlender Tokens ab.
 *
 * Markup-Hooks:
 *   online-shop.php : .shop-sidebar .shop-linenav details/summary
 *                     .ln-brand-count .ln-lines .ln-line .ln-cnt .ln-all
 *                     .page-title-block .shop-line-desc .product-card .product-grid
 *   product.php     : .pdp-variants .pdp-variant-group .pdp-variant-label
 *                     .pdp-variant-current .pdp-variant-options
 *                     .pdp-variant-opt .opt-pill
 * ------------------------------------------------------------------ */


/* ==================================================================
   1. SIDEBAR — MARKEN -> LINIEN AKKORDEON
   Ziel: bei vielen Linien uebersichtlich, kompakte Zeilen,
   klare aktive Linie, dezente Counts, sauberes Scroll-Verhalten.
   ================================================================== */

/* Sidebar selbst: weicheres Panel, dezenter Schatten, gleitendes Scrollen.
   max-height bleibt durch site.css gesetzt — hier nur Feinschliff. */
.shop-sidebar {
    border-radius: var(--radius-md, 10px);
    box-shadow: 0 1px 3px rgba(31, 37, 40, .05);
    scroll-behavior: smooth;
    scrollbar-width: thin;
    scrollbar-color: var(--primary-soft, #adc1c5) transparent;
}
.shop-sidebar::-webkit-scrollbar { width: 7px; }
.shop-sidebar::-webkit-scrollbar-track { background: transparent; }
.shop-sidebar::-webkit-scrollbar-thumb {
    background: var(--primary-soft, #adc1c5);
    border-radius: 999px;
}
.shop-sidebar::-webkit-scrollbar-thumb:hover { background: var(--primary, #90a7ac); }

/* Linien-Navigation: etwas Luft nach unten, kein doppelter Abstand. */
.shop-linenav { margin-bottom: 1.2rem; }

/* "Alle Marken anzeigen"-Rueckweg: als ruhiger Button statt nackter Link. */
.shop-linenav .ln-all {
    margin-bottom: .65rem;
    padding: .5rem .7rem;
    border-radius: var(--radius-sm, 6px);
    background: var(--bg-soft, #f8f8f8);
    color: var(--muted, #6e7679);
    text-decoration: none;
    font-weight: 500;
    transition: background .15s, color .15s;
}
.shop-linenav .ln-all:hover {
    background: var(--primary, #90a7ac);
    color: var(--white, #fff);
}

/* Akkordeon-Karte je Marke: weicher Rahmen, dezenter Trenner. */
.shop-linenav details {
    border-color: var(--border, #e8eaed);
    margin-bottom: .45rem;
    transition: border-color .15s, box-shadow .15s;
}
.shop-linenav details:hover { border-color: var(--primary-soft, #adc1c5); }

/* Geoeffnete Marke: ruhig im Primaerton markiert (statt hartem Rot). */
.shop-linenav details[open] {
    border-color: var(--primary, #90a7ac);
    box-shadow: 0 1px 4px rgba(144, 167, 172, .12);
}

/* Marken-Kopfzeile (summary): kompakter, klarer Hover-Hintergrund. */
.shop-linenav summary {
    padding: .62rem .85rem;
    font-size: .9rem;
    color: var(--text, #2d2d2d);
    transition: background .12s, color .12s;
}
.shop-linenav summary:hover { background: var(--bg-soft, #f8f8f8); }
.shop-linenav details[open] > summary {
    background: var(--bg-soft, #f8f8f8);
    color: var(--primary-dark, #7a9499);
}
.shop-linenav summary::after { color: var(--primary, #90a7ac); }

/* Marken-Count rechts: als dezenter Zaehl-Chip statt nackter Zahl. */
.shop-linenav summary .ln-brand-count {
    min-width: 1.5rem;
    padding: .08rem .4rem;
    border-radius: 999px;
    background: var(--bg-soft, #f8f8f8);
    color: var(--muted, #6e7679);
    text-align: center;
    font-size: .72rem;
    line-height: 1.3;
}
.shop-linenav details[open] > summary .ln-brand-count {
    background: var(--primary-soft, #adc1c5);
    color: var(--white, #fff);
}

/* Linien-Liste: bei sehr vielen Linien je Marke eigenes Scroll-Limit,
   damit eine grosse Marke (z.B. NuSkin mit 16 Linien) die Sidebar nicht
   ueberlaeuft. Dezenter Trenner zur summary. */
.shop-linenav .ln-lines {
    padding: .35rem .4rem .5rem;
    max-height: 19rem;
    overflow-y: auto;
    border-top: 1px solid var(--border, #e8eaed);
    scrollbar-width: thin;
    scrollbar-color: var(--primary-soft, #adc1c5) transparent;
}
.shop-linenav .ln-lines::-webkit-scrollbar { width: 5px; }
.shop-linenav .ln-lines::-webkit-scrollbar-thumb {
    background: var(--primary-soft, #adc1c5);
    border-radius: 999px;
}

/* Einzelne Linien-Zeile: kompakter, klare Trennung, gleichmaessige Hoehe. */
.shop-linenav .ln-line {
    padding: .4rem .6rem;
    font-size: .855rem;
    line-height: 1.35;
    border-radius: var(--radius-sm, 6px);
    transition: background .12s, color .12s, padding-left .12s;
}
.shop-linenav .ln-line:hover {
    background: var(--bg-soft, #f8f8f8);
    color: var(--primary-dark, #7a9499);
    padding-left: .8rem;
}

/* Aktive Linie: klar im Primaerton, mit weichem Akzentstreifen links. */
.shop-linenav .ln-line.active {
    background: var(--primary, #90a7ac);
    color: var(--white, #fff);
    font-weight: 500;
    box-shadow: inset 3px 0 0 var(--primary-dark, #7a9499);
}
.shop-linenav .ln-line.active:hover {
    background: var(--primary, #90a7ac);
    color: var(--white, #fff);
    padding-left: .6rem;
}

/* Linien-Count: als dezenter Chip, in der aktiven Zeile invertiert. */
.shop-linenav .ln-line .ln-cnt {
    flex: 0 0 auto;
    min-width: 1.4rem;
    padding: .03rem .35rem;
    border-radius: 999px;
    background: var(--bg-soft, #f8f8f8);
    color: var(--muted, #6e7679);
    text-align: center;
    font-size: .7rem;
    opacity: 1;
}
.shop-linenav .ln-line:hover .ln-cnt {
    background: var(--white, #fff);
}
.shop-linenav .ln-line.active .ln-cnt {
    background: rgba(255, 255, 255, .25);
    color: var(--white, #fff);
}


/* ==================================================================
   2. LINIEN-HERO / BESCHREIBUNG ueber der Produktliste
   Ziel: edel gesetzte Linienbeschreibung im Seitenkopf.
   ================================================================== */

/* Linien-Beschreibung: ruhige Typo, edler Goldakzent-Trenner darueber. */
.page-title-block .shop-line-desc {
    position: relative;
    margin-top: 1.1rem;
    padding-top: 1.1rem;
    color: var(--muted, #6e7679);
    font-size: 1rem;
    line-height: 1.7;
}
.page-title-block .shop-line-desc::before {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 48px;
    height: 2px;
    background: var(--gold, #dabe92);
    border-radius: 999px;
}


/* ==================================================================
   3. PRODUKTSEITEN-VARIANTEN (Groesse / Farbton / Kaufoption)
   Ziel: sauber, konsistent — inkl. der neuen .opt-pill-Kaufoptionen.
   Die Detail-Optik der .opt-pill steckt in v3_option_css.css; hier nur
   ergaenzender Feinschliff der gemeinsamen Variantenoptik.
   ================================================================== */

/* Varianten-Block: dezent vom Beschreibungstext abgesetzt. */
.pdp-variants {
    padding-top: 1.2rem;
    border-top: 1px solid var(--border, #e8eaed);
}

/* Varianten-Gruppen: gleichmaessiger Abstand, letzte ohne Extra-Abstand. */
.pdp-variant-group:last-child { margin-bottom: 0; }

/* Varianten-Label: konsistent als kleine Caps-Ueberschrift. */
.pdp-variant-label {
    text-transform: uppercase;
    letter-spacing: .07em;
    font-size: .76rem;
    color: var(--muted, #6e7679);
}
/* Aktuelle Auswahl rechts daneben: lesbar, im Textton. */
.pdp-variant-current {
    text-transform: none;
    letter-spacing: 0;
    color: var(--text, #2d2d2d);
    font-weight: 500;
}

/* Pill-Optionen (Groesse): einheitliche Mindestbreite, vertikal zentriert,
   damit Pills unterschiedlicher Textlaenge sauber in Reihe sitzen. */
.pdp-variant-options.is-pills .pdp-variant-opt {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 3.2rem;
    border-radius: var(--radius-sm, 6px);
    color: var(--text, #2d2d2d);
    transition: border-color .15s, box-shadow .15s, background .15s, color .15s;
}

/* Konsistenter, klarer Tastatur-Fokus auf allen Varianten-Buttons. */
.pdp-variant-opt:focus-visible {
    outline: 0;
    border-color: var(--primary, #90a7ac);
    box-shadow: 0 0 0 3px rgba(144, 167, 172, .25);
}

/* Ausgewaehlte Pill/Shade: Akzent ruhig im Brand-Primaerton statt Rot-Fallback. */
.pdp-variant-opt.selected {
    border-color: var(--primary, #90a7ac);
    box-shadow: 0 0 0 1px var(--primary, #90a7ac);
    color: var(--primary-dark, #7a9499);
}
.pdp-variant-opt.shade.selected {
    box-shadow: 0 0 0 2px var(--primary, #90a7ac);
}
.pdp-variant-opt:hover { border-color: var(--primary, #90a7ac); }

/* Kaufoptionen (.opt-pill): nur Feinschliff — Marker/Badges aus
   v3_option_css.css bleiben unangetastet. Etwas mehr Tiefe beim Hover,
   ruhiger Akzent bei Auswahl. */
.pdp-variant-opt.opt-pill {
    border-radius: var(--radius-sm, 6px);
}
.pdp-variant-opt.opt-pill:hover {
    box-shadow: 0 1px 4px rgba(31, 37, 40, .07);
}
.pdp-variant-opt.opt-pill.selected {
    background: var(--bg-light, #fcfcfc);
}


/* ==================================================================
   4. PRODUKTKARTEN IM GRID
   Ziel: konsistente Hoehe und Abstaende, ruhiger Hover.
   ================================================================== */

/* Karten gleich hoch ausrichten — Body fuellt Resthoehe, Preis sitzt unten. */
.product-card {
    height: 100%;
    border-radius: var(--radius-md, 10px);
    overflow: hidden;
    transition: transform .2s ease, box-shadow .2s ease;
}
.product-card .product-media {
    border-radius: var(--radius-sm, 6px);
}
.product-card .product-body {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    padding: 1rem .25rem 1.1rem;
}

/* Titel: gleichmaessige Hoehe ueber zwei Zeilen, damit Preise auf einer
   Linie liegen — egal ob der Produktname kurz oder lang ist. */
.product-card .product-title {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    min-height: 2.6em;
    line-height: 1.3;
}

/* Preis nach unten geschoben — bleibt ueber alle Karten buendig. */
.product-card .product-price {
    margin-top: auto;
    padding-top: .35rem;
    font-size: 1.05rem;
}

/* Rating-/Anamnese-Meta direkt unter dem Preis ruhig gestaffelt. */
.product-card .shop-product-meta { margin-top: .4rem; }

/* Dezenter Hover: leichtes Anheben + weicher Schatten (Karte ist ein <a>). */
.product-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 6px 20px rgba(31, 37, 40, .08);
}
@media (hover: none) {
    .product-card:hover { transform: none; box-shadow: none; }
}


/* ==================================================================
   5. RESPONSIVE — Mobil / Tablet
   Desktop-Verhalten aus site.css / online-shop.php bleibt erhalten.
   ================================================================== */

/* Tablet: Linien-Liste darf etwas hoeher werden, da mehr Platz. */
@media (max-width: 900px) and (min-width: 601px) {
    .shop-linenav .ln-lines { max-height: 24rem; }
}

/* Mobil: Sidebar steht statisch (site.css) — Linien-Liste ohne eigenes
   Scroll-Limit, damit nichts doppelt scrollt. Karten kompakter. */
@media (max-width: 600px) {
    .shop-linenav .ln-lines { max-height: none; overflow-y: visible; }
    .shop-linenav summary { padding: .7rem .8rem; }
    .shop-linenav .ln-line { padding: .5rem .6rem; font-size: .9rem; }

    .product-card .product-body { padding: .8rem .15rem 1rem; }
    .product-card .product-title { min-height: 0; }
    .product-card:hover { transform: none; box-shadow: none; }

    .page-title-block .shop-line-desc { font-size: .95rem; }

    .pdp-variant-options.is-pills .pdp-variant-opt { min-width: 2.8rem; }
}

/* === ENDE LINIEN & PRODUKTSEITE FEINSCHLIFF v4 === */



/* === HARMONIE-FEINSCHLIFF v5 === */
/*
 * Finaler, rein additiver CSS-Feinschliff fuer den Online-Shop von
 * "Art of Beauty Trier" — Ziel: ein harmonisches, edles, ruhiges
 * Gesamtbild aus einem Guss (Beauty-Studio: Teal / Gold / Soft).
 *
 * NUR CSS. Keine PHP-/Markup-Aenderung. Alle Selektoren treffen exakt
 * vorhandene Klassen aus online-shop.php, product.php, includes/header.php
 * und assets/css/site.css. Genutzt werden die bestehenden :root-Tokens
 * (--primary, --gold, --muted, --bg-soft, --radius-* ...); Fallbacks
 * decken fehlende Tokens ab.
 *
 * Dieser Block wird NACH site.css und nach den <style>-Bloecken in den
 * Templates geladen — er harmonisiert gezielt verbliebene Disharmonien
 * der frueheren Passes (Polish-Pass, Linien, Kaufoptionen, v4) und
 * ueberschreibt nichts unnoetig.
 *
 * Erstellt: 2026-05-22  |  Pfad: tools/lines/v5_harmonie.css
 * --------------------------------------------------------------------
 *  1. Farb-Harmonisierung — Rot/Blau-Fremdkoerper auf Brand-Palette
 *  2. Buttons & Pills — einheitliche Form (sanft gerundet)
 *  3. Produktkarten — ruhiges, einheitliches Raster
 *  4. Badges auf Produktkarten — konsistente Optik & Position
 *  5. Kategorie-Hero — ruhige Typo, einheitlicher Goldakzent
 *  6. Sidebar-Filter — Inputs/Chips aus einem Guss
 *  7. Shop-Toolbar — Sortier-Select harmonisiert
 *  8. Produktseite — Hero-Bild, Varianten, Kaufoptionen, Tabs
 *  9. Compat-/Anfrage-Boxen — auf Brand-Toene gebracht
 * 10. Responsive-Feinschliff
 * ==================================================================== */


/* ====================================================================
   1. FARB-HARMONISIERUNG
   Mehrere Shop-Elemente nutzen noch hartes Signal-Rot (#c93030 / #a32020)
   bzw. ein Blau (#0066cc) aus aelteren Passes. Das beisst sich mit der
   ruhigen Teal/Gold-Brand. Hier werden Sale-/Hinweis-Akzente auf einen
   warmen Gold-Ton (--gold-dark) bzw. den Primaerton gebracht — Signal-Rot
   bleibt nur fuer echte Warnungen (Auslauf, Block) erhalten.
   ==================================================================== */

/* Sale-Badge & Sale-Preis: edler Gold-Akzent statt grellem Rot. */
.shop-sale-badge {
    background: var(--gold-dark, #b89261);
    color: var(--white, #fff);
    border-radius: var(--radius-pill, 999px);
    padding: .22em .62em;
    box-shadow: 0 2px 6px rgba(184, 146, 97, .28);
}
.product-price-sale {
    color: var(--gold-dark, #b89261);
}

/* Filter-Chip "entfernen": Rot raus, dezenter Muted-/Primaer-Ton rein. */
.shop-chip {
    background: var(--bg-soft, #f8f8f8);
    border: 1px solid var(--border, #e8eaed);
    border-radius: var(--radius-pill, 999px);
    color: var(--text, #2d2d2d);
}
.shop-chip a {
    color: var(--muted, #6e7679);
    border-left-color: var(--border, #e8eaed);
    transition: color .15s ease;
}
.shop-chip a:hover {
    color: var(--primary-dark, #7a9499);
}


/* ====================================================================
   2. BUTTONS & PILLS — EINHEITLICHE FORM
   Basis-.btn ist scharfkantig (--radius:0), die Pill-Toggles dagegen
   voll rund. Auf einer Seite (Kategorie-Hero + Sidebar-Button) wirkt das
   uneinheitlich. Loesung: alle Buttons bekommen eine dezente, gleiche
   weiche Rundung (--radius-sm) — die echten Pill-Toggles bleiben rund.
   ==================================================================== */

.btn, button.btn, a.btn, .button, button.button, a.button {
    border-radius: var(--radius-sm, 6px);
}
/* Pill-Toggles bleiben bewusst voll rund — Form klar abgegrenzt. */
.btn-pill, .pill-group .btn-pill {
    border-radius: var(--radius-pill, 999px);
}
/* Pill-Gruppe & Varianten-Pills auf gleiche Hoehe wie Buttons bringen. */
.pill-group .btn-pill {
    min-height: 40px;
}
/* Sidebar-"Filter anwenden": gleiche Form wie alle Buttons, ruhiger Stand. */
.shop-sidebar form > .btn {
    border-radius: var(--radius-sm, 6px);
    letter-spacing: .01em;
}


/* ====================================================================
   3. PRODUKTKARTEN — RUHIGES, EINHEITLICHES RASTER
   Produktkarten erscheinen im Shop, in Cross-Sell und in den
   Marken-Kacheln. Ziel: gleiche Innenabstaende, gleiche Bildflaeche,
   ruhiger einheitlicher Hover ueberall.
   ==================================================================== */

/* Etwas grosszuegigeres, gleichmaessiges Gap im Raster. */
.product-grid {
    gap: 1.6rem;
}

/* Bildflaeche: weiche Rundung an die Karte angeglichen, ruhiger Innenrand. */
.product-card .product-media {
    background: var(--bg-soft, #f8f8f8);
    border-radius: var(--radius-md, 10px);
    padding: 16px;
}

/* Karte: dezente, einheitliche Rundung — Hover ueber site.css harmonisiert. */
.product-card {
    border-radius: var(--radius-md, 10px);
}

/* Marke einheitlich klein & ruhig — gleich ueber alle Karten. */
.product-card .product-brand {
    color: var(--muted, #6e7679);
}

/* Preis edel im Primaerton, klare Groesse. */
.product-card .product-price {
    color: var(--primary-dark, #7a9499);
    font-weight: 500;
}

/* Durchgestrichener Alt-Preis: ruhiger Muted-Ton. */
.product-price-strike {
    color: var(--muted, #6e7679);
}


/* ====================================================================
   4. BADGES AUF PRODUKTKARTEN — KONSISTENTE OPTIK
   Sale-Badge, Auslauf-Badge und Galerie-Badge hatten unterschiedliche
   Radien, Positionen und Schatten. Hier auf eine gemeinsame Sprache:
   gleiche Ecken-Distanz, gleiche Pill-Form, gleiche dezente Tiefe.
   ==================================================================== */

.shop-sale-badge,
.shop-auslauf-badge {
    top: var(--sp-3, 12px);
    left: var(--sp-3, 12px);
}
.shop-gallery-badge {
    right: var(--sp-3, 12px);
    bottom: var(--sp-3, 12px);
    background: rgba(31, 37, 40, .72);
    border-radius: var(--radius-pill, 999px);
}
/* Auslauf-Badge bleibt im Warn-Rot (echte Warnung) — nur Form angeglichen. */
.shop-auslauf-badge {
    border-radius: var(--radius-pill, 999px);
    font-weight: 600;
}


/* ====================================================================
   5. KATEGORIE-HERO — RUHIGE TYPO, EINHEITLICHER GOLDAKZENT
   Der .page-title-block tritt auf Shop-, Kategorie- und Voucher-Ansicht
   auf. Ziel: gleicher Rhythmus, ein einziger Gold-Trenner als Akzent.
   ==================================================================== */

/* Lead-Text (Shop/Voucher) ruhiger setzen — gleiche Anmutung wie .shop-line-desc. */
.page-title-block .lead {
    color: var(--muted, #6e7679);
    font-weight: 300;
    max-width: 640px;
    margin-left: auto;
    margin-right: auto;
}

/* Pill-Gruppe im Hero einheitlich zentriert mit ruhigem Abstand. */
.page-title-block .pill-group {
    justify-content: center;
}


/* ====================================================================
   6. SIDEBAR-FILTER — INPUTS AUS EINEM GUSS
   Such-, Preis- und Sortier-Felder hatten teils scharfe, teils runde
   Ecken. Alle Formularfelder im Shop bekommen die gleiche weiche
   Rundung und einen einheitlichen Fokus-Ring im Primaerton.
   ==================================================================== */

.shop-search,
.shop-price-range input,
.shop-toolbar select {
    border-radius: var(--radius-sm, 6px);
    transition: border-color .15s ease, box-shadow .15s ease;
}
.shop-search:focus,
.shop-price-range input:focus,
.shop-toolbar select:focus {
    outline: 0;
    border-color: var(--primary, #90a7ac);
    box-shadow: 0 0 0 3px rgba(144, 167, 172, .18);
}

/* Filter-Checkbox-Zeilen: dezenter, gleichmaessiger Hover. */
.shop-filter-group label {
    border-radius: var(--radius-sm, 6px);
    padding-left: .3em;
    padding-right: .3em;
    transition: background .12s ease, color .12s ease;
}
.shop-filter-group label:hover {
    background: var(--bg-soft, #f8f8f8);
}

/* "Alle Filter zuruecksetzen": ruhiger Muted-Link, gleicher Ton wie Chips. */
.shop-clear-all {
    color: var(--muted, #6e7679);
}
.shop-clear-all:hover {
    color: var(--primary-dark, #7a9499);
}


/* ====================================================================
   7. SHOP-TOOLBAR — SORTIER-SELECT HARMONISIERT
   Ergebniszeile + Sortierung sollen optisch ruhig auf gleicher Linie
   sitzen; das Select wird an die uebrigen Inputs angeglichen.
   ==================================================================== */

.shop-toolbar select {
    background: var(--white, #fff);
    color: var(--text, #2d2d2d);
}
.shop-toolbar .result-count em {
    color: var(--primary-dark, #7a9499);
    font-style: normal;
}


/* ====================================================================
   8. PRODUKTSEITE — HERO-BILD, VARIANTEN, TABS
   ==================================================================== */

/* Produkt-Hero-Bild: hartes #f6f6f6/#e6e6e6 auf Brand-Tokens bringen,
   damit es exakt wie die Produktkarten-Bildflaeche wirkt. */
.split-image.product-image {
    background: var(--bg-soft, #f8f8f8);
    border-color: var(--border, #e8eaed);
    border-radius: var(--radius-lg, 14px);
}

/* PDP-Galerie-Thumbs: aktive Auswahl im Primaerton statt Default-Akzent. */
.pdp-gallery-thumb.active {
    border-color: var(--primary, #90a7ac);
    box-shadow: 0 0 0 1px var(--primary, #90a7ac);
}

/* Variantengruppen: gleichmaessiger vertikaler Rhythmus. */
.pdp-variant-group { margin-bottom: 1.1rem; }

/* Mengen-Feld im Kauf-Formular an die uebrigen Inputs angleichen. */
#product-buy-form input[type="number"] {
    border-radius: var(--radius-sm, 6px);
}

/* Produktseiten-Tabs: aktiver Tab klar im Primaerton, ruhiger Hover. */
.pde-tab {
    transition: color .15s ease, border-color .15s ease;
}
.pde-tab:hover {
    color: var(--primary-dark, #7a9499);
}
.pde-panel {
    border-radius: 0 0 var(--radius-sm, 6px) var(--radius-sm, 6px);
}

/* Cross-Sell-Liste: gleiches ruhiges Raster wie der Haupt-Shop. */
.product-detail-extra + .section-soft .product-grid { gap: 1.6rem; }


/* ====================================================================
   9. COMPAT- / ANFRAGE-BOXEN — AUF BRAND-TOENE
   Die Info-Variante der Compat-Box und die "Auf Anfrage"-Box nutzten ein
   kuehles Blau. Info-Hinweise werden auf den ruhigen Primaerton gebracht;
   Block (rot) und Warn (gold) bleiben als echte Signalstufen bestehen.
   ==================================================================== */

.compat-block-card {
    border-radius: var(--radius-md, 10px);
}
.compat-block-card[data-status="info"] {
    background: rgba(144, 167, 172, .12);
    border-color: var(--primary, #90a7ac);
    color: var(--primary-dark, #7a9499);
}

/* "Preis auf Anfrage"-Box: neutral-soft statt Blau. */
.pdp-request-box {
    background: var(--bg-soft, #f8f8f8) !important;
    border-color: var(--border, #e8eaed) !important;
    border-radius: var(--radius-md, 10px) !important;
}


/* ====================================================================
   10. RESPONSIVE-FEINSCHLIFF
   Desktop-Verhalten aus site.css / v4 bleibt erhalten — hier nur
   Abstands-Glaettung, damit das harmonische Bild auch mobil traegt.
   ==================================================================== */

@media (max-width: 600px) {
    .product-grid { gap: 1rem; }
    .product-card .product-media { padding: 12px; }
    .shop-sale-badge,
    .shop-auslauf-badge {
        top: var(--sp-2, 8px);
        left: var(--sp-2, 8px);
    }
    .shop-gallery-badge {
        right: var(--sp-2, 8px);
        bottom: var(--sp-2, 8px);
    }
    .page-title-block .lead { font-size: .95rem; }
}

/* === ENDE HARMONIE-FEINSCHLIFF v5 === */

/* === Galerie-Fix: bei Mehrfachbild-Galerie den 1:1-Container aufheben,
       sonst werden die Thumbnails durch aspect-ratio:1/1 + overflow:hidden
       abgeschnitten. Generische img-Regeln nicht auf Thumbs anwenden. === */
.split-image.product-image.has-gallery {
    aspect-ratio: auto;
    overflow: visible;
    padding: 1rem;
    background: transparent;
    border: none;
}
.split-image.product-image.has-gallery:hover {
    border-color: transparent;
    box-shadow: none;
}
.split-image.product-image.has-gallery > img,
.split-image.product-image.has-gallery:hover > img { transform: none; }
.split-image.product-image.has-gallery .pdp-gallery-main {
    border: 1px solid var(--border, #e6e6e6);
    background: #f6f6f6;
    border-radius: var(--radius-lg, 12px);
}
.split-image.product-image.has-gallery .pdp-gallery-main img {
    width: 100%; height: auto; aspect-ratio: 1/1;
    object-fit: contain; padding: 1.25rem;
}
.split-image.product-image.has-gallery .pdp-gallery-thumb {
    aspect-ratio: 1/1;
    min-height: 60px;
}
.split-image.product-image.has-gallery .pdp-gallery-thumb img {
    width: 100%; height: 100%;
    object-fit: contain; padding: 4px;
}
@media (max-width: 940px) {
    .split-image.product-image.has-gallery { padding: .5rem; }
    .split-image.product-image.has-gallery .pdp-gallery-main img { padding: .75rem; }
}
/* === /Galerie-Fix === */

/* ======================================================================
   WAVE 72 — CARD POLISH + QW-04 CONSOLIDATION
   Einheitliche Karten-Optik (1px Border, dezenter Hover-Shadow),
   Brand-Tag in Gold, Auslauf-Karten leicht entsaettigt.
   Letzte Cascade-Position -> ueberschreibt frueher gesetzte Defaults.
   ====================================================================== */

/* 1. Border + ruhiger Hover-Shadow auf jeder Produktkarte. */
.product-card {
    border: 1px solid var(--border);
    background: var(--white);
}
.product-card:hover {
    box-shadow: var(--shadow-md);
    border-color: rgba(184, 146, 97, .25); /* leichter Gold-Hauch */
}
@media (hover: none) {
    .product-card:hover { box-shadow: none; border-color: var(--border); }
}

/* 2. Brand-Tag in Gold — konsistent ueber Shop + Kategorie-Seiten.
      Ueberschreibt frueheres var(--muted) (Z. 951 + 6794). */
.product-card .product-brand {
    color: var(--gold-dark);
    font-weight: 500;
}

/* 3. Auslauf-Karten: leicht entsaettigt, dezenter Badge-Stil.
      Beibehaltung des bestehenden roten Frames (s. Z. 3041) ohne ihn
      aggressiver zu machen — Filter wirkt nur auf Medienbereich. */
.product-card-auslauf .product-media {
    filter: grayscale(.25) saturate(.9);
    opacity: .94;
}
.product-card-auslauf:hover .product-media {
    filter: grayscale(.1) saturate(.95);
    opacity: 1;
}
.product-card-auslauf::after {
    border-width: 1px;
    border-color: rgba(201,48,48,.55);
    border-radius: var(--radius-md);
}
.product-card-auslauf .product-title {
    color: var(--text); /* statt #c93030 — ruhiger, Badge traegt die Botschaft */
}
.product-card-auslauf .badge-auslauf,
.product-card-auslauf .product-badge-auslauf {
    background: #c93030;
    color: var(--white);
    border-radius: var(--radius-pill);
    box-shadow: 0 2px 6px rgba(201,48,48,.25);
}

/* === /Wave 72 — Card Polish === */

/* =============================================================================
   Wave 81 — R2 Color-Contrast Fixes (WCAG AA, ratio >= 4.5:1)
   Adressiert v73-Audit-Findings auf: Mobile-Nav-Aktiv, Cookie-Banner, PDP-Tabs,
   Shop-Brand-Headlines, Filter-FAB, Result-Count, External-Reviews-Footer.
   ============================================================================= */

/* Mobile-Nav aktiver Link — vorher heller Akzent auf hellem Bg */
.mobile-nav a.active,
.mobile-nav .nav-item.active a,
nav.mobile-nav a[aria-current="page"] {
    color: var(--text, #2a2620) !important;
    background: rgba(218, 190, 146, .25);
    font-weight: 600;
}

/* Cookie-Banner — sicherstellen dass Text klar lesbar ist */
.cookie-banner, .aob-cookie, [data-cookie-banner] {
    color: var(--text, #2a2620);
    background: #fff;
    border: 1px solid var(--border, #e8eaed);
    box-shadow: 0 -2px 16px rgba(0,0,0,.12);
}
.cookie-banner a, .aob-cookie a, [data-cookie-banner] a {
    color: var(--primary, #4a7a5c);
    text-decoration: underline;
}
.cookie-banner button, .aob-cookie button, [data-cookie-banner] button {
    border: 1px solid var(--primary, #4a7a5c);
}

/* PDP-Tabs — inaktive Tabs hatten muted-grau auf weiß */
.pde-tab { color: #555 !important; }
.pde-tab.active, .pde-tab[aria-selected="true"] {
    color: var(--primary, #4a7a5c) !important;
    font-weight: 600;
}
.pde-tab:focus-visible {
    outline: 2px solid var(--primary, #4a7a5c);
    outline-offset: 2px;
}

/* Shop Brand-Headlines — Sektion-Überschriften müssen kräftig sein */
.shop-brand-headline { color: var(--text, #2a2620); font-weight: 600; }
.shop-brand-headline-row .shop-brand-cta { color: var(--primary, #4a7a5c) !important; }

/* Filter-FAB — Schriftfarbe auf primärem Hintergrund */
.shop-filter-mobile-fab {
    color: #fff !important;
    background: var(--primary, #4a7a5c);
}
.shop-filter-mobile-fab .shop-filter-fab-badge { color: var(--primary, #4a7a5c); background: #fff; }
.shop-filter-mobile-fab:focus-visible { outline: 3px solid var(--gold, #dabe92); outline-offset: 2px; }

/* Shop-Toolbar Result-Count — Muted-Color war zu hell */
.shop-toolbar .result-count { color: #555 !important; }
.shop-toolbar .result-count strong { color: var(--text); }

/* External Reviews Footer — Quellenangabe sichtbar */
.external-reviews-section .er-card__source a,
.external-reviews-section .er-card__date {
    color: #5b5b5b !important;
}

/* Globale Focus-Outline-Verbesserung — sichtbar auf allen interaktiven Elementen */
a:focus-visible, button:focus-visible, [role="button"]:focus-visible,
input:focus-visible, select:focus-visible, textarea:focus-visible {
    outline: 2px solid var(--primary, #4a7a5c);
    outline-offset: 2px;
}

/* prefers-reduced-motion: animations deaktivieren */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
}
/* === /Wave 81 R2 === */


/* === Wave 80: Vorher-Nachher Galerien (v80_galleries.php) === */
.vn-gallery-group { margin-top: 2.4rem; }
.vn-gallery-name {
    text-align: center;
    font-weight: 600;
    font-size: 1.15rem;
    margin: 1.4rem 0 1.2rem;
    letter-spacing: .02em;
    color: var(--black, #222);
}
.vn-card {
    margin: 0;
    background: var(--white, #fff);
    overflow: hidden;
    box-shadow: var(--shadow-sm, 0 1px 4px rgba(0,0,0,.08));
    transition: transform 200ms ease, box-shadow 200ms ease;
    display: flex;
    flex-direction: column;
    cursor: zoom-in;
}
.vn-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 6px 18px rgba(0,0,0,.12);
}
.vn-card img {
    width: 100%;
    height: auto;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    display: block;
}
.vn-card figcaption {
    padding: .6rem .8rem;
    font-size: .85rem;
    color: var(--muted, #666);
    text-align: center;
    border-top: 1px solid var(--border, #eee);
    background: #fafafa;
}
.vn-card .vn-pos {
    font-weight: 400;
    opacity: .7;
}
@media (max-width: 600px) {
    .vn-gallery-group .services-grid { grid-template-columns: repeat(2, 1fr) !important; gap: .6rem !important; }
}

/* Wave 86E: Mini-Galerien (1-2 Bilder) duerfen nicht stretchen — Cards bleiben gleich gross
   wie in den 4-Spalten-Galerien daneben. Erzwingt feste Spaltenbreite ueber den auto-fit hinaus. */
.vn-gallery-group .services-grid {
    grid-template-columns: repeat(auto-fill, minmax(220px, 280px)) !important;
    justify-content: center;
}
@media (max-width: 600px) {
    .vn-gallery-group .services-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}
/* === /Wave 80 === */

/* === Wave 83E (Portrait-Photo-Support fuer Produkt-Karten) ============
 * Wenn ein Produktbild im 1:1-Slot hochformatig ist (h > w, z.B. echte
 * Studio-Photography statt Packshot mit transparentem Background),
 * dann edge-to-edge mit object-fit:cover anzeigen statt mit cream-Bars.
 * Klasse `.is-portrait` wird von einem winzigen JS-Snippet in
 * includes/footer.php zur Laufzeit gesetzt (img.onload Aspect-Check).
 * ====================================================================== */
.product-card .product-media.is-portrait {
    padding: 0;
    background: transparent;
}
.product-card .product-media.is-portrait img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}
/* === /Wave 83E === */

/* === Wave 83E-PDP (Produkt-Detail-Layout-Fix) ==========================
 * Vor dem Fix: Text-Spalte oft 2x so lang wie das quadratische
 * .split-image.product-image-Box → grosse weisse Flaeche unter dem Bild,
 * Bild "haengt" alleine oben. Loesung: Bild oben anheften (sticky) und
 * vertikal am Top der Zeile ausrichten, plus den max-width sanft cappen,
 * damit das Quadrat auf grossen Viewports nicht uebermaessig wird.
 * Mobile (<940px) bleibt der bestehende 1-Spalten-Stack.
 * ====================================================================== */
@media (min-width: 941px) {
    .split:has(.split-image.product-image) {
        align-items: start;
    }
    .split-image.product-image {
        position: sticky;
        top: 96px;                 /* unter dem fixen Header */
        align-self: start;
        max-width: 560px;
        width: 100%;
        margin-left: auto;         /* falls Bild rechts, sonst auto-auto */
        margin-right: auto;
    }
}
/* Portrait-Foto (h > w) im PDP edge-to-edge, kein cream-Padding.
   Wichtig: Wave-76 Auto-Lightbox wickelt das img in ein <a> — daher
   descendant-Selektor (nicht `> img`), sonst greift die Regel nicht. */
.split-image.product-image.is-portrait-photo {
    padding: 0;
    background: transparent;
}
.split-image.product-image.is-portrait-photo img {
    object-fit: cover !important;
    object-position: center;
}
/* === /Wave 83E-PDP === */

/* === Wave 83F (V/N-Galerien lesbarer machen) ==========================
 * Problem: Plasma-Pen / Microneedling / etc. nutzen noch `.collage-thumb`
 * fuer ihre Vorher-Nachher-Bilder. Diese Klasse war urspruenglich fuer
 * die Home-Collage gedacht (80-130px runde Kreise mit Tilt-Rotation).
 * In einer V/N-Galerie ist das viel zu klein und kreisrunder Crop
 * versteckt gerade Hals/Stirn/Wangen-Details, die man sehen WILL.
 *
 * Fix: nur wenn `.collage-thumb` Kind einer `.services-grid` ist
 * (das ist die V/N-Sektion, nie die Home-Collage), groesser machen,
 * quadratisch statt rund, Tilt entfernen.
 * ====================================================================== */
.services-grid > .collage-thumb {
    width: 100%;
    height: auto;
    aspect-ratio: 1 / 1;
    border-radius: 14px;
    border: 1px solid var(--border, #e3e3e3);
    box-shadow: 0 2px 10px rgba(0,0,0,.06);
    transform: none !important;     /* killt die nth-child-Rotationen aus .collage */
    margin: 0 !important;
    background: #fff;
}
.services-grid > .collage-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 14px;
    transition: transform 500ms cubic-bezier(.25,.46,.45,.94);
}
.services-grid > .collage-thumb:hover {
    transform: translateY(-3px) !important;
    box-shadow: 0 10px 28px rgba(0,0,0,.12);
    border-color: var(--primary, #90a7ac);
}
.services-grid > .collage-thumb:hover img {
    transform: scale(1.06);
}

/* Galerie-Grid in V/N-Sektionen sinnvoll dimensionieren —
   nicht zu winzig, nicht zu wenige Spalten. */
.section .services-grid,
.section-soft .services-grid {
    /* default minmax 280 ist gut, hier nur sicherstellen, dass V/N saubere
       Reihen ergibt (~ 3-4 per row auf desktop, 2 tablet, 1-2 phone). */
}
@media (min-width: 1100px) {
    .services-grid:has(> .collage-thumb) {
        grid-template-columns: repeat(4, 1fr) !important;
        gap: 1.2rem !important;
    }
}
@media (min-width: 700px) and (max-width: 1099px) {
    .services-grid:has(> .collage-thumb) {
        grid-template-columns: repeat(3, 1fr) !important;
        gap: 1rem !important;
    }
}
@media (max-width: 699px) {
    .services-grid:has(> .collage-thumb) {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: .7rem !important;
    }
}

/* Kleines "VOR / NACH"-Hinweis-Banner ueber der Galerie, damit der User
   weiss, dass die Bilder paarweise zu lesen sind. */
.section .services-grid:has(> .collage-thumb)::before,
.section-soft .services-grid:has(> .collage-thumb)::before {
    content: "Bilder paarweise lesen — links: Vorher, rechts: Nachher. Klick fuer Vollbild.";
    display: block;
    grid-column: 1 / -1;
    font-size: .82rem;
    color: var(--muted, #777);
    text-align: center;
    margin-bottom: .75rem;
    letter-spacing: .02em;
}
/* === /Wave 83F === */

/* === Wave 83I (Online-Shop Firstvoucher-Look) ===
   Hero, Featured-Tiles, Pills-Block + Brand-Tile-Politur.
   Scoped via .fv-shop-* — kein Konflikt mit shop-line-hero / shop-brand-section. */

.fv-shop-hero {
    position: relative;
    overflow: hidden;
    margin: 0 0 2.4rem;
    min-height: 460px;
    display: flex;
    align-items: center;
    color: #fff;
}
.fv-shop-hero__bg {
    position: absolute; inset: 0;
    z-index: 0;
}
.fv-shop-hero__bg::after {
    content: "";
    position: absolute; inset: 0;
    background: linear-gradient(115deg, rgba(20,18,16,.78) 0%, rgba(40,30,24,.55) 55%, rgba(20,18,16,.35) 100%);
}
.fv-shop-hero__bg img {
    width: 100%; height: 100%;
    object-fit: cover; object-position: center 35%;
    display: block;
}
.fv-shop-hero__inner {
    position: relative;
    z-index: 1;
    padding: 3.2rem 1.2rem 3rem;
    max-width: 760px;
}
.fv-shop-hero__eyebrow {
    margin: 0 0 .8rem;
    font-size: .76rem;
    text-transform: uppercase;
    letter-spacing: .22em;
    color: var(--gold, #dabe92);
    font-weight: 500;
}
.fv-shop-hero__title {
    margin: 0 0 .9rem;
    font-size: clamp(1.85rem, 4.2vw, 2.9rem);
    line-height: 1.12;
    font-weight: 400;
    letter-spacing: .005em;
    color: #fff;
}
.fv-shop-hero__lead {
    margin: 0 0 1.6rem;
    font-size: clamp(1rem, 1.6vw, 1.12rem);
    line-height: 1.55;
    color: rgba(255,255,255,.92);
    max-width: 620px;
}
.fv-shop-hero__ctas {
    display: flex;
    flex-wrap: wrap;
    gap: .7rem .8rem;
    margin-bottom: 1.8rem;
}
.fv-shop-hero__cta-primary {
    background: var(--primary, #c93030);
    color: #fff;
    border: 1px solid var(--primary, #c93030);
    padding: .95em 1.6em;
    letter-spacing: .08em;
    font-weight: 500;
    text-transform: uppercase;
    font-size: .82rem;
}
.fv-shop-hero__cta-primary:hover {
    background: #a82525;
    border-color: #a82525;
    transform: translateY(-1px);
}
.fv-shop-hero__cta-secondary.btn-outline {
    border-color: rgba(255,255,255,.7);
    color: #fff;
    background: transparent;
    padding: .95em 1.6em;
    letter-spacing: .08em;
    font-weight: 500;
    text-transform: uppercase;
    font-size: .82rem;
}
.fv-shop-hero__cta-secondary.btn-outline:hover {
    background: #fff;
    color: #1c1c1c;
    border-color: #fff;
}
.fv-shop-hero__trust {
    list-style: none;
    margin: 0; padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: .4rem 1.6rem;
    font-size: .82rem;
    color: rgba(255,255,255,.85);
}
.fv-shop-hero__trust li {
    position: relative;
    padding-left: 1.2em;
}
.fv-shop-hero__trust li::before {
    content: "\2713";
    position: absolute; left: 0; top: 0;
    color: var(--gold, #dabe92);
    font-weight: 700;
}
@media (max-width: 720px) {
    .fv-shop-hero { min-height: 380px; }
    .fv-shop-hero__inner { padding: 2.2rem 1rem 2rem; }
    .fv-shop-hero__trust { gap: .35rem 1.1rem; font-size: .76rem; }
}

/* === Featured-Tiles === */
.fv-shop-featured {
    padding: 2.4rem 0 2.8rem;
}
.fv-shop-featured__title {
    text-align: center;
    margin: 0 0 .4rem;
    font-size: clamp(1.5rem, 3vw, 2rem);
    font-weight: 400;
    letter-spacing: .01em;
    color: var(--text, #2d2d2d);
}
.fv-shop-featured__lead {
    text-align: center;
    margin: 0 auto 2.2rem;
    max-width: 640px;
    color: var(--muted, #6e7679);
    font-size: 1rem;
    line-height: 1.55;
}
.fv-shop-tiles {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1.4rem;
}
@media (min-width: 900px) {
    .fv-shop-tiles { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 560px) {
    .fv-shop-tiles { grid-template-columns: 1fr; gap: 1.1rem; }
}
.fv-shop-tile {
    position: relative;
    display: flex;
    flex-direction: column;
    background: #fff;
    border: 1px solid var(--border, #e8eaed);
    border-radius: var(--radius-md, 10px);
    overflow: hidden;
    text-decoration: none;
    color: inherit;
    transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease;
}
.fv-shop-tile:hover {
    transform: translateY(-4px);
    box-shadow: 0 14px 32px rgba(0,0,0,.10);
    border-color: var(--gold, #dabe92);
}
.fv-shop-tile__media {
    position: relative;
    aspect-ratio: 4 / 3;
    overflow: hidden;
    background: #f4f1ec;
}
.fv-shop-tile__media img {
    width: 100%; height: 100%;
    object-fit: cover; object-position: center;
    display: block;
    transition: transform 1.1s ease;
}
.fv-shop-tile:hover .fv-shop-tile__media img { transform: scale(1.05); }
.fv-shop-tile__body {
    padding: 1.2rem 1.2rem 1.3rem;
    display: flex;
    flex-direction: column;
    gap: .4rem;
    flex: 1;
}
.fv-shop-tile__title {
    margin: 0;
    font-size: 1.08rem;
    line-height: 1.25;
    font-weight: 600;
    letter-spacing: .02em;
    color: var(--text, #2d2d2d);
}
.fv-shop-tile__desc {
    margin: 0;
    font-size: .88rem;
    line-height: 1.5;
    color: var(--muted, #6e7679);
    flex: 1;
}
.fv-shop-tile__cta {
    margin-top: .4rem;
    font-size: .82rem;
    font-weight: 500;
    color: var(--primary, #c93030);
    letter-spacing: .02em;
    transition: gap .2s ease;
}
.fv-shop-tile:hover .fv-shop-tile__cta { letter-spacing: .04em; }

/* SALE-Tile Akzent */
.fv-shop-tile--sale .fv-shop-tile__title {
    color: var(--primary, #c93030);
    font-weight: 700;
    letter-spacing: .04em;
}
.fv-shop-tile--sale {
    background: linear-gradient(180deg, #fff 0%, #fff8f7 100%);
}

/* === Pills-Block (Heading vor Filter-Layout) === */
.fv-shop-pills {
    padding: 1.6rem 0 .4rem;
    text-align: center;
}
.fv-shop-pills__title {
    margin: 0 0 .3rem;
    font-size: clamp(1.3rem, 2.4vw, 1.7rem);
    font-weight: 400;
    color: var(--text, #2d2d2d);
}
.fv-shop-pills .lead {
    margin: 0 auto 0;
    max-width: 580px;
    color: var(--muted, #6e7679);
    font-size: .95rem;
}

/* === Brand-Tile Politur (firstvoucher-look) === */
.section-soft .brand-tile {
    transition: transform .25s ease, box-shadow .25s ease;
}
.section-soft .brand-tile:hover {
    transform: translateY(-3px);
    box-shadow: 0 10px 24px rgba(0,0,0,.08);
}
/* === /Wave 83I === */

/* === Wave 83L (Filter-Mode-Header) =====================================
 * Wenn ein Filter aktiv ist (z.B. ?brand[]=NuSkin), wird statt des grossen
 * Wave-83I Overview-Hero ein kompakter Filter-Mode-Header gezeigt:
 *   - Breadcrumb-Pfad
 *   - H1 mit aktuellem Filter
 *   - Anzahl Produkte + Reset
 *   - Active-Filter-Chips (klickbar = entfernen)
 *   - Brand-Switcher-Pillenleiste (alle Marken, klick = Wechsel)
 * Damit User direkt zur Auswahl kommt, nicht erst durch den Overview-Block
 * scrollen muss.
 * ====================================================================== */
.fv-shop-filtermode {
    padding: 1.6rem 0 .4rem;
    background: linear-gradient(180deg, #fbfaf8 0%, #fff 100%);
    border-bottom: 1px solid #f0eae0;
}
.fv-shop-filtermode__crumbs {
    font-size: .82rem; color: var(--muted, #777);
    margin-bottom: .4rem; letter-spacing: .02em;
}
.fv-shop-filtermode__crumbs a {
    color: var(--muted, #777); text-decoration: none;
}
.fv-shop-filtermode__crumbs a:hover { color: var(--primary, #90a7ac); text-decoration: underline; }
.fv-shop-filtermode__crumbs .sep { margin: 0 .4em; opacity: .5; }
.fv-shop-filtermode__crumbs .cur { color: var(--text, #222); font-weight: 500; }
.fv-shop-filtermode__title {
    font-size: clamp(1.6rem, 2.6vw, 2.1rem);
    font-weight: 500; margin: 0 0 .4rem; color: var(--black, #222);
    letter-spacing: -.01em;
}
.fv-shop-filtermode__lead {
    color: var(--muted, #666); font-size: .95rem;
    display: flex; align-items: center; gap: 1rem; flex-wrap: wrap;
    margin: 0 0 1rem;
}
.fv-shop-filtermode__reset {
    color: var(--primary, #90a7ac);
    text-decoration: none;
    font-size: .88rem;
    border: 1px solid currentColor;
    padding: .25em .75em;
    border-radius: 999px;
    transition: background .15s, color .15s;
}
.fv-shop-filtermode__reset:hover {
    background: var(--primary, #90a7ac); color: #fff;
}
.fv-shop-filtermode__chips {
    display: flex; flex-wrap: wrap; gap: .4rem;
    margin: 0 0 1rem;
}
.fv-shop-chip {
    display: inline-flex; align-items: center; gap: .35em;
    padding: .3em .75em; background: #f3eee2; color: #5a4e2d;
    border: 1px solid #e3d9c3; border-radius: 999px;
    font-size: .82rem; text-decoration: none;
    transition: background .15s, border-color .15s;
}
.fv-shop-chip:hover { background: #e8dec3; border-color: #c9b88f; }
.fv-shop-chip__x { font-weight: 600; opacity: .6; }
.fv-shop-chip:hover .fv-shop-chip__x { opacity: 1; }

.fv-shop-filtermode__brands {
    display: flex; flex-wrap: wrap; gap: .4rem; align-items: center;
    padding-top: .75rem;
    border-top: 1px dashed #ebe3d2;
}
.fv-shop-filtermode__brands-label {
    font-size: .82rem; color: var(--muted, #777);
    margin-right: .4rem; font-weight: 500;
}
.fv-shop-brandpill {
    display: inline-flex; align-items: center; gap: .35em;
    padding: .4em .9em; background: #fff;
    color: var(--text, #222);
    border: 1px solid var(--border, #e3e3e3);
    border-radius: 999px;
    font-size: .85rem; text-decoration: none;
    transition: all .15s;
}
.fv-shop-brandpill:hover {
    border-color: var(--primary, #90a7ac);
    color: var(--primary, #90a7ac);
}
.fv-shop-brandpill.is-active {
    background: var(--primary, #90a7ac); color: #fff;
    border-color: var(--primary, #90a7ac);
}
.fv-shop-brandpill .cnt { opacity: .65; font-size: .78em; }
.fv-shop-brandpill.is-active .cnt { opacity: .85; }

@media (max-width: 600px) {
    .fv-shop-filtermode { padding: 1rem 0 .2rem; }
    .fv-shop-filtermode__lead { gap: .5rem; font-size: .9rem; }
    .fv-shop-filtermode__brands { gap: .3rem; }
    .fv-shop-brandpill { padding: .35em .7em; font-size: .8rem; }
}
/* === /Wave 83L === */

/* === Wave 84-PT (Preise-Behandlungen Card-Grid) ========================
 * /preise-behandlungen-trier nutzt jetzt das Firstvoucher-Style-Card-Grid
 * statt der schmalen Preisliste. Nutzt bestehende .services-grid + .service-card
 * als Basis, ergaenzt um pbt-spezifische Klassen fuer Badge, Subtitle, Meta.
 * ====================================================================== */
.page-title-block__count {
    color: var(--muted, #888);
    font-size: .9rem;
    margin: .4rem 0 0;
    letter-spacing: .02em;
}
.pbt-cards {
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1.5rem;
}
.pbt-card {
    position: relative;
    text-decoration: none;
    color: inherit;
    background: #fff;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0,0,0,.05);
    transition: transform 220ms ease, box-shadow 220ms ease;
    display: flex; flex-direction: column;
}
.pbt-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 32px rgba(0,0,0,.10);
}
.pbt-card__media {
    aspect-ratio: 4 / 3;
    overflow: hidden;
    position: relative;
    background: #f4f0e8;
}
.pbt-card__media img {
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform 600ms cubic-bezier(.25,.46,.45,.94);
}
.pbt-card:hover .pbt-card__media img { transform: scale(1.05); }
.pbt-card__badge {
    position: absolute;
    top: .75rem; left: .75rem;
    padding: .25em .7em;
    background: rgba(255,255,255,.92);
    color: var(--primary, #90a7ac);
    font-size: .72rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .08em;
    border-radius: 999px;
    box-shadow: 0 2px 6px rgba(0,0,0,.08);
}
.pbt-card__badge--signature {
    background: var(--primary, #90a7ac);
    color: #fff;
}
.pbt-card__body {
    padding: 1.1rem 1.2rem 1.3rem;
    display: flex; flex-direction: column; gap: .5rem;
    flex: 1;
}
.pbt-card__title {
    margin: 0;
    font-size: 1.05rem;
    font-weight: 500;
    line-height: 1.3;
    color: var(--black, #222);
}
.pbt-card__subtitle {
    margin: 0;
    font-size: .82rem;
    color: var(--muted, #777);
    line-height: 1.4;
}
.pbt-card__meta {
    margin-top: auto;
    padding-top: .6rem;
    border-top: 1px solid #f0eae0;
    display: flex; align-items: baseline; justify-content: space-between;
    gap: .6rem;
}
.pbt-card__price {
    color: var(--primary, #90a7ac);
    font-weight: 600;
    font-size: 1.05rem;
}
.pbt-card__duration {
    color: var(--muted, #888);
    font-size: .78rem;
}

.pbt-info-strip {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 1.5rem;
    margin: 3rem 0 2rem;
    padding: 1.5rem;
    background: #fbf6ec;
    border-radius: 12px;
    border: 1px solid #eadfc8;
}
.pbt-info-strip__item {
    display: flex; flex-direction: column; gap: .25rem;
    font-size: .88rem;
    color: var(--text, #444);
}
.pbt-info-strip__item strong {
    color: var(--black, #222);
    font-size: .92rem;
    font-weight: 600;
}
.pbt-info-strip__item span {
    color: var(--muted, #777);
}

.pbt-ctas {
    display: flex;
    gap: .8rem;
    flex-wrap: wrap;
    justify-content: center;
    margin-top: 1.5rem;
}

@media (max-width: 600px) {
    .pbt-cards { grid-template-columns: repeat(2, 1fr); gap: .8rem; }
    .pbt-card__body { padding: .8rem .9rem 1rem; }
    .pbt-card__title { font-size: .92rem; }
    .pbt-card__subtitle { font-size: .76rem; }
    .pbt-card__price { font-size: .95rem; }
    .pbt-info-strip { padding: 1.1rem; gap: 1rem; }
}
/* === /Wave 84-PT === */

/* === Wave 84-VB (Behandlungs-Gutschein-Auswahl) ========================
 * /geschenkgutschein-trier: Modus-Switcher Wert vs Behandlung +
 * Service-Picker mit Bild-Kacheln.
 * ====================================================================== */
.vc-mode-tabs {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .5rem;
}
.vc-mode-tab {
    text-align: left;
    padding: .9rem 1rem;
    background: #fff;
    border: 2px solid var(--border, #e3e3e3);
    border-radius: 8px;
    cursor: pointer;
    transition: border-color .15s, background .15s, transform .15s;
    font: inherit;
    color: var(--text, #222);
    display: flex; flex-direction: column; gap: .15rem;
}
.vc-mode-tab strong { font-size: .95rem; font-weight: 600; color: var(--black, #222); }
.vc-mode-tab span   { font-size: .8rem; color: var(--muted, #777); line-height: 1.3; }
.vc-mode-tab:hover  { border-color: var(--primary, #90a7ac); }
.vc-mode-tab.is-active {
    border-color: var(--primary, #90a7ac);
    background: rgba(144,167,172,.07);
}
.vc-mode-tab.is-active strong { color: var(--primary, #90a7ac); }

.vc-treatment-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: .7rem;
    margin-bottom: 1rem;
}
.vc-treatment-card {
    padding: 0;
    background: #fff;
    border: 2px solid var(--border, #e3e3e3);
    border-radius: 8px;
    cursor: pointer;
    overflow: hidden;
    text-align: left;
    transition: all .18s;
    font: inherit;
    color: var(--text, #222);
    display: flex; flex-direction: column;
}
.vc-treatment-card:hover {
    border-color: var(--primary, #90a7ac);
    transform: translateY(-2px);
    box-shadow: 0 6px 16px rgba(0,0,0,.08);
}
.vc-treatment-card.is-selected {
    border-color: var(--primary, #90a7ac);
    box-shadow: 0 0 0 3px rgba(144,167,172,.25), 0 8px 20px rgba(0,0,0,.1);
}
.vc-treatment-card__media {
    aspect-ratio: 4 / 3;
    overflow: hidden;
    background: #f4f0e8;
}
.vc-treatment-card__media img {
    width: 100%; height: 100%;
    object-fit: cover; display: block;
}
.vc-treatment-card__body {
    padding: .55rem .7rem .65rem;
    display: flex; flex-direction: column; gap: .15rem;
}
.vc-treatment-card__title {
    font-size: .85rem; font-weight: 500;
    color: var(--black, #222);
    line-height: 1.3;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.vc-treatment-card__price {
    font-size: .9rem; font-weight: 600;
    color: var(--primary, #90a7ac);
}

.vc-treatment-selected {
    display: flex; align-items: center; gap: .6rem;
    padding: .75rem 1rem;
    background: rgba(144,167,172,.08);
    border: 1px solid rgba(144,167,172,.3);
    border-radius: 8px;
    font-size: .92rem;
    color: var(--text, #222);
}
.vc-treatment-selected .lbl  { color: var(--muted, #777); font-size: .82rem; }
.vc-treatment-selected .amt  {
    margin-left: auto;
    color: var(--primary, #90a7ac);
    font-weight: 600;
    margin-right: .6rem;
}
.vc-treatment-clear {
    background: transparent; border: 0; font-size: 1.2rem; line-height: 1;
    color: var(--muted, #777); cursor: pointer; padding: 0 .25rem;
    transition: color .15s;
}
.vc-treatment-clear:hover { color: var(--alert, #c93030); }

@media (max-width: 600px) {
    .vc-mode-tabs { grid-template-columns: 1fr; }
    .vc-treatment-grid { grid-template-columns: repeat(2, 1fr); gap: .5rem; }
    .vc-treatment-card__title { font-size: .8rem; }
}
/* === /Wave 84-VB === */

/* === Wave 84-CL (Admin/Customers Layout) ===============================
 * Kompakte Kunden-Liste mit Avatar, Daten-Verfuegbarkeits-Indikatoren
 * und fixer Tabellenbreite — kein horizontales Scrollen mehr.
 * ====================================================================== */
.adm-cust-total {
    color: var(--muted, #888);
    font-size: .85rem;
    font-weight: 400;
    margin-left: .3rem;
}
.adm-cust-legend {
    display: flex; flex-wrap: wrap; align-items: center; gap: .35rem .6rem;
    margin: 1.1rem 0 0;
    padding: .65rem .9rem;
    background: #fafafa;
    border: 1px solid #ececec;
    border-radius: 8px;
    font-size: .78rem;
    color: var(--muted, #666);
}
.adm-cust-legend__title {
    font-weight: 600;
    color: var(--text, #333);
    margin-right: .25rem;
}

.adm-cust-table-wrap {
    width: 100%;
    /* WICHTIG: kein overflow-x scroll mehr */
    overflow-x: visible;
}
.adm-cust-table {
    width: 100%;
    border-collapse: collapse;
    table-layout: fixed;
    font-size: .88rem;
}
.adm-cust-table thead th {
    text-align: left;
    padding: .65rem .55rem;
    font-size: .78rem;
    font-weight: 600;
    color: var(--muted, #777);
    text-transform: uppercase;
    letter-spacing: .04em;
    border-bottom: 1px solid #eaeaea;
    background: #fafafa;
}
.adm-cust-table tbody td {
    padding: .85rem .55rem;
    border-bottom: 1px solid #f0f0f0;
    vertical-align: middle;
}
.adm-cust-table tbody tr:hover { background: #fbfaf5; }

/* Spalten-Breiten — Summe = 100%, kein H-Scroll */
.adm-cust-table .col-name     { width: 26%; }
.adm-cust-table .col-contact  { width: 24%; }
.adm-cust-table .col-avail    { width: 22%; }
.adm-cust-table .col-activity { width: 14%; }
.adm-cust-table .col-action   { width: 14%; }

/* Spalte: Name + Avatar */
.adm-cust-name__inner {
    display: flex; align-items: center; gap: .65rem;
    text-decoration: none; color: inherit;
}
.adm-cust-name__inner:hover .adm-cust-name__text strong { color: var(--primary, #90a7ac); }
.adm-cust-avatar {
    flex: 0 0 auto;
    width: 38px; height: 38px;
}
.adm-cust-avatar__img,
.adm-cust-avatar__initials {
    width: 38px; height: 38px;
    border-radius: 50%;
    object-fit: cover;
    display: inline-flex; align-items: center; justify-content: center;
    color: #fff;
    font-weight: 600;
    font-size: .82rem;
    box-shadow: 0 1px 3px rgba(0,0,0,.08);
}
.adm-cust-name__text { display: flex; flex-direction: column; gap: .1rem; min-width: 0; }
.adm-cust-name__text strong {
    color: var(--black, #222); font-weight: 600; font-size: .92rem;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.adm-cust-role {
    font-size: .7rem;
    color: var(--muted, #888);
    text-transform: uppercase;
    letter-spacing: .04em;
}
.adm-cust-role.is-owner { color: #b48a4d; font-weight: 600; }
.adm-cust-role.is-admin { color: #6b8eb8; font-weight: 600; }

/* Spalte: Kontakt */
.adm-cust-contact { display: flex; flex-direction: column; gap: .15rem; min-width: 0; }
.adm-cust-contact__mail,
.adm-cust-contact__phone {
    display: block;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    font-size: .82rem;
    text-decoration: none;
}
.adm-cust-contact__mail  { color: var(--primary, #90a7ac); }
.adm-cust-contact__phone { color: var(--text, #555); }
.adm-cust-contact__phone.is-empty { color: #c4c4c4; }
.adm-cust-contact__phone .ico,
.adm-cust-contact__mail .ico { opacity: .6; font-size: .78em; }

/* Spalte: Verfuegbare Daten — Pills */
.adm-cust-avail-row {
    display: flex; flex-wrap: wrap; gap: .25rem;
}
.adm-cust-avail-pill {
    display: inline-flex; align-items: center; gap: .15rem;
    padding: .15rem .4rem;
    background: #f0f4ec;
    border: 1px solid #d8e2cf;
    border-radius: 999px;
    font-size: .72rem;
    color: #3a5a30;
    cursor: default;
    transition: transform .15s;
}
.adm-cust-avail-pill.is-none {
    background: #f5f5f5;
    border-color: #e0e0e0;
    color: #b8b8b8;
}
.adm-cust-avail-pill .ico { font-size: .9em; line-height: 1; }
.adm-cust-avail-pill .cnt { font-weight: 600; }
.adm-cust-avail-pill:hover { transform: translateY(-1px); }

/* Spalte: Aktivitaet */
.adm-cust-activity { font-size: .78rem; color: var(--text, #555); line-height: 1.4; }
.adm-cust-activity__line { display: flex; gap: .35rem; }
.adm-cust-activity__line.is-muted { color: var(--muted, #999); }
.adm-cust-activity__line .lbl { color: var(--muted, #aaa); font-weight: 500; }

/* Spalte: Aktion */
.adm-cust-action {
    display: flex; flex-direction: column; align-items: flex-end; gap: .35rem;
}
.adm-cust-action .btn { padding: .35em .8em; font-size: .78rem; white-space: nowrap; }
.adm-cust-action__pw { margin: 0; display: inline; }
.adm-cust-action__pwbtn {
    background: transparent;
    border: 1px solid var(--border, #e0e0e0);
    padding: .3em .55em;
    border-radius: 6px;
    cursor: pointer;
    font-size: .88rem;
    transition: background .15s, border-color .15s;
}
.adm-cust-action__pwbtn:hover {
    background: #fbf6ec;
    border-color: #d4a96a;
}

/* Mobile: Cards statt Tabelle ab < 900px */
@media (max-width: 900px) {
    .adm-cust-table thead { display: none; }
    .adm-cust-table, .adm-cust-table tbody { display: block; }
    .adm-cust-table tbody tr {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: .5rem .8rem;
        padding: .9rem 1rem;
        margin-bottom: .6rem;
        border: 1px solid #ececec;
        border-radius: 8px;
        background: #fff;
    }
    .adm-cust-table tbody td {
        padding: 0;
        border: none;
        display: block;
    }
    .adm-cust-table .col-name,
    .adm-cust-table .adm-cust-name { grid-column: 1 / -1; }
    .adm-cust-table .adm-cust-contact { grid-column: 1 / -1; }
    .adm-cust-table .adm-cust-avail   { grid-column: 1 / -1; }
    .adm-cust-table .adm-cust-activity,
    .adm-cust-table .adm-cust-action  { font-size: .8rem; }
    .adm-cust-action { flex-direction: row; align-items: center; }
}
/* === /Wave 84-CL === */

/* === Wave 84-VAR (Service-Variants-Picker auf Behandlungs-Detail-Seiten) ===
 * 187 service_variants existieren in der DB, waren bisher nur in
 * service_variants-Tabelle und unsichtbar fuer Besucher.
 * Jetzt: smarter Picker mit Gruppen + Click-to-Inquire.
 * ====================================================================== */
.svp-section { padding-top: 2.5rem; padding-bottom: 3rem; }
.svp-section .section-head-centered { margin-bottom: 2rem; }
.svp-group {
    background: #fff;
    border: 1px solid #ececec;
    border-radius: 10px;
    margin: 0 0 1rem;
    overflow: hidden;
    transition: border-color .15s;
}
.svp-group[open] { border-color: rgba(144,167,172,.4); box-shadow: 0 4px 14px rgba(0,0,0,.04); }
.svp-group__head {
    list-style: none;
    cursor: pointer;
    padding: 1rem 1.3rem;
    display: flex; align-items: center; justify-content: space-between;
    gap: 1rem; font-size: 1rem; font-weight: 600;
    color: var(--black, #222);
    transition: background .15s;
}
.svp-group__head::-webkit-details-marker { display: none; }
.svp-group__head::after {
    content: "▾"; font-size: .85rem; color: var(--muted, #888);
    transition: transform .2s; margin-left: auto;
}
.svp-group[open] .svp-group__head::after { transform: rotate(180deg); }
.svp-group__head:hover { background: #fbfaf5; }
.svp-group__title { flex: 1; }
.svp-group__count { font-size: .8rem; font-weight: 400; color: var(--muted, #777); }

.svp-list {
    list-style: none; margin: 0; padding: 0;
    border-top: 1px solid #f0eae0;
}
.svp-row { border-bottom: 1px solid #f5f5f5; }
.svp-row:last-child { border-bottom: 0; }
.svp-row__link {
    display: grid;
    grid-template-columns: 1fr auto auto;
    gap: 1rem;
    align-items: center;
    padding: .85rem 1.3rem;
    text-decoration: none;
    color: var(--text, #222);
    transition: background .15s, color .15s;
}
.svp-row__link:hover {
    background: #fbf6ec;
    color: var(--primary, #90a7ac);
}
.svp-row__title { font-size: .93rem; line-height: 1.4; }
.svp-row__dur   { color: var(--muted, #888); font-size: .8rem; font-weight: 400; }
.svp-row__price {
    color: var(--primary, #90a7ac);
    font-weight: 600;
    font-size: 1rem;
    white-space: nowrap;
    min-width: 80px; text-align: right;
}
.svp-row__cta {
    font-size: .82rem;
    color: var(--muted, #888);
    transition: color .15s;
    white-space: nowrap;
}
.svp-row__link:hover .svp-row__cta { color: var(--primary, #90a7ac); }

.svp-bottom-ctas {
    display: flex; gap: .75rem; flex-wrap: wrap; justify-content: center;
    margin-top: 2rem;
}

@media (max-width: 640px) {
    .svp-group__head { padding: .8rem 1rem; font-size: .92rem; }
    .svp-row__link { padding: .75rem 1rem; grid-template-columns: 1fr auto; gap: .6rem; }
    .svp-row__cta { display: none; }
    .svp-row__title { font-size: .88rem; }
}
/* === /Wave 84-VAR === */


/* ============================================================
   === Wave 87K: Live-CSS Polish (Mai 2026) ==================
   - Shop-Grid 8-Spalten-Bug -> max 4-5 Spalten (Karten lesbar)
   - Homepage Portrait max-height (Section laenge auf 800px)
   ============================================================ */

/* Shop-Produktraster: keine engen 8-Spalten mehr. Min-Kachelbreite
 * auf 250px erhoeht; bei breiten Screens deckelt repeat(auto-fill)
 * auf maximal 5 Spalten via max-width per Karte.
 * Spezifitaet erhoeht via .shop-brand-section, .shop-layout etc.,
 * damit es Wave 83I-Overrides schlaegt. */
.shop-brand-section .product-grid,
.shop-layout .product-grid,
.shop-content .product-grid,
section.section .product-grid {
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)) !important;
    gap: 1.6rem;
}

@media (min-width: 1280px) {
    .shop-brand-section .product-grid,
    .shop-layout .product-grid,
    .shop-content .product-grid,
    section.section .product-grid {
        /* Auf grossen Screens hart auf 4 Spalten deckeln,
         * sonst sind Karten optisch immer noch zu klein. */
        grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    }
}

@media (min-width: 1600px) {
    .shop-brand-section .product-grid,
    .shop-layout .product-grid,
    .shop-content .product-grid,
    section.section .product-grid {
        /* Ultra-wide: 5 Spalten erlaubt, aber nie mehr. */
        grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
    }
}

/* Homepage "Schoen, dass du da bist" - Portrait war 800x1000 ohne
 * max-height, dadurch wurde die Section auf 1230px aufgeblasen.
 * Wir begrenzen das Portrait auf max 600px Hoehe und behalten 4:5. */
.collage .about-portrait-wrap {
    max-height: 600px;
    overflow: hidden;
}
@media (max-width: 768px) {
    .collage .about-portrait-wrap { max-height: 480px; }
}

/* === /Wave 87K === */


/* ═══════════════════════════════════════════════════════════════
   Wave 87BP — Premium Quick-Wins Pack
   Auto-Audit-Findings (6 Agents): A11y + Contrast + Motion + Mobile
   ═══════════════════════════════════════════════════════════════ */

/* — Screenreader-Only (für versteckte Labels, WCAG 2.2 SC 1.3.1) — */
.visually-hidden,
.sr-only {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
}

/* — Color-Contrast-Fix (WCAG AA 4.5:1) —
   Gold #dabe92 hatte ~2.8:1 auf Weiß, Placeholder #aab1b3 hatte ~3.2:1.
   Token bleibt für Brand-Akzente, aber bei reinem Text auf weißem Grund
   verwenden wir die abgedunkelte Variante. */
:root {
    --gold-text-on-light: #8b6a2f;     /* 4.7:1 auf #fff */
    --gold-text-on-dark:  var(--gold);  /* hell auf dunkel = OK */
    --text-placeholder-aa: #6a6f72;    /* 4.6:1 auf #fff (vorher #aab1b3 = 3.2:1) */
}
input::placeholder,
textarea::placeholder,
select:invalid {
    color: var(--text-placeholder-aa);
    opacity: 1; /* Firefox sonst dimmt nochmal */
}
.text-gold-aa,
a.text-gold-aa,
.btn-gold-text {
    color: var(--gold-text-on-light);
}

/* — Safe-Area-Inset Polish (iPhone Notch + Android Gesture-Bar) — */
@supports (padding: max(0px)) {
    .site-footer {
        padding-bottom: max(2rem, env(safe-area-inset-bottom, 0px));
    }
}

/* — Bottom-Nav: Active-Page-Highlight als Klasse —
   Werden via JS in body[data-path] gesetzt; CSS hier macht den Look. */
.mobile-bottom-nav a.is-active,
.mobile-bottom-nav a[aria-current="page"] {
    color: var(--primary);
    font-weight: 600;
}
.mobile-bottom-nav a.is-active::before,
.mobile-bottom-nav a[aria-current="page"]::before {
    content: '';
    position: absolute;
    top: 0; left: 50%;
    width: 24px; height: 3px;
    border-radius: 0 0 3px 3px;
    background: var(--primary);
    transform: translateX(-50%);
}

/* — Premium-Polish: Smooth Image-Fade-In nach lazy-load
   Vermeidet "Pop-in"-Effekt, Apple-typische Smooth-Reveal. */
img[loading="lazy"] {
    transition: opacity 0.35s ease-out, filter 0.35s ease-out;
}
img[loading="lazy"]:not([src]),
img[loading="lazy"][src=""] {
    opacity: 0;
    filter: blur(8px);
}

/* — Tap-Highlight für Mobile (kein hässlicher grauer Kasten beim Tap) — */
a, button, [role="button"], .btn, .card-premium, .product-card, .service-card {
    -webkit-tap-highlight-color: rgba(144, 167, 172, 0.15);
}

/* — Smooth-Scrolling-Behavior für anchor-Links (sanfter wie iOS) — */
@media (prefers-reduced-motion: no-preference) {
    html {
        scroll-behavior: smooth;
    }
}

/* — Focus-Visible-Ring vereinheitlichen (Premium-Look statt Browser-Default) — */
:focus-visible {
    outline: 2px solid var(--primary);
    outline-offset: 2px;
    border-radius: var(--radius-sm, 4px);
    box-shadow: 0 0 0 4px rgba(144, 167, 172, 0.2);
    transition: outline-offset 0.15s ease;
}

/* — Selection-Color (subtile Brand-Hervorhebung beim Text-Markieren) — */
::selection {
    background: rgba(144, 167, 172, 0.25);
    color: var(--text);
}

/* — Loading-Skeleton-Klasse für künftige Verwendung (Empty-States) — */
.skeleton {
    background: linear-gradient(90deg, #f1f5f9 25%, #e2e8f0 50%, #f1f5f9 75%);
    background-size: 200% 100%;
    animation: skeleton-shimmer 1.6s ease-in-out infinite;
    border-radius: var(--radius-md, 8px);
}
@keyframes skeleton-shimmer {
    0%   { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}
@media (prefers-reduced-motion: reduce) {
    .skeleton { animation: none; background: #f1f5f9; }
}

/* === /Wave 87BP === */
