:root {
    --color-bg: #ffffff;
    --color-text: #0e0b0b;
    --color-accent: #c9a27d;
    --color-muted: #f4f1ee;
    --color-dark: #161111;
    --color-shadow: rgba(15, 10, 10, 0.12);
    --color-bg-rgb: 255, 255, 255;
    --spacing-xs: 0.5rem;
    --spacing-sm: 0.75rem;
    --spacing-md: 1.25rem;
    --spacing-lg: 2rem;
    --spacing-xl: 3rem;
    --spacing-xxl: 4.5rem;
    --radius-sm: 12px;
    --radius-lg: 24px;
    --burger-box-size: calc(var(--burger-size, 26px) + 1.4rem);
    --max-width: 1200px;
    --font-sans: "Verdana", "Geneva", "Tahoma", sans-serif;
    --font-body: var(--font-sans);
    --font-heading: var(--font-sans);
    --font-ui: var(--font-sans);
    --transition: 0.35s ease;
}

* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html,
body {
    font-family: Verdana, Geneva, Tahoma, sans-serif;
}

body {
    background: var(--color-bg);
    color: var(--color-text);
    line-height: 1.6;
}

.skip-link {
    position: absolute;
    left: 1rem;
    top: 1rem;
    z-index: 1000;
    padding: 0.75rem 1rem;
    border-radius: 999px;
    background: var(--color-dark);
    color: #fff;
    transform: translateY(-200%);
    transition: transform 0.2s ease;
}

.skip-link:focus-visible {
    transform: translateY(0);
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: var(--font-heading);
}

button,
input,
select,
textarea {
    font-family: var(--font-ui);
}

img {
    max-width: 100%;
    display: block;
}

a {
    color: inherit;
    text-decoration: none;
}

ul {
    list-style: none;
}

.container {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 0 var(--spacing-lg);
}

.section {
    padding: var(--spacing-xxl) 0;
}

main[id],
section[id],
footer[id] {
    scroll-margin-top: 6rem;
}

.section__heading {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--spacing-lg);
    margin-bottom: var(--spacing-lg);
}

.section__heading h2 {
    font-size: clamp(1.8rem, 2vw, 2.5rem);
}

.section__heading p {
    max-width: 460px;
    color: rgba(0, 0, 0, 0.7);
}

.site-header {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    z-index: 100;
    background: rgba(var(--color-bg-rgb, 255, 255, 255), var(--header-bg-opacity, 0.85));
    border-bottom: none;
}

.header__inner {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    padding: var(--spacing-md) 0;
}

.header__inner--full {
    width: 100%;
    padding: var(--spacing-md) var(--spacing-lg);
}

