/* ===== Fonts ===== */

/* — Satoshi (unified family, variable + static fallbacks) — */
@font-face {
    font-family: 'Satoshi';
    src: url('../font/satoshi/fonts/Satoshi-Variable.woff2') format('woff2 supports variations'),
         url('../font/satoshi/fonts/Satoshi-Variable.woff2') format('woff2');
    font-weight: 300 900; font-style: normal; font-display: swap;
}
@font-face {
    font-family: 'Satoshi';
    src: url('../font/satoshi/fonts/Satoshi-VariableItalic.woff2') format('woff2 supports variations'),
         url('../font/satoshi/fonts/Satoshi-VariableItalic.woff2') format('woff2');
    font-weight: 300 900; font-style: italic; font-display: swap;
}
/* static fallbacks */
@font-face { font-family:'Satoshi'; src:url('../font/satoshi/fonts/Satoshi-Light.woff2') format('woff2'); font-weight:300; font-style:normal; font-display:swap; }
@font-face { font-family:'Satoshi'; src:url('../font/satoshi/fonts/Satoshi-LightItalic.woff2') format('woff2'); font-weight:300; font-style:italic; font-display:swap; }
@font-face { font-family:'Satoshi'; src:url('../font/satoshi/fonts/Satoshi-Regular.woff2') format('woff2'); font-weight:400; font-style:normal; font-display:swap; }
@font-face { font-family:'Satoshi'; src:url('../font/satoshi/fonts/Satoshi-Italic.woff2') format('woff2'); font-weight:400; font-style:italic; font-display:swap; }
@font-face { font-family:'Satoshi'; src:url('../font/satoshi/fonts/Satoshi-Medium.woff2') format('woff2'); font-weight:500; font-style:normal; font-display:swap; }
@font-face { font-family:'Satoshi'; src:url('../font/satoshi/fonts/Satoshi-MediumItalic.woff2') format('woff2'); font-weight:500; font-style:italic; font-display:swap; }
@font-face { font-family:'Satoshi'; src:url('../font/satoshi/fonts/Satoshi-Bold.woff2') format('woff2'); font-weight:700; font-style:normal; font-display:swap; }
@font-face { font-family:'Satoshi'; src:url('../font/satoshi/fonts/Satoshi-BoldItalic.woff2') format('woff2'); font-weight:700; font-style:italic; font-display:swap; }
@font-face { font-family:'Satoshi'; src:url('../font/satoshi/fonts/Satoshi-Black.woff2') format('woff2'); font-weight:900; font-style:normal; font-display:swap; }
@font-face { font-family:'Satoshi'; src:url('../font/satoshi/fonts/Satoshi-BlackItalic.woff2') format('woff2'); font-weight:900; font-style:italic; font-display:swap; }

/* — Montserrat (all weights) — */
@font-face { font-family:'Montserrat'; src:url('../font/montserrat/Montserrat-Thin.ttf') format('truetype'); font-weight:100; font-style:normal; font-display:swap; }
@font-face { font-family:'Montserrat'; src:url('../font/montserrat/Montserrat-ThinItalic.ttf') format('truetype'); font-weight:100; font-style:italic; font-display:swap; }
@font-face { font-family:'Montserrat'; src:url('../font/montserrat/Montserrat-ExtraLight.ttf') format('truetype'); font-weight:200; font-style:normal; font-display:swap; }
@font-face { font-family:'Montserrat'; src:url('../font/montserrat/Montserrat-ExtraLightItalic.ttf') format('truetype'); font-weight:200; font-style:italic; font-display:swap; }
@font-face { font-family:'Montserrat'; src:url('../font/montserrat/Montserrat-Light.ttf') format('truetype'); font-weight:300; font-style:normal; font-display:swap; }
@font-face { font-family:'Montserrat'; src:url('../font/montserrat/Montserrat-LightItalic.ttf') format('truetype'); font-weight:300; font-style:italic; font-display:swap; }
@font-face { font-family:'Montserrat'; src:url('../font/montserrat/Montserrat-Regular.ttf') format('truetype'); font-weight:400; font-style:normal; font-display:swap; }
@font-face { font-family:'Montserrat'; src:url('../font/montserrat/Montserrat-Italic.ttf') format('truetype'); font-weight:400; font-style:italic; font-display:swap; }
@font-face { font-family:'Montserrat'; src:url('../font/montserrat/Montserrat-Medium.ttf') format('truetype'); font-weight:500; font-style:normal; font-display:swap; }
@font-face { font-family:'Montserrat'; src:url('../font/montserrat/Montserrat-MediumItalic.ttf') format('truetype'); font-weight:500; font-style:italic; font-display:swap; }
@font-face { font-family:'Montserrat'; src:url('../font/montserrat/Montserrat-SemiBold.ttf') format('truetype'); font-weight:600; font-style:normal; font-display:swap; }
@font-face { font-family:'Montserrat'; src:url('../font/montserrat/Montserrat-SemiBoldItalic.ttf') format('truetype'); font-weight:600; font-style:italic; font-display:swap; }
@font-face { font-family:'Montserrat'; src:url('../font/montserrat/Montserrat-Bold.ttf') format('truetype'); font-weight:700; font-style:normal; font-display:swap; }
@font-face { font-family:'Montserrat'; src:url('../font/montserrat/Montserrat-BoldItalic.ttf') format('truetype'); font-weight:700; font-style:italic; font-display:swap; }
@font-face { font-family:'Montserrat'; src:url('../font/montserrat/Montserrat-ExtraBold.ttf') format('truetype'); font-weight:800; font-style:normal; font-display:swap; }
@font-face { font-family:'Montserrat'; src:url('../font/montserrat/Montserrat-ExtraBoldItalic.ttf') format('truetype'); font-weight:800; font-style:italic; font-display:swap; }
@font-face { font-family:'Montserrat'; src:url('../font/montserrat/Montserrat-Black.ttf') format('truetype'); font-weight:900; font-style:normal; font-display:swap; }
@font-face { font-family:'Montserrat'; src:url('../font/montserrat/Montserrat-BlackItalic.ttf') format('truetype'); font-weight:900; font-style:italic; font-display:swap; }

/* — JosefinSans (all weights) — */
@font-face { font-family:'JosefinSans'; src:url('../font/josefinsans/JosefinSans-Thin.ttf') format('truetype'); font-weight:100; font-style:normal; font-display:swap; }
@font-face { font-family:'JosefinSans'; src:url('../font/josefinsans/JosefinSans-ThinItalic.ttf') format('truetype'); font-weight:100; font-style:italic; font-display:swap; }
@font-face { font-family:'JosefinSans'; src:url('../font/josefinsans/JosefinSans-ExtraLight.ttf') format('truetype'); font-weight:200; font-style:normal; font-display:swap; }
@font-face { font-family:'JosefinSans'; src:url('../font/josefinsans/JosefinSans-ExtraLightItalic.ttf') format('truetype'); font-weight:200; font-style:italic; font-display:swap; }
@font-face { font-family:'JosefinSans'; src:url('../font/josefinsans/JosefinSans-Light.ttf') format('truetype'); font-weight:300; font-style:normal; font-display:swap; }
@font-face { font-family:'JosefinSans'; src:url('../font/josefinsans/JosefinSans-LightItalic.ttf') format('truetype'); font-weight:300; font-style:italic; font-display:swap; }
@font-face { font-family:'JosefinSans'; src:url('../font/josefinsans/JosefinSans-Regular.ttf') format('truetype'); font-weight:400; font-style:normal; font-display:swap; }
@font-face { font-family:'JosefinSans'; src:url('../font/josefinsans/JosefinSans-Italic.ttf') format('truetype'); font-weight:400; font-style:italic; font-display:swap; }
@font-face { font-family:'JosefinSans'; src:url('../font/josefinsans/JosefinSans-Medium.ttf') format('truetype'); font-weight:500; font-style:normal; font-display:swap; }
@font-face { font-family:'JosefinSans'; src:url('../font/josefinsans/JosefinSans-MediumItalic.ttf') format('truetype'); font-weight:500; font-style:italic; font-display:swap; }
@font-face { font-family:'JosefinSans'; src:url('../font/josefinsans/JosefinSans-SemiBold.ttf') format('truetype'); font-weight:600; font-style:normal; font-display:swap; }
@font-face { font-family:'JosefinSans'; src:url('../font/josefinsans/JosefinSans-SemiBoldItalic.ttf') format('truetype'); font-weight:600; font-style:italic; font-display:swap; }
@font-face { font-family:'JosefinSans'; src:url('../font/josefinsans/JosefinSans-Bold.ttf') format('truetype'); font-weight:700; font-style:normal; font-display:swap; }
@font-face { font-family:'JosefinSans'; src:url('../font/josefinsans/JosefinSans-BoldItalic.ttf') format('truetype'); font-weight:700; font-style:italic; font-display:swap; }

