
:root {
    --bg: white;
    --surface: oklch(0.95 0.008 255);
    --surface-strong: oklch(0.92 0.01 255);
    --text: oklch(0.28 0.02 258);
    --text-soft: oklch(0.4 0.018 258);
    --accent: oklch(0.31 0.07 262);
    --accent-strong: oklch(0.24 0.08 262);
    --line: oklch(0.84 0.01 255);
    --shadow-sm: 0 8px 24px color-mix(in oklch, var(--accent-strong) 12%, transparent);
    --shadow-md: 0 16px 44px color-mix(in oklch, var(--accent-strong) 18%, transparent);
    --shadow-lg: 0 26px 70px color-mix(in oklch, var(--accent-strong) 26%, transparent);

    --space-2xs: 0.25rem;
    --space-xs: 0.5rem;
    --space-sm: 0.75rem;
    --space-md: 1rem;
    --space-lg: 1.5rem;
    --space-xl: 2rem;
    --space-2xl: 3rem;
    --space-3xl: 4rem;

    --cc-primary-color: oklch(0.24 0.08 262);
    --cc-btn-primary-bg: oklch(0.31 0.07 262);
    --cc-btn-primary-color: #fff;
    --cc-btn-primary-border-color: var(--cc-btn-primary-bg);
    --cc-modal-border-radius: 0;
    --cc-btn-border-radius: 0;
}

*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;]
    overflow-x: hidden;
}

body {
    margin: 0;
    font-family: Verdana, Geneva, Tahoma, sans-serif;
    color: var(--text);
    background: var(--bg);
    line-height: 1.6;
    overflow-x: hidden;
}

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

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

/* Table - default */
table {
    width: 100%;
    margin-bottom: var(--space-lg);
    border-collapse: collapse;
    box-shadow: var(--shadow-sm);
}
table th, table td {
    padding: .5rem;
    background: var(--surface);
    border: 1px solid var(--line);
}

.nav {
    margin-top: 0;
    margin-bottom: 0;
    padding-left: 0;
    list-style: none;
}

.container {
    width: min(1300px, calc(100% - 2rem));
    margin: 0 auto;
}

.h-container {
    display: grid;
    grid-template-columns: 1fr;
    align-items: center;
    gap: var(--space-lg);
    width: min(1300px, calc(100% - 2rem));
    margin: 0 auto;
}

.feature-breakout {
    overflow: visible;
}

.feature-visual {
    position: relative;
    width: min(760px, 96vw);
    margin-inline: auto;
    isolation: isolate;
}

.feature-visual .section-img {
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    position: relative;
    z-index: 1;
    transform: translateX(clamp(-1.5rem, -2.5vw, -0.4rem));
    border: 1px solid color-mix(in oklch, var(--line) 78%, var(--accent) 22%);
    box-shadow: var(--shadow-lg);
}

.feature-copy {
    display: grid;
    gap: var(--space-lg);
}

.feature-copy > h2 {
    margin-bottom: 0;
}

.feature-ornament {
    position: absolute;
    pointer-events: none;
}

.feature-ornament-grid {
    right: clamp(-1.5rem, -2vw, -0.5rem);
    bottom: clamp(-1.75rem, -2.5vw, -0.65rem);
    z-index: 0;
    width: clamp(84px, 12vw, 142px);
    aspect-ratio: 1 / 1;
    background:
        linear-gradient(
            180deg,
            color-mix(in oklch, var(--surface) 8%, transparent),
            transparent 70%
        ),
        repeating-linear-gradient(
            0deg,
            color-mix(in oklch, var(--accent) 28%, transparent) 0 1px,
            transparent 1px 14px
        ),
        repeating-linear-gradient(
            90deg,
            color-mix(in oklch, var(--accent) 24%, transparent) 0 1px,
            transparent 1px 14px
        );
    border-radius: 0.2rem;
    opacity: 0.8;
}