.header__actions {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.header__brand {
    margin-right: auto;
    display: flex;
    align-items: center;
}

.header__logo-container {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: var(--header-logo-padding, 18px);
    margin: var(--header-logo-margin, 0px);
    border-radius: var(--header-logo-radius, 24px);
    border: var(--header-logo-border-width, 1px) solid var(--header-logo-border-color, #ffffff);
    background: rgba(var(--header-logo-bg-rgb, 255, 255, 255), var(--header-logo-bg-opacity, 0.35));
    backdrop-filter: blur(var(--header-logo-blur, 18px));
    -webkit-backdrop-filter: blur(var(--header-logo-blur, 18px));
    box-shadow: 0 18px 40px rgba(15, 10, 10, 0.18);
    overflow: hidden;
    opacity: 0;
    transform: translateX(calc(var(--header-logo-slide-direction, -1) * var(--header-logo-slide-distance, 36px))) translateY(var(--header-logo-sticky-offset, 0px));
    animation: header-logo-reveal var(--header-logo-reveal-duration, 0.7s) ease var(--header-logo-reveal-delay, 1500ms) forwards;
}

.header__logo {
    width: auto;
    max-width: var(--hero-logo-max-width, 240px);
    max-height: var(--hero-logo-max-height, 120px);
    display: block;
}

@keyframes header-logo-reveal {
    from {
        opacity: 0;
        transform: translateX(calc(var(--header-logo-slide-direction, -1) * var(--header-logo-slide-distance, 36px))) translateY(var(--header-logo-sticky-offset, 0px));
    }
    to {
        opacity: 1;
        transform: translateX(0) translateY(var(--header-logo-sticky-offset, 0px));
    }
}

.language-toggle {
    display: inline-flex;
    position: absolute;
    top: var(--spacing-md);
    right: calc(var(--spacing-lg) + var(--burger-box-size) + 30px);
    border: 1px solid rgba(0, 0, 0, 0.1);
    border-radius: 999px;
    overflow: hidden;
}

.language-toggle__button {
    background: transparent;
    border: none;
    padding: 0.35rem 0.8rem;
    font-size: 0.75rem;
    letter-spacing: 0.2em;
    cursor: pointer;
}

.language-toggle__button.is-active {
    background: var(--color-accent);
    color: #fff;
}

.nav-link {
    position: relative;
    padding-bottom: 4px;
}

.nav-link::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 0;
    height: 1px;
    background: var(--color-accent);
    transition: width var(--transition);
}

.nav-link:hover::after,
.nav-link:focus::after {
    width: 100%;
}

.burger {
    background: rgba(255, 255, 255, 0.82);
    position: fixed;
    top: var(--spacing-md);
    right: var(--spacing-lg);
    border: 1px solid rgba(255, 255, 255, 0.6);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: calc(var(--burger-size, 26px) / 5);
    cursor: pointer;
    width: var(--burger-box-size);
    height: var(--burger-box-size);
    padding: 0;
    border-radius: 10px;
    backdrop-filter: blur(14px);
    box-shadow: 0 22px 40px rgba(15, 10, 10, 0.2);
    transition: transform var(--transition), background var(--transition), box-shadow var(--transition), opacity var(--transition);
    z-index: 101;
}

.burger span {
    width: var(--burger-size, 26px);
    height: calc(var(--burger-size, 26px) / 10);
    background: var(--color-text);
}

.burger.is-hidden {
    opacity: 0;
    transform: scale(0.85);
    pointer-events: none;
}

.burger.is-visible {
    animation: burgerEntrance 0.85s cubic-bezier(0.16, 1, 0.3, 1);
}

.burger:hover,
.burger:focus-visible {
    transform: scale(1.06);
}

.site-header.is-scrolled .burger {
    background: rgba(255, 255, 255, 0.92);
}

@keyframes burgerEntrance {
    0% {
        opacity: 0;
        transform: scale(0.6) rotate(-6deg);
        box-shadow: 0 0 0 rgba(0, 0, 0, 0);
    }
    55% {
        opacity: 1;
        transform: scale(1.08) rotate(1deg);
    }
    80% {
        transform: scale(0.98);
    }
    100% {
        transform: scale(1);
    }
}

.hero {
    position: relative;
    min-height: 100vh;
    height: 100vh;
    box-sizing: border-box;
}

.hero__media {
    position: absolute;
    inset: 0;
    overflow: hidden;
}

.hero__media img,
.hero__media iframe,
.hero__media video {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.focal-cover-frame {
    position: relative;
    overflow: hidden;
}

.focal-cover-frame > img[data-focal-mode="cover-center"] {
    position: absolute;
    max-width: none;
}

.hero__media iframe {
    pointer-events: none;
}

.hero__media--adaptive {
    z-index: 0;
}

.hero__fallback,
.hero__video-layer {
    position: absolute;
    inset: 0;
    transition: opacity 0.7s ease;
}

.hero__video-layer {
    opacity: 0;
}

.hero.is-video-ready .hero__fallback {
    opacity: 0;
}

.hero.is-video-ready .hero__video-layer {
    opacity: 1;
}

.hero__overlay {
    position: absolute;
    z-index: 1;
    max-width: 480px;
    left: var(--spacing-lg);
    bottom: var(--spacing-lg);
    background: rgba(255, 255, 255, var(--hero-overlay-bg-opacity, 0.85));
    padding: var(--spacing-xl);
    border-radius: var(--radius-lg);
    box-shadow: 0 24px 60px rgba(15, 10, 10, var(--hero-overlay-shadow-opacity, 0.18));
    backdrop-filter: blur(12px);
    border: 1px solid rgba(255, 255, 255, 0.6);
    opacity: 0;
}

.hero__overlay.is-animating {
    animation-duration: 0.9s;
    animation-timing-function: cubic-bezier(0.16, 1, 0.3, 1);
    animation-fill-mode: forwards;
    animation-delay: var(--overlay-delay, 0ms);
    animation-name: heroOverlaySlide;
}

.hero[data-overlay-animation="fade"] .hero__overlay.is-animating {
    animation-name: heroOverlayFade;
}

.hero[data-overlay-animation="zoom"] .hero__overlay.is-animating {
    animation-name: heroOverlayZoom;
}

.hero[data-overlay-animation="rise"] .hero__overlay.is-animating {
    animation-name: heroOverlayRise;
}

@keyframes heroOverlaySlide {
    from {
        opacity: 0;
        transform: translateY(26px) scale(0.98);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes heroOverlayFade {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}

@keyframes heroOverlayZoom {
    from {
        opacity: 0;
        transform: scale(0.9);
    }
    to {
        opacity: 1;
        transform: scale(1);
    }
}

@keyframes heroOverlayRise {
    from {
        opacity: 0;
        transform: translateY(40px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.hero__overlay h1 {
    font-size: clamp(2.4rem, 3vw, 3.5rem);
    margin-bottom: var(--spacing-sm);
}

.eyebrow {
    text-transform: uppercase;
    letter-spacing: 0.3em;
    font-size: 0.75rem;
    color: var(--color-accent);
    margin-bottom: var(--spacing-xs);
}

.primary-button,
.ghost-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.75rem 1.6rem;
    border-radius: 999px;
    font-weight: 600;
    border: none;
    cursor: pointer;
    transition: transform var(--transition), background var(--transition), box-shadow var(--transition), color var(--transition);
}

.primary-button {
    background: var(--color-accent);
    color: #fff;
}

.primary-button:hover,
.primary-button:focus-visible {
    transform: translateY(-3px);
    box-shadow: 0 16px 32px rgba(201, 162, 125, 0.35);
}

.ghost-button {
    background: transparent;
    border: 1px solid var(--color-accent);
    color: var(--color-accent);
}

.ghost-button:hover,
.ghost-button:focus-visible {
    transform: translateY(-2px);
    background: rgba(201, 162, 125, 0.12);
}


.grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: var(--spacing-lg);
}

.domains__grid {
    grid-template-columns: 1fr;
}

@media (min-width: 900px) {
    .domains__grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

.card {
    background: #fff;
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.08);
}

.card--interactive {
    transition: transform var(--transition), box-shadow var(--transition);
}

.card--interactive:hover,
.card--interactive:focus-within {
    transform: translateY(-6px);
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.12);
}

.card__button {
    border: none;
    background: transparent;
    text-align: left;
    width: 100%;
    padding: 0;
    cursor: pointer;
}

.card__media {
    background: var(--color-muted);
    aspect-ratio: 1 / 1;
    min-height: 180px;
    overflow: hidden;
}

.card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition);
}

.card--interactive:hover .card__media img,
.card--interactive:focus-within .card__media img {
    transform: scale(1.06);
}

.card__body {
    padding: var(--spacing-lg);
}

.card__link {
    display: inline-block;
    margin-top: var(--spacing-sm);
    color: var(--color-accent);
    transition: transform var(--transition);
}

.card--interactive:hover .card__link,
.card--interactive:focus-within .card__link {
    transform: translateX(6px);
}

.cta {
    background: var(--color-dark);
    color: #fff;
}

.cta__inner {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: var(--spacing-lg);
}

.why-us__grid {
    display: grid;
    gap: var(--spacing-lg);
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.slideshow {
    position: relative;
    min-height: 200px;
}

.slideshow [data-slide] {
    display: none;
}

.slideshow [data-slide].is-active {
    display: block;
}

.slideshow__controls {
    display: flex;
    gap: var(--spacing-xs);
    margin-top: var(--spacing-md);
}

.slideshow__button {
    border: none;
    background: var(--color-accent);
    color: #fff;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    cursor: pointer;
    transition: transform var(--transition), box-shadow var(--transition);
}

.slideshow__button:hover,
.slideshow__button:focus-visible {
    transform: translateY(-2px) scale(1.05);
    box-shadow: 0 10px 20px rgba(201, 162, 125, 0.4);
}

.testimonial {
    display: grid;
    gap: var(--spacing-md);
    padding: var(--spacing-lg);
    background: #fff;
    border-radius: var(--radius-md);
    border: 1px solid #dadde1;
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.08);
}

.testimonial__quote {
    font-size: 1rem;
    line-height: 1.6;
    color: #050505;
    margin: 0;
}

.testimonial__header {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.testimonial__avatar,
.modal__avatar {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    overflow: hidden;
    flex-shrink: 0;
    border: 1px solid #ccd0d5;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.12);
}

.testimonial__avatar img,
.modal__avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.testimonial__meta {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
}

.testimonial__meta strong {
    font-size: 1rem;
    color: #050505;
}

.testimonial__meta span {
    font-size: 0.9rem;
    color: #65676b;
}

.modal__testimonial-header {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-sm);
}

.contact__grid {
    display: grid;
    gap: var(--spacing-lg);
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.contact__form {
    display: grid;
    gap: var(--spacing-sm);
}

.contact__form label {
    display: grid;
    gap: var(--spacing-xs);
}

.contact__field-label {
    display: flex;
    align-items: baseline;
    gap: var(--spacing-xs);
    justify-content: space-between;
}

.contact__field-meta {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: rgba(0, 0, 0, 0.45);
}

.contact__field-meta.is-required {
    color: rgba(122, 34, 40, 0.7);
}

.contact__status {
    display: grid;
    gap: var(--spacing-xs);
}

.contact__form input,
.contact__form textarea,
.contact__form select {
    padding: 0.7rem 0.9rem;
    border-radius: var(--radius-sm);
    border: 1px solid rgba(0, 0, 0, 0.15);
    transition: border-color var(--transition), box-shadow var(--transition);
}

.contact__form input:focus-visible,
.contact__form textarea:focus-visible,
.contact__form select:focus-visible {
    outline: 2px solid transparent;
    border-color: rgba(201, 162, 125, 0.8);
    box-shadow: 0 0 0 3px rgba(201, 162, 125, 0.2);
}

.contact__status:focus-visible {
    outline: 2px solid rgba(201, 162, 125, 0.7);
    outline-offset: 0.35rem;
}

.contact__form textarea {
    min-height: 120px;
    resize: vertical;
}

.contact__money-field {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: var(--spacing-xs);
    align-items: center;
}

.alert {
    padding: 0.7rem 1rem;
    border-radius: var(--radius-sm);
}

.alert--success {
    background: #e6f5ea;
    color: #1e5a32;
}

.alert--error {
    background: #fbe3e4;
    color: #7a2228;
}

.muted {
    color: rgba(0, 0, 0, 0.6);
    font-size: 0.9rem;
}

.clients__carousel {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: minmax(160px, 1fr);
    gap: var(--spacing-md);
    overflow-x: auto;
    padding-bottom: var(--spacing-sm);
    scroll-snap-type: x mandatory;
}

.clients__item {
    background: #fff;
    border-radius: var(--radius-lg);
    padding: var(--spacing-md);
    display: grid;
    align-items: center;
    justify-items: center;
    gap: var(--spacing-xs);
    min-height: 140px;
    scroll-snap-align: start;
    position: relative;
    transition: transform var(--transition), box-shadow var(--transition);
}

.clients__item:hover,
.clients__item:focus-within {
    transform: translateY(-4px);
    box-shadow: 0 14px 30px rgba(0, 0, 0, 0.12);
}

.clients__label {
    font-size: 0.85rem;
    opacity: 0;
    transition: opacity var(--transition);
}

.clients__item:hover .clients__label {
    opacity: 1;
}

.gallery-section {
    position: relative;
    overflow: hidden;
    background:
        radial-gradient(circle at top left, rgba(201, 162, 125, 0.18), transparent 32%),
        radial-gradient(circle at bottom right, rgba(22, 17, 17, 0.08), transparent 28%);
}

.gallery-section__heading {
    margin-bottom: var(--spacing-xl);
}

.gallery-marquee {
    display: grid;
    gap: calc(var(--gallery-gap, 18px) * 1.1);
    perspective: 1400px;
}

.gallery-marquee__row {
    overflow: hidden;
    padding: 0 var(--gallery-gap, 18px);
}

.gallery-marquee__track {
    display: flex;
    gap: var(--gallery-gap, 18px);
    width: max-content;
    animation: gallery-scroll var(--gallery-duration, 30s) linear infinite;
    will-change: transform;
}

.gallery-marquee__row--reverse .gallery-marquee__track {
    animation-direction: reverse;
}

.gallery-marquee__item {
    flex: 0 0 clamp(160px, calc(var(--gallery-tile-height, 220px) * var(--tile-ratio, 1.4)), 400px);
    display: grid;
    gap: 0.7rem;
    border: none;
    background: transparent;
    cursor: pointer;
    padding: 0;
    color: inherit;
    text-align: left;
    transform-style: preserve-3d;
    transition: transform 0.45s cubic-bezier(0.16, 1, 0.3, 1), filter 0.45s ease;
}

.gallery-marquee__item:nth-child(4n + 2) {
    transform: translateY(18px) rotateX(1.5deg);
}

.gallery-marquee__item:nth-child(4n + 3) {
    transform: translateY(-14px) rotateX(-1.2deg);
}

.gallery-marquee__item:hover,
.gallery-marquee__item:focus-visible {
    filter: saturate(1.04);
}

.gallery-marquee__item:hover .gallery-marquee__image-wrap,
.gallery-marquee__item:focus-visible .gallery-marquee__image-wrap {
    transform: translateY(-6px) rotateY(5deg) rotateX(2deg) scale(1.02);
    box-shadow: 0 26px 50px rgba(15, 10, 10, 0.18);
}

.gallery-marquee__image-wrap {
    position: relative;
    height: var(--gallery-tile-height, 220px);
    border-radius: 24px;
    overflow: hidden;
    background: rgba(255, 255, 255, 0.75);
    box-shadow: 0 18px 38px rgba(15, 10, 10, 0.12);
    transition: transform 0.45s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.45s ease;
}

.gallery-marquee__image-wrap::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(15, 10, 10, 0.16));
    pointer-events: none;
}

.gallery-marquee__image-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.gallery-marquee__caption {
    padding: 0 0.25rem;
    font-size: 0.82rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: rgba(14, 11, 11, 0.62);
}

.gallery-lightbox {
    position: fixed;
    inset: 0;
    z-index: 4500;
}

.gallery-lightbox[hidden] {
    display: none;
}

.gallery-lightbox__backdrop {
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at center, rgba(255, 255, 255, 0.16), transparent 24%),
        rgba(9, 7, 7, 0.82);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    opacity: 0;
}

