/*
Theme Name: Wyss Aesthetik
Theme URI: https://wyss-aesthetik.ch
Author: Praxis Anzhelika Wyss
Description: Premium WordPress Theme für Wyss Aesthetik - ICOONE, Massage & Akupressur mit Amelia Pro Booking
Version: 5.23.2
License: Proprietary
Text Domain: praxis-aw
Requires at least: 6.0
Requires PHP: 8.0
*/

/* ==========================================================================
   MOBILE-FIRST CSS ARCHITECTURE
   Base styles = Smartphone (< 769px)
   @media (min-width: 769px)  = Tablet / Small Desktop
   @media (min-width: 1025px) = Desktop
   ========================================================================== */

/* --- CSS Variables (Mobile Base) --- */
:root{--gold:#C5A55A;--gold-dark:#A8893E;--gold-light:rgba(197,165,90,.15);--gold-text:#866D2E;--anthracite:#2D2D2D;--creme:#F8F5F0;--white:#fff;--text:#333;--text-light:#666;--text-muted:#6e6e6e;--border-light:rgba(0,0,0,.06);--shadow-soft:0 4px 20px rgba(0,0,0,.06);--shadow-hover:0 20px 60px rgba(0,0,0,.08);--shadow-gold:0 8px 30px rgba(197,165,90,.3);--transition:all .3s ease;--max-width:1200px;--nav-height:64px;--fs-2xs:0.65rem;--fs-xs:0.75rem;--fs-sm:0.85rem;--fs-base:1rem;--fs-md:1.05rem;--fs-lg:1.2rem}

/* --- Reset --- */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Lato',-apple-system,BlinkMacSystemFont,sans-serif;color:var(--text);background:var(--white);line-height:1.7;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,h5,h6{font-family:'Playfair Display',Georgia,serif;font-weight:400;line-height:1.3}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit;transition:var(--transition)}
ul,ol{list-style:none}

/* --- Layout (Mobile: 20px padding) --- */
.container{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 20px}

/* --- Typography (Fluid – works at all sizes) --- */
.headline-xl{font-size:clamp(2.2rem,5vw,3.5rem)}
.headline-lg{font-size:clamp(1.8rem,4vw,2.4rem)}
.headline-md{font-size:clamp(1.4rem,3vw,1.8rem)}
.text-body{font-size:var(--fs-base);line-height:1.7;color:var(--text-light)}
.text-small{font-size:var(--fs-sm)}
.text-uppercase{text-transform:uppercase;letter-spacing:2px;font-size:.75rem}
.text-gold{color:var(--gold-text)}.text-white{color:var(--white)}
.gold-line{width:60px;height:2px;background:var(--gold);margin:16px auto 24px}
.gold-line--left{margin-left:0}

/* --- Buttons (WCAG AA – anthracite on light, gold on dark) --- */
.btn{display:inline-block;padding:16px 40px;font-family:'Lato',sans-serif;font-size:.85rem;font-weight:600;letter-spacing:2px;text-transform:uppercase;cursor:pointer;border:none;transition:var(--transition)}
.btn--gold{background:var(--anthracite);color:var(--white)}
.btn--gold:hover{background:var(--gold);color:var(--anthracite);transform:translateY(-2px);box-shadow:var(--shadow-gold)}
.btn--outline{background:transparent;color:var(--gold-text);border:1px solid var(--gold)}
.btn--outline:hover{background:var(--gold);color:var(--anthracite)}
/* Gold buttons on dark sections – gold bg with dark text */
.section--dark .btn--gold,.seo-hero .btn--gold,.hero .btn--gold{background:var(--gold);color:var(--anthracite)}
.section--dark .btn--gold:hover,.seo-hero .btn--gold:hover,.hero .btn--gold:hover{background:var(--gold-dark);box-shadow:var(--shadow-gold)}
.section--dark .btn--outline,.seo-hero .btn--outline,.hero .btn--outline{background:transparent;color:rgba(255,255,255,.85);border-color:rgba(255,255,255,.3)}
.section--dark .btn--outline:hover,.seo-hero .btn--outline:hover,.hero .btn--outline:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.5);color:#fff}