.feature-ornament-angle {
    top: 0;
    left: clamp(0.2rem, 2.5vw, 1.6rem);
    z-index: 2;
    width: clamp(54px, 8vw, 98px);
    aspect-ratio: 1 / 1;
    border: none;
    border-radius: 999px;
    background-image: radial-gradient(
        circle,
        color-mix(in oklch, var(--accent) 42%, transparent) 0 1.6px,
        transparent 1.6px
    );
    background-size: 12px 12px;
    transform: translate(-22%, -22%);
    opacity: 0.72;
}

.section-ornamented {
    position: relative;
    overflow: visible;
    isolation: isolate;
}

.section-ornamented > :not(.feature-ornament) {
    position: relative;
    z-index: 1;
}

.section-ornamented > .feature-ornament {
    z-index: 0;
    opacity: 0.78;
}

.section-ornamented > .feature-ornament-grid {
    top: clamp(0.45rem, 1.4vw, 1.15rem);
    right: clamp(0.35rem, 1.8vw, 1.45rem);
    bottom: auto;
    width: clamp(64px, 9vw, 108px);
}

.section-ornamented > .feature-ornament-angle {
    top: clamp(0.75rem, 2vw, 1.4rem);
    left: clamp(0.25rem, 1.5vw, 1.2rem);
    bottom: auto;
    width: clamp(42px, 6vw, 68px);
    z-index: 0;
    transform: translate(-20%, -20%);
}

.ornament-random-1 > .feature-ornament-grid {
    top: auto;
    right: auto;
    bottom: clamp(0.4rem, 1.6vw, 1.2rem);
    left: clamp(0.45rem, 1.7vw, 1.35rem);
    width: clamp(70px, 9.2vw, 124px);
    opacity: 0.62;
    transform: rotate(-10deg);
}

.ornament-random-1 > .feature-ornament-angle {
    left: auto;
    right: clamp(0.5rem, 1.8vw, 1.55rem);
    transform: translate(40%, -40%) rotate(34deg);
}

.ornament-random-2 > .feature-ornament-grid {
    top: clamp(1.2rem, 3vw, 2.2rem);
    right: clamp(-0.65rem, 1vw, 0.45rem);
    width: clamp(56px, 7.2vw, 92px);
    opacity: 0.55;
    transform: rotate(7deg);
}

.ornament-random-2 > .feature-ornament-angle {
    top: auto;
    bottom: clamp(0.7rem, 2vw, 1.6rem);
    left: clamp(0.35rem, 1.6vw, 1.25rem);
    transform: translate(-34%, 40%) rotate(58deg);
}

.ornament-random-3 > .feature-ornament-grid {
    top: auto;
    right: clamp(0.9rem, 3vw, 2.6rem);
    bottom: clamp(0.2rem, 0.9vw, 0.9rem);
    width: clamp(60px, 8.8vw, 98px);
    opacity: 0.48;
    transform: rotate(11deg);
}

.ornament-random-3 > .feature-ornament-angle {
    top: clamp(1.1rem, 2.6vw, 2rem);
    left: clamp(0.25rem, 1.5vw, 1rem);
    width: clamp(46px, 5.2vw, 64px);
    transform: translate(-40%, -36%) rotate(23deg);
}

.ornament-random-4 > .feature-ornament-grid {
    top: clamp(0.15rem, 1vw, 0.85rem);
    right: auto;
    left: clamp(0.6rem, 2vw, 1.7rem);
    width: clamp(66px, 10vw, 112px);
    opacity: 0.65;
    transform: rotate(-5deg);
}

.ornament-random-4 > .feature-ornament-angle {
    left: auto;
    right: clamp(0.45rem, 1.6vw, 1.3rem);
    width: clamp(40px, 5.1vw, 60px);
    transform: translate(38%, -32%) rotate(50deg);
}

.ornament-random-5 > .feature-ornament-grid {
    top: auto;
    right: auto;
    bottom: clamp(0.55rem, 1.8vw, 1.35rem);
    left: clamp(0.65rem, 2.2vw, 1.7rem);
    width: clamp(62px, 9.8vw, 112px);
    opacity: 0.54;
    transform: rotate(-14deg);
}

