/* /Components/Layout/MainLayout.razor.rz.scp.css */
/* MainLayout has no additional styles � layout is handled by page-level components */
/* /Components/Layout/ReconnectModal.razor.rz.scp.css */
.components-reconnect-first-attempt-visible[b-izjxzgqjx7],
.components-reconnect-repeated-attempt-visible[b-izjxzgqjx7],
.components-reconnect-failed-visible[b-izjxzgqjx7],
.components-pause-visible[b-izjxzgqjx7],
.components-resume-failed-visible[b-izjxzgqjx7],
.components-rejoining-animation[b-izjxzgqjx7] {
    display: none;
}

#components-reconnect-modal.components-reconnect-show .components-reconnect-first-attempt-visible[b-izjxzgqjx7],
#components-reconnect-modal.components-reconnect-show .components-rejoining-animation[b-izjxzgqjx7],
#components-reconnect-modal.components-reconnect-paused .components-pause-visible[b-izjxzgqjx7],
#components-reconnect-modal.components-reconnect-resume-failed .components-resume-failed-visible[b-izjxzgqjx7],
#components-reconnect-modal.components-reconnect-retrying[b-izjxzgqjx7],
#components-reconnect-modal.components-reconnect-retrying .components-reconnect-repeated-attempt-visible[b-izjxzgqjx7],
#components-reconnect-modal.components-reconnect-retrying .components-rejoining-animation[b-izjxzgqjx7],
#components-reconnect-modal.components-reconnect-failed[b-izjxzgqjx7],
#components-reconnect-modal.components-reconnect-failed .components-reconnect-failed-visible[b-izjxzgqjx7] {
    display: block;
}


#components-reconnect-modal[b-izjxzgqjx7] {
    background-color: white;
    width: 20rem;
    margin: 20vh auto;
    padding: 2rem;
    border: 0;
    border-radius: 0.5rem;
    box-shadow: 0 3px 6px 2px rgba(0, 0, 0, 0.3);
    opacity: 0;
    transition: display 0.5s allow-discrete, overlay 0.5s allow-discrete;
    animation: components-reconnect-modal-fadeOutOpacity-b-izjxzgqjx7 0.5s both;
    &[open]

{
    animation: components-reconnect-modal-slideUp-b-izjxzgqjx7 1.5s cubic-bezier(.05, .89, .25, 1.02) 0.3s, components-reconnect-modal-fadeInOpacity-b-izjxzgqjx7 0.5s ease-in-out 0.3s;
    animation-fill-mode: both;
}

}

#components-reconnect-modal[b-izjxzgqjx7]::backdrop {
    background-color: rgba(0, 0, 0, 0.4);
    animation: components-reconnect-modal-fadeInOpacity-b-izjxzgqjx7 0.5s ease-in-out;
    opacity: 1;
}

@keyframes components-reconnect-modal-slideUp-b-izjxzgqjx7 {
    0% {
        transform: translateY(30px) scale(0.95);
    }

    100% {
        transform: translateY(0);
    }
}

@keyframes components-reconnect-modal-fadeInOpacity-b-izjxzgqjx7 {
    0% {
        opacity: 0;
    }

    100% {
        opacity: 1;
    }
}

@keyframes components-reconnect-modal-fadeOutOpacity-b-izjxzgqjx7 {
    0% {
        opacity: 1;
    }

    100% {
        opacity: 0;
    }
}

.components-reconnect-container[b-izjxzgqjx7] {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
}

#components-reconnect-modal p[b-izjxzgqjx7] {
    margin: 0;
    text-align: center;
}

#components-reconnect-modal button[b-izjxzgqjx7] {
    border: 0;
    background-color: #6b9ed2;
    color: white;
    padding: 4px 24px;
    border-radius: 4px;
}

    #components-reconnect-modal button:hover[b-izjxzgqjx7] {
        background-color: #3b6ea2;
    }

    #components-reconnect-modal button:active[b-izjxzgqjx7] {
        background-color: #6b9ed2;
    }

.components-rejoining-animation[b-izjxzgqjx7] {
    position: relative;
    width: 80px;
    height: 80px;
}

    .components-rejoining-animation div[b-izjxzgqjx7] {
        position: absolute;
        border: 3px solid #0087ff;
        opacity: 1;
        border-radius: 50%;
        animation: components-rejoining-animation-b-izjxzgqjx7 1.5s cubic-bezier(0, 0.2, 0.8, 1) infinite;
    }

        .components-rejoining-animation div:nth-child(2)[b-izjxzgqjx7] {
            animation-delay: -0.5s;
        }

@keyframes components-rejoining-animation-b-izjxzgqjx7 {
    0% {
        top: 40px;
        left: 40px;
        width: 0;
        height: 0;
        opacity: 0;
    }

    4.9% {
        top: 40px;
        left: 40px;
        width: 0;
        height: 0;
        opacity: 0;
    }

    5% {
        top: 40px;
        left: 40px;
        width: 0;
        height: 0;
        opacity: 1;
    }

    100% {
        top: 0px;
        left: 0px;
        width: 80px;
        height: 80px;
        opacity: 0;
    }
}
/* /Components/Layout/SiteFooter.razor.rz.scp.css */
.site-footer[b-swjovmwmp1] {
    background: var(--color-bg-overlay);
    border-top: 1px solid var(--color-border-subtle);
    padding: 64px 0 32px;
}

.site-footer__inner[b-swjovmwmp1] {
    max-width: 1240px;
    margin: 0 auto;
    padding: 0 clamp(var(--space-5), 5vw, var(--space-16));
}

/* ---- Top grid ---- */
.site-footer__top[b-swjovmwmp1] {
    display: grid;
    grid-template-columns: 1.6fr 1fr 1fr 1fr;
    gap: var(--space-10);
}

.site-footer__logo[b-swjovmwmp1] {
    display: inline-flex;
    align-items: center;
    gap: var(--space-3);
    text-decoration: none;
    margin-bottom: var(--space-4);
}

.site-footer__logo-mark[b-swjovmwmp1] {
    width: 36px;
    height: 36px;
    flex: none;
    display: block;
}

.site-footer__logo-word[b-swjovmwmp1] {
    font-family: var(--font-display);
    font-weight: var(--font-extrabold);
    font-size: 1.08rem;
    letter-spacing: -0.01em;
    line-height: 1;
    color: var(--color-text-primary);
    white-space: nowrap;
}

.site-footer__logo-accent[b-swjovmwmp1] {
    color: var(--color-brand-mint);
}

.site-footer__logo-word small[b-swjovmwmp1] {
    display: block;
    font-family: var(--font-sans);
    font-weight: var(--font-medium);
    font-size: 0.52rem;
    letter-spacing: 0.34em;
    text-transform: uppercase;
    color: var(--color-text-muted);
    margin-top: 4px;
    -webkit-text-fill-color: var(--color-text-muted);
}

.site-footer__about[b-swjovmwmp1] {
    color: var(--color-text-muted);
    font-size: 0.92rem;
    line-height: 1.65;
    max-width: 30ch;
}

.site-footer__col h5[b-swjovmwmp1] {
    font-family: var(--font-sans);
    font-weight: var(--font-bold);
    font-size: 0.78rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--color-text-muted);
    margin-bottom: var(--space-4);
}

.site-footer__col a[b-swjovmwmp1] {
    display: block;
    color: var(--color-text-secondary);
    font-size: 0.94rem;
    text-decoration: none;
    padding: 6px 0;
    transition: color 0.2s ease;
}

.site-footer__col a:hover[b-swjovmwmp1] {
    color: var(--color-brand-mint);
}

/* ---- Bottom bar ---- */
.site-footer__bottom[b-swjovmwmp1] {
    margin-top: var(--space-12);
    padding-top: var(--space-6);
    border-top: 1px solid var(--color-border-subtle);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--space-5);
    flex-wrap: wrap;
}

.site-footer__copy[b-swjovmwmp1] {
    font-size: 0.84rem;
    color: var(--color-text-muted);
    display: flex;
    align-items: center;
    gap: var(--space-4);
    flex-wrap: wrap;
}

.site-footer__legal-links[b-swjovmwmp1] {
    display: flex;
    gap: var(--space-4);
}

.site-footer__legal-links a[b-swjovmwmp1] {
    color: var(--color-text-muted);
    text-decoration: none;
    font-size: 0.84rem;
    transition: color 0.2s ease;
}

.site-footer__legal-links a:hover[b-swjovmwmp1] {
    color: var(--color-brand-mint);
}

.site-footer__cookie-btn[b-swjovmwmp1] {
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
    color: var(--color-text-muted);
    font-family: var(--font-sans);
    font-size: 0.84rem;
    transition: color 0.2s ease;
}

.site-footer__cookie-btn:hover[b-swjovmwmp1] {
    color: var(--color-brand-mint);
}