:root {
    --color--background-color: #faf8f4;
    --color--text: #1a1a1a;
    --color--grey: #7a7a7a;
    --color--tag--container: rgba(0,0,0,0.4);
    --color1: #c8893f;
    --color2: #b5763a;
    --sand: #e8dfd0;
    --color--white: #FFFFFF;
    --color--white--50: rgba(255, 255, 255, 0.5);
    --color--whatsapp: #25D366;

    --bg-light: #ffffff;
    --accent-gradient: linear-gradient(90deg, #c8893f, #e0a45a, #a06830, #c8893f);

    --font-family-satoshi: 'Satoshi', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
    --font-family-satoshi-light: 'Satoshi', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
    --font-family-montserrat: 'Montserrat', 'Satoshi', system-ui, sans-serif;
    --font-family-josefin: 'JosefinSans', 'Montserrat', 'Satoshi', system-ui, sans-serif;
    --font-family-display: 'Montserrat', 'Satoshi', system-ui, sans-serif;

    --base-font-size: 1rem;
    --ratio: 1.618;
    --body-size: clamp(1rem, 1.6vw, 1.5rem);

    --h1-size: clamp(2rem, 5vw, 4rem);
    --h2-size: clamp(1.5rem, 3vw, 2.5rem);
    --h3-size: 1.5rem;
    --h4-size: 1.25rem;

    --line-height: var(--ratio);

    /* Spacing system */
    --space-xs: 0.5rem;
    --space-sm: 1rem;
    --space-md: 1.5rem;
    --space-lg: 2rem;
    --space-xl: 3rem;
    --space-2xl: 5rem;
    --space-3xl: 10rem;

    /* Transitions */
    --transition-fast: 0.2s ease;
    --transition-base: 0.3s ease;
    --transition-slow: 0.5s ease;

    /* Shadows */
    --shadow-sm: 0 1px 3px rgba(0,0,0,0.08);
    --shadow-md: 0 4px 12px rgba(0,0,0,0.1);
    --shadow-lg: 0 8px 24px rgba(0,0,0,0.12);

    /* Border radius */
    --radius-sm: 0.35rem;
    --radius-md: 0.5rem;
    --radius-lg: 0.75rem;
    --radius-xl: 1rem;
    --radius-pill: 100rem;

    /* ——— Design System: --op-* canonical tokens ——— */
    --op-color1: #c8893f;
    --op-color2: #b5763a;
    --op-sand: #e8dfd0;
    --op-bg: #faf8f4;
    --op-text: #1a1a1a;
    --op-grey: #7a7a7a;
    --op-white: #ffffff;
    --op-white-50: rgba(255,255,255,0.5);
    --op-whatsapp: #25d366;
    --op-tag-scrim: rgba(0,0,0,0.4);

    --op-accent-gradient: linear-gradient(90deg,#c8893f,#e0a45a,#a06830,#c8893f);
    --op-bg-warm: linear-gradient(135deg,#f5f0e8 0%,#ede4d4 50%,#e8ddd0 100%);
    --op-bg-cool: linear-gradient(135deg,#eef4f8 0%,#ddeaf2 60%,#cfe0ed 100%);

    --op-font-sans: 'Satoshi', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
    --op-font-display: 'Montserrat', 'Satoshi', system-ui, sans-serif;

    --op-body-size: clamp(1rem,1.6vw,1.5rem);
    --op-h1-size: clamp(2rem,5vw,4rem);
    --op-h2-size: clamp(1.5rem,3vw,2.5rem);
    --op-h3-size: 1.5rem;
    --op-h4-size: 1.25rem;
    --op-hero-title: clamp(2.5rem,7vw,5.5rem);
    --op-line-height: 1.618;

    --op-space-xs: 0.5rem;
    --op-space-sm: 1rem;
    --op-space-md: 1.5rem;
    --op-space-lg: 2rem;
    --op-space-xl: 3rem;
    --op-space-2xl: 5rem;
    --op-space-3xl: 10rem;

    --op-radius-sm: 0.35rem;
    --op-radius-md: 0.5rem;
    --op-radius-lg: 0.75rem;
    --op-radius-xl: 1rem;
    --op-radius-pill: 100rem;

    --op-shadow-sm: 0 1px 3px rgba(0,0,0,0.08);
    --op-shadow-md: 0 4px 12px rgba(0,0,0,0.1);
    --op-shadow-lg: 0 8px 24px rgba(0,0,0,0.12);
    --op-shadow-brand: 0 4px 20px rgba(200,137,63,0.35);
    --op-shadow-brand-lg: 0 8px 28px rgba(200,137,63,0.45);

    --op-transition-fast: 0.2s ease;
    --op-transition-base: 0.3s ease;
    --op-transition-slow: 0.5s ease;
    --op-ease-out-back: cubic-bezier(0.25,0.46,0.45,0.94);

    --op-container: 1200px;
    --op-navbar-h: 56px;
}

/* ===== RESET & BASE ===== */
*, *::before, *::after {
    box-sizing: border-box;
}

html {
    font-size: var(--base-font-size);
    line-height: var(--line-height);
    font-family: var(--font-family-satoshi);
    color: var(--color--text);
    background-color: var(--color--background-color);
    scroll-behavior: smooth;
}

body {
    margin: 0;
    font-size: var(--body-size);
    overflow-x: hidden;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

/*section {
    flex: 1; /* füllt den verfügbaren Platz */
/*}*/

img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* ===== TYPOGRAPHY ===== */
h1, h2, h3, h4, .h1, .h2, .h3, .h4 {
    font-family: var(--font-family-display);
}

h1, .h1 {
    font-size: var(--h1-size);
    line-height: 1.2;
    margin: var(--space-md) 0;
    font-weight: bold;
}
section h1:first-of-type {
    margin-top: 0;
}

h2, h2 *, h2 span {
    font-size: var(--h2-size);
    line-height: 1.3;
    margin: var(--space-sm) 0 0.75rem;
    font-weight: bold;
}
.h2 {
    font-size: var(--h2-size);
    line-height: 1.3;
    font-weight: bold;
}

h3, .h3 {
    font-size: var(--h3-size);
    line-height: 1.35;
    margin: var(--space-sm) 0;
    font-weight: bold;
}

h4, .h4 {
    font-size: var(--h4-size);
    line-height: 1.4;
    margin: 0.75rem 0;
    font-weight: bold;
}

p {
    margin: 0 0 var(--space-md) 0;
}

/*div p:last-of-type {
    margin-bottom: 0;
}*/

a {
    text-decoration: none;
    color: var(--color1);
    transition: color var(--transition-fast);
}
footer a {
    color: inherit;
}
a:hover {
    color: var(--color2);
}

.highlight {
    color: var(--color2);
}
.dezent {
    color: var(--sand);
}

/* Utilities */
.schlagzeile {
    font-family: var(--font-family-satoshi);
    font-weight: 700;
    font-size: 0.82rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--color1);
    margin: 0 0 0.4rem;
}

.uc { text-transform: uppercase; }
.lc { text-transform: lowercase; }
.bold { font-weight: bold; }
.pt-0 { padding-top: 0; }
.mt-1-5rem { margin-top: var(--space-md); }
.mt-md { margin-top: var(--space-md); }
.mt-lg { margin-top: var(--space-lg); }
.mt-xl { margin-top: var(--space-xl); }
.mt-2xl { margin-top: var(--space-2xl); }
.text-small { font-size: 0.8rem; }
.line-through { text-decoration: line-through; }
.fs-08 {font-size: 0.8em;}
.fs-1_5 {font-size: 1.5em;}
.fs-2 { font-size: 2em; }
.mr-5 { margin-right: 5px; }
.lh-0 {line-height: 0;}
.no-textdecoration { text-decoration: none; }
.inherit { color: inherit; font-size: inherit; text-decoration: inherit; }
.ct { color: var(--color--text)};
.c1 {color: var(--color1);}
.c2 {color: var(--color2);}
.fw-normal {font-weight:normal;}

/* ===== LAYOUT ===== */
.container {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 var(--space-sm);
}

section.hero {
    margin-top: 0;
}

section:not(.hero) {
    padding: var(--space-lg) var(--space-sm);
}

/*section:not(.hero):first-of-type {
    margin-top: var(--space-xl);
}*/

/* ===== NAVBAR ===== */
.navbar {
    position: sticky;
    top: 0;
    left: 0;
    height: 56px;
    width: 100%;
    display: flex;
    align-items: center;
    z-index: 1000;
}

.navbar-bg {
    background-color: rgba(250, 248, 244, 0.88);
    backdrop-filter: blur(16px) saturate(180%);
    -webkit-backdrop-filter: blur(16px) saturate(180%);
    border-bottom: 1px solid rgba(200, 137, 63, 0.12);
    box-shadow: 0 1px 12px rgba(0,0,0,0.06);
}

.navbar-container {
    display: flex;
    width: 100%;
    height: 44px;
    justify-content: space-between;
    align-items: center;
    padding: 0 var(--space-md);
    margin: 0 var(--space-sm);
}

.navbar-logo {
    display: flex;
    align-items: center;
    height: 80%;
}

.navbar-logo img {
    height: 34px;
    width: auto;
    display: block;
}

.navbar-links ul {
    list-style: none;
    display: flex;
    gap: var(--space-lg);
    margin: 0;
    padding: 0;
}

.navbar-links li::before {
    content: none;
}

.navbar-links a {
    text-decoration: none;
    color: var(--color--text);
    font-weight: 500;
    font-size: 0.9rem;
    position: relative;
    padding-bottom: 2px;
    transition: color var(--transition-fast);
}

.navbar-links a::after {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 0;
    height: 2px;
    background: var(--color1);
    border-radius: var(--radius-pill);
    transition: width var(--transition-base);
}

.navbar-links a:hover,
.navbar-links a.active {
    color: var(--color1);
}

.navbar-links a:hover::after,
.navbar-links a.active::after {
    width: 100%;
}

/* Burger Menu Icon */
.menu-toggle {
    display: flex;
    flex-direction: column;
    cursor: pointer;
    gap: 5px;
    border: none;
    background: none;
    padding: 10px;
}

.menu-toggle span {
    display: block;
    width: 25px;
    height: 3px;
    background-color: var(--color--text);
    transition: 0.3s;
    border-radius: 2px;
}

/* Link Liste */
.nav-links {
    position: absolute;
    top: 100%;
    right: 0;
    /*background-color: var(--bg-light);*/
    width: 250px;
    display: flex;
    flex-direction: column;
    max-height: 0; /* Standardmäßig eingeklappt */
    overflow: hidden;
    transition: max-height 0.4s ease-in-out;
    /*box-shadow: -5px 5px 15px rgba(0,0,0,0.05);*/
}

.nav-links.active {
    max-height: 500px; /* Ausgeklappte Höhe */
}

.nav-links a {
    padding: 1.2rem 2rem;
    text-decoration: none;
    color: var(--color--text);
    font-weight: 500;
    border-bottom: 1px solid #eee;
    transition: padding-left 0.3s;
}

/* Hover Effekt: Dezent bunte Linie unten */
.nav-links a:hover {
    padding-left: 2.5rem;
    background: #fafafa;
    border-left: 5px solid transparent;
    border-image: var(--accent-gradient);
    border-image-slice: 1;
}

/* ===== HERO ===== */
/*.hero {
    position: relative;
    width: 100%;
    height: 100vh;
    min-height: 100vh;
    overflow: hidden;
    flex: 0;
    margin-top: -50px;
}*/

.hero-slide-wrapper {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.hero-slide-mask {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    transition: opacity 1.5s ease-in-out;
}

.hero-slide-mask::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(
        135deg,
        rgba(0,0,0,0.55) 0%,
        rgba(0,0,0,0.15) 60%,
        rgba(0,0,0,0.05) 100%
    );
}

.hero-slide-mask.active {
    opacity: 1;
}

.hero-slide-image {
    width: 100%;
    height: 100vh;
    background-size: cover;
    background-position: center;
    transition: transform 8s ease-out;
}

.hero-slide-mask.active .hero-slide-image {
    transform: scale(1.04);
}

/* Hero content */
.hero-content {
    position: absolute;
    top: 50%;
    left: 5%;
    transform: translateY(-50%);
    max-width: min(800px, 90%);
    z-index: 10;
}

.hero-title {
    font-size: clamp(2.5rem, 7vw, 5.5rem);
    font-weight: 800;
    color: #fff;
    line-height: 1.05;
    margin: 0 0 0.5rem;
    text-shadow: 0 2px 20px rgba(0,0,0,0.3);
    transition: opacity 0.4s ease, transform 0.4s ease;
}

.hero .hero-content .hero-subtitle {
    font-size: clamp(1rem, 2vw, 1.6rem);
    font-weight: 300;
    color: rgba(255,255,255,0.9);
    margin: 0 0 var(--space-md);
    letter-spacing: 0.05em;
    text-transform: uppercase;
    transition: opacity 0.4s ease, transform 0.4s ease;
}

.hero-description {
    background: rgba(255, 255, 255, 0.12);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    padding: var(--space-sm);
    border-radius: var(--radius-lg);
    margin-bottom: var(--space-lg);
    max-width: 520px;
    border: 1px solid rgba(255,255,255,0.2);
    transition: opacity 0.4s ease;
}

.hero-description p {
    color: rgba(255,255,255,0.95);
    font-size: clamp(1rem, 1.4vw, 1.05rem);
    line-height: 1.7;
    margin: 0;
}

.hero-button {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    background: var(--color1);
    color: #ffffff;
    padding: 0.9rem 2.4rem;
    border-radius: var(--radius-pill);
    font-weight: 600;
    font-size: 0.9rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    text-decoration: none;
    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    box-shadow: 0 4px 20px rgba(200, 137, 63, 0.35);
    border: none;
    position: relative;
    z-index: 1;
}

.hero-button:hover {
    color: #ffffff;
    transform: translateY(-3px);
    background: var(--color2);
    box-shadow: 0 8px 28px rgba(200, 137, 63, 0.45);
}

/* Social Icons */
.hero-social {
    position: absolute;
    right: 3%;
    top: 50%;
    transform: translateY(-50%);
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    z-index: 10;
}

.hero-social a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.75rem;
    height: 2.75rem;
    background: rgba(255, 255, 255, 0.15);
    backdrop-filter: blur(8px);
    border-radius: 50%;
    color: #fff;
    font-size: 1.1rem;
    transition: all var(--transition-base);
    border: 1px solid rgba(255,255,255,0.2);
}

.hero-social a:hover {
    background: rgba(255, 255, 255, 0.3);
    transform: translateY(-3px) scale(1.05);
    border-color: rgba(255,255,255,0.5);
}

/* Thumbnail Navigation */
.hero-thumbnails {
    position: absolute;
    bottom: 6%;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 0.5rem;
    z-index: 10;
    background: rgba(255, 255, 255, 0.15);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    padding: 0.5rem;
    border-radius: var(--radius-lg);
    border: 1px solid rgba(255,255,255,0.2);
}

.thumbnail {
    width: 64px;
    height: 46px;
    border-radius: var(--radius-sm);
    overflow: hidden;
    cursor: pointer;
    border: 2px solid transparent;
    transition: all var(--transition-base);
    opacity: 0.55;
}

.thumbnail:hover {
    opacity: 0.85;
    transform: translateY(-2px);
}

.thumbnail.active {
    border-color: #fff;
    opacity: 1;
    box-shadow: 0 2px 8px rgba(0,0,0,0.3);
}

.thumbnail img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* ===== SCROLL DOWN ===== */
.scroll-down {
    position: absolute;
    bottom: 2rem;
    left: 50%;
    transform: translateX(-50%);
    font-size: 1.5rem;
    color: rgba(255,255,255,0.8);
    animation: bounce 2s infinite;
    text-decoration: none;
    z-index: 10;
}

@keyframes bounce {
    0%, 20%, 50%, 80%, 100% { transform: translateX(-50%) translateY(0); }
    40% { transform: translateX(-50%) translateY(-10px); }
    60% { transform: translateX(-50%) translateY(-5px); }
}

/* ===== SECTIONS ===== */
.background-gradient {
    background-image: linear-gradient(135deg, #f5f0e8 0%, #ede4d4 50%, #e8ddd0 100%);
    background-attachment: fixed;
}

.background-gradient-blue {
    background-image: linear-gradient(135deg, #eef4f8 0%, #ddeaf2 60%, #cfe0ed 100%);
    background-attachment: fixed;
}

/* ===== FOOTER ===== */
footer {
    background: var(--color--text);
    color: #d7d2c8;
    padding: var(--space-xl) var(--space-lg) var(--space-md);
    font-size: 0.875rem;
}

.footer-cols {
    display: grid;
    grid-template-columns: 1.3fr 1fr 1fr;
    gap: var(--space-lg);
    max-width: var(--op-container);
    margin: 0 auto var(--space-md);
}

@media (max-width: 640px) {
    .footer-cols { grid-template-columns: 1fr; gap: var(--space-md); }
}

.footer-col h4 {
    font-family: var(--font-family-display);
    font-weight: 700;
    font-size: 0.78rem;
    color: #fff;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    margin: 0 0 0.6rem;
}

footer a {
    color: #d7d2c8;
    text-decoration: none;
    transition: color var(--transition-fast);
}

footer a:hover {
    color: var(--color1);
}

.footer-links a {
    display: block;
    font-size: 0.82rem;
    padding: 0.1rem 0;
}

.footer-bottom {
    border-top: 1px solid rgba(255,255,255,0.08);
    margin-top: var(--space-md);
    padding-top: var(--space-sm);
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.5rem;
    font-size: 0.72rem;
    color: #888;
    max-width: var(--op-container);
    margin-left: auto;
    margin-right: auto;
}

.footer-bottom p,
.footer-bottom .text-small {
    color: #888;
    font-size: 0.72rem;
    margin: 0;
}

/* legacy: simple centered footer for pages not yet using cols */
footer:not(:has(.footer-cols)) {
    text-align: center;
    background: var(--color--text);
}
footer:not(:has(.footer-cols)) a {
    margin: 0 0.5rem;
}

/* ===== BUTTON ===== */
body .btn {
    display: inline-block;
    padding: 0.75rem var(--space-md);
    border-radius: var(--radius-md);
    margin: var(--space-xs);
    transition: all var(--transition-base);
}

.button {
    display: inline-block;
    border: 1.5px solid var(--color1);
    background-color: transparent;
    color: var(--color1);
    padding: 0.4em 1.2em;
    border-radius: var(--radius-pill);
    transition: all var(--transition-base);
    font-weight: 600;
    letter-spacing: 0.04em;
}

.button:hover {
    background-color: var(--color1);
    border-color: var(--color1);
    color: var(--color--white);
    transform: translateY(-2px);
    box-shadow: 0 4px 16px rgba(200, 137, 63, 0.3);
}

a.button {
    color: inherit;
}


.text-button {
    display: inline-block;
    /*border: 1px solid var(--color--text);*/
    /*background-color: var(--color--white);*/
    padding: 0.3em 0;
    border-radius: var(--radius-md);
    transition: all var(--transition-base);
    font-weight: 500;
}

.text-button:hover {
    color: var(--color1);
}

a.text-button {
    color: inherit;
}

/* ===== BLOCKQUOTE ===== */
/*blockquote {
    margin: var(--space-sm) var(--space-sm);
    unicode-bidi: isolate;
    border-left: 3px solid var(--color1);
    padding-left: var(--space-sm);
}

blockquote p {
    font-style: italic;
    color: var(--color--grey);
}*/

/* ===== IMAGE CARD ===== */
.image-card-wrapper {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-sm);
    margin: var(--space-md) 0;
}

@media (min-width: 640px) {
    .image-card-wrapper {
        grid-template-columns: repeat(2, 1fr);
    }
    .image-card-wrapper.wide{
        grid-template-columns: repeat(1, 1fr);
    }
}

@media (min-width: 900px) {
    .image-card-wrapper:not(.wide) {
        grid-template-columns: repeat(3, 1fr);
    }
    .image-card-wrapper.wide{
        grid-template-columns: repeat(1, 1fr);
    }
}

.image-card {
    background-color: var(--color--white);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    transition: transform var(--transition-base), box-shadow var(--transition-base);
}


.image-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
}

.image-card-title {
    padding: var(--space-sm);
}
.image-card-title h1 {
    margin: 0;
}


.image-card-image {
    position: relative;
    width: 100%;
    aspect-ratio: 4 / 3;
    overflow: hidden;
}

.image-card-wrapper.wide .image-card-image {
    height: 30vh;
}

.image-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-slow);
}

.image-card:hover .image-card-image img {
    transform: scale(1.05);
}

.image-card-info {
    padding: var(--space-sm);
}

.image-card-info .titel {
    font-weight: 700;
    text-transform: uppercase;
    /*font-size: 0.8rem;*/
    letter-spacing: 0.08em;
    /*color: var(--color1);*/
    margin-bottom: 0.3rem;
}

.image-card-info .text {
    /*font-size: 0.9rem;*/
    /*color: var(--color--grey);*/
    line-height: 1.5;
}


/* ===== TEXT CARD ===== */
.text-card-wrapper {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-sm);
    margin: var(--space-md) 0;
}
.text-card-wrapper.check .text-card {
    display: flex;
    align-items: flex-start;
}

