body.bw-niche-drone-fotografie-limburg {
    --df-bg: #f4efe6;
    --df-surface: rgba(255, 248, 240, 0.82);
    --df-ink: #13222d;
    --df-muted: #586977;
    --df-accent: #df8f2f;
    --df-accent-soft: #f2d4a8;
    --df-deep: #183d4f;
    --df-night: #102432;
    --df-line: rgba(19, 34, 45, 0.14);
}

body.bw-niche-drone-fotografie-limburg .bw-shell {
    background:
        radial-gradient(circle at top right, rgba(223, 143, 47, 0.18), transparent 30%),
        radial-gradient(circle at top left, rgba(24, 61, 79, 0.1), transparent 34%),
        linear-gradient(180deg, #f8f4ee 0%, #f1ece3 52%, #efe8de 100%);
}

body.bw-niche-drone-fotografie-limburg .bw-main-wrap {
    background: transparent;
}

body.bw-niche-drone-fotografie-limburg .site-header-main,
body.bw-niche-drone-fotografie-limburg .bw-footer-wrap,
body.bw-niche-drone-fotografie-limburg .bw-sidebar .bw-widget,
body.bw-niche-drone-fotografie-limburg .bw-layout {
    border-color: var(--df-line);
}

body.bw-niche-drone-fotografie-limburg .site-title a,
body.bw-niche-drone-fotografie-limburg .entry-content a,
body.bw-niche-drone-fotografie-limburg .bw-sidebar a,
body.bw-niche-drone-fotografie-limburg .bw-footer-wrap a {
    color: var(--df-deep);
}

body.bw-niche-drone-fotografie-limburg .site-title a:hover,
body.bw-niche-drone-fotografie-limburg .entry-content a:hover,
body.bw-niche-drone-fotografie-limburg .bw-sidebar a:hover,
body.bw-niche-drone-fotografie-limburg .bw-footer-wrap a:hover {
    color: var(--df-accent);
}

body.bw-niche-drone-fotografie-limburg .entry-content,
body.bw-niche-drone-fotografie-limburg .bw-sidebar,
body.bw-niche-drone-fotografie-limburg .bw-footer-wrap {
    color: var(--df-ink);
}

body.bw-niche-drone-fotografie-limburg .entry-content h1,
body.bw-niche-drone-fotografie-limburg .entry-content h2,
body.bw-niche-drone-fotografie-limburg .entry-content h3 {
    color: var(--df-night);
}

.df-hero {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(280px, 0.95fr);
    gap: clamp(28px, 4vw, 56px);
    margin: clamp(18px, 2vw, 28px) calc(50% - 50vw) clamp(14px, 3vw, 22px);
    padding: clamp(34px, 5vw, 78px) min(7vw, 72px) clamp(36px, 5vw, 72px);
    background:
        linear-gradient(135deg, rgba(255, 207, 147, 0.35), transparent 30%),
        linear-gradient(180deg, #173545 0%, #1f5063 38%, #d17d29 100%);
    color: #f9f2eb;
    overflow: hidden;
}

.df-hero::before,
.df-hero::after {
    content: "";
    position: absolute;
    inset: auto auto -18% -8%;
    width: 62%;
    aspect-ratio: 1;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(255, 224, 173, 0.22), transparent 70%);
    pointer-events: none;
}

.df-hero::after {
    inset: -10% -8% auto auto;
    width: 52%;
    background: radial-gradient(circle, rgba(255, 255, 255, 0.18), transparent 72%);
}

.df-hero-copy,
.df-hero-visual {
    position: relative;
    z-index: 1;
}

.df-kicker,
.df-visual-kicker,
.df-section-kicker,
.df-mini-kicker {
    margin: 0 0 14px;
    font-family: "Bricolage Grotesque", sans-serif;
    font-size: 0.85rem;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
}

.df-brand {
    margin: 0;
    font-family: "Bricolage Grotesque", sans-serif;
    font-size: clamp(2.4rem, 6vw, 5.6rem);
    font-weight: 800;
    line-height: 0.94;
    letter-spacing: -0.06em;
    text-wrap: balance;
}

.df-hero h1 {
    margin: 18px 0 0;
    max-width: 12ch;
    font-family: "Fraunces", serif;
    font-size: clamp(2.15rem, 4vw, 4.45rem);
    line-height: 0.97;
    color: #fff7f0;
    text-wrap: balance;
}

.df-lead {
    margin: 18px 0 0;
    max-width: 39rem;
    font-size: clamp(1rem, 1.45vw, 1.22rem);
    line-height: 1.65;
    color: rgba(249, 242, 235, 0.92);
}

.df-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    margin-top: 26px;
}