.site-footer__social[b-swjovmwmp1] {
    display: flex;
    gap: var(--space-2);
}

.site-footer__social a[b-swjovmwmp1] {
    width: 40px;
    height: 40px;
    border-radius: var(--radius-sm);
    border: 1px solid var(--color-border-default);
    display: grid;
    place-items: center;
    color: var(--color-text-secondary);
    text-decoration: none;
    transition: background 0.25s ease, border-color 0.25s ease, color 0.25s ease, transform 0.25s ease;
}

.site-footer__social a svg[b-swjovmwmp1],
.site-footer__social a i[b-swjovmwmp1] {
    width: 18px;
    height: 18px;
}

.site-footer__social a:hover[b-swjovmwmp1] {
    background: var(--gradient-brand);
    border-color: transparent;
    color: #fff;
    transform: translateY(-2px);
}

/* ---- Responsive ---- */
@media (max-width: 1080px) {
    .site-footer__top[b-swjovmwmp1] {
        grid-template-columns: 1fr 1fr;
        gap: var(--space-8);
    }
}

@media (max-width: 560px) {
    .site-footer__top[b-swjovmwmp1] {
        grid-template-columns: 1fr;
    }
}


.site-footer__inner[b-swjovmwmp1] {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 var(--space-6);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-6);
    flex-wrap: wrap;
}

.site-footer__brand[b-swjovmwmp1] {
    display: flex;
    align-items: center;
    gap: var(--space-3);
}

.site-footer__mark[b-swjovmwmp1] {
    display: grid;
    place-items: center;
    width: 40px;
    height: 40px;
    flex-shrink: 0;
    border-radius: var(--radius-md);
    background: var(--gradient-brand);
    color: var(--color-text-inverted);
    font-size: var(--text-sm);
    font-weight: var(--font-bold);
    letter-spacing: 0.02em;
}

.site-footer__brand-text[b-swjovmwmp1] {
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
}

.site-footer__name[b-swjovmwmp1] {
    font-size: var(--text-base);
    font-weight: var(--font-semibold);
    color: var(--color-text-primary);
}

.site-footer__claim[b-swjovmwmp1] {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
}

.site-footer__meta[b-swjovmwmp1] {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
}
/* /Components/Layout/SiteNav.razor.rz.scp.css */
.site-nav[b-84sfx8vqpc] {
    position: fixed;
    inset: 0 0 auto 0;
    z-index: 200;
    height: 76px;
    display: flex;
    align-items: center;
    border-bottom: 1px solid transparent;
    transition: background 0.35s ease, border-color 0.35s ease, backdrop-filter 0.35s ease;
}

.site-nav.scrolled[b-84sfx8vqpc] {
    height: 64px;
    background: rgba(3, 9, 26, 0.78);
    backdrop-filter: blur(18px) saturate(140%);
    -webkit-backdrop-filter: blur(18px) saturate(140%);
    border-bottom-color: var(--color-border-subtle);
}

.site-nav__inner[b-84sfx8vqpc] {
    max-width: 1240px;
    width: 100%;
    margin: 0 auto;
    padding: 0 clamp(var(--space-5), 5vw, var(--space-16));
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.site-nav__logo[b-84sfx8vqpc] {
    display: inline-flex;
    align-items: center;
    gap: var(--space-3);
    text-decoration: none;
}

.site-nav__logo-mark[b-84sfx8vqpc] {
    width: 38px;
    height: 38px;
    flex: none;
    display: block;
}

.site-nav__logo-word[b-84sfx8vqpc] {
    font-family: var(--font-display);
    font-weight: var(--font-extrabold);
    font-size: 1.18rem;
    letter-spacing: -0.01em;
    line-height: 1;
    color: var(--color-text-primary);
    white-space: nowrap;
}

.site-nav__logo-accent[b-84sfx8vqpc] {
    color: var(--color-brand-mint);
}

.site-nav__logo-word small[b-84sfx8vqpc] {
    display: block;
    font-family: var(--font-sans);
    font-weight: var(--font-medium);
    font-size: 0.54rem;
    letter-spacing: 0.34em;
    text-transform: uppercase;
    color: var(--color-text-muted);
    margin-top: 4px;
}

.site-nav__links[b-84sfx8vqpc] {
    display: flex;
    align-items: center;
    gap: var(--space-8);
}

.site-nav__links a[b-84sfx8vqpc] {
    font-size: 0.92rem;
    font-weight: var(--font-medium);
    color: var(--color-text-secondary);
    text-decoration: none;
    position: relative;
    transition: color 0.2s ease;
}

.site-nav__links a[b-84sfx8vqpc]::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: -6px;
    width: 100%;
    height: 2px;
    background: var(--gradient-brand);
    border-radius: 2px;
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 0.3s ease;
}

.site-nav__links a:hover[b-84sfx8vqpc] {
    color: #fff;
}

.site-nav__links a:hover[b-84sfx8vqpc]::after {
    transform: scaleX(1);
}

.site-nav__right[b-84sfx8vqpc] {
    display: flex;
    align-items: center;
    gap: var(--space-4);
}

.site-nav__cta[b-84sfx8vqpc] {
    padding: 11px 22px;
    font-size: 0.9rem;
}

.site-nav__burger[b-84sfx8vqpc] {
    display: none;
    flex-direction: column;
    gap: 5px;
    padding: 8px;
    background: none;
    border: none;
    cursor: pointer;
}

.site-nav__burger span[b-84sfx8vqpc] {
    width: 22px;
    height: 2px;
    background: var(--color-text-primary);
    border-radius: 2px;
    transition: 0.3s ease;
}

@media (max-width: 900px) {
    .site-nav__links[b-84sfx8vqpc] {
        display: none;
    }

    .site-nav__burger[b-84sfx8vqpc] {
        display: flex;
    }

}

@media (max-width: 560px) {
    .site-nav__cta[b-84sfx8vqpc] {
        display: none;
    }
}

/* /Components/Pages/Datenschutz.razor.rz.scp.css */
/* Datenschutz page — same visual language as Impressum */

.legal-page[b-yy4gmnqo4v] {
    min-height: 100dvh;
    background: var(--color-bg-base);
    display: flex;
    flex-direction: column;
}

.legal-hero[b-yy4gmnqo4v] {
    position: relative;
    padding: clamp(6rem, 14vw, 9rem) 0 clamp(3rem, 6vw, 4.5rem);
    border-bottom: 1px solid var(--color-border-subtle);
    overflow: hidden;
}

.legal-hero__glow[b-yy4gmnqo4v] {
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse 60% 80% at 20% 50%, rgba(1, 165, 157, 0.07) 0%, transparent 70%),
        radial-gradient(ellipse 40% 60% at 80% 20%, rgba(27, 117, 187, 0.05) 0%, transparent 70%);
    pointer-events: none;
}

.legal-hero__inner[b-yy4gmnqo4v] {
    max-width: 1240px;
    margin: 0 auto;
    padding: 0 clamp(1.25rem, 5vw, 4rem);
    position: relative;
    z-index: 1;
}

.legal-back[b-yy4gmnqo4v] {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--color-text-muted);
    text-decoration: none;
    font-size: var(--text-sm);
    font-weight: var(--font-medium);
    margin-bottom: clamp(1.5rem, 4vw, 2.5rem);
    transition: color 0.2s ease, gap 0.2s ease;
}

.legal-back i[b-yy4gmnqo4v] {
    width: 16px;
    height: 16px;
    transition: transform 0.2s ease;
}

.legal-back:hover[b-yy4gmnqo4v] {
    color: var(--color-brand-mint);
    gap: 0.75rem;
}

.legal-back:hover i[b-yy4gmnqo4v] {
    transform: translateX(-3px);
}

.legal-hero__title[b-yy4gmnqo4v] {
    font-family: var(--font-display);
    font-weight: var(--font-extrabold);
    font-size: clamp(2.5rem, 6vw, 4rem);
    letter-spacing: -0.03em;
    line-height: var(--leading-tight);
    color: var(--color-text-primary);
    text-wrap: balance;
    margin: 0 0 var(--space-3);
}

.legal-hero__sub[b-yy4gmnqo4v] {
    font-size: var(--text-base);
    color: var(--color-text-muted);
    margin: 0;
}

.legal-body[b-yy4gmnqo4v] {
    flex: 1;
    padding: clamp(3rem, 8vw, 6rem) 0 clamp(4rem, 10vw, 8rem);
}

.legal-content[b-yy4gmnqo4v] {
    max-width: 720px;
    margin: 0 auto;
    padding: 0 clamp(1.25rem, 5vw, 4rem);
}

.legal-section[b-yy4gmnqo4v] {
    padding-bottom: clamp(2rem, 5vw, 3.5rem);
    margin-bottom: clamp(2rem, 5vw, 3.5rem);
    border-bottom: 1px solid var(--color-border-subtle);
}