.ornament-random-5 > .feature-ornament-angle {
    top: clamp(0.4rem, 1.7vw, 1.2rem);
    left: auto;
    right: clamp(0.6rem, 1.9vw, 1.45rem);
    width: clamp(44px, 5.4vw, 64px);
    transform: translate(36%, -32%) rotate(18deg);
}

.about-grid {
    display: grid;
    gap: var(--space-lg);
}

.about-photo {
    margin: 0;
    background: var(--surface);
    border: 1px solid var(--line);
    box-shadow: var(--shadow-md);
}

.about-photo img {
    width: 100%;
    aspect-ratio: 16 / 10;
    object-fit: cover;
}

.about-body {
    display: grid;
    gap: var(--space-md);
    align-content: start;
}

.about-body p {
    max-width: 64ch;
}

.section {
    padding: clamp(2.5rem, 4vw, 5rem) 0;
}

h1,
h2,
h3,
.eyebrow,
.btn,
.main-nav,
.site-footer {
    font-family: "Saira", Verdana, sans-serif;
}

h1 {
    margin: 0;
    font-size: clamp(2rem, 5.5vw, 4.2rem);
    line-height: 1.05;
    max-width: 20ch;
}

h2 {
    margin: 0 0 var(--space-xl);
    font-size: clamp(1.6rem, 3.8vw, 2.6rem);
    line-height: 1.15;
}
h2::after {
    content: "";
    display: block;
    width: 100px;
    height: 6px;
    clip-path: polygon(0% 0%, 100% 0%, 90% 100%, 0% 100%);
    background: var(--accent);
    margin-top: 10px;
}

h3 {
    margin: 0 0 var(--space-sm);
    font-size: clamp(1.2rem, 2.4vw, 1.6rem);
    line-height: 1.2;
}

.item-head {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    margin-bottom: var(--space-sm);
}

.item-head h3 {
    margin: 0;
}

.item-icon {
    width: 1.4rem;
    height: 1.4rem;
    flex: 0 0 auto;
}

p {
    margin: 0;
    max-width: 72ch;
}

.site-header {
    position: fixed;
    width: 100%;
    top: 0;
    z-index: 40;
    background-image: linear-gradient(to bottom, var(--accent), transparent);
    padding: var(--space-md) 0;
    transition: background-color 220ms ease, background-image 220ms ease;

}
.site-header.scrolled {
    background-color: var(--accent);
}

.site-header .container {
    width: min(1300px, calc(100% - 2rem));
    display: grid;
    grid-template-columns: auto auto;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-md);
    color: white;
}

.brand img {
    height: 50px;
    width: auto;
}

.menu-toggle {
    display: inline-flex;
    flex-direction: column;
    gap: 0.28rem;
    justify-self: end;
    align-items: center;
    font: inherit;
    border: none;
    background: transparent;
    color: white;
    padding: 0.55rem 0.65rem;
    cursor: pointer;
}

.menu-toggle-bar {
    display: block;
    width: 1.3rem;
    height: 2px;
    background: white;
}

.main-nav {
    display: none;
    grid-column: 1 / -1;
    flex-direction: column;
    /*align-items: stretch;
    gap: var(--space-xs);*/
    padding: 0;
    /*background: var(--accent);
    border: 1px solid color-mix(in oklch, white 16%, transparent);
    border-radius: 0;*/
    font-weight: 600;
    font-size: 1rem;
    letter-spacing: 0.01em;
}


.main-nav.is-open {
    display: flex;
}

.main-nav.is-open .nav {
    display: flex;
    grid-column: 1 / -1;
    flex-direction: column;
    align-items: stretch;
    gap: var(--space-xs);
    background: var(--accent);
    border: 1px solid color-mix(in oklch, white 16%, transparent);
    border-radius: 0;
}

.main-nav.is-open a {
    display: block;
}

.main-nav a {
    position: relative;
    padding: var(--space-xs) var(--space-sm);
}

.main-nav a::after {
    content: "";
    position: absolute;
    inset: auto 0 -0.1rem;
    height: 2px;
    background: white;
    transform: scaleX(0);
    transform-origin: right;
    transition: transform 220ms ease;
}