.df-actions .bw-btn {
    min-width: 11rem;
}

.df-proof {
    display: flex;
    flex-wrap: wrap;
    gap: 12px 18px;
    margin: 24px 0 0;
    padding: 0;
    list-style: none;
}

.df-proof li {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-size: 0.98rem;
    color: rgba(255, 246, 237, 0.86);
}

.df-proof li::before {
    content: "";
    width: 9px;
    height: 9px;
    border-radius: 50%;
    background: linear-gradient(180deg, #ffe6bf, #df8f2f);
}

.df-hero-visual {
    align-self: end;
}

.df-hero-visual svg {
    display: block;
    width: min(100%, 560px);
    height: auto;
    margin-left: auto;
    filter: drop-shadow(0 22px 36px rgba(7, 18, 27, 0.28));
    animation: df-drift 18s ease-in-out infinite;
}

.df-marquee {
    display: flex;
    flex-wrap: wrap;
    gap: 14px 20px;
    margin: 0 calc(50% - 50vw) clamp(26px, 4vw, 36px);
    padding: 14px min(7vw, 72px);
    border-top: 1px solid rgba(255, 255, 255, 0.18);
    background: rgba(13, 29, 39, 0.92);
    color: rgba(255, 246, 237, 0.78);
    font-family: "Bricolage Grotesque", sans-serif;
    font-size: 0.88rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.df-editorial-flow {
    display: grid;
    gap: clamp(30px, 4vw, 48px);
}

.df-section {
    padding: clamp(24px, 3vw, 34px) 0;
    border-top: 1px solid var(--df-line);
}

.df-section-head {
    max-width: 46rem;
    margin-bottom: 18px;
}

.df-section-head h2 {
    margin: 0;
    font-family: "Fraunces", serif;
    font-size: clamp(1.8rem, 2.8vw, 3.1rem);
    line-height: 1.02;
    text-wrap: balance;
}

.df-section-head p,
.df-copy p,
.df-process-intro,
.df-quote,
.df-final-copy p {
    margin: 0;
    font-size: 1.04rem;
    line-height: 1.75;
    color: var(--df-muted);
}

.df-section-head p + p,
.df-copy p + p,
.df-final-copy p + p,
.df-process-intro + .df-process-list {
    margin-top: 14px;
}

.df-service-list {
    border-top: 1px solid var(--df-line);
}

.df-service-row {
    display: grid;
    grid-template-columns: minmax(150px, 0.42fr) minmax(0, 1fr);
    gap: 18px 28px;
    align-items: start;
    padding: 22px 0;
    border-bottom: 1px solid var(--df-line);
}

.df-service-label {
    font-family: "Bricolage Grotesque", sans-serif;
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--df-accent);
}

.df-service-copy h3 {
    margin: 0;
    font-family: "Fraunces", serif;
    font-size: clamp(1.35rem, 1.9vw, 1.8rem);
}

.df-service-copy p {
    margin: 10px 0 0;
    color: var(--df-muted);
    line-height: 1.72;
}

.df-service-link {
    display: inline-block;
    margin-top: 14px;
    font-family: "Bricolage Grotesque", sans-serif;
    font-weight: 700;
    text-decoration: none;
    transition: transform 180ms ease, color 180ms ease;
}

.df-service-link:hover {
    transform: translateX(4px);
}

.df-duo {
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(280px, 0.92fr);
    gap: 26px 34px;
    align-items: start;
}

.df-quote {
    padding-left: 18px;
    border-left: 3px solid rgba(223, 143, 47, 0.58);
}

.df-location-ribbon {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin: 20px 0 0;
    padding: 0;
    list-style: none;
}

.df-location-ribbon li {
    padding: 10px 14px;
    border: 1px solid rgba(24, 61, 79, 0.16);
    background: rgba(255, 255, 255, 0.54);
    font-size: 0.94rem;
    color: var(--df-deep);
}

.df-process-list {
    counter-reset: df-process;
    display: grid;
    gap: 14px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.df-process-list li {
    display: grid;
    grid-template-columns: 54px minmax(0, 1fr);
    gap: 14px;
    padding: 14px 0;
    border-top: 1px solid var(--df-line);
}

.df-process-list li::before {
    counter-increment: df-process;
    content: "0" counter(df-process);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 54px;
    height: 54px;
    border-radius: 50%;
    background: linear-gradient(180deg, rgba(223, 143, 47, 0.18), rgba(24, 61, 79, 0.12));
    font-family: "Bricolage Grotesque", sans-serif;
    font-size: 0.88rem;
    font-weight: 800;
    color: var(--df-night);
}

.df-process-list strong {
    display: block;
    margin-bottom: 6px;
    font-family: "Fraunces", serif;
    font-size: 1.05rem;
    color: var(--df-night);
}

.df-signal-band {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px 24px;
    padding: 24px 0 0;
}

.df-signal-band h3 {
    margin: 0 0 8px;
    font-family: "Fraunces", serif;
    font-size: 1.1rem;
}

.df-signal-band p {
    margin: 0;
    color: var(--df-muted);
    line-height: 1.7;
}

.df-final-cta {
    margin: clamp(20px, 3vw, 30px) calc(50% - 50vw) 0;
    padding: clamp(32px, 5vw, 56px) min(7vw, 72px);
    background:
        linear-gradient(135deg, rgba(16, 36, 50, 0.98), rgba(24, 61, 79, 0.96)),
        linear-gradient(180deg, rgba(223, 143, 47, 0.12), transparent);
    color: #f7efe6;
}

.df-final-wrap {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 24px 32px;
    align-items: end;
}

.df-final-copy h2 {
    margin: 0 0 12px;
    color: #fff4e8;
    font-family: "Fraunces", serif;
    font-size: clamp(1.9rem, 3vw, 3rem);
}

.df-final-copy p {
    color: rgba(247, 239, 230, 0.82);
}

.df-final-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    justify-content: flex-end;
}

.df-page-intro {
    max-width: 50rem;
}

.df-page-intro h1 {
    margin: 0;
    font-family: "Fraunces", serif;
    font-size: clamp(2rem, 3vw, 3.3rem);
    line-height: 1;
    text-wrap: balance;
}

.df-page-intro p {
    margin: 12px 0 0;
    color: var(--df-muted);
    line-height: 1.72;
}

.bw-dronefotografie-wijzer {
    margin: clamp(22px, 4vw, 34px) 0;
    padding: clamp(24px, 3vw, 34px);
    background:
        linear-gradient(135deg, rgba(255, 244, 230, 0.92), rgba(246, 236, 223, 0.72)),
        linear-gradient(180deg, rgba(24, 61, 79, 0.04), rgba(223, 143, 47, 0.06));
    border: 1px solid rgba(24, 61, 79, 0.14);
}

.bw-dflw-intro h2 {
    margin: 0;
    font-family: "Fraunces", serif;
    font-size: clamp(1.7rem, 2.6vw, 2.5rem);
}

.bw-dflw-intro p:last-child {
    margin: 12px 0 0;
    color: var(--df-muted);
}

.bw-dflw-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
    margin-top: 22px;
}