.legal-section:last-child[b-yy4gmnqo4v] {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: 0;
}

.legal-section h2[b-yy4gmnqo4v] {
    font-family: var(--font-display);
    font-weight: var(--font-bold);
    font-size: clamp(1.125rem, 2.5vw, 1.375rem);
    letter-spacing: -0.01em;
    color: var(--color-text-primary);
    margin: 0 0 var(--space-5);
}

.legal-section h3[b-yy4gmnqo4v] {
    font-family: var(--font-sans);
    font-weight: var(--font-semibold);
    font-size: var(--text-base);
    color: var(--color-brand-mint);
    letter-spacing: 0.01em;
    margin: var(--space-8) 0 var(--space-3);
}

.legal-section h3:first-child[b-yy4gmnqo4v] {
    margin-top: 0;
}

.legal-section p[b-yy4gmnqo4v] {
    font-size: var(--text-base);
    line-height: var(--leading-relaxed);
    color: var(--color-text-secondary);
    margin: 0 0 var(--space-4);
    max-width: 68ch;
}

.legal-section p:last-child[b-yy4gmnqo4v] {
    margin-bottom: 0;
}

.legal-section ul[b-yy4gmnqo4v] {
    margin: 0 0 var(--space-4);
    padding-left: var(--space-5);
    list-style: none;
}

.legal-section ul li[b-yy4gmnqo4v] {
    position: relative;
    font-size: var(--text-base);
    line-height: var(--leading-relaxed);
    color: var(--color-text-secondary);
    padding: var(--space-1) 0 var(--space-1) var(--space-5);
    margin-bottom: var(--space-2);
}

.legal-section ul li[b-yy4gmnqo4v]::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.7em;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--color-brand-teal);
    box-shadow: 0 0 8px rgba(1, 165, 157, 0.5);
}

.legal-section strong[b-yy4gmnqo4v] {
    color: var(--color-text-primary);
    font-weight: var(--font-semibold);
}

.legal-section a[b-yy4gmnqo4v],
.legal-back[b-yy4gmnqo4v] {
    color: var(--color-brand-teal);
    text-decoration: none;
    transition: color 0.2s ease;
}

.legal-section a:hover[b-yy4gmnqo4v] {
    color: var(--color-brand-mint);
    text-decoration: underline;
    text-underline-offset: 3px;
}

@media (prefers-reduced-motion: reduce) {
    .legal-back[b-yy4gmnqo4v],
    .legal-back i[b-yy4gmnqo4v] {
        transition: none;
    }
}
/* /Components/Pages/Home.razor.rz.scp.css */
/* ============================================================
}
    }
    }
}
/* ============================================================
   Home page section styles
   Shared design tokens live in uibase.css
   ============================================================ */

/* ----------------------------------------------------------
   Shared layout utility
   ---------------------------------------------------------- */
.wrap[b-6nogm1vagd] {
    max-width: 1240px;
    margin: 0 auto;
    padding-left: clamp(var(--space-5), 5vw, var(--space-16));
    padding-right: clamp(var(--space-5), 5vw, var(--space-16));
}

.section-pad[b-6nogm1vagd] {
    padding: clamp(72px, 11vw, 140px) 0;
}

.eyebrow[b-6nogm1vagd] {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-family: var(--font-sans);
    font-size: 0.74rem;
    font-weight: var(--font-semibold);
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--color-brand-mint);
    margin-bottom: var(--space-5);
}

.eyebrow[b-6nogm1vagd]::before {
    content: '';
    width: 26px;
    height: 1px;
    background: linear-gradient(90deg, var(--color-brand-teal), transparent);
}

/* ============================================================
   HERO
   ============================================================ */
.hero[b-6nogm1vagd] {
    padding-top: 76px;
    min-height: 100vh;
    display: flex;
    align-items: center;
    position: relative;
    overflow: hidden;
}

.hero-bg[b-6nogm1vagd] {
    position: absolute;
    inset: 0;
    z-index: 0;
    overflow: hidden;
}

.hero-grid[b-6nogm1vagd] {
    position: absolute;
    inset: -2px;
    background-image:
        linear-gradient(var(--color-border-subtle) 1px, transparent 1px),
        linear-gradient(90deg, var(--color-border-subtle) 1px, transparent 1px);
    background-size: 64px 64px;
    -webkit-mask-image: radial-gradient(ellipse 80% 70% at 60% 40%, #000 0%, transparent 75%);
            mask-image: radial-gradient(ellipse 80% 70% at 60% 40%, #000 0%, transparent 75%);
    opacity: 0.5;
}

.glow[b-6nogm1vagd] {
    position: absolute;
    border-radius: 50%;
    filter: blur(20px);
    pointer-events: none;
}

.glow-a[b-6nogm1vagd] {
    top: -180px;
    right: -120px;
    width: 720px;
    height: 720px;
    background: radial-gradient(circle, rgba(1,165,157,0.22) 0%, rgba(27,117,187,0.12) 42%, transparent 70%);
}

.glow-b[b-6nogm1vagd] {
    bottom: -220px;
    left: -160px;
    width: 620px;
    height: 620px;
    background: radial-gradient(circle, rgba(27,117,187,0.16) 0%, transparent 68%);
}

#code-rain[b-6nogm1vagd] {
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    overflow: hidden;
}

#code-rain[b-6nogm1vagd]  .code-line {
    position: absolute;
    font-family: var(--font-mono);
    font-size: 12.5px;
    white-space: nowrap;
    color: rgba(146,244,236,0.18);
    will-change: transform, opacity;
    -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 8%, #000 88%, transparent 100%);
            mask-image: linear-gradient(90deg, transparent 0%, #000 8%, #000 88%, transparent 100%);
}

#code-rain[b-6nogm1vagd]  .code-line .k { color: rgba(127,188,229,0.32); }
#code-rain[b-6nogm1vagd]  .code-line .s { color: rgba(1,165,157,0.32); }

.hero-inner[b-6nogm1vagd] {
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: 1.05fr 0.95fr;
    gap: clamp(30px, 5vw, 70px);
    align-items: center;
    width: 100%;
    padding: 60px 0;
}

.hero-eyebrow[b-6nogm1vagd] {
    margin-bottom: 26px;
}

.hero h1[b-6nogm1vagd] {
    font-size: clamp(2.5rem, 5.6vw, 4.6rem);
    font-weight: var(--font-extrabold);
    letter-spacing: -0.03em;
    line-height: 1.08;
}

.hero-accent[b-6nogm1vagd] {
    color: var(--color-brand-mint);
    position: relative;
    white-space: nowrap;
}

.hero-accent[b-6nogm1vagd]::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: -0.06em;
    width: 100%;
    height: 3px;
    border-radius: 2px;
    background: var(--gradient-brand);
    opacity: 0.7;
}

.hero-sub[b-6nogm1vagd] {
    margin-top: 26px;
    font-size: clamp(1.05rem, 1.6vw, 1.24rem);
    color: var(--color-text-secondary);
    max-width: 520px;
    line-height: 1.65;
}

.hero-actions[b-6nogm1vagd] {
    margin-top: 38px;
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
}

.hero-trust[b-6nogm1vagd] {
    margin-top: 42px;
    display: flex;
    gap: 26px;
    flex-wrap: wrap;
    align-items: center;
}

.hero-trust .ti[b-6nogm1vagd] {
    display: flex;
    align-items: center;
    gap: 9px;
    font-size: 0.86rem;
    color: var(--color-text-muted);
}

.hero-trust .ti i[b-6nogm1vagd],
.hero-trust .ti svg[b-6nogm1vagd] {
    width: 17px;
    height: 17px;
    color: var(--color-brand-teal);
    flex-shrink: 0;
}

.hero-trust .sep[b-6nogm1vagd] {
    width: 1px;
    height: 26px;
    background: var(--color-border-default);
}

/* ---- Portrait ---- */
.portrait-wrap[b-6nogm1vagd] {
    position: relative;
    justify-self: center;
    width: 100%;
    max-width: 460px;
    aspect-ratio: 4 / 4.4;
}

.portrait-disc[b-6nogm1vagd] {
    position: absolute;
    inset: 6% 8% 0 8%;
    background: radial-gradient(ellipse 70% 60% at 50% 38%, rgba(1,165,157,0.5) 0%, rgba(27,117,187,0.28) 40%, transparent 72%);
    border-radius: 50% 50% 46% 46%;
    filter: blur(6px);
}

.portrait-ring[b-6nogm1vagd] {
    position: absolute;
    inset: 4% 6% 8% 6%;
    border-radius: var(--radius-xl);
    background: linear-gradient(160deg, rgba(1,165,157,0.5), rgba(27,117,187,0.12) 45%, transparent 70%);
    padding: 1.5px;
    -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
    -webkit-mask-composite: xor;
            mask-composite: exclude;
}