.gallery-lightbox__stage {
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    padding: clamp(1rem, 3vw, 2.5rem);
    perspective: 1800px;
}

.gallery-lightbox__figure {
    margin: 0;
    width: min(90vw, 1280px);
    max-height: 86vh;
    display: grid;
    gap: 1rem;
    transform-origin: center center;
    transform-style: preserve-3d;
}

.gallery-lightbox__figure img {
    width: 100%;
    max-height: calc(86vh - 3rem);
    object-fit: contain;
    border-radius: 30px;
    box-shadow: 0 40px 100px rgba(0, 0, 0, 0.45);
    background: rgba(255, 255, 255, 0.05);
}

.gallery-lightbox__caption {
    text-align: center;
    color: rgba(255, 255, 255, 0.86);
    letter-spacing: 0.06em;
    text-transform: uppercase;
    font-size: 0.8rem;
}

@keyframes gallery-scroll {
    from {
        transform: translate3d(0, 0, 0);
    }
    to {
        transform: translate3d(calc(-50% - (var(--gallery-gap, 18px) / 2)), 0, 0);
    }
}

@media (prefers-reduced-motion: reduce) {
    .gallery-marquee__track {
        animation: none;
        width: 100%;
        flex-wrap: wrap;
    }

    .gallery-marquee__item,
    .gallery-marquee__item:nth-child(4n + 2),
    .gallery-marquee__item:nth-child(4n + 3) {
        transform: none;
    }
}