.bw-dflw-fieldset {
    margin: 0;
    padding: 18px;
    border: 1px solid rgba(24, 61, 79, 0.12);
    background: rgba(255, 255, 255, 0.64);
}

.bw-dflw-fieldset legend {
    padding: 0 8px;
    font-family: "Bricolage Grotesque", sans-serif;
    font-size: 0.86rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--df-deep);
}

.bw-dflw-fieldset label {
    display: flex;
    gap: 10px;
    align-items: flex-start;
    margin-top: 12px;
    color: var(--df-ink);
    line-height: 1.55;
}

.bw-dflw-actions {
    margin-top: 18px;
}

.bw-dflw-result {
    margin-top: 18px;
    padding: 22px;
    background: linear-gradient(180deg, rgba(16, 36, 50, 0.98), rgba(24, 61, 79, 0.95));
    color: #f7efe6;
}

.bw-dflw-result-kicker,
.bw-dflw-eyebrow {
    margin: 0 0 10px;
    font-family: "Bricolage Grotesque", sans-serif;
    font-size: 0.84rem;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: rgba(223, 143, 47, 0.92);
}

.bw-dflw-result-title {
    margin: 0;
    color: #fff5ea;
    font-family: "Fraunces", serif;
    font-size: clamp(1.45rem, 2.4vw, 2rem);
}