.portrait-img[b-6nogm1vagd] {
    position: relative;
    z-index: 2;
    width: 100%;
    height: 100%;
    object-fit: contain;
    object-position: bottom center;
    filter: drop-shadow(0 30px 50px rgba(0,0,0,0.55));
    display: block;
}

.float-card[b-6nogm1vagd] {
    position: absolute;
    z-index: 3;
    display: flex;
    align-items: center;
    gap: 10px;
    background: rgba(10,19,48,0.72);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border: 1px solid var(--color-border-default);
    border-radius: var(--radius-md);
    padding: 11px 15px;
    box-shadow: var(--shadow-md);
    font-size: 0.82rem;
    font-weight: var(--font-semibold);
}

.float-card .dot[b-6nogm1vagd] {
    width: 9px;
    height: 9px;
    border-radius: 50%;
    background: var(--color-brand-teal);
    box-shadow: 0 0 10px var(--color-brand-teal);
    flex-shrink: 0;
}

.float-card .ic[b-6nogm1vagd] {
    width: 34px;
    height: 34px;
    border-radius: 9px;
    display: grid;
    place-items: center;
    background: var(--gradient-brand-soft);
    color: var(--color-brand-mint);
    flex-shrink: 0;
}

.float-card .ic svg[b-6nogm1vagd],
.float-card .ic i[b-6nogm1vagd] {
    width: 18px;
    height: 18px;
}

.float-card small[b-6nogm1vagd] {
    display: block;
    font-weight: var(--font-medium);
    color: var(--color-text-muted);
    font-size: 0.72rem;
}

.fc-1[b-6nogm1vagd] { top: 14%; left: -6%; }
.fc-2[b-6nogm1vagd] { top: 46%; right: -10%; }
.fc-3[b-6nogm1vagd] { bottom: 8%; left: -2%; }

@keyframes float-a-b-6nogm1vagd {
    0%, 100% { transform: translateY(0); }
    50%       { transform: translateY(-8px); }
}
@keyframes float-b-b-6nogm1vagd {
    0%, 100% { transform: translateY(0); }
    50%       { transform: translateY(7px); }
}
@keyframes fc-pop-b-6nogm1vagd {
    from { opacity: 0; transform: scale(0.82) translateY(10px); }
    to   { opacity: 1; transform: none; }
}

@media (prefers-reduced-motion: no-preference) {
    .fc-1[b-6nogm1vagd] { animation: fc-pop-b-6nogm1vagd 0.5s var(--ease-out-expo) 1.1s both, float-a-b-6nogm1vagd 4s ease-in-out 1.7s infinite; }
    .fc-2[b-6nogm1vagd] { animation: fc-pop-b-6nogm1vagd 0.5s var(--ease-out-expo) 1.3s both, float-b-b-6nogm1vagd 5s ease-in-out 1.9s infinite; }
    .fc-3[b-6nogm1vagd] { animation: fc-pop-b-6nogm1vagd 0.5s var(--ease-out-expo) 1.2s both, float-a-b-6nogm1vagd 4.5s ease-in-out 1.8s infinite; }
}

.scroll-cue[b-6nogm1vagd] {
    position: absolute;
    bottom: 26px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 3;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    color: var(--color-text-muted);
    font-size: 0.72rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
}

.scroll-cue .mouse[b-6nogm1vagd] {
    width: 22px;
    height: 34px;
    border: 1.5px solid var(--color-border-default);
    border-radius: 12px;
    position: relative;
}

.scroll-cue .mouse[b-6nogm1vagd]::after {
    content: '';
    position: absolute;
    top: 6px;
    left: 50%;
    transform: translateX(-50%);
    width: 3px;
    height: 7px;
    border-radius: 3px;
    background: var(--color-brand-teal);
    animation: scrolldot-b-6nogm1vagd 1.8s ease-in-out infinite;
}

@keyframes scrolldot-b-6nogm1vagd {
    0%  { opacity: 0; transform: translate(-50%, 0); }
    30% { opacity: 1; }
    60% { opacity: 1; transform: translate(-50%, 9px); }
    100%{ opacity: 0; }
}

/* ============================================================
   SERVICES
   ============================================================ */
.svc-grid[b-6nogm1vagd] {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}

.svc-card[b-6nogm1vagd] {
    position: relative;
    padding: 32px 30px;
    border-radius: var(--radius-lg);
    background: linear-gradient(180deg, rgba(255,255,255,0.035), rgba(255,255,255,0.01));
    border: 1px solid var(--color-border-subtle);
    overflow: hidden;
    transition: transform 0.4s ease, border-color 0.4s ease, background 0.4s ease;
}

.svc-card[b-6nogm1vagd]::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: inherit;
    padding: 1px;
    background: var(--gradient-brand);
    opacity: 0;
    -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
    -webkit-mask-composite: xor;
            mask-composite: exclude;
    transition: opacity 0.4s ease;
    pointer-events: none;
}

.svc-card:hover[b-6nogm1vagd] {
    transform: translateY(-6px);
    background: linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.02));
}

.svc-card:hover[b-6nogm1vagd]::before {
    opacity: 0.9;
}

.svc-ic[b-6nogm1vagd] {
    width: 54px;
    height: 54px;
    border-radius: var(--radius-md);
    display: grid;
    place-items: center;
    background: var(--gradient-brand-soft);
    color: var(--color-brand-mint);
    margin-bottom: 22px;
    transition: transform 0.4s ease;
    flex-shrink: 0;
}

.svc-ic svg[b-6nogm1vagd], .svc-ic i[b-6nogm1vagd] {
    width: 26px;
    height: 26px;
}

.svc-card:hover .svc-ic[b-6nogm1vagd] {
    transform: scale(1.06) rotate(-3deg);
}

.svc-card h3[b-6nogm1vagd] {
    font-size: 1.28rem;
    margin-bottom: 10px;
}

.svc-card p[b-6nogm1vagd] {
    color: var(--color-text-muted);
    font-size: 0.96rem;
    line-height: 1.62;
}

.svc-card--lead[b-6nogm1vagd] {
    grid-column: 1 / -1;
    display: flex;
    gap: var(--space-10);
    align-items: flex-start;
}

.svc-card--lead .svc-ic[b-6nogm1vagd] {
    flex-shrink: 0;
    margin-top: 4px;
}

.svc-card--lead h3[b-6nogm1vagd] {
    font-size: clamp(var(--text-xl), 2.2vw, var(--text-2xl));
}


.tag-row[b-6nogm1vagd] {
    margin-top: 18px;
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
}

.svc-ai-banner[b-6nogm1vagd] {
    margin-top: 40px;
    display: flex;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
    padding: 24px 28px;
    border: 1px solid var(--color-border-subtle);
    border-radius: var(--radius-lg);
    background: linear-gradient(120deg, rgba(1,165,157,0.07), rgba(27,117,187,0.04));
}

.svc-ai-text[b-6nogm1vagd] {
    flex: 1;
    min-width: 260px;
}

.svc-ai-text h3[b-6nogm1vagd] {
    font-size: 1.15rem;
    margin-bottom: 4px;
}

.svc-ai-text p[b-6nogm1vagd] {
    font-size: 0.95rem;
    color: var(--color-text-muted);
}

/* ============================================================
   ABOUT
   ============================================================ */
.about-grid[b-6nogm1vagd] {
    display: grid;
    grid-template-columns: 0.82fr 1.18fr;
    gap: clamp(36px, 6vw, 72px);
    align-items: center;
}

.about-photo[b-6nogm1vagd] {
    position: relative;
}

.about-photo__frame[b-6nogm1vagd] {
    position: relative;
    border-radius: var(--radius-xl);
    overflow: hidden;
    background: linear-gradient(165deg, var(--color-bg-elevated), var(--color-bg-overlay));
    border: 1px solid var(--color-border-default);
    aspect-ratio: 4 / 4.7;
}

.about-photo__frame[b-6nogm1vagd]::after {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse 90% 60% at 50% 18%, rgba(1,165,157,0.3), transparent 60%);
    pointer-events: none;
}

.about-photo__frame img[b-6nogm1vagd] {
    position: relative;
    z-index: 1;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top center;
    display: block;
}

.about-photo__badge[b-6nogm1vagd] {
    position: absolute;
    bottom: -22px;
    right: -16px;
    z-index: 3;
    background: rgba(10,19,48,0.92);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid var(--color-border-default);
    border-radius: var(--radius-md);
    padding: 16px 20px;
    box-shadow: var(--shadow-md);
    text-align: center;
}

.about-photo__num[b-6nogm1vagd] {
    font-family: var(--font-display);
    font-weight: var(--font-extrabold);
    font-size: 1.7rem;
    line-height: 1;
    color: var(--color-brand-mint);
}