/* --- Navigation (Mobile Base: Hamburger Menu) --- */
.site-nav{position:fixed;top:0;width:100%;z-index:1000;background:rgba(45,45,45,.95);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);height:var(--nav-height);transition:var(--transition)}
.site-nav.scrolled{background:rgba(45,45,45,.98);box-shadow:0 2px 20px rgba(0,0,0,.15)}
.site-nav .container{display:flex;align-items:center;justify-content:space-between;height:100%}
.nav-logo{font-family:'Playfair Display',serif;font-size:1.3rem;color:var(--white);letter-spacing:.5px}
.nav-logo span{color:var(--gold)}
.nav-menu{display:none;align-items:center;gap:32px}
.nav-menu.active{display:flex;flex-direction:column;position:absolute;top:var(--nav-height);left:0;right:0;background:var(--anthracite);padding:24px 20px;gap:16px}
.nav-menu a{color:var(--gold);font-size:.85rem;letter-spacing:1px;text-transform:uppercase;font-weight:400;position:relative}
.nav-menu a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--gold);transition:width .3s}
.nav-menu a:hover{color:var(--gold-dark)}.nav-menu a:hover::after{width:100%}
.nav-menu a.current-menu-item{color:var(--gold)}
.nav-cta{display:none}
.nav-toggle{display:flex;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:8px}
.nav-toggle span{width:24px;height:2px;background:var(--white);transition:var(--transition)}

/* --- Hero (Mobile: 90vh) --- */
.hero{position:relative;min-height:70vh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;background:var(--anthracite)}
.hero__background{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.65}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(45,45,45,.8),rgba(45,45,45,.5))}
.hero__glow{position:absolute;inset:0;background:radial-gradient(ellipse at 30% 50%,rgba(197,165,90,.12) 0%,transparent 70%)}
.hero__content{position:relative;z-index:2;max-width:800px;padding:0 40px}
.hero__badge{display:inline-block;border:1px solid var(--gold);color:var(--gold);padding:8px 24px;font-size:.7rem;letter-spacing:3px;text-transform:uppercase;margin-bottom:32px}
.hero__title{color:var(--white);margin-bottom:24px}.hero__title em{font-style:italic;color:var(--gold)}
.hero__subtitle{color:rgba(255,255,255,.7);font-size:1.15rem;line-height:1.8;margin-bottom:40px;font-weight:300}

/* --- Trust Bar (Mobile: tighter gap) --- */
.trust-bar{background:var(--creme);padding:36px 0;border-bottom:1px solid rgba(197,165,90,.15)}
.trust-bar .container{display:flex;align-items:center;justify-content:center;gap:24px;flex-wrap:wrap}
.trust-item{text-align:center}.trust-item__icon{font-size:1.4rem;margin-bottom:6px}
.trust-item__label{font-size:.75rem;color:var(--text-light);letter-spacing:1px;text-transform:uppercase}

/* --- Sections (Mobile: 60px padding) --- */
.section{padding:60px 0}.section--dark{background:var(--anthracite);color:var(--white)}.section--creme{background:var(--creme)}
.section__header{text-align:center;max-width:700px;margin:0 auto 60px}.section__header h2{color:var(--anthracite);margin-bottom:8px}
.section--dark .section__header h2{color:var(--white)}.section__header p{color:var(--text-light);font-size:1.05rem;line-height:1.7}

/* --- Grids (Mobile Base: 1 Column) --- */
.services-grid{display:grid;grid-template-columns:1fr;gap:36px}
.feature-grid{display:grid;grid-template-columns:1fr;gap:40px;align-items:center}
.pricing-grid{display:grid;grid-template-columns:1fr;gap:30px;max-width:400px;margin:0 auto}
.testimonial-grid{display:grid;grid-template-columns:1fr;gap:28px}
.about-grid{display:grid;grid-template-columns:1fr;gap:40px;align-items:center}
.contact-grid{display:grid;grid-template-columns:1fr;gap:60px}
.footer-grid{display:grid;grid-template-columns:1fr;gap:40px;margin-bottom:40px}