.impressum__item {
    display: grid;
    gap: var(--spacing-md);
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    align-items: center;
    background: var(--color-muted);
    padding: var(--spacing-lg);
    border-radius: var(--radius-lg);
    transition: transform var(--transition), box-shadow var(--transition);
}

.impressum__item:hover,
.impressum__item:focus-within {
    transform: translateY(-4px);
    box-shadow: 0 16px 36px rgba(0, 0, 0, 0.12);
}

.impressum__media img {
    border-radius: var(--radius-lg);
}

.site-footer {
    background: var(--color-dark);
    color: #fff;
    padding: var(--spacing-xxl) 0;
}

.footer__logo {
    max-width: 200px;
    max-height: 80px;
    width: 100%;
    height: auto;
    object-fit: contain;
    margin-bottom: var(--spacing-sm);
}

.footer__logo-editor {
    display: inline-flex;
    max-width: 200px;
}

.footer__grid {
    display: grid;
    gap: var(--spacing-lg);
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

.footer__contact-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: var(--spacing-xs);
}

.footer__contact-item {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-xs);
}

.footer__contact-icon {
    font-size: 1.1rem;
    color: var(--color-accent);
}

.footer__social-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: var(--spacing-xs);
}

.footer__social-link {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-xs);
    color: #fff;
    text-decoration: none;
    transition: color var(--transition);
}