.card-check {
    width: 1.8em;
    height: 1.8em;
    border-radius: 50%;
    background: var(--color--text);
    color: #fff;
    font-size: 0.8em;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    margin: var(--space-sm) 0 var(--space-sm) var(--space-sm);
  }

@media (min-width: 640px) {
    .text-card-wrapper {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 900px) {
    .text-card-wrapper {
        grid-template-columns: repeat(3, 1fr);
    }
}

.text-card {
    background-color: var(--color--white);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.text-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
}

.text-card-image {
    position: relative;
    width: 100%;
    aspect-ratio: 4 / 3;
    overflow: hidden;
}


.text-card-info {
    padding: var(--space-sm);
}

.text-card-info .titel {
    font-weight: 700;
    text-transform: uppercase;
    /*font-size: 0.8rem;*/
    letter-spacing: 0.08em;
    /*color: var(--color1);*/
    margin-bottom: 0.3rem;
}

.text-card-info .text {
    /*font-size: 0.9rem;*/
    /*color: var(--color--grey);*/
    line-height: 1.5;
}


/* ===== STICKY ===== */
.sticky-heading {
    font-size: var(--h1-size);
    line-height: 1.2;
    font-weight: bold;
}

.sticky-text {
    margin-top: var(--space-md);
}

.sticky-paragraph {
    margin-top: var(--space-md);
    line-height: 1.7;
}

.sticky-image-big {
    width: 100%;
    height: 90vh;
    overflow: hidden;
    margin-top: var(--space-md);
    border-radius: var(--radius-lg);
}

.sticky-image-medium {
    flex: none;
    align-self: flex-end;
    width: 60vw;
    height: 60vh;
    margin-top: var(--space-md);
    position: relative;
    overflow: hidden;
    border-radius: var(--radius-lg);
}

.sticky-image-small {
    flex: none;
    align-self: flex-end;
    width: 50vw;
    height: 50vw;
    margin-top: var(--space-md);
    margin-right: var(--space-md);
    overflow: hidden;
    border-radius: var(--radius-lg);
}

.sticky-text .schlagzeile + .sticky-heading,
.sticky-text .schlagzeile + .sticky-paragraph {
    margin-top: 0.5rem;
}

.sticky-content {
    flex-flow: column;
    align-items: flex-start;
    width: 100%;
    display: flex;
    position: relative;
}

@media (min-width: 1000px) {
    .sticky-component,
    .sticky-content {
        width: 50%;
    }

    .sticky-wrapper {
        gap: var(--space-md);
        margin-top: 8rem;
        display: flex;
        position: relative;
    }

    .sticky-component {
        width: 50%;
        height: 90vh;
        position: sticky;
        top: 5vh;
        bottom: 5vh;
        overflow: hidden;
    }

    .sticky-text {
        margin-right: var(--space-sm);
        margin-left: var(--space-sm);
    }

    .sticky-image-small {
        width: 50%;
        height: auto;
        aspect-ratio: 1 / 1;
        margin-right: 0;
    }

    .sticky-image-medium {
        width: 70%;
        aspect-ratio: 1 / 1;
        height: auto;
    }
}

/* ===== TEXT HIGHLIGHT ===== */
.text-highlight {
    margin-left: 2vw;
    padding: 0.5rem 1.5rem;
    position: relative;
}
.text-highlight::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 3px;
    background: linear-gradient(to bottom, var(--color1), var(--color2));
    opacity: 0.7;
    border-radius: 10px;
}

.text-highlight p {
    line-height: 1.8;
}

/* ===== BLOG ===== */
section.blog-header {
    margin-top: 0;
    padding-bottom: 0;
}

body > section:first-of-type.blog-header-image {
    margin-top: -70px;
}

section.blog-header + section.blog {
    padding-top: 0;
}

section.blog-header .blog-header-image {
    margin: -2rem -1rem 1rem -1rem;
}

section.blog-header .blog-header-image img {
    border-radius: 0;
    margin: 0;
    height: 60vh;
}

.note {
    background: rgba(200, 137, 63, 0.08);
    border-left: 4px solid var(--color1);
    padding: 12px 16px;
    border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
    margin-top: 12px;
}

.hightlights {
    background: var(--color--white);
    border-left: 4px solid var(--color1);
    padding: 8px 12px;
    margin: 10px 0;
    width: fit-content;
}

/* ===== BLOG LIST ===== */
.blog-list .blog-container {
    margin: var(--space-sm) 0;
    position: relative;
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.blog-list .blog-container:first-of-type {
    margin-top: 0;
}

.blog-list .blog-container {
    background-color: var(--color--white);
}

.blog-list .blog-container:hover {
    transform: translateY(-3px);
    box-shadow: var(--shadow-md);
}

.blog-list .blog-container img {
    width: 100%;
    height: 200px;
    object-fit: cover;
    transition: transform var(--transition-slow);
}

.blog-list .blog-container:hover img {
    transform: scale(1.03);
}

.blog-list .blog-list-content {
    padding: var(--space-sm);
}

.blog-list .blog-list-content h2 {
    margin: 0 0 0.5rem;
    font-size: clamp(1.1rem, 2vw, 1.4rem);
}

.blog-list .tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
}

.blog-list .tags span,
.blog-list span.blog-category {
    background: var(--color--tag--container);
    color: var(--color--white);
    padding: 0.15rem 0.6rem;
    border-radius: var(--radius-pill);
    cursor: pointer;
    transition: background var(--transition-fast);
    margin: 0;
    text-transform: uppercase;
    font-size: 0.6rem;
    letter-spacing: 0.06em;
    font-weight: 600;
}

.blog-list span.blog-category {
    position: absolute;
    top: 0.6rem;
    left: 0.6rem;
    z-index: 10;
    background: rgba(0,0,0,0.5);
    backdrop-filter: blur(8px);
}

.blog-list .tags span:hover {
    background: var(--color1);
}

.blog-list-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 0.75rem;
    padding-top: 0.75rem;
    border-top: 1px solid rgba(0,0,0,0.06);
}

.blog-list-footer .buttons {
    display: flex;
    gap: var(--space-sm);
}

.blog-list-footer .buttons div {
    align-items: center;
    justify-content: center;
    display: flex;
    gap: 0.3rem;
}

.blog-list-footer span,
.blog-list-footer i {
    font-size: 0.8rem;
    color: var(--color--grey);
}

/* Multi-image container */
.multi-image-container {
    display: flex;
    width: 100%;
    height: 200px;
    overflow: hidden;
}

.image-left,
.image-right {
    flex: 1;
    background-size: cover;
    background-position: center;
}

.image-left {
    clip-path: polygon(0 0, 100% 0, 85% 100%, 0% 100%);
    margin-right: -8.2%;
}

.image-right {
    clip-path: polygon(15% 0, 100% 0, 100% 100%, 0% 100%);
}