/* --- Cards & Components --- */
.service-card{background:var(--white);border:1px solid var(--border-light);padding:48px 32px;text-align:center;transition:var(--transition);position:relative;overflow:hidden;display:flex;flex-direction:column;align-items:center}
.service-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--gold);transform:scaleX(0);transition:transform .4s ease}
.service-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-hover)}.service-card:hover::after{transform:scaleX(1)}
.service-card__icon{font-size:2.4rem;margin-bottom:24px}
.service-card h3{font-size:1.4rem;color:var(--anthracite);margin-bottom:16px;font-weight:600}
.service-card p{color:var(--text-light);line-height:1.7;margin-bottom:24px;font-size:.95rem}
.service-card__link{color:var(--gold-text);font-size:.8rem;letter-spacing:1.5px;text-transform:uppercase;font-weight:600;margin-top:auto}.service-card__link:hover{color:var(--gold-dark)}
.feature-list{margin:24px 0 36px}
.feature-list li{padding:14px 0;border-bottom:1px solid rgba(255,255,255,.08);color:rgba(255,255,255,.8);font-size:.95rem;padding-left:28px;position:relative}
.feature-list li::before{content:'✦';position:absolute;left:0;color:var(--gold);font-size:.7rem;top:16px}
.feature-image{position:relative;overflow:hidden;border:1px solid rgba(197,165,90,.2)}.feature-image img{width:100%;height:100%;object-fit:cover}
.pricing-card{border:1px solid var(--border-light);padding:40px 28px;text-align:center;transition:var(--transition);position:relative;background:var(--white);display:flex;flex-direction:column;align-items:center}
.pricing-card--featured{border-color:var(--gold)}
.pricing-card--featured::before{content:'BELIEBT';position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--anthracite);color:var(--gold);padding:4px 20px;font-size:.65rem;letter-spacing:2px;font-weight:600}
.pricing-card:hover{box-shadow:var(--shadow-soft)}
.pricing-card h3{font-size:1.3rem;margin-bottom:8px}.pricing-card__duration{color:var(--text-light);font-size:.85rem;margin-bottom:20px}
.pricing-card__price{font-family:'Playfair Display',serif;font-size:2.8rem;color:var(--anthracite);margin-bottom:8px}.pricing-card__price span{font-size:1rem;color:var(--text-light)}
.pricing-card__details{font-size:.85rem;color:var(--text-light);margin-bottom:24px;line-height:1.6}
.pricing-card .btn{margin-top:auto}
.testimonial-card{background:var(--white);padding:36px;box-shadow:var(--shadow-soft)}
.testimonial-card__stars{color:var(--gold);font-size:.9rem;letter-spacing:2px;margin-bottom:16px}
.testimonial-card p{font-style:italic;color:var(--text-light);line-height:1.7;margin-bottom:20px;font-size:.95rem}
.testimonial-card__author{font-weight:600;color:var(--anthracite);font-size:.8rem}
.about-image{position:relative;overflow:hidden}.about-image img{width:100%;height:500px;object-fit:cover}
.about-image::after{display:none} /* v5.13.0 – removed decorative frame per feedback #8 */
.certifications{display:flex;gap:16px;margin-top:28px;flex-wrap:wrap}
.cert-badge{border:1px solid rgba(197,165,90,.4);padding:8px 20px;font-size:.7rem;color:var(--gold-text);letter-spacing:1.5px;text-transform:uppercase}
.cta-banner{background:var(--anthracite);padding:80px 0;text-align:center}
.cta-banner h2{color:var(--white);margin-bottom:16px}.cta-banner p{color:rgba(255,255,255,.6);margin-bottom:36px;font-size:1.05rem}
.contact-detail{margin-bottom:24px}.contact-detail__label{font-size:.7rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);margin-bottom:6px}
.contact-detail__value{color:var(--anthracite);font-size:1rem;line-height:1.6}
.site-footer{background:var(--anthracite);color:rgba(255,255,255,.5);padding:60px 0 0}
.footer-col h4{color:var(--gold);font-size:.75rem;letter-spacing:2px;text-transform:uppercase;margin-bottom:20px;font-family:'Lato',sans-serif;font-weight:600}
.footer-col p{font-size:.85rem;line-height:1.7;color:rgba(255,255,255,.5)}
.footer-col a{display:block;font-size:.85rem;color:rgba(255,255,255,.5);margin-bottom:10px}.footer-col a:hover{color:var(--gold)}
.lang-switch{display:flex;gap:10px;margin-top:20px}
.lang-switch a{color:rgba(255,255,255,.4);font-size:.8rem;padding:4px 10px;border:1px solid rgba(255,255,255,.1);display:inline-block;margin-bottom:0}
.lang-switch a:hover,.lang-switch a.active{color:var(--gold);border-color:var(--gold)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:24px 0;text-align:center;font-size:.8rem}
.breadcrumb{font-size:.8rem;color:var(--text-muted)}.breadcrumb a{color:var(--gold-text);text-decoration:underline;text-underline-offset:2px}.breadcrumb a:hover{color:var(--gold-dark)}