.footer__social-link:hover,
.footer__social-link:focus {
    color: var(--color-accent);
}

.footer__social-icon {
    font-size: 1.25rem;
}

.footer__social-label {
    font-size: 0.95rem;
}

.footer__bottom {
    margin-top: var(--spacing-xl);
    border-top: 1px solid rgba(255, 255, 255, 0.15);
    padding-top: var(--spacing-lg);
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-lg);
    justify-content: space-between;
    align-items: flex-start;
}

.footer__copy {
    margin-left: auto;
}

.modal {
    position: fixed;
    inset: 0;
    display: none;
    align-items: center;
    justify-content: center;
    z-index: 4000;
}

.modal.is-open {
    display: flex;
}

.modal__overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.4);
    opacity: 0;
    transition: opacity 0.35s ease;
}

.modal__content {
    position: relative;
    background: #fff;
    border-radius: var(--radius-lg);
    padding: var(--spacing-xl);
    max-width: 820px;
    width: min(90%, 860px);
    max-height: 85vh;
    overflow: hidden;
    z-index: 1;
}

.modal:not(.modal--menu) .modal__content {
    opacity: 0;
    transform: translateY(20px) scale(0.96);
    transition: opacity 0.35s ease, transform 0.35s ease;
}

.modal.is-open .modal__overlay {
    opacity: 1;
}