.main-nav a:hover::after,
.main-nav a:focus-visible::after {
    transform: scaleX(1);
    transform-origin: left;
}

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.8rem 1.15rem;
    font-weight: 700;
    letter-spacing: 0.01em;
    text-transform: uppercase;
    font-size: 0.95rem;
    transition:
        transform 220ms ease,
        background-color 220ms ease,
        color 220ms ease,
        border-color 220ms ease;
}

.btn-primary {
    background: oklch(0.87 0.03 255);
    color: var(--accent-strong);
    border: 2px solid oklch(0.87 0.03 255);
}

.btn-primary:hover,
.btn-primary:focus-visible {
    background: oklch(0.96 0.018 255);
}

.btn-secondary {
    border: 2px solid oklch(0.95 0.015 255);
    color: oklch(0.96 0.01 255);
}

.btn-secondary:hover,
.btn-secondary:focus-visible {
    background: color-mix(in oklch, oklch(0.95 0.015 255) 22%, transparent);
}

.main-nav .nav-contact a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    letter-spacing: 0.01em;
    text-transform: uppercase;
    font-size: 0.95rem;
    transition: transform 220ms ease, background-color 220ms ease, color 220ms ease, border-color 220ms ease;
    background: oklch(0.87 0.03 255);
    color: var(--accent-strong);
    border: 2px solid oklch(0.87 0.03 255);
    width: 100%;
}
.main-nav .nav-contact a:hover,
.main-nav .nav-contact a:focus-visible {
    background: oklch(0.96 0.018 255);
}
.main-nav .nav-contact a::after {
    content: none;
}
/* https://picsum.photos/seed/sts-hero-industrial/2000/1200 */
.hero {
    position: relative;
    overflow: hidden;
    min-height: clamp(520px, 80vh, 800px);
    display: grid;
    align-items: end;
    background-image: url("../img/hero.webp");
    background-size: cover;
    background-position: center;
    box-shadow: var(--shadow-lg);
}

.hero::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 78% 12%, color-mix(in oklch, oklch(0.96 0.01 255) 14%, transparent), transparent 42%),
        linear-gradient(to top, color-mix(in oklch, var(--accent-strong) 24%, transparent), transparent 60%);
    pointer-events: none;
}

.hero-overlay {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(95deg, color-mix(in oklch, var(--accent-strong) 82%, transparent) 0%, transparent 72%),
        linear-gradient(to top, color-mix(in oklch, var(--text) 85%, transparent), transparent 60%);
}

.hero-content {
    position: relative;
    color: oklch(0.95 0.01 255);
    display: grid;
    gap: var(--space-lg);
    text-shadow: 0 8px 24px color-mix(in oklch, black 45%, transparent);
}

.hero-content p {
    font-size: clamp(1rem, 1.8vw, 1.2rem);
    max-width: 62ch;
}

.eyebrow {
    margin: 0;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    font-weight: 700;
    font-size: 0.88rem;
}

.hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-md);
}

.listing-hero {
    position: relative;
    overflow: hidden;
    min-height: clamp(460px, 68vh, 700px);
    display: grid;
    align-items: end;
    background-size: cover;
    background-position: center;
    box-shadow: var(--shadow-lg);
}

.listing-hero::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 78% 12%, color-mix(in oklch, oklch(0.96 0.01 255) 16%, transparent), transparent 45%),
        linear-gradient(to top, color-mix(in oklch, var(--accent-strong) 30%, transparent), transparent 62%);
    pointer-events: none;
}

.listing-hero-overlay {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(95deg, color-mix(in oklch, var(--accent-strong) 84%, transparent) 0%, transparent 72%),
        linear-gradient(to top, color-mix(in oklch, var(--text) 82%, transparent), transparent 56%);
}

.listing-hero-content {
    position: relative;
    color: oklch(0.95 0.01 255);
    display: grid;
    gap: var(--space-md);
    text-shadow: 0 8px 24px color-mix(in oklch, black 45%, transparent);
}

.listing-hero-content h1 {
    max-width: 18ch;
}

.listing-hero-content p {
    max-width: 62ch;
}