/* === ACCESSIBILITY (WCAG 2.1 AA) === */
.skip-link{position:absolute;top:-100%;left:50%;transform:translateX(-50%);background:var(--gold);color:var(--white);padding:12px 24px;z-index:10000;font-size:.9rem;letter-spacing:1px;text-transform:uppercase;transition:top .3s}.skip-link:focus{top:8px;outline:3px solid var(--gold);outline-offset:2px}
.screen-reader-text{clip:rect(1px,1px,1px,1px);position:absolute!important;height:1px;width:1px;overflow:hidden;word-wrap:normal!important}
*:focus-visible{outline:3px solid var(--gold);outline-offset:2px;border-radius:2px}
a:focus-visible,button:focus-visible,.btn:focus-visible{outline:3px solid var(--gold);outline-offset:2px}
.btn,.nav-cta,.service-card__link,.nav-toggle,.whatsapp-float,.lang-switch a{min-height:48px;min-width:48px;display:inline-flex;align-items:center;justify-content:center}
.nav-menu a{min-height:48px;display:inline-flex;align-items:center}

/* ==========================================================================
   TABLET / SMALL DESKTOP (min-width: 769px)
   ========================================================================== */
@media (min-width: 769px) {
.hero{min-height:85vh}
    :root { --nav-height: 80px; }
    .container { padding: 0 40px; }
    .section { padding: 100px 0; }
    .trust-bar .container { gap: 48px; }
    .hero { min-height: 100vh; }

    /* Nav: horizontal menu, hide toggle */
    .nav-menu { display: flex; }
    .nav-menu.active { position: static; flex-direction: row; background: transparent; padding: 0; }
    .nav-cta { display: inline-flex; margin-left: 16px; }
    .nav-toggle { display: none; }

    /* Grids: 2 Columns */
    .services-grid { grid-template-columns: repeat(2, 1fr); }
    .feature-grid { grid-template-columns: 1fr 1fr; gap: 80px; }
    .testimonial-grid { grid-template-columns: repeat(2, 1fr); }
    .about-grid { grid-template-columns: 1fr 1fr; gap: 80px; }
    .contact-grid { grid-template-columns: 1fr 1fr; }
    .footer-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ==========================================================================
   DESKTOP (min-width: 1025px)
   ========================================================================== */
@media (min-width: 1025px) {
    .services-grid { grid-template-columns: repeat(3, 1fr); }
    .pricing-grid { grid-template-columns: repeat(3, 1fr); max-width: 1000px; }
    .testimonial-grid { grid-template-columns: repeat(3, 1fr); }
    .footer-grid { grid-template-columns: 2fr 1fr 1fr 1fr; }
}

/* ==========================================================================
   v5.6 – NEW UTILITY CLASSES (replace inline styles)
   ========================================================================== */

/* Page content wrapper (replaces <main class="page-content" style="padding-top">) */
.page-content { padding-top: var(--nav-height); }

/* Section utilities */
.section-narrow { max-width: 800px; margin: 0 auto; text-align: center; }
.section-narrow__title { margin-bottom: 20px; }
.section-narrow__sub { max-width: 600px; margin: 8px auto 0; }
.section-cta-center { text-align: center; margin-top: 2rem; }
.section-center { text-align: center; }
.section-subtitle { text-align: center; margin-bottom: 8px; }
.section--compact { padding: 1.5rem 0; }

/* Text utilities */
.text-body-light { color: rgba(255,255,255,0.7); font-size: 1.05rem; line-height: 1.8; margin-bottom: 20px; }
.text-body-spaced { color: var(--text-light); margin: 16px 0 28px; line-height: 1.8; }
.text-body-center { text-align: center; color: var(--text-light); font-size: 1rem; line-height: 1.7; margin-bottom: 2rem; }
.text-strong { font-size: 1rem; color: var(--anthracite); line-height: 1.9; margin-top: 16px; font-weight: 500; }
.text-muted-sm { color: var(--text-muted); font-size: 0.85rem; margin-top: 8px; }
.text-muted-light { color: rgba(255,255,255,0.6); margin-bottom: 28px; }
.text-muted-center { text-align: center; margin-top: 16px; font-size: 0.8rem; color: var(--text-muted); }
.text-source { font-size: 0.78rem; color: var(--text-muted); margin-top: 12px; }
.link-gold { color: var(--gold-text); text-decoration: underline; text-decoration-color: var(--gold); text-underline-offset: 3px; }
.link-gold:hover { color: var(--gold-dark); }

/* Hero page (inner pages) */
.hero-page { padding-top: 100px; padding-bottom: 80px; }
.hero-page__title { margin-bottom: 20px; }
.hero-page__lead { margin-bottom: 28px; }
.hero-page__cta { display: flex; gap: 12px; flex-wrap: wrap; }
.hero__proof--left { justify-content: flex-start; margin-bottom: 28px; }

/* Feature image rounded */
.feature-image-rounded { border-radius: 8px; width: 100%; height: auto; }

/* icoone CTA row */
.icoone-cta-row { display: flex; gap: 16px; flex-wrap: wrap; margin-top: 28px; align-items: center; }

/* Button utilities */
.btn-mt { margin-top: 24px; }
.btn-fullwidth { width: 100%; text-align: center; }

/* Book banner */
.book-banner { margin-top: 1.5rem; }

/* Hours title */
.hours-title { font-family: 'Lato', sans-serif; font-size: 0.95rem; font-weight: 600; margin-bottom: 8px; }

/* EMR badge inline */
.badge-emr { background: var(--gold-light); color: var(--gold-dark); font-size: 0.65rem; padding: 2px 8px; letter-spacing: 1px; text-transform: uppercase; font-family: 'Lato', sans-serif; vertical-align: middle; }

/* Steps list */
.steps-list { display: grid; gap: 0; }
.step-item { display: flex; gap: 20px; padding: 24px 0; border-bottom: 1px solid var(--border-light); }
.step-item__nr { font-family: 'Playfair Display', serif; font-size: 1.8rem; color: var(--gold); flex-shrink: 0; width: 50px; opacity: 0.4; }
.step-item__body strong { font-size: 0.95rem; display: block; margin-bottom: 4px; }
.step-item__body span { font-size: 0.88rem; color: var(--text-light); line-height: 1.7; }

/* Pricing grid narrow (2 cols for single prices) */
.pricing-grid--narrow { max-width: 700px; margin-bottom: 3rem; }

/* CTA inline bar (between sections) */
.cta-inline { padding: 24px 0; background: var(--creme); border-top: 1px solid var(--border-light); border-bottom: 1px solid var(--border-light); }
.cta-inline--dark { background: var(--anthracite); border: none; }
.cta-inline__inner { display: flex; align-items: center; justify-content: center; gap: 24px; flex-wrap: wrap; }
.cta-inline__text { font-size: 0.95rem; color: var(--text-light); font-weight: 500; }
.cta-inline--dark .cta-inline__text { color: rgba(255,255,255,0.7); }
.cta-inline__actions { display: flex; gap: 12px; }

/* CTA final section */
.cta-final { padding: 4rem 0; }
.cta-final__actions { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }

/* Breadcrumb (replaces inline styles) */
.breadcrumb { padding: calc(var(--nav-height) + 4px) 0 0; background: var(--creme); }
.breadcrumb__list { display: flex; gap: 8px; list-style: none; font-size: 0.8rem; color: var(--text-muted); }
.breadcrumb a { color: var(--gold); }
.breadcrumb a:hover { color: var(--gold-dark); }
.breadcrumb__sep { margin-left: 8px; }

@media (min-width: 769px) {
.hero{min-height:85vh}
    .pricing-grid--narrow { grid-template-columns: repeat(2, 1fr); }
}

/* Legal notice banner (shown on EN/RU for legal pages) */
.legal-notice-banner { background: var(--gold-light); padding: 12px 0; text-align: center; }
.legal-notice-banner p { font-size: 0.85rem; color: var(--gold-dark); margin: 0; font-weight: 500; }

/* Expert / Professional Testimonials (evidence-based) */
.expert-grid { display: grid; grid-template-columns: 1fr; gap: 28px; margin-top: 2rem; }
.expert-card { background: var(--white); border-left: 3px solid var(--gold); padding: 32px; box-shadow: var(--shadow-soft); }
.expert-card__quote { margin-bottom: 16px; }
.expert-card__icon { margin-bottom: 12px; opacity: 0.4; }
.expert-card__quote p { font-style: italic; color: var(--text-light); line-height: 1.7; font-size: 0.95rem; }
.expert-card__source { font-size: 0.78rem; color: var(--text-muted); line-height: 1.5; }
.expert-card__source-label { font-weight: 600; color: var(--gold-dark); }

/* Google Rating Badge (standalone) */
.google-badge { display: flex; align-items: center; gap: 16px; background: var(--white); border: 1px solid var(--border-light); padding: 16px 24px; margin: 2rem auto; max-width: 420px; flex-wrap: wrap; justify-content: center; }
.google-badge__rating { display: flex; align-items: center; gap: 8px; }
.google-badge__score { font-family: 'Playfair Display', serif; font-size: 1.6rem; color: var(--anthracite); font-weight: 600; }
.google-badge__meta { font-size: 0.8rem; color: var(--text-muted); }
.google-badge__link { display: flex; align-items: center; gap: 6px; font-size: 0.8rem; color: var(--gold); font-weight: 500; }
.google-badge__link:hover { color: var(--gold-dark); }

@media (min-width: 769px) {
.hero{min-height:85vh}
    .expert-grid { grid-template-columns: repeat(2, 1fr); }
}

/* icoone benefits as clickable links */
a.ib { text-decoration: none; color: inherit; transition: opacity 0.2s; }
a.ib:hover { opacity: 0.8; }

/* ==========================================================================
   NEW COMPONENTS v5.9
   ========================================================================== */

/* --- Logo in Nav --- */
.nav-logo__img{height:34px;width:auto}

/* --- Comparison Table --- */
.comparison-table-wrap{overflow-x:auto;margin:2rem 0}
.comparison-table{width:100%;border-collapse:collapse;font-size:.85rem}
.comparison-table th{background:var(--anthracite);color:var(--white);padding:12px 16px;text-align:left;font-weight:600;font-size:.75rem;letter-spacing:1px;text-transform:uppercase}
.comparison-table td{padding:12px 16px;border-bottom:1px solid var(--border-light);color:var(--text-light)}
.comparison-table__highlight{background:var(--gold-light);font-weight:600}
.comparison-table__highlight td{color:var(--anthracite);border-bottom-color:var(--gold)}

/* --- Ideal For / Not For --- */
.ideal-grid{display:grid;grid-template-columns:1fr;gap:24px;margin:2rem 0}
.ideal-box{padding:32px;border-radius:8px}
.ideal-box h3{font-size:1.1rem;margin-bottom:16px}
.ideal-box ul{list-style:none}
.ideal-box li{padding:8px 0;display:flex;align-items:flex-start;gap:12px;font-size:.95rem;line-height:1.6;color:var(--text)}
.ideal-box--yes{background:rgba(197,165,90,.08);border:1px solid rgba(197,165,90,.2)}
.ideal-box--no{background:rgba(200,50,50,.04);border:1px solid rgba(200,50,50,.12)}
.ideal-icon{font-weight:700;color:var(--gold);flex-shrink:0}
.ideal-icon--no{color:#C83232}
@media(min-width:769px){.ideal-grid{grid-template-columns:1fr 1fr}}

/* --- Erstattungsrechner --- */
.erstattung-rechner{max-width:700px;margin:2rem auto;text-align:center}
.erstattung-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin:1.5rem 0}
@media(max-width:480px){.erstattung-grid{grid-template-columns:1fr;gap:12px}}
.erstattung-card{background:var(--white);border:1px solid var(--border-light);padding:24px;border-radius:8px}
.erstattung-card__title{font-family:'Playfair Display',serif;font-size:1.1rem;margin-bottom:16px;color:var(--anthracite)}
.erstattung-card__row{display:flex;justify-content:space-between;padding:8px 0;font-size:.9rem;color:var(--text-light)}
.erstattung-card__row--refund{color:var(--gold-text)}
.erstattung-card__row--total{border-top:2px solid var(--gold);padding-top:12px;margin-top:8px;font-weight:700;font-size:1.1rem;color:var(--anthracite)}
.erstattung-disclaimer{font-size:.75rem;color:var(--text-muted);margin-top:12px;line-height:1.6}

/* --- SEO Landing Page Classes (replaces inline styles) --- */
.seo-hero{padding-top:calc(var(--nav-height) + 48px);padding-bottom:80px}
.seo-hero__lead{color:rgba(255,255,255,0.7);font-size:1.05rem;line-height:1.8;margin-bottom:28px}
.seo-hero__proof{display:flex;align-items:center;gap:8px;margin-bottom:28px}
.seo-hero__proof-stars{color:var(--gold);font-size:1rem}
.seo-hero__proof-meta{color:rgba(255,255,255,0.5);font-size:.85rem}
.seo-hero__cta{display:flex;gap:12px;flex-wrap:wrap}
.seo-content{max-width:800px;margin:0 auto}
.seo-content--center{text-align:center}
.seo-content p{color:var(--text-light);line-height:1.9}
.seo-content p strong{color:var(--anthracite)}
.seo-cta-section{padding:4rem 0;text-align:center}
.seo-cta-section .container{max-width:700px}
.seo-cta-section p{color:rgba(255,255,255,0.6);margin-bottom:28px}
.seo-interlinks{padding:1.5rem 0;text-align:center}
.seo-interlinks p{font-size:.78rem;color:var(--text-muted)}
.seo-interlinks a{color:var(--gold-text)}

/* --- Package Badge --- */
.pricing-card__badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--gold);color:var(--white);font-size:.7rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:4px 16px;white-space:nowrap}