.modal.is-open:not(.modal--menu) .modal__content {
    opacity: 1;
    transform: translateY(0) scale(1);
}

.modal.is-closing .modal__overlay {
    opacity: 0;
}

.modal.is-closing:not(.modal--menu) .modal__content {
    opacity: 0;
    transform: translateY(12px) scale(0.95);
}

.modal__content--scroll {
    overflow: auto;
}

.modal__content--domain {
    width: min(94vw, var(--max-width, 1200px));
    max-width: var(--max-width, 1200px);
    max-height: 90vh;
    padding: var(--spacing-xl);
    overflow: auto;
    background: linear-gradient(140deg, #fff, #faf7f4);
}

.domain-modal {
    display: grid;
    gap: var(--spacing-lg);
}

.domain-modal__intro {
    display: grid;
    gap: var(--spacing-sm);
}

.domain-modal__eyebrow {
    text-transform: uppercase;
    letter-spacing: 0.18em;
    font-size: 0.75rem;
    color: var(--color-accent);
    font-weight: 600;
}

.domain-modal__hero {
    position: relative;
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.12);
}

.domain-modal__hero img {
    width: 100%;
    display: block;
    object-fit: cover;
    max-height: 460px;
}

.domain-modal__hero-title {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: flex-end;
    justify-content: flex-start;
    padding: clamp(1.5rem, 2vw, 2.75rem);
    pointer-events: none;
}

.domain-modal__hero-title h2 {
    margin: 0;
    color: #fff;
    font-size: clamp(2rem, 3vw, 3.4rem);
    text-shadow: 0 6px 18px rgba(14, 10, 8, 0.75);
}

.domain-modal__title-fallback {
    font-size: clamp(2rem, 3vw, 3.4rem);
    margin: 0;
}

.domain-modal__details {
    display: grid;
    gap: var(--spacing-md);
    align-items: start;
}

.domain-modal__details--with-subnav {
    grid-template-columns: minmax(220px, 25%) 1fr;
}

.domain-modal__subnav {
    display: grid;
    gap: 0.5rem;
    align-content: start;
}

.domain-modal__subnav-button {
    border: 1px solid transparent;
    border-radius: 999px;
    padding: 0.75rem 1rem;
    background: #f4f1ee;
    color: #2c221c;
    font-weight: 600;
    font-size: 1rem;
    text-align: left;
    cursor: pointer;
    width: 100%;
}

.domain-modal__subnav-button:hover {
    border-color: rgba(15, 10, 10, 0.2);
}

.domain-modal__subnav-button.is-active {
    background: var(--color-accent);
    color: #1b130e;
}

.domain-modal__text {
    display: grid;
    gap: var(--spacing-sm);
    font-size: 1.05rem;
    color: #3a2f28;
}

.domain-modal__text > * {
    margin: 0;
}

.domain-modal__actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-sm);
}