.about-photo__lbl[b-6nogm1vagd] {
    font-size: 0.72rem;
    color: var(--color-text-muted);
    margin-top: 5px;
    letter-spacing: 0.05em;
}

.about-text h2[b-6nogm1vagd] {
    font-size: clamp(1.9rem, 4vw, 3rem);
    margin: 16px 0 0;
}

.about-lead[b-6nogm1vagd] {
    margin-top: 22px;
    font-size: 1.12rem;
    color: var(--color-text-secondary);
    line-height: 1.7;
}

.about-text p[b-6nogm1vagd] {
    color: var(--color-text-muted);
    margin-top: 16px;
    line-height: 1.7;
}

.about-creds[b-6nogm1vagd] {
    margin-top: 30px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
}

.cred[b-6nogm1vagd] {
    display: flex;
    gap: 13px;
    align-items: flex-start;
    padding: 16px;
    border: 1px solid var(--color-border-subtle);
    border-radius: var(--radius-md);
    background: rgba(255,255,255,0.02);
}

.cred svg[b-6nogm1vagd], .cred i[b-6nogm1vagd] {
    width: 22px;
    height: 22px;
    color: var(--color-brand-teal);
    flex: none;
    margin-top: 2px;
}

.cred .ct[b-6nogm1vagd] {
    font-weight: var(--font-semibold);
    font-size: 0.96rem;
    color: var(--color-text-primary);
}

.cred .cs[b-6nogm1vagd] {
    font-size: 0.82rem;
    color: var(--color-text-muted);
    margin-top: 2px;
}

.signature[b-6nogm1vagd] {
    margin-top: 30px;
    font-family: var(--font-display);
    font-style: italic;
    font-weight: var(--font-semibold);
    font-size: 1.5rem;
    color: var(--color-text-secondary);
}

/* ============================================================
   PROJECTS
   ============================================================ */
.proj-grid[b-6nogm1vagd] {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 20px;
}

.proj[b-6nogm1vagd] {
    position: relative;
    border-radius: var(--radius-lg);
    overflow: hidden;
    padding: 34px;
    border: 1px solid var(--color-border-subtle);
    background: var(--color-bg-surface);
    min-height: 280px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    transition: transform 0.4s ease, border-color 0.4s ease;
}

.proj:hover[b-6nogm1vagd] {
    transform: translateY(-5px);
    border-color: var(--color-border-default);
}

.proj-bg[b-6nogm1vagd] {
    position: absolute;
    inset: 0;
    opacity: 0.5;
    transition: opacity 0.5s ease, transform 0.8s ease;
}

.proj:hover .proj-bg[b-6nogm1vagd] {
    opacity: 0.8;
    transform: scale(1.04);
}

.proj-span-4[b-6nogm1vagd] { grid-column: span 4; }
.proj-span-3[b-6nogm1vagd] { grid-column: span 3; }
.proj-span-2[b-6nogm1vagd] { grid-column: span 2; }

.pat-mesh[b-6nogm1vagd] {
    background-image: radial-gradient(circle at 1px 1px, rgba(127,188,229,0.25) 1px, transparent 0);
    background-size: 22px 22px;
}

.pat-glow-tl[b-6nogm1vagd] {
    background: radial-gradient(ellipse 60% 70% at 15% 10%, rgba(1,165,157,0.4), transparent 60%);
}

.pat-glow-br[b-6nogm1vagd] {
    background: radial-gradient(ellipse 70% 80% at 90% 100%, rgba(27,117,187,0.45), transparent 60%);
}

.pat-lines[b-6nogm1vagd] {
    background-image: repeating-linear-gradient(115deg, rgba(255,255,255,0.05) 0 1px, transparent 1px 16px);
}

.proj-tag[b-6nogm1vagd] {
    position: relative;
    z-index: 2;
    align-self: flex-start;
    font-size: 0.7rem;
    font-weight: var(--font-bold);
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--color-brand-mint);
    margin-bottom: auto;
}

.proj h3[b-6nogm1vagd] {
    position: relative;
    z-index: 2;
    font-size: 1.5rem;
    margin-top: 18px;
}

.proj p[b-6nogm1vagd] {
    position: relative;
    z-index: 2;
    color: var(--color-text-secondary);
    margin-top: 10px;
    font-size: 0.95rem;
    max-width: 52ch;
    line-height: 1.6;
}

.proj .meta[b-6nogm1vagd] {
    position: relative;
    z-index: 2;
    margin-top: 18px;
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.proj .arrow[b-6nogm1vagd] {
    position: absolute;
    top: 30px;
    right: 30px;
    z-index: 2;
    width: 42px;
    height: 42px;
    border-radius: 50%;
    border: 1px solid var(--color-border-default);
    display: grid;
    place-items: center;
    color: var(--color-text-secondary);
    text-decoration: none;
    transition: background 0.3s ease, border-color 0.3s ease, color 0.3s ease, transform 0.3s ease;
}

.proj .arrow svg[b-6nogm1vagd], .proj .arrow i[b-6nogm1vagd] {
    width: 18px;
    height: 18px;
}

.proj:hover .arrow[b-6nogm1vagd] {
    background: var(--gradient-brand);
    border-color: transparent;
    color: #fff;
    transform: rotate(-45deg);
}


/* ============================================================
   PROCESS
   ============================================================ */
.proc-grid[b-6nogm1vagd] {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 0;
    position: relative;
}

.proc-step[b-6nogm1vagd] {
    padding: 30px 22px;
    position: relative;
}

.proc-step:not(:last-child)[b-6nogm1vagd]::after {
    content: '';
    position: absolute;
    top: 48px;
    right: -1px;
    width: 1px;
    height: calc(100% - 48px);
    background: var(--color-border-subtle);
}

.proc-step .nm[b-6nogm1vagd] {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: 1.5px solid var(--color-border-default);
    background: var(--color-bg-surface);
    position: relative;
    margin-bottom: 22px;
    flex-shrink: 0;
    transition: background 0.35s var(--ease-out-expo), border-color 0.35s var(--ease-out-expo), box-shadow 0.35s var(--ease-out-expo);
}

.proc-step .nm[b-6nogm1vagd]::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 14px;
    height: 14px;
    transform: translate(-50%, -50%) scale(0.7);
    border-radius: 50%;
    background: var(--color-brand-teal);
    opacity: 0.4;
    transition: opacity 0.35s var(--ease-out-expo), transform 0.35s var(--ease-out-expo);
}

.proc-step.active .nm[b-6nogm1vagd] {
    background: rgba(1,165,157,0.1);
    border-color: var(--color-brand-teal);
    box-shadow: 0 0 0 4px rgba(1,165,157,0.1);
}

.proc-step.active .nm[b-6nogm1vagd]::after {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1);
}

.proc-step h4[b-6nogm1vagd] { font-size: 1.18rem; margin-bottom: 9px; }
.proc-step p[b-6nogm1vagd] { font-size: 0.9rem; color: var(--color-text-muted); line-height: 1.6; }

.proc-line[b-6nogm1vagd] {
    position: absolute;
    top: 78px;
    left: 0;
    height: 1px;
    background: var(--gradient-brand);
    width: 0;
    transition: width 1.4s var(--ease-out-expo);
    z-index: 0;
}

/* ============================================================
   TECH STACK
   ============================================================ */
