/* MASEG subpage layer — net-new classes only. Loaded from the four subpages.
   Do not modify lyndor.css; all additions live here. */

.subpage-main {
    background-color: var(--base-color-neutral--beige, #fbf8f1);
    color: var(--base-color-neutral--black, #0c0c0c);
}

.subpage-section {
    padding: 8vh 0;
    position: relative;
}

.subpage-section--primary  { background-color: var(--base-color-neutral--beige, #fbf8f1); }
.subpage-section--tertiary { background-color: var(--base-color-neutral--khaki, #efe9dd); }

.subpage-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 4vw;
}

/* ---------- Hero ---------- */

.subpage-hero { padding: 14vh 0 8vh; }

.subpage-hero__inner {
    display: grid;
    grid-template-columns: 1.05fr 1fr;
    gap: 5vw;
    align-items: center;
}

.subpage-hero__eyebrow {
    font-family: var(--_typography---plus-jakarta-sans), 'Plus Jakarta Sans', sans-serif;
    font-size: .875vw;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--base-color-neutral--neutral-light, #aaa);
    margin: 0 0 1.25rem;
}

.subpage-hero__heading {
    font-family: var(--_typography---cormorant-garamond), 'Cormorant Garamond', serif;
    font-size: 5vw;
    line-height: 1.05;
    margin: 0 0 1.5rem;
    color: var(--base-color-neutral--black, #0c0c0c);
}

.subpage-hero__lead {
    font-family: var(--_typography---plus-jakarta-sans), 'Plus Jakarta Sans', sans-serif;
    font-size: 1.25vw;
    line-height: 1.6;
    color: var(--base-color-neutral--black, #0c0c0c);
    opacity: .8;
    margin: 0;
    max-width: 36em;
}

.subpage-hero__image-wrapper {
    position: relative;
    aspect-ratio: 4 / 5;
    overflow: hidden;
    border-radius: 12px;
    background: var(--base-color-neutral--khaki, #efe9dd);
}

.subpage-hero__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 1.2s cubic-bezier(.2, .8, .2, 1);
}

.subpage-hero__image-wrapper:hover .subpage-hero__image { transform: scale(1.03); }

/* ---------- Section heading ---------- */

.subpage-section__heading {
    font-family: var(--_typography---cormorant-garamond), 'Cormorant Garamond', serif;
    font-size: 3vw;
    line-height: 1.1;
    margin: 0 0 1.25rem;
    color: var(--base-color-neutral--black, #0c0c0c);
}

.subpage-section__eyebrow {
    font-family: var(--_typography---plus-jakarta-sans), 'Plus Jakarta Sans', sans-serif;
    font-size: .875vw;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--base-color-neutral--neutral-light, #aaa);
    margin: 0 0 1rem;
}

.subpage-section__lead {
    font-family: var(--_typography---plus-jakarta-sans), 'Plus Jakarta Sans', sans-serif;
    font-size: 1.25vw;
    line-height: 1.65;
    color: var(--base-color-neutral--black, #0c0c0c);
    opacity: .82;
    margin: 0 0 3rem;
    max-width: 44em;
}

.subpage-section__body p {
    font-family: var(--_typography---plus-jakarta-sans), 'Plus Jakarta Sans', sans-serif;
    font-size: 1.1vw;
    line-height: 1.7;
    color: var(--base-color-neutral--black, #0c0c0c);
    opacity: .85;
    margin: 0 0 1.25rem;
}

.subpage-section__body strong { font-weight: 600; opacity: 1; }

/* ---------- Feature row (text + image side-by-side) ---------- */

.subpage-feature-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 5vw;
    align-items: center;
}

.subpage-feature-row--reverse .subpage-feature-row__text  { order: 2; }
.subpage-feature-row--reverse .subpage-feature-row__image { order: 1; }

.subpage-feature-row__image {
    aspect-ratio: 4 / 5;
    overflow: hidden;
    border-radius: 12px;
    background: var(--base-color-neutral--khaki, #efe9dd);
}

.subpage-feature-row__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 1.2s cubic-bezier(.2, .8, .2, 1);
}

.subpage-feature-row__image:hover img { transform: scale(1.03); }

/* ---------- Icon grid ---------- */

.subpage-icon-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 2rem;
    margin-top: 3rem;
}

.subpage-icon-card {
    background: var(--base-color-neutral--beige, #fbf8f1);
    border: 1px solid var(--border-color--border-primary, #ccc);
    border-radius: 12px;
    padding: 2.25rem 2rem;
    transition: transform .4s cubic-bezier(.2, .8, .2, 1),
                box-shadow .4s cubic-bezier(.2, .8, .2, 1);
}

.subpage-section--primary .subpage-icon-card  { background: var(--base-color-neutral--khaki, #efe9dd); border-color: transparent; }
.subpage-section--tertiary .subpage-icon-card { background: var(--base-color-neutral--beige, #fbf8f1); border-color: transparent; }

.subpage-icon-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 32px rgba(12, 12, 12, .08);
}

.subpage-icon-card__chip {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: var(--base-color-neutral--black, #0c0c0c);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1.5rem;
}

.subpage-icon-card__chip svg { width: 22px; height: 22px; }

.subpage-icon-card__title {
    font-family: var(--_typography---plus-jakarta-sans), 'Plus Jakarta Sans', sans-serif;
    font-size: 1.1vw;
    font-weight: 600;
    color: var(--base-color-neutral--black, #0c0c0c);
    margin: 0 0 .75rem;
}

.subpage-icon-card__body {
    font-family: var(--_typography---plus-jakarta-sans), 'Plus Jakarta Sans', sans-serif;
    font-size: 1vw;
    line-height: 1.6;
    color: var(--base-color-neutral--black, #0c0c0c);
    opacity: .78;
    margin: 0;
}

/* ---------- Check list (replaces the dark check list) ---------- */

.subpage-check-list {
    list-style: none;
    padding: 0;
    margin: 2rem 0 0;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.subpage-check-list li {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
    font-family: var(--_typography---plus-jakarta-sans), 'Plus Jakarta Sans', sans-serif;
    font-size: 1.1vw;
    line-height: 1.6;
    color: var(--base-color-neutral--black, #0c0c0c);
}

.subpage-check-list svg {
    flex-shrink: 0;
    margin-top: .35em;
    color: var(--base-color-neutral--black, #0c0c0c);
}

/* ---------- Stepped timeline ---------- */

.subpage-steps {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 2rem;
    margin-top: 3rem;
    position: relative;
}

.subpage-step {
    position: relative;
    padding-top: 1rem;
}

.subpage-step__number {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: var(--base-color-neutral--black, #0c0c0c);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--_typography---cormorant-garamond), 'Cormorant Garamond', serif;
    font-size: 1.75rem;
    margin-bottom: 1.5rem;
    position: relative;
    z-index: 1;
}

.subpage-step__title {
    font-family: var(--_typography---plus-jakarta-sans), 'Plus Jakarta Sans', sans-serif;
    font-size: 1.1vw;
    font-weight: 600;
    margin: 0 0 .75rem;
    color: var(--base-color-neutral--black, #0c0c0c);
}

.subpage-step__body {
    font-family: var(--_typography---plus-jakarta-sans), 'Plus Jakarta Sans', sans-serif;
    font-size: 1vw;
    line-height: 1.6;
    color: var(--base-color-neutral--black, #0c0c0c);
    opacity: .78;
    margin: 0;
}

/* ---------- Team grid (Über uns) ---------- */

.subpage-team-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 2.5rem;
    margin-top: 3rem;
}

.subpage-team-member { text-align: center; }

.subpage-team-member__image {
    aspect-ratio: 1 / 1;
    overflow: hidden;
    border-radius: 12px;
    margin-bottom: 1.25rem;
    background: var(--base-color-neutral--khaki, #efe9dd);
}

.subpage-team-member__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 1.2s cubic-bezier(.2, .8, .2, 1);
}

.subpage-team-member__image:hover img { transform: scale(1.04); }

.subpage-team-member__name {
    font-family: var(--_typography---plus-jakarta-sans), 'Plus Jakarta Sans', sans-serif;
    font-size: 1.25vw;
    font-weight: 500;
    color: var(--base-color-neutral--black, #0c0c0c);
    margin: 0;
}

/* ---------- CTA ---------- */

.subpage-cta-row {
    margin-top: 3rem;
    display: flex;
    justify-content: center;
}

/* ---------- Fade-up (page-load only, CSS-only) ---------- */

@keyframes subpage-fade-up {
    from { opacity: 0; transform: translate3d(0, 18px, 0); }
    to   { opacity: 1; transform: translate3d(0, 0, 0);      }
}

.subpage-fade-up {
    animation: subpage-fade-up .9s cubic-bezier(.2, .8, .2, 1) both;
}

.subpage-fade-up-2 { animation: subpage-fade-up .9s cubic-bezier(.2, .8, .2, 1) .12s both; }
.subpage-fade-up-3 { animation: subpage-fade-up .9s cubic-bezier(.2, .8, .2, 1) .24s both; }
.subpage-fade-up-4 { animation: subpage-fade-up .9s cubic-bezier(.2, .8, .2, 1) .36s both; }

@media (prefers-reduced-motion: reduce) {
    .subpage-fade-up,
    .subpage-fade-up-2,
    .subpage-fade-up-3,
    .subpage-fade-up-4 { animation: none; }
    .subpage-hero__image,
    .subpage-feature-row__image img,
    .subpage-team-member__image img { transition: none; }
}

/* ---------- Responsive ---------- */

@media (max-width: 991px) {
    .subpage-hero__inner,
    .subpage-feature-row { grid-template-columns: 1fr; gap: 3rem; }
    .subpage-feature-row--reverse .subpage-feature-row__text  { order: 0; }
    .subpage-feature-row--reverse .subpage-feature-row__image { order: 0; }
    .subpage-hero__image-wrapper,
    .subpage-feature-row__image { aspect-ratio: 16 / 10; max-height: 60vh; }
    .subpage-hero__heading     { font-size: 7vw; }
    .subpage-section__heading  { font-size: 5vw; }
    .subpage-hero__lead,
    .subpage-section__lead,
    .subpage-section__body p,
    .subpage-check-list li,
    .subpage-icon-card__body,
    .subpage-icon-card__title,
    .subpage-step__title,
    .subpage-step__body,
    .subpage-team-member__name { font-size: 1.75vw; }
    .subpage-hero__eyebrow,
    .subpage-section__eyebrow  { font-size: 1.5vw; }
}

@media (max-width: 767px) {
    .subpage-container { padding: 0 5vw; }
    .subpage-section { padding: 6vh 0; }
    .subpage-hero    { padding: 12vh 0 6vh; }
    .subpage-hero__inner,
    .subpage-feature-row { gap: 2.5rem; }
    .subpage-icon-card { padding: 1.75rem 1.5rem; }
    .subpage-hero__heading     { font-size: 9vw; }
    .subpage-section__heading  { font-size: 7vw; }
    .subpage-hero__lead,
    .subpage-section__lead,
    .subpage-section__body p,
    .subpage-check-list li,
    .subpage-icon-card__body,
    .subpage-icon-card__title,
    .subpage-step__title,
    .subpage-step__body,
    .subpage-team-member__name { font-size: 2.75vw; }
    .subpage-hero__eyebrow,
    .subpage-section__eyebrow  { font-size: 2.5vw; }
}

@media (max-width: 479px) {
    .subpage-container { padding: 0 6vw; }
    .subpage-icon-grid,
    .subpage-steps,
    .subpage-team-grid { grid-template-columns: 1fr; gap: 1.5rem; margin-top: 2rem; }
    .subpage-icon-card { padding: 1.5rem 1.25rem; }
    .subpage-hero__image-wrapper,
    .subpage-feature-row__image { aspect-ratio: 4 / 3; }
    .subpage-hero__heading     { font-size: 11vw; }
    .subpage-section__heading  { font-size: 8.5vw; }
    .subpage-hero__lead,
    .subpage-section__lead,
    .subpage-section__body p,
    .subpage-check-list li,
    .subpage-icon-card__body,
    .subpage-icon-card__title,
    .subpage-step__title,
    .subpage-step__body,
    .subpage-team-member__name { font-size: 4vw; }
    .subpage-hero__eyebrow,
    .subpage-section__eyebrow  { font-size: 3.5vw; }
    .subpage-step__number { width: 48px; height: 48px; font-size: 1.4rem; margin-bottom: 1rem; }
    .subpage-icon-card__chip { width: 42px; height: 42px; margin-bottom: 1rem; }
    .subpage-icon-card__chip svg { width: 18px; height: 18px; }
}