.domain-modal__gallery {
    display: grid;
    gap: var(--spacing-md);
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.domain-modal__item {
    background: #fff;
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: 0 12px 28px rgba(0, 0, 0, 0.08);
}

.domain-modal__item img,
.domain-modal__item iframe {
    width: 100%;
    height: 100%;
    min-height: 200px;
    object-fit: cover;
    display: block;
}

.domain-modal__animate {
    opacity: 0;
    transform: translateY(16px) scale(0.98);
}

.modal.is-open .domain-modal__animate {
    animation: domain-fade-rise 0.7s ease forwards;
    animation-delay: var(--delay, 0ms);
}

@keyframes domain-fade-rise {
    0% {
        opacity: 0;
        transform: translateY(16px) scale(0.98);
    }
    100% {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

.modal__content--domain p {
    font-size: 1.05rem;
    color: #3a2f28;
}

.modal__close {
    position: absolute;
    top: 1rem;
    right: 1rem;
    border: none;
    background: var(--color-muted);
    border-radius: 50%;
    width: 32px;
    height: 32px;
    cursor: pointer;
}

.modal__nav ul {
    display: grid;
    gap: var(--spacing-sm);
}

.modal__menu-logo {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: var(--spacing-md);
}

.modal__menu-logo img {
    width: min(100%, var(--menu-logo-max-width, 180px));
    max-height: var(--menu-logo-max-height, 90px);
    height: auto;
    object-fit: contain;
}

.modal--menu .modal__nav a {
    font-size: var(--menu-link-font-size, 18px);
    font-weight: 600;
    letter-spacing: 0.04em;
}

.modal--menu .modal__content {
    width: min(90%, 420px);
    transform-origin: var(--menu-origin-x, 100%) var(--menu-origin-y, 0%);
    opacity: 0;
    transform: translate3d(0, -24px, 0) scale(0.4) rotate(-8deg);
    filter: blur(16px);
    box-shadow: 0 30px 80px rgba(12, 9, 9, 0.35);
    transition: opacity 0.2s ease;
    will-change: transform, opacity, filter;
}

.modal--menu.is-open.is-animating .modal__content {
    animation: menuImpactIn 0.75s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

.modal--menu.is-open.is-closing .modal__content {
    animation: menuImpactOut 0.55s cubic-bezier(0.55, 0, 0.4, 1) forwards;
}

@keyframes menuImpactIn {
    0% {
        opacity: 0;
        transform: translate3d(0, -30px, 0) scale(0.35) rotate(-10deg);
        filter: blur(18px);
    }
    55% {
        opacity: 1;
        transform: translate3d(0, 6px, 0) scale(1.08) rotate(1deg);
        filter: blur(2px);
    }
    75% {
        transform: translate3d(0, -2px, 0) scale(0.98) rotate(-0.5deg);
        filter: blur(0);
    }
    100% {
        opacity: 1;
        transform: translate3d(0, 0, 0) scale(1) rotate(0deg);
        filter: blur(0);
    }
}

@keyframes menuImpactOut {
    0% {
        opacity: 1;
        transform: translate3d(0, 0, 0) scale(1) rotate(0deg);
        filter: blur(0);
    }
    100% {
        opacity: 0;
        transform: translate3d(0, -20px, 0) scale(0.45) rotate(-8deg);
        filter: blur(12px);
    }
}

.modal__gallery {
    display: grid;
    gap: var(--spacing-md);
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    margin-top: var(--spacing-md);
}

.modal__media img,
.modal__media iframe {
    width: 100%;
    border-radius: var(--radius-sm);
}

.modal__list {
    display: grid;
    gap: var(--spacing-lg);
    margin-top: var(--spacing-md);
}

.modal__client {
    display: grid;
    gap: var(--spacing-md);
    grid-template-columns: auto 1fr;
    align-items: center;
}

.modal__client-logo {
    display: block;
}

.modal__client-logo img {
    display: block;
    max-width: 100%;
    border-radius: var(--radius-sm);
}

.reveal {
    opacity: 0;
    transform: translateY(20px);
    transition: opacity var(--transition), transform var(--transition);
    transition-delay: var(--reveal-delay, 0ms);
}

.reveal.is-visible {
    opacity: 1;
    transform: translateY(0);
}

.hero__cta {
    position: absolute;
    right: var(--spacing-lg);
    bottom: var(--spacing-lg);
    z-index: 2;
    opacity: 0;
    transform: translateY(20px) scale(0.85);
    filter: drop-shadow(0 18px 40px rgba(15, 10, 10, 0.28));
    margin: var(--cta-margin, 0);
    --cta-animation: heroCtaEntrance 1.1s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

.hero__cta.is-visible {
    animation: var(--cta-animation);
}

.hero__cta[data-cta-animation='fade'] {
    --cta-animation: heroCtaFade 0.8s ease forwards;
}

.hero__cta[data-cta-animation='slide'] {
    --cta-animation: heroCtaSlide 0.9s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

.hero__cta[data-cta-animation='zoom'] {
    --cta-animation: heroCtaZoom 0.9s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

.hero__cta[data-cta-animation='none'] {
    --cta-animation: none;
}

.hero__cta[data-cta-animation='none'].is-visible {
    opacity: 1;
    transform: none;
}

.hero__cta-button {
    font-size: var(--cta-font-size, 1rem);
    padding: var(--cta-padding, 0.95rem 2.1rem);
    box-shadow: 0 12px 30px rgba(201, 162, 125, 0.45);
    background: var(--cta-bg-color, var(--color-accent));
    color: var(--cta-text-color, #fff);
    border-width: var(--cta-border-width, 0);
    border-style: var(--cta-border-style, solid);
    border-color: var(--cta-border-color, transparent);
    border-radius: var(--cta-border-radius, 999px);
}

.hero__cta-button:hover,
.hero__cta-button:focus-visible {
    background: var(--cta-hover-bg-color, var(--cta-bg-color, var(--color-accent)));
    color: var(--cta-hover-text-color, var(--cta-text-color, #fff));
    border-color: var(--cta-hover-border-color, var(--cta-border-color, transparent));
}

@keyframes heroCtaEntrance {
    0% {
        opacity: 0;
        transform: translateY(24px) scale(0.75) rotate(-2deg);
        box-shadow: 0 0 0 rgba(201, 162, 125, 0.2);
    }
    55% {
        opacity: 1;
        transform: translateY(-6px) scale(1.05) rotate(1deg);
    }
    80% {
        transform: translateY(2px) scale(0.98);
    }
    100% {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

@keyframes heroCtaFade {
    from {
        opacity: 0;
        transform: translateY(8px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes heroCtaSlide {
    from {
        opacity: 0;
        transform: translateX(24px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes heroCtaZoom {
    from {
        opacity: 0;
        transform: scale(0.85);
    }
    to {
        opacity: 1;
        transform: scale(1);
    }
}

@media (max-width: 900px) {
    :root {
        --burger-box-size: calc((var(--burger-size, 26px) + 1.4rem) * 0.7);
    }

    .modal__content--domain {
        width: 100vw;
        max-width: 100vw;
        max-height: 100vh;
        min-height: 100vh;
        border-radius: 0;
        padding: var(--spacing-lg);
    }

    .domain-modal__details--with-subnav {
        grid-template-columns: 1fr;
    }

    .hero__slide {
        padding: var(--spacing-lg);
        align-items: flex-end;
    }

    .hero__video {
        padding: var(--spacing-lg);
        align-items: flex-end;
    }

    .section__heading {
        flex-direction: column;
        align-items: flex-start;
    }

    .header__inner {
        flex-direction: row;
        justify-content: flex-start;
        gap: var(--spacing-sm);
    }

    .header__inner--full {
        padding: var(--spacing-md) 0;
    }

    .header__logo-container {
        width: calc(100vw * 2 / 3);
        max-width: calc(100vw * 2 / 3);
        margin-left: var(--spacing-md);
        justify-content: flex-start;
    }

    .header__logo {
        width: 100%;
        max-width: 100%;
        height: auto;
        max-height: none;
    }

    .language-toggle {
        position: absolute;
        left: calc(var(--burger-left-edge, 0px) + (var(--burger-width, 0px) / 2) - (var(--language-toggle-width, 0px) / 2));
        right: auto;
        top: calc(var(--burger-bottom, 0px) + 10px);
    }

    .burger {
        top: var(--spacing-md);
        right: var(--spacing-md);
        transform-origin: top right;
    }

    .site-header.is-scrolled .burger {
        transform: scale(0.5);
    }

    .hero--overlay-mobile-hidden .hero__overlay {
        display: none;
    }

    .hero__cta {
        right: var(--spacing-md);
        bottom: var(--spacing-md);
    }

    .hero__overlay {
        position: relative;
        left: auto;
        bottom: auto;
    }

    .gallery-marquee__item {
        flex-basis: clamp(150px, calc(var(--gallery-tile-height, 220px) * var(--tile-ratio, 1.2)), 78vw);
    }

    .gallery-lightbox__figure img {
        border-radius: 22px;
    }
}