.tech-cloud[b-6nogm1vagd] {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    justify-content: center;
    max-width: 920px;
    margin: 0 auto;
}
.tech-pill[b-6nogm1vagd] {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 14px 22px;
    border: 1px solid var(--color-border-subtle);
    border-radius: var(--radius-full);
    background: rgba(255,255,255,0.025);
    font-weight: var(--font-semibold);
    font-size: 1rem;
    color: var(--color-text-primary);
    cursor: default;
    transition: transform 0.3s ease, border-color 0.3s ease, background 0.3s ease, color 0.3s ease;
}
.tech-pill .d[b-6nogm1vagd] {
    width: 9px; height: 9px;
    border-radius: 50%;
    background: var(--color-brand-teal);
    transition: transform 0.3s ease;
    flex-shrink: 0;
}
.tech-pill:hover[b-6nogm1vagd] {
    transform: translateY(-4px) scale(1.04);
    border-color: transparent;
    background: var(--gradient-brand);
    color: #fff;
    box-shadow: 0 12px 30px rgba(1,165,157,0.3);
}
.tech-pill:hover .d[b-6nogm1vagd] { background: #fff; transform: scale(1.4); }
.tech-pill--lg[b-6nogm1vagd] { font-size: 1.25rem; padding: 16px 28px; }
.tech-pill--sm[b-6nogm1vagd] { font-size: 0.9rem; padding: 11px 18px; opacity: 0.82; }

/* ============================================================
   PRICING
   ============================================================ */
.price-grid[b-6nogm1vagd] {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 22px;
    align-items: stretch;
}
.price-card[b-6nogm1vagd] {
    position: relative;
    border: 1px solid var(--color-border-subtle);
    border-radius: var(--radius-lg);
    padding: 36px 32px;
    background: var(--color-bg-surface);
    display: flex;
    flex-direction: column;
    transition: transform 0.4s ease;
}
.price-card:hover[b-6nogm1vagd] { transform: translateY(-6px); }
.price-card--pop[b-6nogm1vagd] {
    border-color: transparent;
    background: linear-gradient(180deg, rgba(1,165,157,0.10), rgba(27,117,187,0.05));
}
.price-card--pop[b-6nogm1vagd]::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: inherit;
    padding: 1.5px;
    background: var(--gradient-brand);
    -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
    -webkit-mask-composite: xor;
            mask-composite: exclude;
    pointer-events: none;
}
.price-badge[b-6nogm1vagd] {
    position: absolute;
    top: -13px; left: 50%;
    transform: translateX(-50%);
    background: var(--gradient-brand);
    color: #fff;
    font-size: 0.7rem;
    font-weight: var(--font-bold);
    letter-spacing: 0.1em;
    text-transform: uppercase;
    padding: 6px 16px;
    border-radius: var(--radius-full);
    white-space: nowrap;
}
.pname[b-6nogm1vagd] { font-family: var(--font-display); font-weight: var(--font-bold); font-size: 1.3rem; color: var(--color-text-primary); }
.pdesc[b-6nogm1vagd] { color: var(--color-text-muted); font-size: 0.9rem; margin-top: 8px; min-height: 42px; }
.pprice[b-6nogm1vagd] { margin: 22px 0 6px; font-family: var(--font-display); font-weight: var(--font-extrabold); font-size: 2.6rem; line-height: 1; color: var(--color-text-primary); }
.pprice small[b-6nogm1vagd] { font-size: 0.9rem; color: var(--color-text-muted); font-weight: var(--font-medium); font-family: var(--font-sans); }
.pnote[b-6nogm1vagd] { font-size: 0.8rem; color: var(--color-text-muted); margin-bottom: var(--space-5); }
.price-feats[b-6nogm1vagd] { list-style: none; padding: 0; margin: 0 0 var(--space-6) 0; display: flex; flex-direction: column; gap: 13px; flex: 1; }
.price-feats li[b-6nogm1vagd] { display: flex; gap: 11px; align-items: flex-start; font-size: 0.92rem; color: var(--color-text-secondary); }
.price-feats li svg[b-6nogm1vagd], .price-feats li i[b-6nogm1vagd] { width: 19px; height: 19px; color: var(--color-brand-teal); flex: none; margin-top: 2px; }
.price-card .as-btn[b-6nogm1vagd] { width: 100%; justify-content: center; }
.price-note[b-6nogm1vagd] { text-align: center; margin-top: 28px; font-size: 0.9rem; color: var(--color-text-faint); }

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.quotes[b-6nogm1vagd] {
	display: grid;
	grid-template-columns: 1.3fr 1fr 1fr;
	gap: 20px;
	align-items: start;
}

.quote[b-6nogm1vagd] {
	padding: 32px 30px;
	border: 1px solid var(--color-border-subtle);
	border-radius: var(--radius-lg);
	background: var(--color-bg-surface);
	position: relative;
	margin: 0;
}

.stars[b-6nogm1vagd] {
	display: flex;
	gap: 3px;
	margin-bottom: 16px;
}

.stars svg[b-6nogm1vagd], .stars i[b-6nogm1vagd] {
	width: 16px;
	height: 16px;
	color: #FEBC2E;
	fill: #FEBC2E;
}

.quote p[b-6nogm1vagd] {
	color: var(--color-text-secondary);
	font-size: 1.02rem;
	line-height: 1.7;
}

.quote .who[b-6nogm1vagd] {
	margin-top: 22px;
	display: flex;
	align-items: center;
	gap: 13px;
}

.quote .who > span:last-child[b-6nogm1vagd] {
	display: flex;
	flex-direction: column;
}

.quote .av[b-6nogm1vagd] {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background: var(--gradient-brand-soft);
	border: 1px solid var(--color-border-default);
	display: grid;
	place-items: center;
	font-family: var(--font-display);
	font-weight: var(--font-bold);
	color: var(--color-brand-mint);
	flex: none;
	font-size: 0.9rem;
}

.quote .wn[b-6nogm1vagd] { font-weight: var(--font-semibold); font-size: 0.92rem; display: block; color: var(--color-text-primary); }
.quote .wr[b-6nogm1vagd] { font-size: 0.8rem; color: var(--color-text-muted); display: block; }

/* ============================================================
   FAQ
   ============================================================ */
.faq-list[b-6nogm1vagd] {
	max-width: 860px;
	margin: 0 auto;
}

.faq-item[b-6nogm1vagd] {
	border-bottom: 1px solid var(--color-border-subtle);
}

.faq-q[b-6nogm1vagd] {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
	padding: 26px 4px;
	text-align: left;
	background: none;
	border: none;
	cursor: pointer;
	font-family: var(--font-display);
	font-weight: var(--font-semibold);
	font-size: 1.14rem;
	color: var(--color-text-primary);
	transition: color 0.2s ease;
}

.faq-q:hover[b-6nogm1vagd] { color: var(--color-brand-mint); }

.faq-q .pm[b-6nogm1vagd] {
	width: 28px;
	height: 28px;
	flex: none;
	border-radius: 50%;
	border: 1px solid var(--color-border-default);
	display: grid;
	place-items: center;
	color: var(--color-text-secondary);
	transition: background 0.3s var(--ease-out-quart), border-color 0.3s var(--ease-out-quart), color 0.3s var(--ease-out-quart);
}

.faq-q .pm svg[b-6nogm1vagd], .faq-q .pm i[b-6nogm1vagd] {
	width: 15px;
	height: 15px;
	transition: transform 0.35s var(--ease-out-expo);
}

.faq-item.open .faq-q .pm[b-6nogm1vagd] {
	background: var(--gradient-brand);
	border-color: transparent;
	color: #fff;
}

.faq-item.open .faq-q .pm svg[b-6nogm1vagd],
.faq-item.open .faq-q .pm i[b-6nogm1vagd] { transform: rotate(45deg); }

.faq-a[b-6nogm1vagd] {
	display: grid;
	grid-template-rows: 0fr;
	transition: grid-template-rows 0.42s var(--ease-out-quart);
}

.faq-item.open .faq-a[b-6nogm1vagd] {
	grid-template-rows: 1fr;
}

.faq-a-inner[b-6nogm1vagd] {
	overflow: hidden;
	min-height: 0;
	padding: 0 4px 26px;
	color: var(--color-text-muted);
	line-height: 1.7;
	max-width: 92%;
	font-size: 0.98rem;
}

/* ============================================================
   CONTACT
   ============================================================ */
.contact-grid[b-6nogm1vagd] {
	display: grid;
	grid-template-columns: 0.72fr 1fr;
	gap: clamp(30px, 5vw, 60px);
}

.contact-info h2[b-6nogm1vagd] { font-size: clamp(2rem, 4vw, 3rem); }

.contact-lead[b-6nogm1vagd] {
	color: var(--color-text-secondary);
	font-size: 1.1rem;
	margin-top: 18px;
	line-height: 1.7;
}

.contact-list[b-6nogm1vagd] {
	margin-top: 36px;
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.contact-item[b-6nogm1vagd] {
	display: flex;
	gap: 16px;
	align-items: center;
	padding: 16px;
	border-radius: var(--radius-md);
	text-decoration: none;
	color: inherit;
	transition: background 0.25s ease;
}

.contact-item:hover[b-6nogm1vagd] { background: rgba(255,255,255,0.03); }

.contact-item .ci[b-6nogm1vagd] {
	width: 46px;
	height: 46px;
	border-radius: var(--radius-md);
	display: grid;
	place-items: center;
	background: var(--gradient-brand-soft);
	color: var(--color-brand-mint);
	flex: none;
}

.contact-item .ci svg[b-6nogm1vagd], .contact-item .ci i[b-6nogm1vagd] { width: 21px; height: 21px; }

.contact-item .cl[b-6nogm1vagd] {
	font-size: 0.76rem;
	color: var(--color-text-muted);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	display: block;
}

.contact-item .cv[b-6nogm1vagd] {
	font-weight: var(--font-semibold);
	font-size: 1.02rem;
	color: var(--color-text-primary);
	margin-top: 2px;
	display: block;
	transition: color 0.2s ease;
}

.contact-item:hover .cv[b-6nogm1vagd] { color: var(--color-brand-mint); }

.form-card[b-6nogm1vagd] {
	background: var(--color-bg-surface);
	border: 1px solid var(--color-border-subtle);
	border-radius: var(--radius-lg);
	padding: clamp(26px, 4vw, 40px);
	box-shadow: var(--shadow-md);
}

.field[b-6nogm1vagd] { margin-bottom: 20px; }

.field label[b-6nogm1vagd] {
	display: block;
	font-size: 0.78rem;
	font-weight: var(--font-semibold);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--color-text-muted);
	margin-bottom: 9px;
}