.listing-back-link {
    justify-self: start;
    font-weight: 700;
    font-family: "Saira", Verdana, sans-serif;
    color: oklch(0.96 0.01 255);
}

.listing-meta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-sm);
}

.listing-meta-item {
    margin: 0;
    min-width: min(190px, 100%);
    padding: var(--space-sm) var(--space-md);
    background: color-mix(in oklch, var(--accent) 62%, transparent);
    border: 1px solid color-mix(in oklch, white 28%, transparent);
    display: grid;
    gap: var(--space-2xs);
}

.listing-meta-item span {
    text-transform: uppercase;
    letter-spacing: 0.07em;
    font-size: 0.7rem;
    opacity: 0.9;
}

.listing-meta-item strong {
    font-size: 1rem;
}

.listing-detail-grid {
    display: grid;
    gap: var(--space-xl);
}

.listing-gallery {
    margin: 0;
    display: grid;
    gap: var(--space-sm);
}
.listing-gallery > figcaption {
    display: none;
}
.listing-video {
    width: 100%;
    min-height: 315px;
    max-height: 420px;
    height: 100%;
}

#listing-main-image {
    width: 100%;
    aspect-ratio: 16 / 10;
    object-fit: cover;
    border: 1px solid var(--line);
    box-shadow: var(--shadow-md);
}

#listing-main-caption {
    color: var(--text-soft);
}

.listing-thumbs {
    margin-top: var(--space-lg);
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: var(--space-sm);
}

.listing-thumb {
    border: 1px solid var(--line);
    padding: 0;
    background: var(--surface);
    cursor: pointer;
    transition: transform 220ms ease, box-shadow 220ms ease, border-color 220ms ease;
}

.listing-thumb img {
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
}

.listing-thumb:hover,
.listing-thumb:focus-visible,
.listing-thumb.is-active {
    border-color: color-mix(in oklch, var(--accent) 45%, var(--line));
    box-shadow: var(--shadow-sm);
}

.listing-summary {
    display: grid;
    gap: var(--space-md);
    align-content: start;
}

.listing-subheading {
    margin: 0;
    font-size: 1.05rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.listing-quick {
    display: grid;
    gap: var(--space-xs);
    padding: var(--space-lg);
    border: 1px solid var(--line);
    background: var(--surface);
    box-shadow: var(--shadow-sm);
}

.technical-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-lg);
}

.listing-summary .technical-grid {
    gap: var(--space-sm);
}

.technical-item {
    background: var(--surface);
    border: 1px solid var(--line);
    box-shadow: var(--shadow-sm);
    padding: var(--space-lg);
    display: grid;
    gap: var(--space-xs);
}
.technical-item.more-info {
    grid-column: span 2;
}

.technical-label {
    margin: 0;
    font-size: 0.74rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--text-soft);
}

.technical-value {
    margin: 0;
    font-family: "Saira", Verdana, sans-serif;
    font-weight: 600;
    font-size: 1.05rem;
    line-height: 1.35;
}

.section-soft {
    background: linear-gradient(180deg, var(--surface), color-mix(in oklch, var(--surface-strong) 70%, white 30%));
    box-shadow:
        inset 0 1px 0 color-mix(in oklch, white 55%, transparent),
        inset 0 -1px 0 color-mix(in oklch, var(--accent-strong) 14%, transparent);
}

.stat-strip,
.process-grid,
.info-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-lg);
}

.stat-card,
.process-step,
.info-card {
    background: var(--surface);
    border: 1px solid var(--line);
    padding: var(--space-xl);
    box-shadow: var(--shadow-sm);
    transition: transform 220ms ease, box-shadow 220ms ease;
}

.stat-card:hover,
.process-step:hover,
.info-card:hover,
.stat-card:focus-within,
.process-step:focus-within,
.info-card:focus-within {
    transform: translateY(-4px);
    box-shadow: var(--shadow-md);
}

.stat-value {
    font-family: "Saira", Verdana, sans-serif;
    font-size: clamp(1.8rem, 6vw, 2.6rem);
    line-height: 1.05;
    color: var(--accent-strong);
}