.bw-dflw-result-summary,
.bw-dflw-result-note {
    color: rgba(247, 239, 230, 0.86);
    line-height: 1.72;
}

.bw-dflw-result-steps {
    margin: 16px 0 0;
    padding-left: 20px;
}

.bw-dflw-result-steps li + li {
    margin-top: 10px;
}

.bw-dflw-result-steps a {
    color: #ffd79f;
    font-weight: 700;
}

.bw-dflw-result-steps a:hover {
    color: #fff1da;
}

@keyframes df-fade-up {
    from {
        opacity: 0;
        transform: translateY(18px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes df-drift {
    0%,
    100% {
        transform: translate3d(0, 0, 0);
    }
    50% {
        transform: translate3d(0, -10px, 0);
    }
}

.df-hero-copy > * {
    animation: df-fade-up 640ms ease both;
}

.df-hero-copy > *:nth-child(2) {
    animation-delay: 70ms;
}

.df-hero-copy > *:nth-child(3) {
    animation-delay: 140ms;
}

.df-hero-copy > *:nth-child(4) {
    animation-delay: 210ms;
}

.df-hero-copy > *:nth-child(5) {
    animation-delay: 280ms;
}

@media (max-width: 980px) {
    .df-hero,
    .df-duo,
    .df-final-wrap,
    .bw-dflw-grid,
    .df-signal-band {
        grid-template-columns: 1fr;
    }

    .df-final-actions {
        justify-content: flex-start;
    }
}

@media (max-width: 720px) {
    .df-hero,
    .df-marquee,
    .df-final-cta {
        margin-inline: calc(50% - 50vw);
        padding-inline: 22px;
    }

    .df-hero {
        gap: 22px;
        padding-top: 28px;
        padding-bottom: 30px;
    }

    .df-brand {
        font-size: 2.55rem;
    }

    .df-hero h1 {
        max-width: none;
        font-size: 2.2rem;
    }

    .df-proof {
        gap: 10px 14px;
    }

    .df-service-row,
    .df-process-list li {
        grid-template-columns: 1fr;
    }

    .df-process-list li::before {
        width: 42px;
        height: 42px;
    }

    .bw-dronefotografie-wijzer {
        padding: 18px;
    }

    .bw-dflw-fieldset {
        padding: 14px;
    }
}

@media (prefers-reduced-motion: reduce) {
    .df-hero-copy > *,
    .df-hero-visual svg,
    .df-service-link {
        animation: none !important;
        transition: none !important;
    }
}