.field input[b-6nogm1vagd],
.field textarea[b-6nogm1vagd] {
	width: 100%;
	background: rgba(255,255,255,0.03);
	border: 1px solid var(--color-border-default);
	border-radius: var(--radius-sm);
	padding: 14px 16px;
	color: var(--color-text-primary);
	font-family: var(--font-sans);
	font-size: 0.98rem;
	transition: border-color 0.25s ease, background 0.25s ease;
	resize: vertical;
}

.field input:focus[b-6nogm1vagd],
.field textarea:focus[b-6nogm1vagd] {
	outline: none;
	border-color: var(--color-brand-teal);
	background: rgba(1,165,157,0.05);
}

.field input[b-6nogm1vagd]::placeholder,
.field textarea[b-6nogm1vagd]::placeholder { color: var(--color-text-faint); }

.field input.has-error[b-6nogm1vagd],
.field textarea.has-error[b-6nogm1vagd] {
    border-color: var(--color-error) !important;
    background: rgba(239,68,68,0.04);
}

.field-err[b-6nogm1vagd] {
    display: block;
    font-size: 0.76rem;
    color: var(--color-error);
    margin-top: var(--space-2);
}

.field--row2[b-6nogm1vagd] {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
}

.form-note[b-6nogm1vagd] {
	font-size: 0.78rem;
	color: var(--color-text-faint);
	margin-top: 14px;
	text-align: center;
	line-height: 1.5;
}

.form-success[b-6nogm1vagd] { display: none; text-align: center; padding: 30px 10px; }
.form-success.show[b-6nogm1vagd] { display: block; }

.form-success .ok[b-6nogm1vagd] {
	width: 64px;
	height: 64px;
	border-radius: 50%;
	background: var(--gradient-brand);
	display: grid;
	place-items: center;
	margin: 0 auto 20px;
	box-shadow: var(--glow-teal);
}