/* ===== ENTRY ===== */
.entry.landing {
    padding-top: 0;
    margin: -70px 0 0 0;
    height: 100vh;
    background-image: url("../img/sammlung/unsplash/johnny-africa-DSqXpNwzJgk-unsplash.jpg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
    padding-bottom: max(10%, 10vh);
    box-sizing: border-box;
}

.entry-box {
    width: auto;
    max-width: 100%;
    max-height: 50vh;
    aspect-ratio: 1/1;
    margin: 10vh auto 0 auto;
    background-color: rgba(255,255,255, 0.25);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    padding: 1vw;
    border: 1px solid rgba(255,255,255,0.4);
    display: flex;
    justify-content: center;
    align-items: center;
    box-sizing: border-box;
    border-radius: var(--radius-lg);
}

.entry-box .entry-content {
    display: flex;
    flex-direction: column;
    width: 100%;
    height: 100%;
    box-sizing: border-box;
    padding: 2vw;
}

.entry-box .entry-logo {
    flex: 1 1 auto;
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 0;
    max-width: 45vw;
    margin: 0 auto;
}

.entry-box .entry-text p {
    text-align: center;
    font-size: 2em;
    color: var(--color--text);
}

.entry-box .entry-text .entry-text-h {
    margin: 0;
    font-size: clamp(1.5rem, 5vw, 3rem);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.entry-box .entry-text .entry-text-p {
    margin: 0;
    font-size: clamp(1rem, 3vw, 2rem);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.entry-box .entry-logo img {
    max-width: 220px;
    max-height: 220px;
    width: 100%;
    height: auto;
    object-fit: contain;
}

.entry .entry-buttons {
    margin-top: 2vh;
    display: flex;
    gap: var(--space-xs);
}

.entry .entry-buttons a {
    text-decoration: none;
    font-size: clamp(1rem, 3.5vw, 1.75rem);
}

.entry .entry-buttons .btn {
    color: var(--color--white);
    background: var(--color--text);
    border-radius: var(--radius-pill);
    padding: 0.75rem;
    aspect-ratio: 1 / 1;
    display: flex;
    justify-content: center;
    align-items: center;
    transition: all var(--transition-base);
}

.entry .entry-buttons .btn:hover {
    background: var(--color1);
    transform: scale(1.08);
}

.entry-category-buttons {
    max-width: 100%;
    margin: 0 var(--space-sm);
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));
    gap: var(--space-sm);
    justify-items: center;
}

.entry-category-container {
    background-color: var(--color--white);
    border-radius: var(--radius-lg);
    padding: 0.75rem;
    width: 7rem;
    height: 5rem;
    display: grid;
    place-items: center;
    text-align: center;
    box-shadow: var(--shadow-sm);
    transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.entry-category-container:hover {
    transform: translateY(-3px);
    box-shadow: var(--shadow-md);
}

.entry-category-icon {
    font-size: 1.75rem;
    color: var(--color1);
}

.entry-category-text {
    color: var(--color--text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    font-size: 0.8rem;
}

/* ===== DETAILS ===== */
details summary {
    font-weight: bold;
    cursor: pointer;
    padding: 0.5rem 0;
    user-select: none;
}

details summary:hover {
    color: var(--color2);
}

details > *:not(summary) {
    margin-left: var(--space-sm);
}

/* ===== SLIDESHOW ===== */
.slideshow-container {
    position: relative;
    height: 60vh;
    overflow: hidden;
    border-radius: var(--radius-lg);
}

.slide {
    position: absolute;
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0;
    transition: opacity 1s ease-in-out;
}

.slide.active {
    opacity: 1;
}

.dots {
    position: absolute;
    bottom: 12px;
    width: 100%;
    text-align: center;
}

.dot {
    display: inline-block;
    width: 8px;
    height: 8px;
    margin: 0 4px;
    background-color: rgba(255,255,255,0.4);
    border-radius: 50%;
    cursor: pointer;
    transition: all var(--transition-fast);
}

.dot.active {
    background-color: #fff;
    transform: scale(1.3);
}

/* ===== LISTS ===== */
ul, ol {
    margin-block-start: 0;
    padding-inline-start: var(--space-sm);
}

ul:not(.numbered-list) li,
ol:not(.numbered-list) li {
    list-style: none;
    padding-left: 1em;
    position: relative;
    line-height: 1.7;
}

ul:not(.numbered-list, .no-list) li:not(.navbar li, .no-list)::before,
ol:not(.numbered-list, .no-list) li:not(.navbar li, .no-list)::before {
    content: "▪";
    position: absolute;
    left: 0;
    color: var(--color1);
}

ol.numbered-list {
    list-style-type: decimal;
    padding-left: calc(var(--space-sm) * 2); /* doppelter Grundabstand */
}

ol.numbered-list li {
    padding-left: 0.2em; /* kleiner Puffer zwischen Zahl und Text */
    margin-bottom: 0.5rem;
    line-height: 1.7; /* gleiche Zeilenhöhe wie Punktliste */
}

.numbered-list li::marker {
    color: var(--color1);
    font-weight: bold;
}

.navbar li

/* ===== BREADCRUMB ===== */
ul.breadcrumb {
    padding: 10px 16px;
    list-style: none;
}

ul.breadcrumb li {
    display: inline;
    font-size: 0.8rem;
}

ul.breadcrumb li + li:before {
    padding: 0.25rem;
    color: var(--color--grey);
    content: "›";
}

ul.breadcrumb li a {
    text-decoration: none;
    font-size: 0.8rem;
    color: var(--color--grey);
    transition: color var(--transition-fast);
}

ul.breadcrumb li a:hover {
    color: var(--color2);
}

ul.breadcrumb li::before {
    content: none;
}

/* ===== FIGURES ===== */
figure {
    margin: 0;
}

figcaption {
    font-size: 0.78rem;
    line-height: 1.4;
    font-style: italic;
    color: var(--color--grey);
    padding: 0.4rem 0;
}

/* ===== TOC ===== */
.toc {
    text-align: center;
    margin: var(--space-lg) 0;
}

.toc a {
    margin: 0 var(--space-sm);
    color: var(--color1);
    font-weight: bold;
    text-decoration: none;
}

/* ===== CARD ===== */
.card {
    margin: var(--space-lg) 0;
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
}

section .card:first-of-type {
    margin-top: 0;
}

.card img {
    width: 100%;
    height: 200px;
    object-fit: cover;
}

.card h2 {
    margin: 0.5rem 0;
}

/* ===== TABLES ===== */
.table-wrap {
    overflow-x: auto;
    border-radius: var(--radius-lg);
    width: 100%;
    box-shadow: var(--shadow-sm);
}

table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--body-size, 1rem);
}

th, td {
    padding: 0.75rem var(--space-sm);
    text-align: left;
    vertical-align: top;
}

/* Table Variants */
.table-standard {
    background: var(--color--white);
    border-radius: var(--radius-lg);
    overflow: hidden;
}

.table-standard thead {
    background: var(--color1);
    color: var(--color--white);
}

.table-standard thead th {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-weight: 700;
    border: none;
}

.table-standard tbody tr {
    border-bottom: 1px solid #e5e5e5;
    transition: background var(--transition-fast);
}

.table-standard tbody tr:last-child {
    border-bottom: none;
}

.table-standard tbody tr:hover {
    background: rgba(200, 137, 63, 0.06);
}

.table-striped {
    background: var(--color--white);
    border-radius: var(--radius-lg);
    overflow: hidden;
}

.table-striped thead {
    background: var(--color--text);
    color: var(--color--white);
}

.table-striped thead th {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-weight: 700;
    border: none;
}

.table-striped tbody tr:nth-child(even) {
    background: #f5f5f5;
}

.table-striped tbody tr {
    transition: background var(--transition-fast);
}

.table-striped tbody tr:hover {
    background: rgba(200, 137, 63, 0.08);
}

.table-lined {
    background: transparent;
}

.table-lined thead th {
    border-bottom: 2px solid var(--color1);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-weight: 700;
    color: var(--color1);
    padding-left: 0;
}

.table-lined tbody td {
    border-bottom: 1px solid #e0e0e0;
    padding-left: 0;
    transition: color var(--transition-fast);
}

.table-lined tbody tr:last-child td {
    border-bottom: none;
}

.table-lined tbody tr:hover td {
    color: var(--color1);
}

.table-compact th,
.table-compact td {
    padding: 0.4rem 0.75rem;
    font-size: 0.85rem;
}

.table-compact thead th {
    font-size: 0.72rem;
}

/* Table Badges */
.table-badge {
    display: inline-block;
    padding: 0.1rem 0.5rem;
    border-radius: var(--radius-pill);
    font-size: 0.65rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    white-space: nowrap;
}

.table-badge--teal { background: rgba(200, 137, 63, 0.12); color: #8a6030; }
.table-badge--blue { background: rgba(0, 88, 150, 0.10); color: #005896; }
.table-badge--grey { background: #e8e8e8; color: var(--color--grey); }
.table-badge--sand { background: var(--sand); color: #8a6a50; }

/* ===== LAENDERLISTE ===== */
.laenderliste {
    list-style: none;
    padding-left: 0;
}

.laenderliste > .land {
    margin-top: 1em;
}

.laenderliste .staedte {
    list-style-type: circle;
    margin-left: 0.5em;
    background-color: var(--color--white);
    padding: var(--space-sm);
    border-radius: var(--radius-lg);
    margin-top: 0.5rem;
}

.laenderliste .staedte a {
    white-space: nowrap;
}

.laenderliste .landzeile {
    display: flex;
    align-items: center;
    gap: 0.5em;
    font-weight: bold;
}

.laenderliste .land h2 {
    margin-top: var(--space-sm);
    margin-bottom: 0;
}

.laenderliste .land h2 span {
    margin: 0;
}

.laenderliste .land h3:first-of-type {
    margin-top: 0;
}

.laenderliste .land h3 {
    margin-bottom: 0;
}

/* ===== FLAGS ===== */
.flagge {
    font-family: system-ui, sans-serif;
}

.flagge img.twemoji {
    width: 2rem;
    height: 2rem;
    vertical-align: middle;
}

.flag.flag-30h img {
    height: 30px;
}

/* ===== BLOG COVER ===== */
.blog-cover {
    margin-top: var(--space-lg);
}

.blog-header p,
.blog-header img {
    margin-top: 0.5rem;
    margin-bottom: 0.5rem;
}

.styling-guide-h {
    margin: 0;
    text-decoration: underline;
    color: blue;
}

/* ===== RESPONSIVE ===== */

/* Small phones */
@media (max-width: 480px) {
    :root {
        --space-lg: 1.5rem;
        --space-xl: 2rem;
    }

    .hero-title {
        font-size: clamp(2rem, 10vw, 3rem);
    }

    .hero-description {
        display: none;
    }

    .hero-social {
        display: none;
    }

    .hero-thumbnails {
        bottom: 4%;
    }

    .thumbnail {
        width: 48px;
        height: 36px;
    }
}

/* Tablets and mobile */
@media (max-width: 768px) {
    .hero-content {
        left: 50%;
        transform: translate(-50%, -50%);
        width: 90%;
        max-width: 90%;
        text-align: center;
    }

    .hero-description {
        max-width: 100%;
        margin-left: auto;
        margin-right: auto;
    }

    .hero-social {
        right: 2%;
        top: auto;
        bottom: 20%;
        transform: none;
        flex-direction: column;
    }

    .hero-button {
        justify-content: center;
    }

    .navbar-links {
        display: none;
        position: absolute;
        top: 70px;
        right: 0;
        left: 0;
        background: rgba(250, 248, 244, 0.97);
        backdrop-filter: blur(20px);
        width: calc(100% - 2rem);
        margin: 0 var(--space-sm);
        padding: var(--space-sm) var(--space-md);
        border-radius: var(--radius-lg);
        box-shadow: var(--shadow-md);
        border: 0.5px solid rgba(0,0,0,0.08);
    }

    .navbar-links ul {
        flex-direction: column;
        gap: var(--space-sm);
    }

    .navbar-toggle {
        display: flex;
    }

    .navbar-links.active {
        display: block;
        animation: slideDown 0.25s ease;
    }

    @keyframes slideDown {
        from { opacity: 0; transform: translateY(-8px); }
        to { opacity: 1; transform: translateY(0); }
    }

    section.blog-header .blog-header-image img {
        height: 40vh;
    }
}

/* Responsive table */
@media (max-width: 600px) {
    .table-responsive thead {
        display: none;
    }

    .table-responsive tr {
        display: block;
        background: var(--color--white);
        border-radius: var(--radius-lg);
        margin-bottom: var(--space-sm);
        padding: 0.75rem var(--space-sm);
        box-shadow: 0 1px 4px rgba(0, 0, 0, 0.06);
    }

    .table-responsive td {
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding: 0.35rem 0;
        border-bottom: 1px solid #efefef;
        font-size: 0.9rem;
    }

    .table-responsive td:last-child {
        border-bottom: none;
    }

    .table-responsive td::before {
        content: attr(data-label);
        font-size: 0.72rem;
        text-transform: uppercase;
        letter-spacing: 0.08em;
        color: var(--color--grey);
        font-weight: 700;
        flex-shrink: 0;
        margin-right: var(--space-sm);
    }
}

/* Large screens */
@media (min-width: 1200px) {
    section:not(.hero) {
        padding: var(--space-xl) var(--space-lg);
    }
}



/* === QUELLE-HINWEIS BEI BILDERN === */

img[data-quelle] {
    position: relative;
    display: inline-block; /* wichtig */
}

/* Das Overlay-Icon */
img[data-quelle]::after {
    content: "";
    position: absolute;
    bottom: 8px;
    right: 8px;
    width: 28px;
    height: 28px;
    background-image: url("/assets/img/icons/camera.svg");
    background-size: contain;
    background-repeat: no-repeat;
    pointer-events: none;
    z-index: 10;
}

/* === WhatsApp === */
/* WhatsApp Floating Button */
.whatsapp-float {
    position: fixed;
    width: 48px;
    height: 48px;
    bottom: 20px;
    right: 20px;
    background-color: #25d366;
    color: #FFF;
    border-radius: 50px;
    text-align: center;
    font-size: 24px;
    box-shadow: 2px 2px 10px rgba(0,0,0,0.2);
    z-index: 1000;
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    transition: transform 0.3s ease;
}

.whatsapp-float:hover {
    transform: scale(1.1);
    color: #FFF;
}

/* Tooltip (optional) */
.whatsapp-float::before {
    content: "Du willst auch in den Urlaub? Schreib mir!";
    position: absolute;
    right: 70px;
    background: #333;
    color: #fff;
    padding: 5px 10px;
    border-radius: 5px;
    font-size: 12px;
    white-space: nowrap;
    opacity: 0;
    transition: opacity 0.3s;
    pointer-events: none;
}

.whatsapp-float:hover::before {
    opacity: 1;
}




.quote {
    border-left: 3px solid var(--color1);
    padding: 8px 20px;
    margin: var(--space-sm) 0 var(--space-md);
  }

  .quote.no-border {
    border-left: none;
  }

  .quote p {
    font-family: var(--font-family-satoshi);
    font-size: 1.05em;
    font-style: italic;
    font-weight: 400;
    color: var(--color--grey);
    line-height: 1.65;
  }

  .amondo-badge {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    background: #f7f6f3;
    border-radius: 12px;
    padding: 16px 20px;
    margin-bottom: 36px;
  }
 
  .amondo-dot {
    width: 9px;
    height: 9px;
    border-radius: 50%;
    background: #4CAF7D;
    flex-shrink: 0;
    margin-top: 7px;
  }
 
  .amondo-badge p {
    /*font-size: 13px;*/
    /*color: #777;*/
    line-height: 1.65;
  }

  .amondo-badge p:last-of-type{
    margin-bottom: 0;
  }
 
  .amondo-badge strong {
    color: #2e2e2e;
    font-weight: 500;
  }













/* ── HERO ── */
.op-hero {
  position: relative;
  min-height: 85vh;
  display: flex;
  align-items: center;
  overflow: hidden;
  background: #1a1a1a;
}
.op-hero__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.45;
}
.op-hero__inner {
  position: relative;
  z-index: 1;
  max-width: 860px;
  margin: 0 auto;
  padding: 80px 32px;
  text-align: center;
  color: #fff;
}
.op-hero__title {
  font-size: clamp(2rem, 5vw, 3.6rem);
  font-weight: 700;
  line-height: 1.18;
  margin-bottom: 20px;
  color: #fff;
}
.op-hero__title em {
  font-style: italic;
  font-weight: 400;
  opacity: 0.85;
}
.op-hero__sub {
  font-size: clamp(1rem, 2vw, 1.2rem);
  opacity: 0.85;
  max-width: 580px;
  margin: 0 auto 32px;
  line-height: 1.7;
}
.op-hero__ctas {
  display: flex;
  gap: 14px;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 28px;
}
.op-hero__trust {
  display: flex;
  gap: 20px;
  justify-content: center;
  flex-wrap: wrap;
  font-size: 0.83rem;
  opacity: 0.7;
  letter-spacing: 0.03em;
}
 
/* ── BUTTONS ── */
.op-btn {
  display: inline-block;
  padding: 12px 26px;
  border-radius: 100px;
  font-size: 0.95rem;
  font-weight: 500;
  text-decoration: none;
  transition: opacity 0.15s, transform 0.1s;
  cursor: pointer;
}
.op-btn:hover { opacity: 0.85; transform: translateY(-1px); }
.op-btn--primary  { background: #fff;         color: #1a1a1a; }
.op-btn--secondary{ background: transparent;  color: #fff; border: 1.5px solid rgba(255,255,255,0.6); }
.op-btn--ghost    { background: transparent;  color: #2e2e2e; border: 1.5px solid rgba(0,0,0,0.2); }
 
/* ── TOPICS ── */
.op-topics {
  max-width: 1100px;
  margin: 0 auto;
  padding: 80px 24px;
}
.op-topics__intro {
  text-align: center;
  margin-bottom: 48px;
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}
.op-topics__intro h2 { margin-bottom: 12px; }
.op-topics__lead { color: #666; font-size: 1rem; }
.op-eyebrow {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #999;
  margin-bottom: 10px;
  display: block;
}
.op-topics__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 24px;
}
.op-topic-card {
  display: flex;
  flex-direction: column;
  background: #fff;
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid rgba(0,0,0,0.07);
  text-decoration: none;
  color: inherit;
  transition: box-shadow 0.2s, transform 0.2s;
}
.op-topic-card:hover { box-shadow: 0 10px 36px rgba(0,0,0,0.1); transform: translateY(-3px); }
.op-topic-card img {
  width: 100%;
  height: 200px;
  object-fit: cover;
  display: block;
}
.op-topic-card__body { padding: 22px 24px; flex: 1; display: flex; flex-direction: column; gap: 8px; }
.op-topic-card__tag {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #888;
}
.op-topic-card__body h3 { font-size: 1.05rem; line-height: 1.3; color: #1a1a1a; }
.op-topic-card__body p  { font-size: 0.88rem; color: #666; line-height: 1.6; flex: 1; }
.op-topic-card__link    { font-size: 0.88rem; font-weight: 500; color: #1a1a1a; margin-top: 4px; }
 
/* ── BRAND ── */
.op-brand {
  background: #f7f6f3;
  padding: 72px 24px;
}
.op-brand__inner {
  max-width: 640px;
  margin: 0 auto;
  text-align: center;
}
.op-brand__inner h2 { margin-bottom: 16px; }
.op-brand__inner p  { color: #666; font-size: 1rem; line-height: 1.8; margin-bottom: 28px; }
 
@media (max-width: 600px) {
  .op-hero__inner { padding: 60px 20px; }
  .op-hero__ctas  { flex-direction: column; align-items: center; }
}





.op-nl {
  background: #1a1a1a;
  color: #fff;
  padding: 80px 24px;
}
.op-nl__inner {
  max-width: 1000px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}
.op-nl__eyebrow {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #888;
  margin-bottom: 12px;
  display: block;
}
.op-nl__title {
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: 16px;
  color: #fff;
}
.op-nl__title em { font-style: italic; font-weight: 400; color: #aaa; }
.op-nl__lead {
  font-size: 0.97rem;
  color: #999;
  line-height: 1.75;
  margin-bottom: 28px;
}
.op-nl__magnet {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 12px;
  padding: 16px 18px;
  font-size: 0.88rem;
  color: #ccc;
  line-height: 1.6;
}
.op-nl__magnet strong { color: #fff; display: block; margin-bottom: 2px; }
.op-nl__magnet-icon { font-size: 22px; flex-shrink: 0; margin-top: 1px; }
 
/* Form */
.op-nl__form { display: flex; flex-direction: column; gap: 10px; }
.op-nl__label {
  font-size: 12px;
  font-weight: 500;
  color: #aaa;
  letter-spacing: 0.05em;
  margin-bottom: -4px;
}
.op-nl__input {
  width: 100%;
  padding: 13px 16px;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,0.15);
  background: rgba(255,255,255,0.07);
  color: #fff;
  font-size: 0.95rem;
  font-family: inherit;
  outline: none;
  transition: border-color 0.15s;
}
.op-nl__input::placeholder { color: #666; }
.op-nl__input:focus { border-color: rgba(255,255,255,0.4); }
.op-nl__btn {
  margin-top: 6px;
  padding: 14px 24px;
  background: #fff;
  color: #1a1a1a;
  font-size: 0.97rem;
  font-weight: 600;
  font-family: inherit;
  border: none;
  border-radius: 100px;
  cursor: pointer;
  transition: opacity 0.15s, transform 0.1s;
}
.op-nl__btn:hover { opacity: 0.88; transform: translateY(-1px); }
.op-nl__disclaimer {
  font-size: 11px;
  color: #555;
  line-height: 1.6;
  margin-top: 4px;
}
.op-nl__disclaimer a { color: #777; }
 
/* Feedback messages */
.op-nl__feedback {
  border-radius: 12px;
  padding: 20px 22px;
  display: flex;
  gap: 14px;
  align-items: flex-start;
  font-size: 0.92rem;
  line-height: 1.65;
}
.op-nl__feedback--ok  { background: rgba(76,175,125,0.15); border: 1px solid rgba(76,175,125,0.3); color: #a8e6c8; }
.op-nl__feedback--err { background: rgba(220,80,80,0.15);  border: 1px solid rgba(220,80,80,0.3);  color: #f5a8a8; }
.op-nl__feedback strong { color: #fff; display: block; margin-bottom: 4px; }
.op-nl__feedback a { color: inherit; }
.op-nl__feedback-icon {
  width: 26px; height: 26px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; font-weight: 700; flex-shrink: 0;
}
.op-nl__feedback--ok  .op-nl__feedback-icon { background: rgba(76,175,125,0.3); }
.op-nl__feedback--err .op-nl__feedback-icon { background: rgba(220,80,80,0.3); }
 
@media (max-width: 700px) {
  .op-nl__inner { grid-template-columns: 1fr; gap: 40px; }
}


/* ============================================================
   DESIGN SYSTEM COMPONENTS  (ONEPLACES Design System 2025)
   ============================================================ */

/* ── Buttons ── */
.btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-family: var(--op-font-sans);
    font-weight: 700;
    font-size: 0.95rem;
    padding: 0.75rem 1.35rem;
    border-radius: var(--op-radius-pill);
    border: 1px solid transparent;
    cursor: pointer;
    text-decoration: none;
    transition: transform var(--op-transition-fast),
                box-shadow var(--op-transition-base),
                background var(--op-transition-base),
                color var(--op-transition-base);
    letter-spacing: 0.01em;
    line-height: 1;
}

.btn-primary {
    background: var(--op-color1);
    color: #fff;
    box-shadow: var(--op-shadow-brand);
}
.btn-primary:hover {
    background: var(--op-color2);
    color: #fff;
    box-shadow: var(--op-shadow-brand-lg);
    transform: translateY(-1px);
}

.btn-secondary {
    background: transparent;
    color: var(--op-color1);
    border-color: var(--op-color1);
}
.btn-secondary:hover {
    background: var(--op-color1);
    color: #fff;
    transform: translateY(-1px);
}

.btn-text {
    background: transparent;
    color: var(--op-color1);
    padding: 0.75rem 0.5rem;
    border-radius: 0;
    position: relative;
}
.btn-text::after {
    content: "";
    position: absolute;
    left: 0.5rem;
    right: 0.5rem;
    bottom: 0.45rem;
    height: 1px;
    background: currentColor;
    transform: scaleX(0.4);
    transform-origin: left;
    transition: transform var(--op-transition-base);
}
.btn-text:hover { color: var(--op-color2); }
.btn-text:hover::after { transform: scaleX(1); }

.btn-dark { background: var(--op-text); color: #fff; }
.btn-dark:hover { background: #000; color: #fff; transform: translateY(-1px); }

.btn-lg { font-size: 1.05rem; padding: 1rem 1.75rem; }
.btn-sm { font-size: 0.82rem; padding: 0.55rem 1rem; }

/* WhatsApp Floating Action Button — use .op-fab (NOT .fab — that conflicts with Font Awesome) */
.op-fab {
    position: fixed;
    bottom: 20px;
    right: 20px;
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: var(--op-whatsapp);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 6px 20px rgba(37,211,102,0.4);
    cursor: pointer;
    border: 0;
    text-decoration: none;
    font-size: 1.6rem;
    z-index: 999;
    transition: transform var(--op-transition-base);
}
.op-fab:hover { transform: scale(1.08); color: #fff; }
.op-fab::after {
    content: "";
    position: absolute;
    inset: -6px;
    border-radius: 50%;
    border: 2px solid var(--op-whatsapp);
    opacity: 0.35;
    animation: op-fab-pulse 2.2s ease-out infinite;
}
@keyframes op-fab-pulse {
    0%   { transform: scale(0.85); opacity: 0.55; }
    100% { transform: scale(1.4);  opacity: 0; }
}

/* ── Cards (Design System) ── */
.card-image {
    position: relative;
    border-radius: var(--op-radius-lg);
    overflow: hidden;
    background: var(--op-sand);
    aspect-ratio: 4/5;
    box-shadow: var(--op-shadow-sm);
    transition: box-shadow var(--op-transition-base), transform var(--op-transition-base);
    text-decoration: none;
    color: inherit;
    display: block;
}
.card-image:hover { box-shadow: var(--op-shadow-lg); transform: translateY(-2px); }

.card-image .card-img {
    position: absolute;
    inset: 0;
}
.card-image .card-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.card-image .card-img::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 50%, rgba(0,0,0,0.65));
}

.card-image .card-tag {
    position: absolute;
    top: 0.75rem;
    left: 0.75rem;
    font-size: 0.65rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: #fff;
    background: var(--op-tag-scrim);
    backdrop-filter: blur(6px);
    padding: 0.3rem 0.55rem;
    border-radius: var(--op-radius-sm);
}
.card-image .card-meta {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    padding: 1rem 1.1rem;
    color: #fff;
}
.card-image .card-meta h3 {
    margin: 0 0 0.15rem;
    font-family: var(--op-font-display);
    font-weight: 700;
    font-size: 1.15rem;
    line-height: 1.15;
    color: #fff;
}
.card-image .card-meta small {
    opacity: 0.8;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

.card-text {
    background: var(--op-white);
    border: 1px solid rgba(26,26,26,0.06);
    border-radius: var(--op-radius-lg);
    padding: 1.25rem;
    box-shadow: var(--op-shadow-sm);
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    transition: box-shadow var(--op-transition-base), transform var(--op-transition-base);
}
.card-text:hover { box-shadow: var(--op-shadow-lg); transform: translateY(-2px); }
.card-text .eyebrow {
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--op-color1);
}
.card-text h3 {
    margin: 0;
    font-family: var(--op-font-display);
    font-weight: 700;
    font-size: 1.15rem;
    line-height: 1.25;
}
.card-text p { margin: 0; color: #333; font-size: 0.92rem; }
.card-text .card-foot {
    margin-top: auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 0.6rem;
    border-top: 1px solid rgba(26,26,26,0.06);
    font-size: 0.78rem;
    color: var(--op-grey);
}

.card-check-ds {
    background: var(--op-sand);
    border-radius: var(--op-radius-lg);
    padding: 1.25rem;
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
}
.card-check-ds .eyebrow {
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--op-color1);
}
.card-check-ds h3 {
    margin: 0 0 0.15rem;
    font-family: var(--op-font-display);
    font-weight: 700;
    font-size: 1.1rem;
}
.card-check-ds ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    font-size: 0.92rem;
}
.card-check-ds li {
    display: flex;
    gap: 0.55rem;
    align-items: flex-start;
}
.card-check-ds li::before {
    content: "";
    width: 18px;
    height: 18px;
    flex: 0 0 18px;
    border-radius: 50%;
    background: var(--op-color1);
    -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='white' d='M9.55 17.4 4.9 12.75l1.4-1.4 3.25 3.25 8.1-8.1 1.4 1.4Z'/></svg>") center/14px no-repeat;
    mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='white' d='M9.55 17.4 4.9 12.75l1.4-1.4 3.25 3.25 8.1-8.1 1.4 1.4Z'/></svg>") center/14px no-repeat;
    margin-top: 0.1rem;
}

/* ── Tags · Chips · Schlagzeile ── */
.tag {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    padding: 0.35rem 0.7rem;
    border-radius: var(--op-radius-sm);
    background: rgba(200,137,63,0.12);
    color: var(--op-color2);
    border: 1px solid rgba(200,137,63,0.25);
}
.tag-dark  { background: var(--op-tag-scrim); color: #fff; border-color: transparent; backdrop-filter: blur(6px); }
.tag-sand  { background: var(--op-sand); color: var(--op-text); border-color: rgba(26,26,26,0.08); }
.tag-solid { background: var(--op-color1); color: #fff; border-color: transparent; }
.tag-dot::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: currentColor; }

.chip {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.85rem;
    font-weight: 500;
    padding: 0.35rem 0.85rem;
    border-radius: var(--op-radius-pill);
    background: var(--op-white);
    border: 1px solid rgba(26,26,26,0.12);
    cursor: pointer;
    transition: all var(--op-transition-fast);
    text-decoration: none;
    color: var(--op-text);
}
.chip:hover, .chip.active {
    background: var(--op-color1);
    color: #fff;
    border-color: var(--op-color1);
}
.chip small { font-size: 0.72rem; opacity: 0.7; }

.meta-row {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
    font-size: 0.78rem;
    color: var(--op-grey);
    align-items: center;
    padding: 0.5rem 0;
}
.meta-row b { color: var(--op-text); font-weight: 700; }
.meta-row .dot {
    width: 3px;
    height: 3px;
    border-radius: 50%;
    background: var(--op-grey);
    display: inline-block;
}

/* ── Forms (Design System) ── */
.ds-field { display: flex; flex-direction: column; gap: 0.35rem; margin-bottom: 0.85rem; }
.ds-field label {
    font-size: 0.78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--op-text);
}
.ds-field input,
.ds-field select,
.ds-field textarea {
    font-family: inherit;
    font-size: 0.95rem;
    padding: 0.7rem 0.85rem;
    background: var(--op-white);
    border: 1px solid rgba(26,26,26,0.15);
    border-radius: var(--op-radius-md);
    color: var(--op-text);
    transition: border-color var(--op-transition-base), box-shadow var(--op-transition-base);
    outline: 0;
}
.ds-field input:focus,
.ds-field select:focus,
.ds-field textarea:focus {
    border-color: var(--op-color1);
    box-shadow: 0 0 0 3px rgba(200,137,63,0.2);
}

/* Newsletter inline variant */
.newsletter-block {
    background: var(--op-sand);
    border-radius: var(--op-radius-lg);
    padding: 1.1rem 1.2rem;
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
}
.newsletter-block h4 {
    margin: 0;
    font-family: var(--op-font-display);
    font-weight: 700;
}
.newsletter-block p { margin: 0; font-size: 0.85rem; color: #333; }
.newsletter-block .nl-row { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.newsletter-block input {
    flex: 1;
    min-width: 160px;
    background: #fff;
    border: 1px solid rgba(26,26,26,0.1);
    border-radius: var(--op-radius-pill);
    padding: 0.6rem 1rem;
    font-family: inherit;
    font-size: 0.9rem;
    outline: 0;
}
.newsletter-block button {
    background: var(--op-color1);
    color: #fff;
    border: 0;
    border-radius: var(--op-radius-pill);
    font-weight: 700;
    padding: 0.6rem 1.2rem;
    cursor: pointer;
    transition: background var(--op-transition-fast);
}
.newsletter-block button:hover { background: var(--op-color2); }

/* ── Image Layouts ── */

/* Single image between text */
figure.op-figure {
    margin: 1.5rem 0;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}
figure.op-figure img {
    width: 100%;
    aspect-ratio: 3/2;
    object-fit: cover;
    border-radius: var(--op-radius-lg);
    box-shadow: var(--op-shadow-sm);
    display: block;
    height: auto;
}
figure.op-figure figcaption {
    font-size: 0.82rem;
    line-height: 1.45;
    font-style: italic;
    color: var(--op-grey);
    padding-left: 0.75rem;
    border-left: 2px solid var(--op-color1);
}
/* Bleed variant */
figure.op-figure.bleed {
    margin-left: calc(50% - 46vw);
    margin-right: calc(50% - 46vw);
    max-width: none;
}
@media (max-width: 780px) {
    figure.op-figure.bleed { margin-left: -1rem; margin-right: -1rem; }
}

/* Carousel */
.op-carousel { position: relative; margin: 1.5rem 0; }
.op-carousel .op-track {
    display: flex;
    gap: 0.75rem;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    padding-bottom: 0.5rem;
    scrollbar-width: none;
}
.op-carousel .op-track::-webkit-scrollbar { display: none; }
.op-carousel .op-slide {
    flex: 0 0 82%;
    scroll-snap-align: center;
    border-radius: var(--op-radius-lg);
    overflow: hidden;
    aspect-ratio: 3/2;
    box-shadow: var(--op-shadow-sm);
    position: relative;
}
.op-carousel .op-slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.op-carousel .op-slide figcaption {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    padding: 0.75rem 1rem;
    color: #fff;
    font-size: 0.82rem;
    font-style: italic;
    background: linear-gradient(180deg, transparent, rgba(0,0,0,0.6));
}
.op-carousel .op-ctrl {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: 0;
    cursor: pointer;
    background: var(--op-white);
    color: var(--op-text);
    box-shadow: var(--op-shadow-md);
    display: grid;
    place-items: center;
    transition: background var(--op-transition-fast);
    z-index: 2;
}
.op-carousel .op-ctrl:hover { background: var(--op-color1); color: #fff; }
.op-carousel .op-ctrl.op-prev { left: -8px; }
.op-carousel .op-ctrl.op-next { right: -8px; }
.op-carousel .op-ctrl svg { width: 18px; height: 18px; stroke: currentColor; fill: none; stroke-width: 2.2; }
.op-carousel .op-dots {
    display: flex;
    gap: 0.4rem;
    justify-content: center;
    margin-top: 0.75rem;
}
.op-carousel .op-dots button {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    border: 0;
    cursor: pointer;
    background: rgba(26,26,26,0.2);
    padding: 0;
    transition: all var(--op-transition-fast);
}
.op-carousel .op-dots button.active {
    background: var(--op-color1);
    width: 24px;
    border-radius: var(--op-radius-pill);
}

/* Masonry */
.op-masonry {
    columns: 3 160px;
    column-gap: 0.6rem;
    margin: 1.5rem 0;
}
.op-masonry figure {
    break-inside: avoid;
    margin: 0 0 0.6rem;
    border-radius: var(--op-radius-md);
    overflow: hidden;
    box-shadow: var(--op-shadow-sm);
    position: relative;
}
.op-masonry figure img {
    width: 100%;
    display: block;
    height: auto;
}
.op-masonry figure figcaption {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    padding: 0.45rem 0.6rem;
    color: #fff;
    font-size: 0.7rem;
    font-style: italic;
    line-height: 1.3;
    background: linear-gradient(180deg, transparent, rgba(0,0,0,0.65));
    opacity: 0;
    transition: opacity var(--op-transition-base);
}
.op-masonry figure:hover figcaption { opacity: 1; }

/* Triptych — 3 equal columns */
.op-triptych {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.5rem;
    margin: 1.5rem 0;
}
.op-triptych figure {
    margin: 0;
    border-radius: var(--op-radius-md);
    overflow: hidden;
    aspect-ratio: 3/4;
    box-shadow: var(--op-shadow-sm);
}
.op-triptych figure img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* 2+1 Split */
.op-split {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 0.5rem;
    margin: 1.5rem 0;
    aspect-ratio: 3/2;
}
.op-split figure { margin: 0; border-radius: var(--op-radius-md); overflow: hidden; box-shadow: var(--op-shadow-sm); }
.op-split figure img { width: 100%; height: 100%; object-fit: cover; display: block; }
.op-split .op-split-stack { display: grid; grid-template-rows: 1fr 1fr; gap: 0.5rem; }

@media (max-width: 480px) {
    .op-triptych { grid-template-columns: repeat(2, 1fr); }
    .op-split { grid-template-columns: 1fr; aspect-ratio: auto; }
    .op-split .op-split-stack { grid-template-columns: 1fr 1fr; grid-template-rows: 1fr; }
}

/* ── Carousel JS helper ── */
/* Add this script to pages using op-carousel:
   document.querySelectorAll('.op-carousel').forEach(root => {
     const track = root.querySelector('.op-track');
     const slides = [...track.querySelectorAll('.op-slide')];
     const dotsHost = root.querySelector('.op-dots');
     if (!dotsHost) return;
     slides.forEach((_,i) => {
       const b = document.createElement('button');
       b.type='button'; if(i===0) b.classList.add('active');
       b.addEventListener('click', () => slides[i].scrollIntoView({behavior:'smooth',inline:'center',block:'nearest'}));
       dotsHost.appendChild(b);
     });
     const dots = [...dotsHost.children];
     function syncDots() {
       const cx = track.scrollLeft + track.clientWidth/2;
       let nearest=0, best=Infinity;
       slides.forEach((s,i) => { const c=s.offsetLeft+s.clientWidth/2; const d=Math.abs(c-cx); if(d<best){best=d;nearest=i;} });
       dots.forEach((d,i) => d.classList.toggle('active', i===nearest));
     }
     track.addEventListener('scroll', () => requestAnimationFrame(syncDots));
     root.querySelector('.op-prev')?.addEventListener('click', () => track.scrollBy({left:-track.clientWidth*0.85,behavior:'smooth'}));
     root.querySelector('.op-next')?.addEventListener('click', () => track.scrollBy({left: track.clientWidth*0.85,behavior:'smooth'}));
   });
*/

/* end of Design System additions */


/* ═══════════════════════════════════════════════════════════════
     HEADER
  ═══════════════════════════════════════════════════════════════ */
.hero{position:relative;height:calc(100vh - var(--op-navbar-h));margin-top:0;overflow:hidden;color:#fff;background:#0a0604}
.hero-layers{position:absolute;inset:0}
.hero-scenes{position:absolute;inset:0;z-index:0;isolation:isolate}
.hero-scenes .scene{position:absolute;inset:0;opacity:0;transition:opacity 1.6s cubic-bezier(.4,0,.2,1),transform 8s ease-out;transform:scale(1.06);background-size:cover;background-position:center}
.hero-scenes .scene.is-active{opacity:1;transform:scale(1)}
.hero-scenes .scene::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.35) 0%,rgba(0,0,0,.1) 45%,rgba(0,0,0,.55) 100%);pointer-events:none}
.hero-scene-nav{position:absolute;bottom:7rem;right:clamp(1.25rem,4vw,3rem);transform:translateX(-50%);z-index:4;display:flow;gap:.6rem;align-items:center;opacity:0;animation:heroFadeUp 1s 2.2s forwards}
@media(max-width:640px){.hero-scene-nav{bottom:5rem}}
.hero-scene-nav button{appearance:none;border:0;background:transparent;cursor:pointer;padding:.4rem;display:flex;align-items:center;gap:.5rem;color:rgba(255,255,255,.55);font-family:inherit;font-size:.62rem;text-transform:uppercase;letter-spacing:.18em;font-weight:700;transition:color .3s ease}
.hero-scene-nav button .dot{width:28px;height:2px;background:rgba(255,255,255,.3);position:relative;overflow:hidden;transition:background .3s ease}
.hero-scene-nav button .dot::after{content:"";position:absolute;inset:0;background:var(--op-color1);transform:scaleX(0);transform-origin:left;transition:transform .4s ease}
.hero-scene-nav button.active{color:#fff}
.hero-scene-nav button.active .dot::after{transform:scaleX(1)}
.hero-sky{position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 110%,var(--m-cruise-glow),transparent 60%),radial-gradient(ellipse 60% 50% at 15% 85%,var(--m-sun-2),transparent 65%),radial-gradient(ellipse 100% 80% at 70% 20%,rgba(40,30,50,.5),transparent 60%),linear-gradient(180deg,var(--m-sky-1) 0%,var(--m-sky-2) 40%,var(--m-sky-3) 75%,var(--m-sky-4) 100%);transition:background 1.2s ease}
.hero-horizon{position:absolute;left:-5%;right:-5%;bottom:22%;height:1px;background:linear-gradient(90deg,transparent,var(--m-horizon) 30%,var(--m-horizon-h) 50%,var(--m-horizon) 70%,transparent);box-shadow:0 0 40px var(--m-horizon);transition:background 1.2s ease}
.hero-sun{position:absolute;left:50%;bottom:15%;width:clamp(280px,40vw,500px);aspect-ratio:1;transform:translateX(-50%);border-radius:50%;background:radial-gradient(circle,var(--m-sun) 0%,var(--m-sun-2) 35%,transparent 70%);filter:blur(8px);animation:heroSunRise 3.5s cubic-bezier(.2,.8,.2,1) both;transition:background 1.2s ease}
@keyframes heroSunRise{from{transform:translate(-50%,60%);opacity:0}to{transform:translate(-50%,0);opacity:1}}
.hero-stars{position:absolute;inset:0;opacity:.8;animation:twinkle 6s ease-in-out infinite}
@keyframes twinkle{0%,100%{opacity:.5}50%{opacity:.9}}
.hero-ship{position:absolute;right:8%;bottom:26%;width:clamp(100px,14vw,180px);color:rgba(0,0,0,.75);animation:heroShipDrift 24s linear infinite}
@keyframes heroShipDrift{0%{transform:translateX(0)}50%{transform:translateX(-20px)}100%{transform:translateX(0)}}
.hero-water{position:absolute;left:0;right:0;bottom:0;height:22%;background:linear-gradient(180deg,rgba(10,6,4,0) 0%,rgba(10,6,4,.6) 40%,#050302 100%);overflow:hidden}
.hero-water::before{content:"";position:absolute;left:50%;top:0;width:60%;height:100%;transform:translateX(-50%);background:radial-gradient(ellipse 50% 80% at 50% 0%,rgba(255,210,150,.25),transparent 70%);filter:blur(2px);animation:heroWaterShimmer var(--m-shimmer-dur) ease-in-out infinite alternate}
@keyframes heroWaterShimmer{from{opacity:.6;transform:translateX(-50%) scaleX(1)}to{opacity:.9;transform:translateX(-50%) scaleX(1.05)}}
.hero-grain{position:absolute;inset:0;opacity:var(--m-grain);mix-blend-mode:overlay;pointer-events:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120'><filter id='n'><feTurbulence baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='.8'/></svg>")}
.hero::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;background:radial-gradient(ellipse at center,transparent 30%,rgba(0,0,0,var(--m-scrim)) 100%);transition:background .8s ease}
.hero-inner{position:relative;z-index:2;height:100%;display:flex;flex-direction:column;justify-content:center;padding:clamp(1.5rem,4vw,3rem);max-width:var(--op-container);margin:0 auto}
.hero-eyebrow{font-family:var(--op-font-sans);font-weight:700;font-size:.8rem;
    text-transform:uppercase;letter-spacing:.22em;color:var(--op-color1);
    margin:0 0 2rem;display:flex;align-items:center;gap:.75rem;}
.hero-eyebrow::before{content:"";width:40px;height:1px;background:var(--op-color1)}
.hero h1{font-family:var(--op-font-display);font-weight:800;font-size:clamp(2.8rem,8vw,6.5rem);/*line-height:.98;*/letter-spacing:-.025em;margin:0 0 1.5rem;max-width:18ch;filter:drop-shadow(0 4px 20px rgba(0, 0, 0, 0.45));}
.hero h1 span.line:not(:first-child){margin-top:clamp(-0.4rem,calc(-1 * var(--space-sm)),-6rem);}
.hero h1 .line{display:block;overflow:hidden}
.hero h1 .line>span{display:block;transform:translateY(110%);animation:heroLineUp 1.1s cubic-bezier(.2,.8,.2,1) forwards}
.hero h1 .line:nth-child(1)>span{animation-delay:.6s}
.hero h1 .line:nth-child(2)>span{animation-delay:.8s}
.hero h1 .line:nth-child(3)>span{animation-delay:1s}
.hero h1 em{font-style:italic;font-weight:800;color:var(--op-color1);font-family:var(--op-font-display)}
@keyframes heroLineUp{to{transform:translateY(0)}}
.hero-sub{max-width:46ch;font-size:clamp(1rem,1.6vw,1.22rem);color:#f5efe2;margin:0 0 2.5rem;line-height:1.55;opacity:0;animation:heroFadeUp 1s 1.4s cubic-bezier(.2,.8,.2,1) forwards}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;opacity:0;animation:heroFadeUp 1s 1.6s cubic-bezier(.2,.8,.2,1) forwards}
@keyframes heroFadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.s2-btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--op-font-sans);font-weight:700;font-size:.95rem;padding:.95rem 1.6rem;border-radius:var(--op-radius-pill);border:1px solid transparent;cursor:pointer;text-decoration:none;transition:transform var(--op-transition-fast),box-shadow var(--op-transition-base),background var(--op-transition-base),color var(--op-transition-base),border-color var(--op-transition-base);letter-spacing:.01em;line-height:1;white-space:nowrap}
.s2-btn-primary{background:var(--op-color1);color:#fff;box-shadow:var(--op-shadow-brand)}
.s2-btn-primary:hover{background:var(--op-color2);box-shadow:var(--op-shadow-brand-lg);transform:translateY(-1px)}
.s2-btn-ghost{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.25);backdrop-filter:blur(8px)}
.s2-btn-ghost:hover{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.5);transform:translateY(-1px)}
.s2-btn-secondary{background:transparent;color:var(--op-color1);border-color:var(--op-color1)}
.s2-btn-secondary:hover{background:var(--op-color1);color:#fff}
.s2-btn-dark{background:var(--op-text);color:#fff}
.s2-btn-dark:hover{background:#000}
.hero-scroll{position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);z-index:3;font-size:.7rem;text-transform:uppercase;letter-spacing:.22em;color:rgba(255,255,255,.65);display:flex;flex-direction:column;align-items:center;gap:.6rem;opacity:0;animation:heroFadeUp 1s 2s cubic-bezier(.2,.8,.2,1) forwards}
.hero-scroll .line{width:1px;height:40px;background:linear-gradient(180deg,rgba(255,255,255,.6),transparent);animation:scrollLine 2.2s ease-in-out infinite}
@keyframes scrollLine{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}
.hero-meta-tl{position:absolute;top:1.25rem;left:clamp(1.25rem,4vw,3rem);z-index:2;font-size:.68rem;text-transform:uppercase;letter-spacing:.18em;color:rgba(255,255,255,.55);opacity:0;animation:heroFadeUp 1s .2s forwards}
.hero-meta-br{position:absolute;bottom:clamp(1.25rem,4vw,3rem);right:clamp(1.25rem,4vw,3rem);z-index:3;font-size:.68rem;text-transform:uppercase;letter-spacing:.18em;color:rgba(255,255,255,.55);text-align:right;line-height:1.6;opacity:0;animation:heroFadeUp 1s 2.2s forwards}
.hero-meta-br b{color:var(--op-color1);font-weight:700;display:block;font-size:.85rem;letter-spacing:.1em}
@media(max-width:640px){.hero-meta-br,.hero-scroll{display:none}}



/* ═══════════════════════════════════════════════════════════════
     EMPATHY — word-by-word scroll reveal
  ═══════════════════════════════════════════════════════════════ */
  .empathy{
    background:var(--op-text);color:#d7d2c8;
    padding:clamp(6rem,14vw,12rem) 0;
    position:relative;
    min-height:100vh;
    display:flex;align-items:center;
  }
  .empathy::before{
    content:"";position:absolute;inset:0;
    background:
      radial-gradient(ellipse at 20% 30%,rgba(200,137,63,.08),transparent 50%),
      radial-gradient(ellipse at 80% 70%,rgba(200,137,63,.06),transparent 50%);
    pointer-events:none;
  }
  .empathy-inner{position:relative;max-width:960px;margin:0 auto;padding:0 clamp(1.25rem,4vw,3rem)}
  .empathy-eyebrow{
    font-family:var(--op-font-sans);font-weight:700;font-size:.8rem;
    text-transform:uppercase;letter-spacing:.22em;color:var(--op-color1);
    margin:0 0 2rem;display:flex;align-items:center;gap:.75rem;
  }
  .empathy-eyebrow::before{content:"";width:40px;height:1px;background:var(--op-color1)}
  .empathy-text{
    font-family:var(--op-font-display);font-weight:800;
    font-size:clamp(1.8rem,4.2vw,3.4rem);line-height:1.18;letter-spacing:-.015em;
    margin:0;
  }
  .empathy-text .w{
    display:inline-block;color:rgba(215,210,200,.18);
    transition:color .5s ease;
    margin-right:.2em;
  }
  .empathy-text .w.lit{color:#f5efe2}
  .empathy-text .w.accent.lit{color:var(--op-color1)}
  .empathy-text br + br{line-height:1}
  .empathy-end{
    margin-top:3rem;font-family:var(--op-font-sans);font-weight:400;
    font-size:clamp(1rem,1.4vw,1.15rem);color:rgba(215,210,200,.55);
    max-width:55ch;opacity:0;transition:opacity .8s ease;
  }
  .empathy-end.lit{opacity:1}
  .empathy-cta{
    margin-top:2.5rem;display:flex;gap:1rem;flex-wrap:wrap;
    opacity:0;transform:translateY(16px);transition:opacity .8s ease .2s,transform .8s ease .2s;
  }
  .empathy-cta.lit{opacity:1;transform:translateY(0)}


  /* ═══════════════════════════════════════════════════════════════
     PERSONAL INTRO
  ═══════════════════════════════════════════════════════════════ */
  .intro{
    padding:clamp(5rem,10vw,8rem) 0;
    background:var(--op-bg);position:relative;
  }
  .intro-grid{
    display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2rem,5vw,5rem);
    align-items:center;
  }
  @media(max-width:860px){.intro-grid{grid-template-columns:1fr}}
  .intro-photo{
    position:relative;aspect-ratio:4/5;border-radius:var(--op-radius-lg);
    overflow:hidden;background:var(--op-sand);
    box-shadow:var(--op-shadow-lg);
  }
  .intro-photo .ph{
    position:absolute;inset:0;
    background:
      radial-gradient(circle at 40% 35%,rgba(255,220,180,.4),transparent 50%),
      linear-gradient(160deg,#e8c89f 0%,#c8893f 45%,#6b3a15 100%);
  }
  .intro-photo .ph::after{
    content:"";position:absolute;inset:0;
    background:radial-gradient(ellipse 80% 60% at 50% 100%,rgba(0,0,0,.4),transparent 60%);
  }
  .intro-photo .caption{
    position:absolute;bottom:1rem;left:1rem;right:1rem;
    display:flex;align-items:center;gap:.75rem;
    background:rgba(0,0,0,.4);backdrop-filter:blur(10px);
    padding:.7rem .9rem;border-radius:var(--op-radius-md);
    border:1px solid rgba(255,255,255,.1);color:#f5efe2;
  }
  .intro-photo .caption b{color:#fff;display:block;font-size:.88rem;font-family:var(--op-font-display);font-weight:700}
  .intro-photo .caption small{font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;opacity:.75}
  .intro-photo .badge{
    position:absolute;top:1rem;left:1rem;
    font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;
    color:#fff;background:rgba(0,0,0,.45);backdrop-filter:blur(8px);
    padding:.4rem .7rem;border-radius:var(--op-radius-sm);
    border:1px solid rgba(255,255,255,.12);
  }

  .intro-eyebrow{
    font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.22em;
    color:var(--op-color1);margin:0 0 1.25rem;display:flex;align-items:center;gap:.75rem;
  }
  .intro-eyebrow::before{content:"";width:40px;height:1px;background:var(--op-color1)}
  .intro h2{
    font-family:var(--op-font-display);font-weight:800;
    font-size:clamp(1.8rem,3.8vw,2.8rem);line-height:1.08;letter-spacing:-.015em;
    margin:0 0 1.25rem;max-width:18ch;
  }
  .intro h2 em{font-style:italic;color:var(--op-color1)}
  .intro p.lead{font-size:1.08rem;color:#333;margin:0 0 2rem;line-height:1.7;max-width:52ch}
  .intro-signature{
    display:flex;align-items:center;gap:.85rem;margin-bottom:2.5rem;
    padding-top:1.5rem;border-top:1px solid rgba(26,26,26,.08);
  }
  .intro-signature .mark{
    font-family:var(--op-font-display);font-style:italic;font-weight:400;
    font-size:1.5rem;color:var(--op-color1);letter-spacing:.01em;
  }
  .intro-signature small{color:var(--op-grey);font-size:.82rem}

  .stats{
    display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(1rem,3vw,2rem);
    padding-top:2rem;border-top:1px solid rgba(26,26,26,.08);
  }
  .stat .num{
    font-family:var(--op-font-display);font-weight:800;
    font-size:clamp(2rem,4vw,2.75rem);line-height:1;letter-spacing:-.02em;
    color:var(--op-text);
    display:flex;align-items:baseline;gap:.2rem;
  }
  .stat .num .suffix{font-size:.55em;color:var(--op-color1);font-weight:700}
  .stat .label{
    margin-top:.5rem;font-size:.78rem;font-weight:500;
    text-transform:uppercase;letter-spacing:.14em;color:var(--op-grey);
  }


  /* ═══════════════════════════════════════════════════════════════
     PILLARS — hover reveal cards
  ═══════════════════════════════════════════════════════════════ */
  .pillars{
    padding:clamp(5rem,10vw,8rem) 0;
    background:linear-gradient(180deg,var(--op-bg) 0%,#f2ece0 100%);
  }
  .pillars-head{text-align:center;margin-bottom:clamp(2.5rem,5vw,4rem);max-width:58ch;margin-inline:auto;padding:0 1rem}
  .pillars-eyebrow{
    font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.22em;
    color:var(--op-color1);margin:0 0 1rem;
  }
  .pillars h2{
    font-family:var(--op-font-display);font-weight:800;
    font-size:clamp(1.8rem,3.8vw,2.8rem);line-height:1.08;letter-spacing:-.015em;
    margin:0 0 .85rem;
  }
  .pillars h2 em{color:var(--op-color1);font-style:italic}
  .pillars-head p{color:var(--op-grey);font-size:1.05rem;margin:0}

  .pillar-grid{
    display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;
    padding:0 clamp(1rem,3vw,2rem);max-width:var(--op-container);margin:0 auto;
  }
  @media(max-width:860px){.pillar-grid{grid-template-columns:1fr}}

  .pillar{
    position:relative;aspect-ratio:3/4;border-radius:var(--op-radius-lg);
    overflow:hidden;cursor:pointer;color:#fff;text-decoration:none;
    box-shadow:var(--op-shadow-sm);
    transition:transform .6s cubic-bezier(.2,.8,.2,1),box-shadow .6s cubic-bezier(.2,.8,.2,1);
    isolation:isolate;
  }
  .pillar:hover{transform:translateY(-4px);box-shadow:var(--op-shadow-lg)}
  .pillar .img{
    position:absolute;inset:0;z-index:1;overflow:hidden;
  }
  .pillar .img::before{
    content:"";position:absolute;inset:0;z-index:1;
    transition:transform .9s cubic-bezier(.2,.8,.2,1),filter .6s ease;
  }
  .pillar:hover .img::before{transform:scale(1.08);filter:brightness(.75)}
  .pillar .img::after{
    content:"";position:absolute;inset:0;z-index:2;
    background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.85) 100%);
    opacity:.7;transition:opacity .5s ease;pointer-events:none;
  }
  .pillar:hover .img::after{opacity:1}

  .pillar:nth-child(1) .img::before{background:
    radial-gradient(circle at 25% 20%,rgba(255,255,255,.2),transparent 55%),
    linear-gradient(160deg,#2a4760 0%,#1e2f44 40%,#0c1520 100%);
  }
  .pillar:nth-child(2) .img::before{background:
    radial-gradient(circle at 70% 25%,rgba(255,220,180,.3),transparent 55%),
    linear-gradient(160deg,#c4a77a 0%,#8b6538 45%,#3d2610 100%);
  }
  .pillar:nth-child(3) .img::before{background:
    radial-gradient(circle at 35% 30%,rgba(200,220,180,.2),transparent 55%),
    linear-gradient(160deg,#6b7d5f 0%,#3a4a33 50%,#1a2014 100%);
  }

  .pillar .tag{
    position:absolute;top:1rem;left:1rem;z-index:3;
    font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;
    color:#fff;background:rgba(0,0,0,.35);backdrop-filter:blur(8px);
    padding:.4rem .7rem;border-radius:var(--op-radius-sm);
    border:1px solid rgba(255,255,255,.1);
  }
  .pillar .num-tag{
    position:absolute;top:1rem;right:1rem;z-index:3;
    font-family:var(--op-font-display);font-weight:800;font-size:1rem;
    color:rgba(255,255,255,.45);letter-spacing:.05em;
  }
  .pillar .body{
    position:absolute;left:0;right:0;bottom:0;z-index:3;
    padding:1.5rem;
    transition:padding-bottom .5s cubic-bezier(.2,.8,.2,1);
  }
  .pillar:hover .body{padding-bottom:1.75rem}
  .pillar .body h3{
    font-family:var(--op-font-display);font-weight:800;
    font-size:clamp(1.3rem,2vw,1.7rem);line-height:1.05;letter-spacing:-.01em;
    margin:0 0 .5rem;text-shadow:0 2px 20px rgba(0,0,0,.4);
  }
  .pillar .body .kicker{
    font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.16em;
    color:var(--op-color1);margin:0 0 .6rem;
  }
  .pillar .reveal{
    max-height:0;overflow:hidden;opacity:0;
    transition:max-height .55s cubic-bezier(.2,.8,.2,1),opacity .45s ease,margin .5s ease;
  }
  .pillar:hover .reveal{max-height:240px;opacity:1;margin-top:.75rem}
  .pillar .reveal p{margin:0 0 1rem;font-size:.92rem;color:#e8dfd0;line-height:1.55;max-width:38ch}
  .pillar .reveal .cta{
    display:inline-flex;align-items:center;gap:.4rem;
    font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;
    color:var(--op-color1);
  }
  .pillar .reveal .cta svg{width:16px;height:16px;transition:transform .3s ease}
  .pillar:hover .reveal .cta svg{transform:translateX(4px)}

  /* ═══════════════════════════════════════════════════════════════
     BLOG
  ═══════════════════════════════════════════════════════════════ */
  .blog{padding:clamp(5rem,10vw,8rem) 0;background:var(--op-bg)}
  .blog-head{
    display:flex;align-items:flex-end;justify-content:space-between;gap:2rem;
    margin-bottom:clamp(2rem,4vw,3rem);flex-wrap:wrap;
  }
  .blog-head h2{
    font-family:var(--op-font-display);font-weight:800;
    font-size:clamp(1.8rem,3.8vw,2.8rem);line-height:1.08;letter-spacing:-.015em;
    margin:.5rem 0 0;max-width:18ch;
  }
  .blog-head .eyebrow{
    font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.22em;
    color:var(--op-color1);margin:0;
  }
  .blog-head .btn-text{
    color:var(--op-color1);text-decoration:none;font-weight:700;font-size:.9rem;
    display:inline-flex;align-items:center;gap:.4rem;
  }
  .blog-head .btn-text:hover{color:var(--op-color2)}
  .blog-head .btn-text svg{width:16px;height:16px;transition:transform .3s ease}
  .blog-head .btn-text:hover svg{transform:translateX(4px)}

  .blog-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:1.25rem}
  @media(max-width:960px){.blog-grid{grid-template-columns:1fr 1fr}}
  @media(max-width:640px){.blog-grid{grid-template-columns:1fr}}

  .post{
    position:relative;border-radius:var(--op-radius-lg);overflow:hidden;
    background:var(--op-white);box-shadow:var(--op-shadow-sm);
    text-decoration:none;color:inherit;display:flex;flex-direction:column;
    transition:transform var(--op-transition-base),box-shadow var(--op-transition-base);
  }
  .post:hover{transform:translateY(-3px);box-shadow:var(--op-shadow-lg)}
  .post.feat{grid-row:span 1}
  @media(min-width:961px){
    .post.feat{grid-row:span 2;grid-column:span 1}
    .post.feat .img{aspect-ratio:4/5}
  }
  .post .img{
    position:relative;aspect-ratio:16/10;overflow:hidden;
  }
  .post .img::before{
    content:"";position:absolute;inset:0;z-index:1;
    background:inherit;
    transition:transform .7s cubic-bezier(.2,.8,.2,1);
  }
  .post:hover .img::before{transform:scale(1.03)}
  .post.p1 .img::before{background:linear-gradient(160deg,#3a5f8f 0%,#1e2b45 45%,#0c1628 100%)}
  .post.p2 .img::before{background:linear-gradient(160deg,#c8893f 0%,#8b5a28 50%,#3d2610 100%)}
  .post.p3 .img::before{background:linear-gradient(160deg,#9caea5 0%,#5a6d5f 50%,#2a3429 100%)}
  .post.p4 .img::before{background:linear-gradient(160deg,#d4b888 0%,#a67344 50%,#5a3d20 100%)}
  .post.p5 .img::before{background:linear-gradient(160deg,#8c6b9c 0%,#4d3d5a 50%,#201a2a 100%)}
  .post .img::after{
    content:"";position:absolute;inset:0;
    background:radial-gradient(circle at 30% 25%,rgba(255,255,255,.18),transparent 55%),linear-gradient(180deg,transparent 60%,rgba(0,0,0,.5));
  }
  .post .tag{
    position:absolute;top:.85rem;left:.85rem;z-index:2;
    font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;
    color:#fff;background:rgba(0,0,0,.45);backdrop-filter:blur(8px);
    padding:.35rem .65rem;border-radius:var(--op-radius-sm);
  }
  .post .body{padding:1.25rem 1.35rem 1.5rem;display:flex;flex-direction:column;flex:1}
  .post h3{
    font-family:var(--op-font-display);font-weight:700;
    font-size:clamp(1.05rem,1.4vw,1.3rem);line-height:1.22;letter-spacing:-.01em;
    margin:0 0 .5rem;
  }
  .post.feat h3{font-size:clamp(1.4rem,2vw,1.8rem);line-height:1.1}
  .post p{margin:0 0 1rem;color:#444;font-size:.95rem;line-height:1.5}
  .post .meta{
    margin-top:auto;font-size:.75rem;color:var(--op-grey);
    display:flex;gap:.55rem;align-items:center;flex-wrap:wrap;
  }
  .post .meta .dot{width:3px;height:3px;border-radius:50%;background:var(--op-grey)}
  .post .meta b{color:var(--op-text);font-weight:700}

  /* ═══════════════════════════════════════════════════════════════
     KREUZFAHRT PARALLAX
  ═══════════════════════════════════════════════════════════════ */
  .cruise{
    position:relative;min-height:88vh;overflow:hidden;color:#fff;
    background:#080510;
    display:flex;align-items:center;
  }
  .cruise-bg{
    position:absolute;inset:0;
    background:
      radial-gradient(ellipse 60% 40% at 75% 30%,var(--m-cruise-glow),transparent 60%),
      radial-gradient(ellipse 50% 40% at 20% 70%,var(--m-cruise-cool),transparent 60%),
      linear-gradient(180deg,var(--m-cruise-1) 0%,var(--m-cruise-2) 40%,var(--m-cruise-3) 100%);
    transition:background 1.2s ease;
  }
  .cruise-layer{position:absolute;inset:0;will-change:transform}
  .cruise-moon{
    position:absolute;top:12%;right:12%;width:clamp(140px,18vw,260px);aspect-ratio:1;
    border-radius:50%;
    background:radial-gradient(circle,rgba(255,220,180,.95) 0%,rgba(200,137,63,.5) 45%,transparent 75%);
    filter:blur(4px);
  }
  .cruise-horizon{
    position:absolute;left:-10%;right:-10%;top:60%;height:1px;
    background:linear-gradient(90deg,transparent,rgba(200,137,63,.5) 30%,rgba(255,210,150,.8) 50%,rgba(200,137,63,.5) 70%,transparent);
    box-shadow:0 0 60px rgba(200,137,63,.4);
  }
  .cruise-ship{
    position:absolute;left:50%;top:55%;transform:translate(-50%,0);
    width:clamp(280px,42vw,520px);color:rgba(5,3,10,.85);
    filter:drop-shadow(0 0 40px rgba(200,137,63,.3));
  }
  .cruise-reflection{
    position:absolute;left:0;right:0;top:60%;bottom:0;
    background:
      linear-gradient(180deg,rgba(10,8,20,0) 0%,rgba(10,8,20,.4) 30%,#020108 100%);
    overflow:hidden;
  }
  .cruise-reflection::before{
    content:"";position:absolute;left:50%;top:0;width:70%;height:100%;transform:translateX(-50%);
    background:radial-gradient(ellipse 60% 70% at 50% 0%,rgba(255,210,150,.18),transparent 70%);
    animation:heroWaterShimmer 5s ease-in-out infinite alternate;
  }
  .cruise-stars{position:absolute;inset:0}
  .cruise-inner{
    position:relative;z-index:3;max-width:var(--op-container);margin:0 auto;
    padding:clamp(5rem,10vw,8rem) clamp(1.25rem,4vw,3rem);width:100%;
    display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;
  }
  @media(max-width:860px){.cruise-inner{grid-template-columns:1fr}}
  .cruise-eyebrow{
    font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.22em;
    color:var(--op-color1);margin:0 0 1.25rem;display:flex;align-items:center;gap:.75rem;
  }
  .cruise-eyebrow::before{content:"";width:40px;height:1px;background:var(--op-color1)}
  .cruise h2{
    font-family:var(--op-font-display);font-weight:800;
    font-size:clamp(2rem,4.2vw,3.4rem);line-height:1.02;letter-spacing:-.02em;
    margin:0 0 1.5rem;
  }
  .cruise h2 em{color:var(--op-color1);font-style:italic}
  .cruise p{font-size:1.08rem;color:#d7d2c8;margin:0 0 2rem;line-height:1.7;max-width:48ch}
  .cruise .port-list{
    list-style:none;padding:0;margin:0 0 2rem;
    display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem 1rem;
  }
  .cruise .port-list li{
    display:flex;align-items:center;gap:.65rem;font-size:.92rem;color:#e8dfd0;
    padding:.35rem 0;
  }
  .cruise .port-list li::before{
    content:"";width:6px;height:6px;border-radius:50%;background:var(--op-color1);
    flex:0 0 6px;
  }
  #kreuzfahrt .port-list li::before{
    content:"";position:static;left:auto;color:inherit;
  }
  .cruise-actions{display:flex;gap:.85rem;flex-wrap:wrap}

  /* ═══════════════════════════════════════════════════════════════
     BERATUNG
  ═══════════════════════════════════════════════════════════════ */
  .beratung{
    padding:clamp(5rem,10vw,8rem) 0;background:var(--op-bg);
    position:relative;overflow:hidden;
  }
  .beratung::before{
    content:"";position:absolute;top:-20%;right:-20%;width:80%;height:140%;
    background:radial-gradient(ellipse at center, rgba(200, 137, 63, 0.06), transparent 60%);
    pointer-events:none;
  }
  .beratung-inner{position:relative;max-width:var(--op-container);margin:0 auto;padding:0 clamp(1.25rem,4vw,3rem)} 
  .beratung-eyebrow{
    font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.22em;
    color:var(--op-color1);margin:0 0 2rem;display:flex;align-items:center;gap:.75rem;
    justify-content:center;text-align:center;
  }
  .beratung-eyebrow::before,.beratung-eyebrow::after{content:"";width:40px;height:1px;background:var(--op-color1)}

  .quote{
    max-width:32ch;margin:0 auto 3rem;text-align:center;position:relative;
  }
  .quote::before{
    content:"\201C";position:absolute;top:-.4em;left:50%;transform:translateX(-50%);
    font-family:var(--op-font-display);font-size:clamp(6rem,12vw,10rem);
    color:var(--op-color1);opacity:.15;line-height:1;font-weight:800;
    z-index:0;
  }
  .quote blockquote{
    position:relative;z-index:1;margin:0;
    font-family:var(--op-font-display);font-weight:700;font-style:italic;
    font-size:clamp(1.8rem,4.2vw,3.2rem);line-height:1.12;letter-spacing:-.015em;
    color:var(--op-text);
  }
  .quote blockquote .accent{color:var(--op-color1);font-style:italic}
  .quote cite{
    display:flex;align-items:center;gap:.85rem;justify-content:center;
    margin-top:2rem;font-style:normal;
  }
  .quote cite .av{
    width:44px;height:44px;border-radius:50%;
    background:linear-gradient(135deg,#e8c89f,#c8893f,#6b3a15);
    border:2px solid var(--op-white);box-shadow:var(--op-shadow-sm);
  }
  .quote cite .nm{text-align:left}
  .quote cite .nm b{font-family:var(--op-font-sans);font-style:normal;font-weight:700;color:var(--op-text);font-size:.95rem;display:block}
  .quote cite .nm small{color:var(--op-grey);font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;font-style:normal}

  .trust{
    display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;
    max-width:980px;margin:0 auto;
  }
  @media(max-width:760px){.trust{grid-template-columns:repeat(2,1fr)}}
  .trust-card{
    background:var(--op-white);border:1px solid rgba(26,26,26,.06);
    border-radius:var(--op-radius-lg);padding:1.5rem 1.25rem;
    text-align:center;display:flex;flex-direction:column;align-items:center;gap:.75rem;
    transition:transform var(--op-transition-base),box-shadow var(--op-transition-base),border-color var(--op-transition-base);
  }
  .trust-card:hover{transform:translateY(-3px);box-shadow:var(--op-shadow-md);border-color:rgba(200,137,63,.25)}
  .trust-card .ic{
    width:48px;height:48px;border-radius:50%;
    background:rgba(200,137,63,.1);color:var(--op-color1);
    display:flex;align-items:center;justify-content:center;
  }
  .trust-card .ic svg{width:24px;height:24px;stroke:currentColor;fill:none;stroke-width:1.75}
  .trust-card h4{
    font-family:var(--op-font-display);font-weight:700;font-size:1rem;
    margin:0;letter-spacing:-.005em;
  }
  .trust-card p{margin:0;font-size:.85rem;color:var(--op-grey);line-height:1.5}

  .consult-actions{
    margin-top:3rem;display:flex;gap:.85rem;justify-content:center;flex-wrap:wrap;
  }
  .consult-note{
    margin-top:1.25rem;text-align:center;font-size:.82rem;color:var(--op-grey);
    display:flex;flex-direction:column;align-items:center;gap:.35rem;justify-content:center;
  }
  .consult-note svg{width:18px;height:18px;color:var(--op-color1)}

  .amondo-logo{
    width: 100%;
    padding: 3rem 0 0;
  }
.amondo-logo img{
    width: 20%;
    margin: auto;
  }


  /* ═══════════════════════════════════════════════════════════════
     FAQ
  ═══════════════════════════════════════════════════════════════ */
  .faq{
    background:var(--op-text);color:#f5efe2;
    padding:clamp(5rem,10vw,8rem) 0;position:relative;overflow:hidden;
  }
  .faq::before{
    content:"";position:absolute;top:-30%;left:-10%;width:100%;height:120%;
    background:radial-gradient(circle,rgba(200,137,63,.08),transparent 60%);
    pointer-events:none;
  }
  .faq-inner{position:relative;max-width:880px;margin:0 auto;padding:0 clamp(1.25rem,4vw,3rem)}
  .faq-head{text-align:center;margin-bottom:3rem}
  .faq-eyebrow{
    font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.22em;
    color:var(--op-color1);margin:0 0 1rem;
  }
  .faq h2{
    font-family:var(--op-font-display);font-weight:800;
    font-size:clamp(1.8rem,3.8vw,2.8rem);line-height:1.08;letter-spacing:-.015em;
    margin:0 0 .5rem;
  }
  .faq-head p{color:rgba(245,239,226,.65);margin:0;font-size:1.02rem}

  .faq-item{
    border-bottom:1px solid rgba(245,239,226,.1);
    transition:border-color var(--op-transition-base);
  }
  .faq-item:first-of-type{border-top:1px solid rgba(245,239,226,.1)}
  .faq-item.open{border-color:rgba(200,137,63,.3)}

  .faq-q{
    width:100%;background:transparent;border:0;color:inherit;cursor:pointer;
    padding:1.4rem 0;display:flex;align-items:center;justify-content:space-between;gap:1rem;
    font-family:var(--op-font-display);font-weight:700;font-size:clamp(1.05rem,1.6vw,1.3rem);
    text-align:left;letter-spacing:-.005em;line-height:1.3;
    transition:color var(--op-transition-base);
  }
  .faq-q:hover{color:var(--op-color1)}
  .faq-item.open .faq-q{color:var(--op-color1)}
  .faq-q .ic{
    width:32px;height:32px;border-radius:50%;flex:0 0 32px;
    border:1px solid rgba(245,239,226,.25);
    display:flex;align-items:center;justify-content:center;
    position:relative;transition:all var(--op-transition-base);
  }
  .faq-q .ic::before,.faq-q .ic::after{
    content:"";position:absolute;background:currentColor;
    transition:transform var(--op-transition-base);
  }
  .faq-q .ic::before{width:12px;height:1.5px}
  .faq-q .ic::after{width:1.5px;height:12px}
  .faq-item.open .faq-q .ic{background:var(--op-color1);border-color:var(--op-color1);color:#fff}
  .faq-item.open .faq-q .ic::after{transform:scaleY(0)}

  .faq-a{
    max-height:0;overflow:hidden;
    transition:max-height .5s cubic-bezier(.2,.8,.2,1);
  }
  .faq-item.open .faq-a{max-height:280px}
  .faq-a-inner{
    padding:0 0 1.6rem;color:rgba(245,239,226,.75);line-height:1.7;font-size:1rem;
    max-width:62ch;
  }

  .faq-foot{
    margin-top:3rem;text-align:center;padding:2rem;
    background:rgba(245,239,226,.03);border:1px solid rgba(245,239,226,.08);
    border-radius:var(--op-radius-lg);
  }
  .faq-foot p{margin:0 0 1rem;color:rgba(245,239,226,.85)}
  .faq-foot .btn-ghost{color:#fff}

  /* ═══════════════════════════════════════════════════════════════
     SOCIAL + FOOTER
  ═══════════════════════════════════════════════════════════════ */
  .social{
    padding:clamp(3rem,6vw,5rem) 0;background:var(--op-bg);
    border-bottom:1px solid rgba(26,26,26,.06);
  }
  .social-inner{
    max-width:var(--op-container);margin:0 auto;padding:0 clamp(1.25rem,4vw,3rem);
    display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap;
  }
  .social-txt{
    font-family:var(--op-font-display);font-weight:700;
    font-size:clamp(1.1rem,1.8vw,1.4rem);
    margin:0;max-width:32ch;line-height:1.25;
  }
  .social-txt em{color:var(--op-color1);font-style:italic}
  .social-list{display:flex;gap:.75rem;list-style:none;padding:0;margin:0}
  .social-list a{
    width:48px;height:48px;border-radius:50%;
    background:var(--op-white);border:1px solid rgba(26,26,26,.08);
    display:flex;align-items:center;justify-content:center;color:var(--op-text);
    transition:all var(--op-transition-base);text-decoration:none;
  }
  .social-list a:hover{background:var(--op-color1);color:#fff;border-color:var(--op-color1);transform:translateY(-2px);box-shadow:var(--op-shadow-brand)}
  .social-list svg{width:20px;height:20px;fill:currentColor}

  footer{
    background:var(--op-text);color:#a8a29a;padding:3rem var(--space-sm) 1.5rem;
  }
  footer .wrap{max-width:var(--op-container);margin:0 auto;padding:0 clamp(1.25rem,4vw,3rem)}
  footer .cols{
    display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:2rem;margin-bottom:2rem;
  }
  @media(max-width:760px){footer .cols{grid-template-columns:1fr 1fr}}
  @media(max-width:480px){footer .cols{grid-template-columns:1fr}}
  footer .brand img{height:30px;filter:brightness(0) invert(1);margin-bottom:.75rem}
  footer .brand strong{color:#fff;font-family:var(--op-font-display);font-weight:800;letter-spacing:.01em;display:block;margin-bottom:.5rem}
  footer .brand p{margin:0;color:#888;font-size:.88rem;max-width:38ch;line-height:1.6}
  footer h4{
    font-family:var(--op-font-display);font-weight:700;font-size:.75rem;
    color:#fff;text-transform:uppercase;letter-spacing:.18em;margin:0 0 1rem;
  }
  footer a{
    color:#a8a29a;text-decoration:none;font-size:.88rem;display:block;padding:.22rem 0;
    transition:color var(--op-transition-base);
  }
  footer a:hover{color:var(--op-color1)}
  footer .bottom{
    border-top:1px solid rgba(255,255,255,.08);padding-top:1.25rem;
    display:flex;justify-content:space-between;font-size:.75rem;color:#666;flex-wrap:wrap;gap:.75rem;
  }
  footer .bottom a{display:inline;padding:0;margin-right:1rem}

  /* ═══════════════════════════════════════════════════════════════
     ATTRIBUTION CHIPS — Drittquelle, KI, Affiliate
     injected via JS into the image container so hover-zoom on the
     image layer doesn't move them
  ═══════════════════════════════════════════════════════════════ */
  .attr-stack{
    position:absolute;bottom:.65rem;right:.65rem;z-index:5;
    display:flex;flex-direction:column;align-items:flex-end;gap:.35rem;
    pointer-events:none;max-width:calc(100% - 1.3rem);
  }
  .attr-chip{
    display:inline-flex;align-items:center;gap:.32rem;
    font-family:var(--op-font-sans);font-size:.6rem;font-weight:normal;
    text-transform:uppercase;letter-spacing:.14em;color:#fff;
    background:rgba(0,0,0,.3);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
    padding:.32rem .55rem;border-radius:var(--op-radius-sm);
    border:1px solid rgba(255,255,255,.14);
    pointer-events:auto;line-height:1;white-space:nowrap;
    max-width:100%;overflow:hidden;text-overflow:ellipsis;
    transition:background .25s ease,transform .25s ease;
  }
  .attr-chip:hover{background:rgba(0,0,0,.78);transform:translateY(-1px)}
  .attr-chip .dot{width:4px;height:4px;border-radius:50%;background:currentColor;flex:none;opacity:.85}
  .attr-chip--photo{}
  .attr-chip--ai{color:var(--op-color1);border-color:rgba(200,137,63,.55);background:rgba(10,10,10,.8)}
  .attr-chip--aff{color:#b8dabb;border-color:rgba(140,200,150,.45);background:rgba(10,20,14,.78)}