.stat-label {
    margin-top: var(--space-xs);
    color: var(--text-soft);
}

.usp-grid,
.category-grid,
.listing-grid,
.footer-grid,
.contact-grid {
    display: grid;
    gap: var(--space-lg);
    grid-template-columns: 1fr;
}

.usp-grid article,
.listing {
    background: var(--surface);
    border: 1px solid var(--line);
    box-shadow: var(--shadow-sm);
    display: flex;
    flex-direction: column;
    transition: transform 220ms ease, box-shadow 220ms ease;
}
.listing-last {
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 200px;
}

.usp-grid article {
    padding: var(--space-xl);
}

.usp-grid article:hover,
.listing:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-md);
}

.category-item {
    position: relative;
    overflow: hidden;
    min-height: 230px;
    box-shadow: var(--shadow-md);
}

.category-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: saturate(0.8) contrast(1.05);
    transition: transform 450ms ease;
}

.category-item span {
    position: absolute;
    left: var(--space-lg);
    bottom: var(--space-lg);
    background: color-mix(in oklch, var(--accent) 86%, transparent);
    color: oklch(0.96 0.01 255);
    padding: var(--space-xs) var(--space-sm);
    font-family: "Saira", Verdana, sans-serif;
    font-weight: 600;
    box-shadow: var(--shadow-sm);
}

.category-item:hover img,
.category-item:focus-visible img {
    transform: scale(1.05);
}

.listing img {
    width: 100%;
    aspect-ratio: 16 / 10;
    object-fit: cover;
}

.listing-body {
    padding: var(--space-lg);
    display: flex;
    flex-direction: column;
    gap: var(--space-xs);
    flex: 1;
    align-items: flex-start;
}

.listing-link {
    align-self: flex-start;
    margin-top: auto;
}

.badge {
    display: inline-block;
    justify-self: start;
    background: color-mix(in oklch, var(--accent) 78%, white 22%);
    color: oklch(0.97 0.01 255);
    padding: 0.2rem 0.55rem;
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    margin-bottom: var(--space-sm);
}

.price-note {
    margin-top: var(--space-lg);
    color: var(--text-soft);
    font-style: italic;
    float: right;
}
.t-margin-sm {
    margin-top: var(--space-sm);
}
.references {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-xl);
}

.reference-card {
    display: flex;
    justify-content: center;
    align-items: center;
    overflow: hidden;
    display: grid;
    padding: 10px;
    background: var(--surface);
    border: 1px solid var(--line);
    box-shadow: var(--shadow-sm);
    transition: transform 220ms ease, box-shadow 220ms ease;
}

.reference-card.reference-logo {
    padding: 10px;
    background: transparent;
    border: 0;
    box-shadow: none;
}

.reference-card img {
    width: 100%;
    height: 100px;
    object-fit: contain;
}

.reference-card span {
    padding: var(--space-sm) var(--space-md);
    font-weight: 600;
    font-family: "Saira", Verdana, sans-serif;
}

.reference-card:hover,
.reference-card:focus-visible {
    background: var(--surface-strong);
    transform: translateY(-4px);
    box-shadow: var(--shadow-md);
}

.reference-card.reference-logo:hover,
.reference-card.reference-logo:focus-visible {
    background: transparent;
    box-shadow: none;
}

.contact-block {
    background:
        linear-gradient(180deg, var(--surface), var(--surface-strong));
    background-size: cover;
    background-position: center;
    background-blend-mode: soft-light;
    box-shadow:
        inset 0 1px 0 color-mix(in oklch, white 50%, transparent),
        inset 0 -1px 0 color-mix(in oklch, var(--accent-strong) 16%, transparent);
}

.contact-content {
    display: grid;
    gap: var(--space-sm);
    font-size: 1rem;
    align-content: center;
}

.contact-content a {
    font-weight: 700;
    font-family: "Saira", Verdana, sans-serif;
}

.contact-map {
    width: 100%;
    height: 350px;
    margin-bottom: var(--space-md);
}