.form-success .ok svg[b-6nogm1vagd], .form-success .ok i[b-6nogm1vagd] { width: 30px; height: 30px; color: #fff; }
.form-success h3[b-6nogm1vagd] { font-size: 1.4rem; color: var(--color-text-primary); }
.form-success p[b-6nogm1vagd] { margin-top: 10px; color: var(--color-text-muted); line-height: 1.6; }

/* ============================================================
   REVEAL ANIMATIONS
   ============================================================ */
@keyframes revealUp-b-6nogm1vagd {
	from { opacity: 0; transform: translateY(22px); }
	to   { opacity: 1; transform: none; }
}

@keyframes heroEnter-b-6nogm1vagd {
	from { opacity: 0; transform: translateY(36px); }
	to   { opacity: 1; transform: none; }
}

@keyframes heroPortraitEnter-b-6nogm1vagd {
	from { opacity: 0; transform: scale(0.94) translateY(20px); }
	to   { opacity: 1; transform: none; }
}

@keyframes shake-b-6nogm1vagd {
	0%, 100% { transform: none; }
	18%       { transform: translateX(-7px); }
	36%       { transform: translateX(7px); }
	54%       { transform: translateX(-4px); }
	72%       { transform: translateX(4px); }
}

.field-shake[b-6nogm1vagd] {
	animation: shake-b-6nogm1vagd 0.42s var(--ease-out-quart);
}

@media (prefers-reduced-motion: no-preference) {
	html.js-reveal .reveal:not(.in)[b-6nogm1vagd] {
		opacity: 0;
		transform: translateY(22px);
	}

	html.js-reveal .reveal.in[b-6nogm1vagd] {
		animation: revealUp-b-6nogm1vagd 0.65s var(--ease-out-expo) both;
	}

	html.js-reveal .reveal.in.d1[b-6nogm1vagd] { animation-delay: 0.08s; }
	html.js-reveal .reveal.in.d2[b-6nogm1vagd] { animation-delay: 0.16s; }
	html.js-reveal .reveal.in.d3[b-6nogm1vagd] { animation-delay: 0.24s; }
	html.js-reveal .reveal.in.d4[b-6nogm1vagd] { animation-delay: 0.32s; }

	/* Hero entrance — more dramatic, tighter sequence */
	html.js-reveal .hero .reveal.in[b-6nogm1vagd] {
		animation: heroEnter-b-6nogm1vagd 0.9s var(--ease-out-expo) both;
	}
	html.js-reveal .hero .reveal.in.d1[b-6nogm1vagd] { animation-delay: 0.12s; }
	html.js-reveal .hero .reveal.in.d2[b-6nogm1vagd] { animation-delay: 0.22s; }
	html.js-reveal .hero .reveal.in.d3[b-6nogm1vagd] { animation-delay: 0.36s; }
	html.js-reveal .hero .reveal.in.d4[b-6nogm1vagd] { animation-delay: 0.52s; }
	html.js-reveal .hero .portrait-wrap.reveal.in[b-6nogm1vagd] {
		animation: heroPortraitEnter-b-6nogm1vagd 1.1s var(--ease-out-expo) 0.2s both;
	}

	html.js-reveal .reveal.shown[b-6nogm1vagd] {
		animation: none !important;
		opacity: 1 !important;
		transform: none !important;
	}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1080px) {
	.svc-grid[b-6nogm1vagd] { grid-template-columns: 1fr; }
	.svc-card--lead[b-6nogm1vagd] { flex-direction: column; }
	.proj-grid[b-6nogm1vagd] { grid-template-columns: repeat(4, 1fr); }
	.proj-span-4[b-6nogm1vagd], .proj-span-3[b-6nogm1vagd], .proj-span-2[b-6nogm1vagd] { grid-column: span 2; }
	.quotes[b-6nogm1vagd] { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 900px) {
	.hero[b-6nogm1vagd] { padding-bottom: 60px; min-height: auto; }
	.hero-inner[b-6nogm1vagd] { grid-template-columns: 1fr; gap: 50px; }
	.portrait-wrap[b-6nogm1vagd] { max-width: 360px; order: -1; margin: 0 auto; }
	/* Float cards use negative offsets that overflow in single-column layout */
	.fc-1[b-6nogm1vagd], .fc-2[b-6nogm1vagd], .fc-3[b-6nogm1vagd] { display: none; }
	.about-grid[b-6nogm1vagd] { grid-template-columns: 1fr; }
	.about-photo[b-6nogm1vagd] { max-width: 380px; margin: 0 auto; }
	/* Prevent badge from bleeding outside its container on narrow screens */
	.about-photo__badge[b-6nogm1vagd] { right: 0; bottom: -10px; }
	.contact-grid[b-6nogm1vagd] { grid-template-columns: 1fr; }
	.proc-grid[b-6nogm1vagd] { grid-template-columns: 1fr 1fr; }
	.proc-step:not(:last-child)[b-6nogm1vagd]::after { display: none; }
	.quotes[b-6nogm1vagd] { grid-template-columns: 1fr; }
	.price-grid[b-6nogm1vagd] { grid-template-columns: 1fr; max-width: 460px; margin: 0 auto; }
}

@media (max-width: 560px) {
	.svc-grid[b-6nogm1vagd], .proj-grid[b-6nogm1vagd] { grid-template-columns: 1fr; }
	.proj-span-4[b-6nogm1vagd], .proj-span-3[b-6nogm1vagd], .proj-span-2[b-6nogm1vagd] { grid-column: span 1; }
	.field--row2[b-6nogm1vagd] { grid-template-columns: 1fr; }
	.about-creds[b-6nogm1vagd] { grid-template-columns: 1fr; }
	.proc-grid[b-6nogm1vagd] { grid-template-columns: 1fr; }
	.hero-trust .sep[b-6nogm1vagd] { display: none; }
	/* Allow the hero accent text to wrap on narrow phones to prevent overflow */
	.hero-accent[b-6nogm1vagd] { white-space: normal; }
	/* Stack the AI-banner vertically and remove min-width so it doesn't overflow */
	.svc-ai-banner[b-6nogm1vagd] { flex-direction: column; align-items: flex-start; }
	.svc-ai-text[b-6nogm1vagd] { min-width: 0; }
}

@media (max-width: 420px) {
	.portrait-wrap[b-6nogm1vagd] { max-width: 260px; }
	.svc-card[b-6nogm1vagd] { padding: 24px 20px; }
	.price-card[b-6nogm1vagd] { padding: 28px 22px; }
	.proj[b-6nogm1vagd] { padding: 24px; }
	.proc-step[b-6nogm1vagd] { padding: 22px 16px; }
}

/* ── Konfigurator teaser (Pricing section) ── */
.kfg-teaser[b-6nogm1vagd] {
	display: flex;
	align-items: center;
	gap: 1.25rem;
	margin-top: 2.5rem;
	padding: 1.25rem 1.5rem;
	background: rgba(1, 165, 157, 0.07);
	border: 1px solid rgba(1, 165, 157, 0.22);
	border-radius: 14px;
	flex-wrap: wrap;
}

.kfg-teaser__icon[b-6nogm1vagd] {
	width: 40px;
	height: 40px;
	border-radius: 10px;
	background: rgba(1, 165, 157, 0.15);
	display: grid;
	place-items: center;
	flex-shrink: 0;
	color: #01A59D;
}

.kfg-teaser__icon i[b-6nogm1vagd],
.kfg-teaser__icon svg[b-6nogm1vagd] { width: 18px; height: 18px; }

.kfg-teaser__text[b-6nogm1vagd] {
	flex: 1;
	min-width: 200px;
	font-size: 0.875rem;
	color: #8A99B8;
	line-height: 1.6;
}

.kfg-teaser__text strong[b-6nogm1vagd] {
	display: block;
	color: #F4F8FF;
	font-weight: 600;
	margin-bottom: 0.2rem;
}

.kfg-teaser__cta[b-6nogm1vagd] {
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
	padding: 0.6rem 1.25rem;
	background: linear-gradient(120deg, #01A59D 0%, #1B9FB8 48%, #1B75BB 100%);
	color: #fff;
	font-size: 0.875rem;
	font-weight: 600;
	border-radius: 9999px;
	text-decoration: none;
	white-space: nowrap;
	flex-shrink: 0;
	transition: box-shadow 0.25s ease, transform 0.25s ease;
}

.kfg-teaser__cta i[b-6nogm1vagd],
.kfg-teaser__cta svg[b-6nogm1vagd] { width: 14px; height: 14px; }

.kfg-teaser__cta:hover[b-6nogm1vagd] {
	box-shadow: 0 4px 20px rgba(1, 165, 157, 0.45);
	transform: translateY(-1px);
	color: #fff;
}

/* ── Hero "Preis berechnen" link ── */
.hero-kfg-link[b-6nogm1vagd] {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	margin-top: 0.75rem;
	font-size: 0.875rem;
	font-weight: 500;
	color: #8A99B8;
	text-decoration: none;
	transition: color 0.2s ease, gap 0.2s ease;
}

.hero-kfg-link i[b-6nogm1vagd],
.hero-kfg-link svg[b-6nogm1vagd] { width: 15px; height: 15px; }

.hero-kfg-link:hover[b-6nogm1vagd] {
	color: #92F4EC;
	gap: 0.65rem;
}
/* /Components/Pages/Impressum.razor.rz.scp.css */
/* ============================================================
   Legal pages — Impressum & Datenschutz
   Shared styles via scoped CSS on Impressum.razor;
   Datenschutz.razor.css imports the same rules.
   ============================================================ */

/* ---- Page shell ---- */
.legal-page[b-0bgc1v8yxb] {
    min-height: 100dvh;
    background: var(--color-bg-base);
    display: flex;
    flex-direction: column;
}

/* ---- Hero ---- */
.legal-hero[b-0bgc1v8yxb] {
    position: relative;
    padding: clamp(6rem, 14vw, 9rem) 0 clamp(3rem, 6vw, 4.5rem);
    border-bottom: 1px solid var(--color-border-subtle);
    overflow: hidden;
}

.legal-hero__glow[b-0bgc1v8yxb] {
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse 60% 80% at 20% 50%, rgba(1, 165, 157, 0.07) 0%, transparent 70%),
        radial-gradient(ellipse 40% 60% at 80% 20%, rgba(27, 117, 187, 0.05) 0%, transparent 70%);
    pointer-events: none;
}

.legal-hero__inner[b-0bgc1v8yxb] {
    max-width: 1240px;
    margin: 0 auto;
    padding: 0 clamp(1.25rem, 5vw, 4rem);
    position: relative;
    z-index: 1;
}

/* ---- Back link ---- */
.legal-back[b-0bgc1v8yxb] {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--color-text-muted);
    text-decoration: none;
    font-size: var(--text-sm);
    font-weight: var(--font-medium);
    margin-bottom: clamp(1.5rem, 4vw, 2.5rem);
    transition: color 0.2s ease, gap 0.2s ease;
}

.legal-back i[b-0bgc1v8yxb] {
    width: 16px;
    height: 16px;
    transition: transform 0.2s ease;
}

.legal-back:hover[b-0bgc1v8yxb] {
    color: var(--color-brand-mint);
    gap: 0.75rem;
}

.legal-back:hover i[b-0bgc1v8yxb] {
    transform: translateX(-3px);
}

/* ---- Hero title ---- */
.legal-hero__title[b-0bgc1v8yxb] {
    font-family: var(--font-display);
    font-weight: var(--font-extrabold);
    font-size: clamp(2.5rem, 6vw, 4rem);
    letter-spacing: -0.03em;
    line-height: var(--leading-tight);
    color: var(--color-text-primary);
    text-wrap: balance;
    margin: 0 0 var(--space-3);
}

.legal-hero__sub[b-0bgc1v8yxb] {
    font-size: var(--text-base);
    color: var(--color-text-muted);
    margin: 0;
}

/* ---- Body wrapper ---- */
.legal-body[b-0bgc1v8yxb] {
    flex: 1;
    padding: clamp(3rem, 8vw, 6rem) 0 clamp(4rem, 10vw, 8rem);
}

/* ---- Content column ---- */
.legal-content[b-0bgc1v8yxb] {
    max-width: 720px;
    margin: 0 auto;
    padding: 0 clamp(1.25rem, 5vw, 4rem);
}

/* ---- Sections ---- */
.legal-section[b-0bgc1v8yxb] {
    padding-bottom: clamp(2rem, 5vw, 3.5rem);
    margin-bottom: clamp(2rem, 5vw, 3.5rem);
    border-bottom: 1px solid var(--color-border-subtle);
}

.legal-section:last-child[b-0bgc1v8yxb] {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: 0;
}

/* ---- Headings ---- */
.legal-section h2[b-0bgc1v8yxb] {
    font-family: var(--font-display);
    font-weight: var(--font-bold);
    font-size: clamp(1.125rem, 2.5vw, 1.375rem);
    letter-spacing: -0.01em;
    color: var(--color-text-primary);
    margin: 0 0 var(--space-5);
}

.legal-section h3[b-0bgc1v8yxb] {
    font-family: var(--font-sans);
    font-weight: var(--font-semibold);
    font-size: var(--text-base);
    color: var(--color-brand-mint);
    letter-spacing: 0.01em;
    margin: var(--space-8) 0 var(--space-3);
}

.legal-section h3:first-child[b-0bgc1v8yxb] {
    margin-top: 0;
}

/* ---- Body text ---- */
.legal-section p[b-0bgc1v8yxb] {
    font-size: var(--text-base);
    line-height: var(--leading-relaxed);
    color: var(--color-text-secondary);
    margin: 0 0 var(--space-4);
    max-width: 68ch;
}

.legal-section p:last-child[b-0bgc1v8yxb] {
    margin-bottom: 0;
}

.legal-section ul[b-0bgc1v8yxb] {
    margin: 0 0 var(--space-4);
    padding-left: var(--space-5);
    list-style: none;
}

.legal-section ul li[b-0bgc1v8yxb] {
    position: relative;
    font-size: var(--text-base);
    line-height: var(--leading-relaxed);
    color: var(--color-text-secondary);
    padding: var(--space-1) 0 var(--space-1) var(--space-5);
    margin-bottom: var(--space-2);
}

.legal-section ul li[b-0bgc1v8yxb]::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.7em;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--color-brand-teal);
    box-shadow: 0 0 8px rgba(1, 165, 157, 0.5);
}

.legal-section strong[b-0bgc1v8yxb] {
    color: var(--color-text-primary);
    font-weight: var(--font-semibold);
}

/* ---- Links ---- */
.legal-section a[b-0bgc1v8yxb],
.legal-back[b-0bgc1v8yxb] {
    color: var(--color-brand-teal);
    text-decoration: none;
    transition: color 0.2s ease;
}

.legal-section a:hover[b-0bgc1v8yxb] {
    color: var(--color-brand-mint);
    text-decoration: underline;
    text-underline-offset: 3px;
}

/* ---- Reduced motion ---- */
@media (prefers-reduced-motion: reduce) {
    .legal-back[b-0bgc1v8yxb],
    .legal-back i[b-0bgc1v8yxb] {
        transition: none;
    }
}