/* --- Compact Service Mention (for homepage 80/20) --- */
.services-compact{display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap;padding:20px;background:var(--creme);border:1px solid var(--border-light);border-radius:8px;margin-top:2rem}
.services-compact span{font-size:.9rem;color:var(--text-light)}
.services-compact a{color:var(--gold-text);font-weight:600;font-size:.9rem}
.services-compact__item { display: flex; align-items: center; gap: 12px; }
@media (max-width: 768px) {
    .services-compact { flex-direction: column; gap: 12px; }
    .services-compact__sep { display: none; }
    .services-compact__item { flex-direction: column; gap: 4px; text-align: center; }
}

/* --- link-gold arrow --- */
.link-gold{color:var(--gold-text);font-weight:500;font-size:.9rem;text-decoration:underline;text-decoration-color:var(--gold);text-underline-offset:3px}
.link-gold:hover{color:var(--gold-dark);text-decoration:underline}
a.ib{text-decoration:none;color:inherit;transition:opacity .2s}
a.ib:hover{opacity:.8}

/* --- Footer Logo --- */
.footer-logo{display:inline-block;margin-bottom:16px}
.footer-logo__img{height:34px;width:auto}

/* --- Desktop Sticky Logo --- */
.desktop-sticky__logo{width:28px;height:28px;border-radius:4px;margin-right:8px;vertical-align:middle}