/* Page - default */
.page-default .hero {
    min-height: clamp(200px, 50vh, 450px);
}
.page-default .edit-content p {
    max-width: none;
    margin-bottom: var(--space-lg);
}
.page-default .edit-content p:last-of-type {
    margin-bottom: 0;
}
.page-default .edit-content .card-body {
    text-align: left;
}

/* Footer  */
.site-footer {
    background: var(--accent-strong);
    color: oklch(0.95 0.008 255);
    padding: 5rem 0 var(--space-lg);
}

.footer-top {
    display: grid;
    gap: var(--space-xl);
    padding-bottom: 5rem;
    border-bottom: 1px solid color-mix(in oklch, oklch(0.95 0.008 255) 20%, transparent);
}

.footer-brand {
    display: grid;
    gap: var(--space-md);
    max-width: 42ch;
}

.footer-brand img {
    width: min(170px, 30vw);
    height: auto;
}

.footer-brand p {
    color: color-mix(in oklch, oklch(0.95 0.008 255) 88%, var(--accent));
}

.footer-column {
    display: grid;
    gap: var(--space-sm);
}

.footer-heading {
    margin: 0;
    font-size: 1.02rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.footer-links {
    display: grid;
    gap: var(--space-xs);
}

.footer-links p {
    color: color-mix(in oklch, oklch(0.95 0.008 255) 85%, var(--accent));
}

.footer-bottom {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    gap: var(--space-sm);
    padding-top: var(--space-lg);
}

.footer-gdpr {
    font-weight: 600;
}

.site-footer a:hover,
.site-footer a:focus-visible {
    text-decoration: underline;
}

.copyright {
    margin: 0;
    font-family: Verdana, Geneva, Tahoma, sans-serif;
    font-size: 0.9rem;
}
.section-img {
    aspect-ratio: 1 / 1;
    object-fit: cover;
    width: 100%;
}
.contact-map iframe {
    width: 100%;
    height: 100%;
    border: none;
    box-shadow: var(--shadow-lg);
}

@media (max-width: 820px) {
    .feature-visual,
    .section-ornamented {
        overflow-x: hidden;
        overflow-y: visible;
    }


    .feature-visual .feature-ornament-grid {
        right: clamp(0.35rem, 2vw, 0.9rem);
        bottom: clamp(0.35rem, 2.2vw, 0.95rem);
        width: clamp(56px, 16vw, 84px);
        transform: rotate(-6deg);
    }

    .feature-visual .feature-ornament-angle {
        top: clamp(0.4rem, 1.8vw, 1rem);
        left: clamp(0.4rem, 1.8vw, 1rem);
        width: clamp(34px, 9vw, 52px);
        transform: rotate(45deg);
    }

    .section-ornamented.ornament-random-1 > .feature-ornament-grid {
        left: clamp(0.5rem, 2vw, 1rem);
        bottom: clamp(0.45rem, 2vw, 1rem);
        width: clamp(56px, 14vw, 82px);
        transform: rotate(-8deg);
    }

    .section-ornamented.ornament-random-1 > .feature-ornament-angle {
        right: clamp(0.5rem, 2.3vw, 1.1rem);
        transform: rotate(33deg);
    }

    .section-ornamented.ornament-random-2 > .feature-ornament-grid {
        right: clamp(0.45rem, 2vw, 1rem);
        top: clamp(0.9rem, 2.8vw, 1.5rem);
        width: clamp(50px, 13vw, 74px);
        transform: rotate(7deg);
    }

    .section-ornamented.ornament-random-2 > .feature-ornament-angle {
        bottom: clamp(0.55rem, 2vw, 1.1rem);
        left: clamp(0.5rem, 2vw, 1rem);
        transform: rotate(55deg);
    }

    .section-ornamented.ornament-random-3 > .feature-ornament-grid {
        right: clamp(0.6rem, 2.4vw, 1.2rem);
        bottom: clamp(0.4rem, 1.8vw, 0.9rem);
        width: clamp(50px, 13vw, 74px);
        transform: rotate(10deg);
    }

    .section-ornamented.ornament-random-3 > .feature-ornament-angle {
        top: clamp(0.85rem, 2.2vw, 1.45rem);
        left: clamp(0.45rem, 2vw, 1rem);
        width: clamp(34px, 8vw, 48px);
        transform: rotate(23deg);
    }

    .section-ornamented.ornament-random-4 > .feature-ornament-grid {
        left: clamp(0.6rem, 2vw, 1.15rem);
        top: clamp(0.35rem, 1.3vw, 0.85rem);
        width: clamp(54px, 14vw, 80px);
        transform: rotate(-5deg);
    }

    .section-ornamented.ornament-random-4 > .feature-ornament-angle {
        right: clamp(0.45rem, 1.8vw, 1rem);
        width: clamp(32px, 8vw, 44px);
        transform: rotate(50deg);
    }

    .section-ornamented.ornament-random-5 > .feature-ornament-grid {
        left: clamp(0.55rem, 2vw, 1.1rem);
        bottom: clamp(0.45rem, 1.8vw, 0.95rem);
        width: clamp(52px, 14vw, 78px);
        transform: rotate(-12deg);
    }

    .section-ornamented.ornament-random-5 > .feature-ornament-angle {
        right: clamp(0.45rem, 1.9vw, 1rem);
        width: clamp(32px, 8.3vw, 46px);
        transform: rotate(18deg);
    }
}

@media (min-width: 640px) {
    .category-grid {
        grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    }

    .listing-grid {
        grid-template-columns: repeat(auto-fill, minmax(min(100%, 320px), 1fr));
        gap: var(--space-xl);
    }

    .stat-strip {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .process-grid,
    .info-grid {
        grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
        gap: var(--space-xl);
    }

    .footer-top {
        grid-template-columns: 1.2fr 1fr 1fr;
        align-items: start;
    }

    .footer-bottom {
        grid-template-columns: auto 1fr;
        align-items: center;
        gap: var(--space-lg);
    }

    .copyright {
        text-align: right;
    }

    .references {
        grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    }

    .contact-content {
        font-size: 1.02rem;
    }

    .about-grid {
        grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
        gap: var(--space-xl);
        align-items: center;
    }

    .listing-detail-grid {
        /*grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr);*/
        grid-template-columns: 1fr 1fr;
        align-items: start;
    }

    .technical-grid {
        /*grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));*/
        grid-template-columns: 1fr;
    }
    .technical-grid-2 {
        grid-template-columns: 1fr 1fr;
    }
}

@media (min-width: 821px) {
    .h-container {
        grid-template-columns: auto auto;
    }

    .feature-breakout {
        grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr);
        gap: clamp(1.5rem, 4vw, 4rem);
        align-items: center;
    }

    .feature-breakout .feature-visual {
        width: min(820px, 100%);
    }

    .feature-breakout .feature-visual .section-img {
        aspect-ratio: 16 / 11;
    }

    .feature-breakout .feature-copy {
        margin-top: clamp(1.2rem, 3.5vw, 2.8rem);
    }

    .feature-breakout .usp-grid {
        grid-template-columns: 1fr;
    }

    .site-header .container {
        grid-template-columns: auto 1fr auto;
        gap: var(--space-lg);
    }

    .menu-toggle {
        display: none;
    }

    .main-nav {
        display: flex;
        justify-content: flex-end;
        grid-column: auto;
        /*display: flex;
        grid-column: auto;
        flex-direction: row;
        justify-content: flex-end;
        align-items: center;
        gap: var(--space-md);
        padding-bottom: 0;
        background: transparent;
        border: 0;*/
        font-size: 1.1rem;
    }

    .main-nav ul {
        display: flex;
        flex-direction: row;
        align-items: center;
        gap: var(--space-md);

        grid-column: auto;
        justify-content: flex-end;
    }

    .main-nav .nav-contact a {
        width: auto;
    }

    .contact-grid {
        grid-template-columns: 1fr 1.2fr;
        gap: var(--space-xl);
    }
    .contact-map {
        height: 100%;
        margin-bottom: 0;
    }
}

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

#spotlight {
    background-color: rgba(0, 0, 0, 0.9) !important;
}