/* ==========================================================================
   QUICK FACTS BAR (v5.10)
   ========================================================================== */
.quick-facts{display:flex;flex-wrap:wrap;justify-content:center;gap:12px 24px;padding:20px 24px;background:var(--anthracite);border-radius:12px;margin:24px 0}
.quick-facts__item{display:flex;align-items:center;gap:8px;color:rgba(255,255,255,.85);font-size:.88rem}
.quick-facts__icon{font-size:1.1rem}
@media(max-width:600px){.quick-facts{gap:8px 16px;padding:16px}.quick-facts__item{font-size:.82rem}}

/* ==========================================================================
   LUXURY REFERENCES (v5.10)
   ========================================================================== */
.luxury-refs{text-align:center;padding:32px 24px;background:linear-gradient(135deg,#f9f6f0 0%,#f0ece4 100%);border-radius:12px;margin:32px 0}
.luxury-refs__intro{font-size:.85rem;color:var(--text-light);margin-bottom:12px;letter-spacing:.02em;text-transform:uppercase}
.luxury-refs__list{font-size:.95rem;color:var(--text-dark);line-height:2;font-style:italic}
.luxury-refs__sep{color:var(--gold);margin:0 4px}
.luxury-refs__source{margin-top:12px;font-size:.8rem}
.luxury-refs__source a{color:var(--gold);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .2s}
.luxury-refs__source a:hover{border-color:var(--gold)}

/* ==========================================================================
   THREE PILLARS (v5.10)
   ========================================================================== */
.three-pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin:32px 0}
.three-pillars__item{text-align:center;padding:28px 20px;background:#fff;border-radius:12px;box-shadow:0 2px 12px rgba(0,0,0,.06)}
.three-pillars__icon{font-size:2rem;display:block;margin-bottom:12px}
.three-pillars__title{font-size:1.05rem;font-weight:600;color:var(--text-dark);margin-bottom:8px}
.three-pillars__text{font-size:.88rem;color:var(--text-light);line-height:1.6}
@media(max-width:768px){.three-pillars{grid-template-columns:1fr}}

/* === Problemfinder Matrix (v5.11.0) === */
.problemfinder-wrap{overflow-x:auto;margin-top:24px;-webkit-overflow-scrolling:touch}
.problemfinder-table{width:100%;border-collapse:collapse;font-size:.92rem}
.problemfinder-table thead{background:var(--anthracite);color:#fff}
.problemfinder-table th{padding:14px 16px;text-align:center;font-weight:600;font-size:.85rem;letter-spacing:.02em}
.problemfinder-table th:first-child{text-align:left}
.problemfinder-table td{padding:12px 16px;text-align:center;border-bottom:1px solid rgba(0,0,0,.08)}
.problemfinder-table td:first-child{text-align:left;font-weight:500}
.problemfinder-table td:first-child a{color:var(--gold);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .2s}
.problemfinder-table td:first-child a:hover{border-bottom-color:var(--gold)}
.problemfinder-table tbody tr:hover{background:rgba(191,155,80,.06)}
.pf-main{color:var(--gold);font-size:1.2rem;font-weight:700}
.pf-support{color:var(--text-light);font-size:1rem}
.pf-kk{background:rgba(191,155,80,.08)}
.pf-ratgeber a{color:var(--gold);font-size:.82rem;font-weight:600;text-decoration:none}
.pf-ratgeber a:hover{text-decoration:underline}
@media(max-width:768px){.problemfinder-table{font-size:.82rem}.problemfinder-table th,.problemfinder-table td{padding:10px 8px}}

/* === Evidence Box (v5.11.0) === */
.evidence-box{background:#fff;border-left:4px solid var(--gold);padding:24px 28px;border-radius:0 12px 12px 0;box-shadow:0 2px 12px rgba(0,0,0,.06)}

/* === KK Steps (v5.11.0) === */
.kk-steps{display:grid;gap:16px;margin-top:16px}
.kk-step{display:flex;align-items:center;gap:16px;padding:16px 20px;background:#fff;border-radius:10px;box-shadow:0 2px 8px rgba(0,0,0,.05)}
.kk-step__nr{display:flex;align-items:center;justify-content:center;width:36px;min-width:36px;height:36px;min-height:36px;aspect-ratio:1;background:var(--gold);color:#fff;border-radius:50%;font-weight:700;font-size:.85rem;flex-shrink:0}
.kk-step p{margin:0;font-size:.92rem;line-height:1.5;color:var(--text-dark)}

/* === Social Icons with Circle Background (v5.11.0) === */
.social-links{display:flex;gap:12px;align-items:center}
.social-link{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;background:rgba(191,155,80,.12);color:var(--gold);transition:background .2s,color .2s,transform .2s}
.social-link:hover{background:var(--gold);color:#fff;transform:scale(1.08)}
.social-link svg{display:block}

/* === Gutschein Banner (v5.11.0) === */
.gutschein-banner{display:flex;align-items:center;gap:20px;padding:20px 28px;background:#fff;border:2px solid var(--gold);border-radius:12px;box-shadow:0 2px 12px rgba(0,0,0,.05)}
.gutschein-banner__icon{font-size:2rem;flex-shrink:0}
@media(max-width:600px){.gutschein-banner{flex-direction:column;text-align:center}}

/* === B/A Evidence System (v5.11.0) === */
.ba-card__evidence{display:flex;flex-direction:column;gap:4px;margin:8px 0}
.ba-evidence{font-size:.78rem;color:var(--text-muted);line-height:1.4;padding-left:12px;border-left:2px solid var(--gold)}

/* === Missing Classes Fix (v5.11.0 patch) === */
.abo-set{display:none}.abo-set.active{display:grid}
.abo-grid{display:grid;gap:24px;grid-template-columns:repeat(3,1fr);max-width:900px;margin:0 auto}
@media(max-width:768px){.abo-grid{grid-template-columns:1fr}}
.blog-article-body{font-size:1rem;line-height:1.9;color:var(--text-dark)}
.blog-article-body h2{font-size:1.5rem;margin:2rem 0 1rem;color:var(--anthracite)}
.blog-article-body h3{font-size:1.2rem;margin:1.5rem 0 .8rem;color:var(--anthracite)}
.blog-article-body p{margin-bottom:1.2rem}
.blog-article-body a{color:var(--gold);text-decoration:underline}
.blog-article-body a:hover{color:var(--gold-dark)}
.blog-meta{font-size:.82rem;color:var(--text-muted);margin-bottom:1.5rem}
.blog-cta{background:var(--creme);padding:32px;border-radius:12px;text-align:center;margin-top:3rem}
