:root { --bg: #eef3f8; --bg-strong: #dce5ef; --surface: rgba(255, 255, 255, 0.94); --surface-solid: #ffffff; --surface-muted: #f7f9fc; --text: #172134; --muted: #5f6c83; --border: #d9e2ec; --accent: #0570d5; --accent-strong: #045fc2; --accent-soft: #e9f4ff; --warm: #e36a11; --shadow: 0 18px 45px rgba(23, 33, 52, 0.08); --radius: 28px; --radius-sm: 20px; --container: 1280px; --content: 760px; --font-size-base: 0.9375rem; --font-size-small: 0.8125rem; --font-size-heading-compact: 1.125rem; --font-size-heading-sm: clamp(1.22rem, 2.1vw, 1.5rem); --font-size-heading-md: clamp(1.45rem, 2.5vw, 2rem); --font-size-heading-lg: clamp(1.7rem, 2.9vw, 2.45rem); --font-size-heading-xl: clamp(2.25rem, 5vw, 4.1rem); --font-size-heading-xl-mobile: clamp(2rem, 12vw, 3rem); --font-size-heading-lg-mobile: clamp(1.45rem, 7vw, 1.95rem); --font-family-base: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; } *, *::before, *::after { box-sizing: border-box; } html { scroll-behavior: smooth; } @media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } } body { margin: 0; font-family: var(--font-family-base); font-size: var(--font-size-base); color: var(--text); background: radial-gradient(circle at top left, rgba(13, 128, 242, 0.12), transparent 32%), radial-gradient(circle at top right, rgba(227, 106, 17, 0.08), transparent 26%), linear-gradient(180deg, #eef3f8 0%, #f7f9fc 52%, #edf2f7 100%); line-height: 1.6; -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; } body.nav-open { overflow: hidden; } .text-small, .brand__copy small, .site-nav__submenu--nested a, .site-nav__overview, .language-switcher a, .language-switcher span, .menu-cv__note, .breadcrumbs__list, .section-kicker, .page-hero__meta, .article-hero__meta, .article-card__meta, .tag-list a, .article-card__meta span, .profile-card__qr span, .profile-card__qr-copy span, .profile-card__skills-grid .skill-meter__meta, .blog-rail__link strong, .blog-rail__tag strong, .blog-rail__post time, .meta-list span, .skill-meter__meta, .site-footer__bottom, .social-list--footer a, .pagination__summary, .legacy-timeline__meta--mobile { font-size: var(--font-size-small); } .profile-card__section h3, .content-flow h3, .feature-card h3, .service-card h3, .article-card h3, .home-main--legacy .legacy-card h3, .home-main--legacy .legacy-timeline__card h3 { font-size: var(--font-size-heading-compact); } .menu-cv__title, .profile-card__body h2, .profile-card__intro h2, .blog-rail__panel h2, .legacy-skill-orbit__ring > span { font-size: var(--font-size-heading-sm); } .section-head h2, .content-flow h2 { font-size: var(--font-size-heading-md); } .home-main--legacy .legacy-home-heading--center h2, .home-main--legacy .legacy-story-block h2 { font-size: var(--font-size-heading-lg); } .page-hero h1, .hero-panel h1, .article-hero h1 { font-size: var(--font-size-heading-xl); } img { display: block; max-width: 100%; } a { color: inherit; text-decoration: none; } a:hover { color: var(--accent-strong); } button, input, textarea { font: inherit; } button { cursor: pointer; } [hidden] { display: none !important; } ::selection { background: rgba(13, 128, 242, 0.22); } .sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); border: 0; white-space: nowrap; } .skip-link { position: absolute; top: 1rem; left: 1rem; z-index: 100; padding: 0.8rem 1rem; border-radius: 999px; background: var(--accent); color: #fff; transform: translateY(-180%); transition: transform 0.2s ease; } .skip-link:focus { transform: translateY(0); } a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible, summary:focus-visible, [tabindex]:not([tabindex="-1"]):focus-visible { outline: 3px solid rgba(4, 95, 194, 0.72); outline-offset: 3px; } .container { width: min(var(--container), calc(100% - 2rem)); margin: 0 auto; } .site-header { position: sticky; top: 0; z-index: 40; border-bottom: 1px solid rgba(217, 226, 236, 0.9); background: rgba(255, 255, 255, 0.88); -webkit-backdrop-filter: blur(18px); backdrop-filter: blur(18px); } .site-header__inner { display: grid; grid-template-columns: auto 1fr auto auto auto; align-items: center; gap: 1rem; min-height: 88px; } .brand { display: flex; align-items: center; gap: 0.95rem; min-width: 0; } .brand__mark { display: grid; place-items: center; width: 44px; height: 44px; border-radius: 14px; overflow: hidden; box-shadow: 0 12px 22px rgba(13, 128, 242, 0.16); flex: 0 0 auto; } .brand__logo { display: block; width: auto; height: clamp(50px, 5vw, 58px); max-width: none; object-fit: contain; flex: 0 0 auto; } .brand__media { display: block; flex: 0 0 auto; } .brand__copy { display: grid; min-width: 0; } .brand__copy strong { letter-spacing: 0.08em; text-transform: uppercase; white-space: nowrap; } .brand__copy small { color: var(--muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } .site-nav { justify-self: center; } .site-nav__list { display: flex; align-items: center; gap: 0.2rem; list-style: none; margin: 0; padding: 0; } .site-nav__item { position: relative; } .site-nav__item.has-children::after { content: ""; position: absolute; top: 100%; left: 0; width: max(100%, 260px); height: 18px; } .site-nav__link { display: inline-flex; align-items: center; padding: 0.85rem 1rem; border-radius: 999px; color: var(--muted); font-weight: 500; transition: background 0.2s ease, color 0.2s ease; } .site-nav__item.is-active > .site-nav__link, .site-nav__link:hover, .site-nav__link[aria-current='page'] { background: var(--accent-soft); color: var(--accent-strong); } .site-nav__item.has-children > .site-nav__link::after { content: ''; width: 7px; height: 7px; margin-left: 0.55rem; border-right: 1.5px solid currentColor; border-bottom: 1.5px solid currentColor; transform: rotate(45deg) translateY(-1px); } .site-nav__dropdown { position: absolute; top: calc(100% + 6px); left: 0; min-width: 260px; padding: 1rem; border: 1px solid var(--border); border-radius: 24px; background: var(--surface-solid); box-shadow: var(--shadow); opacity: 0; transform: translateY(12px); pointer-events: none; transition: opacity 0.2s ease, transform 0.2s ease; } .site-nav__item:hover .site-nav__dropdown, .site-nav__item:focus-within .site-nav__dropdown { opacity: 1; transform: translateY(0); pointer-events: auto; } .site-nav__submenu { list-style: none; margin: 0 0 0.85rem; padding: 0; display: grid; gap: 0.35rem; } .site-nav__submenu a { display: block; padding: 0.7rem 0.8rem; border-radius: 16px; color: var(--muted); transition: background 0.2s ease, color 0.2s ease; } .site-nav__submenu a:hover, .site-nav__submenu a.is-active { background: var(--accent-soft); color: var(--accent-strong); } .site-nav__submenu-item { position: relative; } .site-nav__submenu--nested { position: absolute; top: -0.5rem; left: calc(100% - 0.5rem); width: 240px; padding: 0.75rem; border: 1px solid var(--border); border-radius: 20px; background: var(--surface-solid); box-shadow: var(--shadow); opacity: 0; visibility: hidden; transform: translateX(10px); transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s; z-index: 10; display: grid; gap: 0.2rem; } .site-nav__submenu-item:hover > .site-nav__submenu--nested { opacity: 1; visibility: visible; transform: translateX(0); } .site-nav__submenu--nested a { padding: 0.5rem 0.75rem; } .site-nav__overview { display: inline-flex; align-items: center; gap: 0.5rem; color: var(--accent-strong); font-weight: 600; } .site-nav__overview::after, .text-link::after, .back-link::before { content: ''; width: 0.55rem; height: 0.55rem; border-top: 2px solid currentColor; border-right: 2px solid currentColor; } .site-nav__overview::after, .text-link::after { transform: rotate(45deg); } .language-switcher { display: flex; align-items: center; gap: 0.35rem; } .language-switcher > a, .language-switcher > span { display: grid; place-items: center; width: 44px; height: 44px; border-radius: 999px; border: 1px solid var(--border); background: rgba(255, 255, 255, 0.74); color: var(--muted); font-weight: 700; transition: transform 0.2s ease, background 0.2s ease, color 0.2s ease, border-color 0.2s ease, opacity 0.2s ease; } .language-switcher a:hover { transform: translateY(-1px); } .language-switcher a.is-active { border-color: var(--accent); background: var(--accent); color: #fff; } .site-footer .language-switcher a.is-active, .template-pages-shopware-ads .site-footer .language-switcher a.is-active { color: #fff; } .language-switcher .is-unavailable { opacity: 0.42; } .menu-cv { position: relative; isolation: isolate; justify-self: end; align-self: start; display: grid; gap: 0.14rem; min-width: 82px; min-height: 88px; padding: 0.78rem 0.85rem 0.72rem 0.72rem; margin-top: -1px; overflow: hidden; border: 1px solid rgba(13, 128, 242, 0.18); border-top: 0; border-radius: 0 0 22px 22px; /*clip-path: polygon(0 0, calc(100% - 24px) 0, 100% 24px, 100% 100%, 0 100%);*/ clip-path: border-box; background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(233, 244, 255, 0.98) 52%, rgba(215, 231, 248, 0.98) 100%); /* box-shadow: 0 16px 30px rgba(13, 128, 242, 0.12);*/ color: var(--accent-strong); transition: transform 0.22s ease, box-shadow 0.22s ease, color 0.22s ease; } .menu-cv:hover, .menu-cv:focus-visible { transform: translateY(3px); box-shadow: 0 20px 34px rgba(13, 128, 242, 0.18); color: var(--accent-strong); } .menu-cv > span { position: relative; z-index: 1; } .menu-cv__fold { position: absolute !important; top: 0; right: 0; width: 24px; height: 24px; background: linear-gradient(135deg, rgba(227, 106, 17, 0.98), rgba(13, 128, 242, 0.98)); clip-path: polygon(0 0, 100% 0, 100% 100%); box-shadow: -8px 10px 18px rgba(13, 128, 242, 0.18); } .menu-cv__fold::after { content: ""; position: absolute; inset: 0; background: linear-gradient(135deg, rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0)); clip-path: polygon(0 0, 100% 0, 100% 100%); opacity: 0.75; } .menu-cv__note { font-weight: 700; letter-spacing: 0.2em; text-transform: uppercase; color: var(--warm); } .menu-cv__title { line-height: 1; font-weight: 800; letter-spacing: 0.16em; } .nav-toggle, .nav-close, .submenu-toggle { border: 1px solid var(--border); background: rgba(255, 255, 255, 0.82); color: var(--text); } .nav-toggle { display: none; width: 46px; height: 46px; padding: 0; border-radius: 16px; align-items: center; justify-content: center; gap: 4px; flex-direction: column; box-shadow: var(--shadow); } .nav-toggle span { width: 18px; height: 2px; border-radius: 999px; background: currentColor; } .site-mobile-overlay { position: fixed; inset: 0; background: rgba(23, 33, 52, 0.38); z-index: 49; } .site-mobile-panel { position: fixed; top: 0; right: 0; z-index: 50; width: min(92vw, 380px); height: 100vh; padding: 1.15rem; overflow-y: auto; background: #fff; box-shadow: -18px 0 42px rgba(23, 33, 52, 0.18); } .site-mobile-panel__header { display: flex; align-items: flex-start; justify-content: space-between; gap: 1rem; margin-bottom: 1.5rem; } .site-mobile-panel__header strong { display: block; line-height: 1.35; } .nav-close { position: relative; width: 44px; height: 44px; padding: 0; border-radius: 14px; flex: 0 0 auto; } .nav-close span:not(.sr-only) { position: absolute; top: 50%; left: 50%; width: 24px; height: 2px; background: currentColor; border-radius: 999px; margin: -1px 0 0 -12px; transition: transform 0.25s cubic-bezier(0.4, 0, 0.2, 1); } .nav-close span:not(.sr-only):first-of-type { transform: translate(0, 0) rotate(45deg); } .nav-close span:not(.sr-only):last-of-type { transform: translate(0, 0) rotate(-45deg); } .nav-close:hover span:not(.sr-only) { background: var(--primary); } .site-mobile-nav ul, .footer-list { list-style: none; margin: 0; padding: 0; } .site-mobile-nav__item { border-top: 1px solid var(--border); padding: 0.8rem 0; } .site-mobile-nav__item:last-child { border-bottom: 1px solid var(--border); } .site-mobile-nav__row { display: flex; align-items: center; justify-content: space-between; gap: 1rem; } .site-mobile-nav__row > a { display: flex; align-items: center; min-width: 44px; min-height: 44px; font-weight: 600; } .site-mobile-nav__item.is-active > .site-mobile-nav__row > a { color: var(--accent-strong); } .submenu-toggle { width: 44px; height: 44px; padding: 0; border-radius: 12px; display: grid; place-items: center; flex: 0 0 auto; } .submenu-toggle span { width: 10px; height: 10px; border-right: 2px solid currentColor; border-bottom: 2px solid currentColor; transform: rotate(45deg) translateY(-1px); transition: transform 0.2s ease; } .submenu-toggle[aria-expanded='true'] span { transform: rotate(225deg) translateY(-1px); } .site-mobile-nav__submenu { padding: 0.75rem 0 0 1rem; } .site-mobile-nav__submenu > ul { display: grid; gap: 0.35rem; margin-bottom: 0.85rem; } .site-mobile-nav__subitem { display: grid; gap: 0.2rem; } .site-mobile-nav__subitem > a { display: flex; align-items: center; min-height: 44px; padding: 0.45rem 0; color: var(--muted); } .site-mobile-nav__subitem.is-active > a, .site-mobile-nav__submenu a.is-active { color: var(--accent-strong); font-weight: 600; } .site-mobile-nav__nested { display: grid; gap: 0.2rem; margin: 0.1rem 0 0 0.8rem; padding-left: 0.9rem; border-left: 1px solid var(--border); } .site-mobile-nav__nested a { display: flex; align-items: center; min-height: 44px; padding: 0.35rem 0; color: var(--muted); } .site-mobile-nav__overview { display: flex; align-items: center; min-height: 44px; color: var(--accent-strong); font-weight: 600; } .site-mobile-panel__meta { display: grid; gap: 1rem; margin-top: 1.5rem; padding-top: 1rem; border-top: 1px solid var(--border); } .meta-list--mobile { display: grid; gap: 0.4rem; color: var(--muted); font-weight: 500; } .meta-list--mobile a { display: flex; align-items: center; min-height: 44px; } .page-shell { padding: 1.5rem 0 5rem; } .breadcrumbs { margin-bottom: 1.25rem; } .breadcrumbs__list { display: flex; flex-wrap: wrap; gap: 0.55rem; list-style: none; margin: 0; padding: 0; color: var(--muted); } .breadcrumbs__list li { display: flex; align-items: center; gap: 0.55rem; } .breadcrumbs__list a, .breadcrumbs__list span { display: inline-flex; align-items: center; min-width: 44px; min-height: 44px; } .breadcrumbs__list li + li::before { content: '/'; color: #98a4b7; } .surface-panel { border: 1px solid var(--border); border-radius: var(--radius); background: var(--surface); box-shadow: var(--shadow); -webkit-backdrop-filter: blur(18px); backdrop-filter: blur(18px); } .prose { font-size: 1.0625rem; line-height: 1.75; color: var(--text); } .prose p, .prose ul, .prose ol, .prose blockquote { margin-bottom: 1.6rem; } .prose h2 { margin: 3.2rem 0 1.4rem; font-size: 1.85rem; font-weight: 700; line-height: 1.2; color: var(--accent); } .prose h3 { margin: 2.4rem 0 1.1rem; font-size: 1.45rem; font-weight: 700; line-height: 1.3; } .prose ul, .prose ol { margin-left: 0; padding-left: 1.5rem; } /*.prose li { margin-bottom: 0.65rem; }*/ .prose blockquote { margin: 2.5rem 0; padding: 1rem 1.5rem; border-left: 4px solid var(--accent); background: var(--accent-soft); border-radius: 0 12px 12px 0; font-style: italic; } .prose img { border-radius: 16px; margin: 2.5rem 0; box-shadow: 0 12px 32px rgba(0, 0, 0, 0.08); } .prose code { padding: 0.2rem 0.4rem; background: var(--bg-strong); border-radius: 4px; font-size: 0.9em; } .prose pre { padding: 1.5rem; background: #1e293b; color: #f8fafc; border-radius: 12px; overflow-x: auto; margin: 2rem 0; } .page-block, .page-section, .home-section { margin-top: 1.5rem; } .page-block:first-child { margin-top: 0; } .page-block--narrow, .page-block--article { max-width: calc(var(--content) + 2rem); margin-left: auto; margin-right: auto; } .page-layout { display: grid; grid-template-columns: minmax(0, 1fr) 340px; gap: 1.5rem; align-items: start; } .page-layout--contact { grid-template-columns: 1fr; } .page-sidebar { position: sticky; top: 104px; } .page-article, .article-panel, .hero-panel, .callout-panel, .contact-form, .side-panel { padding: clamp(1.35rem, 2vw, 2.25rem); } .expert-signal-panel { display: grid; gap: 1rem; margin-top: 1.5rem; padding: clamp(1.35rem, 2vw, 2.25rem); overflow: hidden; background: radial-gradient(circle at 92% 0%, rgba(13, 128, 242, 0.11), transparent 34%), radial-gradient(circle at 8% 100%, rgba(227, 106, 17, 0.08), transparent 28%), var(--surface); } .expert-signal-panel h2 { max-width: 15ch; margin: 0; line-height: 1.08; letter-spacing: -0.04em; } .expert-signal-panel__intro { max-width: 76ch; margin: 0; color: var(--muted); line-height: 1.72; } .expert-signal-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 0.85rem; } .expert-signal-grid article { padding: 1rem; border: 1px solid var(--border); border-radius: 22px; background: rgba(255, 255, 255, 0.66); } .expert-signal-grid span { display: block; color: var(--accent-strong); font-size: 0.7rem; font-weight: 800; letter-spacing: 0.14em; text-transform: uppercase; } .expert-signal-grid p { margin: 0.35rem 0 0; color: var(--text); line-height: 1.6; } .expert-signal-panel__note { margin: 0; padding: 0.9rem 1rem; border-left: 4px solid var(--accent); border-radius: 0 18px 18px 0; background: rgba(13, 128, 242, 0.08); color: var(--text); font-weight: 650; line-height: 1.62; } .page-article--centered { text-align: center; } .section-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 1rem; margin-bottom: 1rem; } .section-head h2, .callout-panel h2, .profile-card h2 { margin: 0; line-height: 1.1; letter-spacing: -0.04em; } .section-head p, .callout-panel p, .feature-card p, .service-card p, .article-card p, .profile-card__summary, .page-copy, .hero-panel__lead, .article-hero__lead { color: var(--muted); } .section-kicker { margin: 0 0 0.5rem; color: var(--accent-strong); font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase; } .page-hero h1, .hero-panel h1, .article-hero h1 { margin: 0; line-height: 1.03; letter-spacing: -0.05em; } .hero-panel, .callout-panel { position: relative; overflow: hidden; } .hero-panel::before, .callout-panel::before { content: ''; position: absolute; inset: auto -8% -42% 52%; height: 18rem; background: radial-gradient(circle, rgba(13, 128, 242, 0.16), transparent 68%); pointer-events: none; } .hero-panel__lead, .article-hero__lead { max-width: 60ch; margin: 0.9rem 0 0; } .page-hero__meta, .article-hero__meta, .article-card__meta { display: flex; flex-wrap: wrap; gap: 0.65rem; margin-top: 1rem; color: var(--muted); } .article-hero__meta { margin: 0 0 1rem; } .content-flow { line-height: 1.75; } .content-flow > :first-child { margin-top: 0; } .content-flow p, .content-flow ul, .content-flow ol, .content-flow blockquote, .content-flow pre, .content-flow table, .content-flow hr { margin: 1.15rem 0; } .content-flow pre { white-space: pre-wrap; } .content-flow h2 { margin: 2.4rem 0 1rem; line-height: 1.12; letter-spacing: -0.03em; } .content-flow h3 { margin: 1.8rem 0 0.8rem; line-height: 1.2; } .content-flow ul, .content-flow ol { padding-left: 1.3rem; } /*.content-flow li + li { margin-top: 0.45rem; }*/ .content-flow a { color: var(--accent-strong); text-decoration: underline; text-decoration-thickness: 0.08em; text-underline-offset: 0.18em; } .content-flow blockquote { padding: 1rem 1.2rem; border-left: 4px solid var(--accent); border-radius: 18px; background: var(--surface-muted); } .content-flow hr { border: 0; border-top: 1px solid var(--border); } .content-flow img { border-radius: 22px; box-shadow: var(--shadow); } .button { display: inline-flex; align-items: center; justify-content: center; min-height: 48px; padding: 0.9rem 1.25rem; border: 1px solid var(--accent); border-radius: 999px; background: var(--accent); color: #fff; font-weight: 600; transition: transform 0.2s ease, background 0.2s ease, border-color 0.2s ease; box-shadow: 0 14px 28px rgba(13, 128, 242, 0.18); } .button:hover { transform: translateY(-1px); background: var(--accent-strong); border-color: var(--accent-strong); color: #fff; } .button--secondary { background: transparent; color: var(--accent-strong); border-color: var(--border); box-shadow: none; } .button--secondary:hover { background: var(--accent-soft); border-color: rgba(13, 128, 242, 0.28); color: var(--accent-strong); } .service-conversion-panel { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 1rem; align-items: center; margin-top: 1.6rem; padding: clamp(1rem, 2vw, 1.35rem); border: 1px solid rgba(13, 128, 242, 0.2); border-radius: 22px; background: linear-gradient(135deg, rgba(13, 128, 242, 0.1), rgba(227, 106, 17, 0.06)), rgba(255, 255, 255, 0.72); } .service-conversion-panel strong { display: block; margin-bottom: 0.25rem; color: var(--text); font-size: 1.05rem; line-height: 1.2; } .service-conversion-panel span { display: block; max-width: 66ch; color: var(--muted); line-height: 1.55; } .service-conversion-panel .cta-row { justify-content: flex-end; margin: 0; } .service-fit-panel { display: grid; grid-template-columns: minmax(0, 1fr) minmax(220px, 0.55fr); gap: 1rem; margin-top: 1.7rem; padding: clamp(1rem, 2vw, 1.35rem); border: 1px solid rgba(32, 58, 87, 0.12); border-radius: 22px; background: linear-gradient(180deg, rgba(248, 251, 255, 0.96), rgba(255, 255, 255, 0.84)); } .service-fit-panel h2 { margin: 0 0 0.85rem; font-size: var(--font-size-heading-compact); } .service-fit-list { display: grid; gap: 0.65rem; margin: 0; padding: 0; list-style: none; } .service-fit-list li { position: relative; padding-left: 1.55rem; color: var(--muted); line-height: 1.55; } .service-fit-list li::before { content: ""; position: absolute; top: 0.52rem; left: 0; width: 0.58rem; height: 0.58rem; border-radius: 999px; background: var(--accent); box-shadow: 0 0 0 5px rgba(13, 128, 242, 0.1); } .service-fit-note { display: grid; align-content: start; gap: 0.5rem; padding: 1rem; border: 1px solid rgba(227, 106, 17, 0.18); border-radius: 18px; background: rgba(255, 247, 240, 0.78); } .service-fit-note strong { color: var(--text); } .service-fit-note span { color: var(--muted); line-height: 1.55; } .service-faq-panel { margin-top: 1.4rem; padding: clamp(1.35rem, 2.4vw, 2rem); } .service-faq-panel .section-kicker { margin: 0 0 0.85rem; } .service-faq-panel h2 { margin: 0 0 1.45rem; font-size: var(--font-size-heading-compact); line-height: 1.25; } .service-faq-list { display: grid; gap: 0.8rem; } .service-faq-item { padding: 0; border: 1px solid var(--border); border-radius: 18px; background: rgba(255, 255, 255, 0.72); overflow: hidden; } .service-faq-item summary { display: flex; align-items: center; gap: 1rem; min-height: 58px; margin: 0; padding: 0.95rem 1.05rem; border: 0; border-radius: 0; background: transparent; color: var(--text); cursor: pointer; font-weight: 700; } .service-faq-item div { margin: 0; padding: 0 1.05rem 1rem 4.2rem; color: var(--muted); line-height: 1.6; } .service-faq-item div > :first-child { margin-top: 0; } .service-faq-item div > :last-child { margin-bottom: 0; } .shopware-sticky-cta { position: fixed; right: clamp(1rem, 2vw, 1.8rem); bottom: clamp(1rem, 2vw, 1.8rem); z-index: 80; display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 1rem; align-items: center; width: min(600px, calc(100% - 2rem)); padding: 0.85rem; border: 1px solid rgba(13, 128, 242, 0.2); border-radius: 22px; background: rgba(255, 255, 255, 0.94); box-shadow: 0 22px 54px rgba(15, 35, 60, 0.2); backdrop-filter: blur(14px); } .shopware-sticky-cta strong, .shopware-sticky-cta span { display: block; } .shopware-sticky-cta strong { color: var(--text); font-size: var(--font-size-small); } .shopware-sticky-cta span { margin-top: 0.18rem; color: var(--muted); font-size: 0.86rem; line-height: 1.35; } .shopware-sticky-cta .button { min-height: 44px; padding: 0.72rem 1rem; white-space: nowrap; } body:has(.shopware-sticky-cta) .site-footer { padding-bottom: 7.5rem; } body:has(.shopware-sticky-cta) .page-shell { padding-bottom: 8.5rem; } .text-link, .back-link { display: inline-flex; align-items: center; gap: 0.5rem; min-height: 44px; color: var(--accent-strong); font-weight: 600; } .back-link { margin-bottom: 1rem; } .back-link--inline { margin-bottom: 0; } .back-link--flush { padding-left: 0; } .back-link::before { transform: rotate(-135deg); } .cta-row, .tag-list, .social-list { display: flex; flex-wrap: wrap; gap: 0.7rem; } .social-list a { display: inline-flex; align-items: center; justify-content: center; min-height: 44px; padding: 0.5rem 0.9rem; border: 1px solid var(--border); border-radius: 999px; background: rgba(255, 255, 255, 0.82); color: var(--text); font-weight: 600; transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, transform 0.2s ease; } .social-list a:hover { background: var(--accent-soft); border-color: rgba(13, 128, 242, 0.22); color: var(--accent-strong); transform: translateY(-1px); } .cta-row { margin-top: 1.5rem; } .tag-list a, .article-card__meta span { display: inline-flex; align-items: center; padding: 0.18rem 0.65rem; border-radius: 999px; background: var(--accent-soft); color: var(--accent-strong); font-size: 0.8rem; font-weight: 600; } .tag-list--spacious { margin-top: 1.15rem; } .article-back-links { display: flex; align-items: center; gap: 1rem; margin-bottom: 2rem; } .article-hero__meta-sep--muted { color: var(--muted); } .article-footer-tags { margin-top: 3rem; padding-top: 2rem; border-top: 1px solid var(--border); } .article-footer-tags__title { margin: 0 0 1rem; font-size: 1.125rem; } .filter-pill { display: inline-flex; align-items: center; gap: 0.5rem; margin-top: 1rem; padding: 0.25rem 0.75rem; border-radius: 999px; background: var(--accent-soft); color: var(--accent-strong); font-size: 0.85rem; font-weight: 600; } .home-shell { margin-top: 0.5rem; } .home-grid { display: grid; grid-template-columns: minmax(0, 1fr) 286px; gap: 1.4rem; align-items: start; } .home-main { display: grid; gap: 1.5rem; } .home-grid > .home-main, #site-content-column { width: min(100%, 920px); max-width: 920px; min-width: 0; justify-self: start; } .home-grid > .profile-rail, .home-grid--service-overview > .profile-rail, .home-grid--service-detail > .profile-rail { grid-column: 2; grid-row: 1; } .home-grid > .home-main, .home-grid--service-overview > .home-main, .home-grid--service-detail > .home-main { grid-column: 1; grid-row: 1; } .profile-card { position: sticky; top: 104px; overflow: hidden; } .profile-card__media { padding: 1rem 1rem 0; } .profile-card__media img { width: 100%; max-height: 480px; aspect-ratio: 1 / 1; object-fit: cover; border: 1px solid var(--border); border-radius: 24px; background: linear-gradient(135deg, rgba(13, 128, 242, 0.1), rgba(227, 106, 17, 0.08)); } .profile-card__body { padding: 1.05rem 1rem 1.2rem; } .profile-card__section { margin-top: 1.35rem; padding-top: 1.05rem; border-top: 1px solid var(--border); } .profile-card__section h3 { margin: 0 0 0.85rem; } .social-list--sidebar { margin-top: 1rem; } .profile-card__qr { display: grid; justify-items: center; gap: 0.55rem; margin-top: 1rem; padding: 1rem; border: 1px solid var(--border); border-radius: 24px; background: linear-gradient(180deg, rgba(13, 128, 242, 0.06), rgba(227, 106, 17, 0.08)); text-align: center; } .profile-card__qr a { display: block; } .profile-card__qr img { display: block; width: min(168px, 100%); height: auto; border: 1px solid rgba(13, 128, 242, 0.18); border-radius: 20px; background: #fff; box-shadow: 0 14px 28px rgba(23, 33, 52, 0.08); } .profile-card__qr strong { color: var(--text); } .profile-card__qr span { color: var(--muted); } .profile-card--sidebar { overflow: visible; } .profile-card__body--sidebar { padding: 0.9rem; } .profile-card__layout { display: grid; grid-template-columns: 1fr; gap: 0.85rem; align-items: start; } .profile-card__logo.cv-hero__photo { flex-shrink: 0; width: 180px; height: 180px; border-radius: 28px; overflow: hidden; border: 1px solid var(--border); box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08); } .profile-card__logo-panel { flex-shrink: 0; width: 100%; height: auto; aspect-ratio: 1; border-radius: 20px; overflow: hidden; border: 1px solid var(--border); } .profile-card__logo-panel img { width: 100%; height: 100%; object-fit: cover; } /* CV Timeline Styles */ .cv-timeline-list { position: relative; padding-top: 1rem; } .cv-timeline-item { display: flex; gap: 2rem; margin-bottom: 3rem; position: relative; } .cv-timeline-item__meta { flex: 0 0 120px; font-weight: 700; color: var(--accent); text-align: right; font-size: 0.95rem; padding-top: 0.25rem; } .cv-timeline-item__content { flex: 1; position: relative; padding-left: 1.5rem; } .cv-timeline-item__content::before { content: ''; position: absolute; left: -19px; /* Center on the dashed line */ top: 0.5rem; width: 14px; height: 14px; background: var(--surface-solid); border: 2px solid var(--accent); border-radius: 50%; z-index: 2; box-shadow: 0 0 0 4px var(--bg); } .cv-timeline-item__content::after { content: ''; position: absolute; left: -13px; /* Center under the circle */ top: 1.5rem; bottom: -3.5rem; /* Connect to next item's circle */ width: 2px; background: repeating-linear-gradient( to bottom, var(--accent) 0, var(--accent) 8px, transparent 8px, transparent 16px ); opacity: 0.25; z-index: 1; } .cv-timeline-item:last-child .cv-timeline-item__content::after { display: none; } .cv-timeline-item__content h3 { margin-top: 0; margin-bottom: 0.5rem; color: var(--accent); font-size: 1.25rem; line-height: 1.3; } .cv-timeline-item__body { color: var(--muted); font-size: 1.05rem; line-height: 1.6; } .cv-standard-list { display: grid; gap: 1.5rem; } .cv-standard-item { padding: 1.5rem; background: var(--surface-card); border: 1px solid var(--border); border-radius: 12px; transition: transform 0.2s ease; } .cv-standard-item:hover { transform: translateY(-2px); border-color: var(--accent-faint); } .cv-standard-item h3 { margin-top: 0; margin-bottom: 0.75rem; color: var(--accent); font-size: 1.15rem; } /* Mobile CV adjustments */ @media (max-width: 768px) { .cv-timeline-item { flex-direction: column; gap: 0.5rem; padding-left: 1.5rem; } .cv-timeline-item__meta { text-align: left; flex: none; font-size: 0.85rem; } .cv-timeline-item__content { padding-left: 0; } .cv-timeline-item__content::before { left: -20px; top: -1.4rem; } .cv-timeline-item__content::after { left: -14px; top: -0.4rem; bottom: -2.5rem; } } .profile-card__intro { display: grid; gap: 0.75rem; min-width: 0; } .article-hero h1 { margin: 0.5rem 0 1.5rem; font-size: 2.4rem; line-height: 1.15; letter-spacing: -0.02em; color: var(--text); } .profile-contact-list { display: grid; gap: 0.55rem; padding-top: 0.7rem; border-top: 1px solid var(--border); } .profile-contact-item { display: grid; grid-template-columns: 18px minmax(0, 1fr); gap: 0.5rem; align-items: center; min-height: 30px; } .profile-contact-item__icon { align-self: center; width: 18px; height: 18px; color: rgba(23, 33, 52, 0.82); } .profile-contact-item__icon svg { display: block; width: 18px; height: 18px; } .profile-contact-item a, .profile-contact-item span { color: var(--text); font-weight: 600; line-height: 1.3; word-break: break-word; } .profile-contact-item > a, .profile-contact-item > span:not(.profile-contact-item__icon) { display: flex; align-items: center; min-height: 30px; } .social-list--sidebar-icons { display: flex; flex-wrap: wrap; justify-content: flex-start; gap: 0.75rem; margin-top: 1rem; } .social-list--sidebar-icons a { display: grid; place-items: center; width: 44px; height: 44px; padding: 0; border: 1px solid var(--border); border-radius: 12px; background: white; box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05); transition: all 0.2s ease; } .social-list--sidebar-icons a:hover { background: var(--accent); border-color: var(--accent); color: #fff; transform: none; } .social-link__icon { display: grid; place-items: center; width: 100%; height: 100%; } .social-link__icon svg { display: block; width: 22px; height: 22px; fill: currentColor; } .profile-card__qr--sidebar { grid-column: auto; display: grid; grid-template-columns: 76px minmax(0, 1fr); gap: 0.75rem; align-items: center; margin-top: 0; padding: 0.72rem 0.8rem; border-radius: 20px; background: linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(13, 128, 242, 0.05)); text-align: left; } .profile-card__qr--sidebar img { width: 76px; border-radius: 14px; border: 1px solid var(--border); box-shadow: none; } .profile-card__qr-copy { display: grid; gap: 0.18rem; } .profile-card__qr-copy strong { color: var(--text); } .profile-card__qr-copy span { color: var(--muted); } .profile-card__skills-grid { grid-column: auto; display: grid; grid-template-columns: 1fr; gap: 0.55rem; padding-top: 0.85rem; border-top: 1px solid var(--border); } .profile-card__skills-grid .skill-meter { gap: 0.4rem; } .profile-card__skills-grid .skill-meter__meta { margin-bottom: 0; } .profile-card__skills-grid .skill-meter__track { height: 6px; } .blog-index-shell { display: grid; gap: 1.1rem; min-width: 0; } .blog-layout { display: grid; grid-template-columns: 280px minmax(0, 1fr); gap: 1rem; align-items: start; min-width: 0; } .blog-main { display: grid; gap: 1rem; min-width: 0; } .blog-layout > .blog-main { width: 100%; max-width: none; min-width: 0; } .blog-index-shell > .blog-layout { padding: 0.95rem 1rem 1rem; border: 1px solid var(--border); border-radius: 26px; background: var(--surface-solid); box-shadow: 0 14px 28px rgba(23, 33, 52, 0.06); } .blog-main--index { padding-left: 1rem; border-left: 1px solid var(--border); } .blog-main--index .blog-feed { padding: 0; } .blog-index-shell > .blog-layout .surface-panel.blog-feed, .blog-index-shell > .blog-layout .surface-panel.blog-rail__panel { border: 0; border-radius: 0; background: transparent; box-shadow: none; } .blog-index-shell > .blog-layout .blog-rail__panel + .blog-rail__panel { padding-top: 1rem; border-top: 1px solid var(--border); } .blog-hero { min-width: 0; overflow: hidden; padding: 0; } .blog-hero__media { position: relative; display: flex; flex-direction: column; justify-content: center; align-items: center; padding: 4rem 2rem; min-height: 400px; text-align: center; background-size: cover; background-position: center; background: linear-gradient(180deg, rgba(23, 33, 52, 0.4), rgba(23, 33, 52, 0.7)); } .blog-hero__image { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0; } .blog-hero__media::after { content: ''; position: absolute; inset: 0; z-index: 1; background: linear-gradient(180deg, rgba(23, 33, 52, 0.4), rgba(23, 33, 52, 0.7)); } .blog-hero__copy { position: relative; z-index: 2; margin: 0 auto; text-align: center; color: #fff; } .blog-hero__copy h1 { font-size: clamp(2.2rem, 6vw, 3.8rem); font-weight: 800; line-height: 1.1; margin-bottom: 1.5rem; letter-spacing: -0.03em; text-shadow: 0 4px 12px rgba(0, 0, 0, 0.5); } .blog-hero__copy p { font-size: clamp(1.2rem, 2.5vw, 1.7rem); font-weight: 500; line-height: 1.4; opacity: 1; text-shadow: 0 2px 8px rgba(0, 0, 0, 0.4); } .blog-rail { display: grid; gap: 1rem; align-items: start; } .blog-rail__panel { padding: 0.95rem 1rem 1rem; } .blog-rail__panel--list { padding: 1rem 1rem 1.05rem; } .blog-rail__panel h2 { margin: 0 0 0.75rem; line-height: 1.18; letter-spacing: -0.03em; } .blog-rail__list { list-style: none; margin: 0; padding: 0; display: grid; } .blog-rail__list > li + li { border-top: 1px solid var(--border); } .blog-rail__list-link, .blog-rail__tag-link { display: flex; align-items: center; justify-content: space-between; gap: 0.75rem; min-height: 44px; padding: 0.55rem 0; color: var(--text); font-weight: 600; } .blog-rail__list-link strong, .blog-rail__tag-link strong { color: var(--muted); } .blog-rail__list-link:hover, .blog-rail__list-link.is-active, .blog-rail__tag-link:hover, .blog-rail__tag-link.is-active, .blog-rail__recent:hover { color: var(--accent-strong); } .blog-rail__recent { display: grid; gap: 0.25rem; min-height: 44px; padding: 0.65rem 0; } .blog-rail__recent strong { color: var(--text); line-height: 1.35; font-size: var(--font-size-small); } .blog-rail__recent p { display: -webkit-box; margin: 0; color: var(--muted); font-size: var(--font-size-small); line-height: 1.45; -webkit-box-orient: vertical; -webkit-line-clamp: 2; line-clamp: 2; overflow: hidden; } .blog-feed { padding: 1.05rem 1.2rem 1.15rem; } .blog-feed__head { display: grid; gap: 0.2rem; margin-bottom: 0.55rem; } .blog-feed__head h2 { margin: 0; font-size: clamp(1.6rem, 2.4vw, 2.15rem); line-height: 1.08; letter-spacing: -0.03em; } .blog-feed__head .filter-pill { margin-top: 0.1rem; } .blog-feed__list { display: grid; gap: 2.2rem; } .blog-list-post { padding: 1.5rem; border: 1px solid var(--border); border-radius: 20px; background: var(--surface-solid); box-shadow: 0 4px 12px rgba(23, 33, 52, 0.03); transition: transform 0.2s ease, box-shadow 0.2s ease; } .blog-list-post:hover { transform: translateY(-3px); box-shadow: 0 8px 24px rgba(23, 33, 52, 0.06); } .blog-list-post:first-child { border-top: 1px solid var(--border); } .blog-list-post h3 { margin: 0; font-size: clamp(1.05rem, 1.45vw, 1.36rem); line-height: 1.22; letter-spacing: -0.02em; } .blog-list-post.is-featured h3 { font-size: clamp(1.16rem, 1.7vw, 1.55rem); } .blog-list-post__meta { display: flex; flex-wrap: wrap; align-items: center; gap: 0.38rem; margin: 0.42rem 0 0.58rem; color: var(--muted); font-size: var(--font-size-small); } .blog-list-post__meta a, .blog-list-post__meta time, .blog-list-post__meta span { color: inherit; } .blog-list-post__meta a { display: inline-flex; align-items: center; min-width: 44px; min-height: 44px; } .blog-list-post__meta-sep { color: #98a4b7; } .blog-list-post p { margin: 0; max-width: 72ch; color: var(--text); font-size: 1.05rem; line-height: 1.68; } .button--blog { min-height: 44px; margin-top: 0.7rem; padding: 0.65rem 0.85rem; border-radius: 10px; box-shadow: none; font-size: var(--font-size-small); } .meta-list { list-style: none; margin: 0; padding: 0; display: grid; gap: 0.85rem; } .meta-list--contact-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 1.5rem; margin-bottom: 2rem; } .meta-list li { display: grid; gap: 0.2rem; } .meta-list--contact-grid li { background: var(--surface); padding: 1.5rem; border-radius: 16px; border: 1px solid var(--border); box-shadow: 0 4px 12px rgba(23, 33, 52, 0.04); transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1); display: flex; flex-direction: column; gap: 0.5rem; } .meta-list--contact-grid li:hover { transform: translateY(-4px); border-color: var(--primary); box-shadow: 0 12px 24px rgba(23, 33, 52, 0.08); } .meta-list span { color: var(--muted); font-weight: 700; font-size: 0.75rem; letter-spacing: 0.1em; text-transform: uppercase; } .meta-list strong, .meta-list a { font-weight: 600; color: var(--text); font-size: 1.1rem; } .meta-list a { display: flex; align-items: center; min-height: 1.5rem; text-decoration: none; } .meta-list a:hover { color: var(--primary); } .skill-stack { display: grid; gap: 0.85rem; } .skill-meter__meta { display: flex; justify-content: space-between; gap: 1rem; margin-bottom: 0.35rem; color: var(--muted); } .skill-meter__track { height: 10px; border-radius: 999px; overflow: hidden; background: var(--bg-strong); } .skill-meter__track span { display: block; height: 100%; width: var(--skill-meter-value, 0%); border-radius: inherit; background: linear-gradient(90deg, var(--accent), var(--warm)); } .feature-grid, .cards-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1rem; } .article-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); } .feature-card, .service-card, .article-card, .blog-list-post { padding: 1.2rem; border: 1px solid var(--border); border-radius: 24px; background: var(--surface-solid); box-shadow: 0 12px 24px rgba(23, 33, 52, 0.05); cursor: pointer; transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease; } .feature-card:hover, .service-card:hover, .article-card:hover, .blog-list-post:hover { transform: translateY(-4px); box-shadow: 0 16px 32px rgba(23, 33, 52, 0.08); border-color: var(--accent); } .feature-card h3, .service-card h3, .article-card h3 { margin: 0 0 0.45rem; line-height: 1.2; } .feature-card h3 a, .service-card h3 a, .article-card h3 a, .blog-list-post h3 a { display: block; min-height: 44px; } .content-flow li > a:only-child { display: flex; align-items: center; min-height: 44px; } .article-card__meta { margin: 0 0 0.75rem; } .article-card--featured { background: linear-gradient(180deg, #ffffff, #f8fbff); border-color: rgba(13, 128, 242, 0.28); } .empty-state { padding: 1.25rem; text-align: center; color: var(--muted); } .page-actions { margin-top: 1.5rem; } .contact-form { display: grid; gap: 0.9rem; } #contact-form { scroll-margin-top: 8rem; } .contact-form label { display: grid; gap: 0.4rem; color: var(--text); font-weight: 600; } .contact-form__label-text { display: inline-flex; align-items: baseline; gap: 0.28rem; } .contact-form__required-note { margin: -0.1rem 0 0.1rem; color: var(--muted); font-size: var(--font-size-small); font-weight: 500; } .contact-form__required-note .form-required { margin-right: 0.22rem; } .contact-form__status { display: grid; gap: 0.65rem; } .contact-form__consent { display: grid !important; grid-template-columns: 44px minmax(0, 1fr); align-items: start; gap: 0.6rem; color: var(--muted) !important; font-weight: 500 !important; line-height: 1.65; } .contact-form__consent input[type='checkbox'] { position: relative; width: 44px; min-width: 44px; height: 44px; min-height: 44px; margin: 0; padding: 0; border: 0; border-radius: 14px; -webkit-appearance: none; appearance: none; background: transparent; box-shadow: none; cursor: pointer; } .contact-form__consent input[type='checkbox']::before { content: ''; position: absolute; top: 12px; left: 12px; width: 20px; height: 20px; border: 1px solid var(--border); border-radius: 6px; background: var(--surface-solid); } .contact-form__consent input[type='checkbox']:checked::before { border-color: var(--accent); background: var(--accent); } .contact-form__consent input[type='checkbox']:checked::after { content: ''; position: absolute; top: 16px; left: 19px; width: 6px; height: 11px; border-right: 2px solid #fff; border-bottom: 2px solid #fff; transform: rotate(45deg); } .contact-form__consent-text { display: block; } .contact-form__consent a { display: inline-flex; align-items: center; min-height: 44px; color: var(--accent-strong); text-decoration: underline; text-underline-offset: 0.16em; } .contact-form input, .contact-form textarea { width: 100%; padding: 0.9rem 1rem; border: 1px solid var(--border); border-radius: 18px; background: var(--surface-solid); color: var(--text); transition: border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease; } .contact-form input:focus, .contact-form textarea:focus { border-color: rgba(13, 128, 242, 0.56); box-shadow: 0 0 0 4px rgba(13, 128, 242, 0.12); outline: none; } .flash { padding: 0.95rem 1rem; border-radius: 18px; font-weight: 500; } .flash.success { background: #e8f7ee; color: #146b39; } .flash.error { background: #fdeceb; color: #9b2d24; } .hp-field { position: absolute; left: -9999px; visibility: hidden; width: 1px !important; min-height: 1px !important; height: 1px !important; padding: 0 !important; border: 0 !important; } details > summary { display: flex; align-items: center; min-height: 44px; } .legacy-home-panel details { margin-bottom: 1.25rem; border: 1px solid var(--border); border-radius: 12px; background: white; transition: all 0.2s ease; } .legacy-home-panel details:hover { border-color: var(--accent); box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05); } .legacy-home-panel summary { padding: 1rem 1.25rem; font-weight: 600; cursor: pointer; list-style: none; } .legacy-home-panel summary::-webkit-details-marker { display: none; } /*.legacy-home-panel .prose { padding: 0 1.25rem 1.25rem; }*/ .site-footer { margin-top: 5rem; padding: 2.25rem 0 2rem; border-top: 1px solid rgba(217, 226, 236, 0.9); background: rgba(255, 255, 255, 0.72); -webkit-backdrop-filter: blur(16px); backdrop-filter: blur(16px); } .site-footer__inner { display: grid; gap: 1.6rem; } .site-footer__quote { width: 100%; max-width: none; line-height: 1.72; text-align: center; } .site-footer__grid { display: grid; grid-template-columns: 1.3fr 0.9fr 0.8fr; gap: 1rem; } .site-footer__block { padding: 1.25rem; border: 1px solid var(--border); border-radius: 24px; background: rgba(255, 255, 255, 0.78); } .footer-list { display: grid; gap: 0.6rem; color: var(--muted); } .footer-list a { display: inline-flex; align-items: center; min-height: 44px; } .site-footer__bottom { display: flex; align-items: center; justify-content: space-between; gap: 1rem; color: var(--muted); } .social-list--footer a { min-height: 44px; } @media (max-width: 1160px) { .home-grid { grid-template-columns: minmax(0, 1fr) 260px; } .blog-layout { grid-template-columns: 260px minmax(0, 1fr); } .article-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } .menu-cv { min-width: 74px; min-height: 80px; padding: 0.72rem 0.72rem 0.62rem 0.64rem; } .menu-cv__title { font-size: var(--font-size-heading-compact); } } @media (max-width: 1024px) { .home-grid { gap: 1.5rem; } .blog-layout { grid-template-columns: 1fr; gap: 1.25rem; } .blog-layout > .blog-main { order: 1; } .blog-layout > .blog-rail { order: 2; } .blog-index-shell > .blog-layout { padding: 1rem; gap: 1rem; } .blog-main--index { padding-left: 0; border-left: 0; } .blog-index-shell > .blog-layout > .blog-rail { padding-top: 1rem; border-top: 1px solid var(--border); } .site-header__inner { grid-template-columns: 1fr auto; } .site-nav, .language-switcher--desktop, .menu-cv { display: none; } .nav-toggle { display: inline-flex; } } @media (max-width: 768px) { .home-grid, .page-layout, .page-layout--contact, .site-footer__grid, .feature-grid, .cards-grid, .article-grid { grid-template-columns: 1fr; } .expert-signal-grid { grid-template-columns: 1fr; } .page-sidebar, .profile-card { position: static; max-width: 480px; margin-inline: auto; } .home-grid > .home-main, .home-grid--service-overview > .home-main, .home-grid--service-detail > .home-main { grid-column: 1; grid-row: 1; } .home-grid > .profile-rail, .home-grid--service-overview > .profile-rail, .home-grid--service-detail > .profile-rail { grid-column: 1; grid-row: 2; } .service-conversion-panel { grid-template-columns: 1fr; } .service-conversion-panel .cta-row { justify-content: flex-start; } .service-fit-panel, .shopware-sticky-cta { grid-template-columns: 1fr; } .shopware-sticky-cta { right: 0.75rem; bottom: 0.75rem; width: calc(100% - 1.5rem); } body:has(.shopware-sticky-cta) .page-shell { padding-bottom: 13rem; } .shopware-sticky-cta .button { width: 100%; } .section-head, .site-footer__bottom { flex-direction: column; align-items: flex-start; } } @media (max-width: 720px) { .container { width: min(var(--container), calc(100% - 1.1rem)); } .blog-index-shell { gap: 1.15rem; } .site-header__inner { grid-template-columns: 1fr auto; } .brand__logo { height: 44px; } .brand__copy small { display: none; } .site-mobile-panel { width: 100%; } .page-shell { padding-top: 1rem; } .profile-card__layout, .profile-card__skills-grid { grid-template-columns: 1fr; } .profile-card__qr--sidebar { grid-template-columns: 82px minmax(0, 1fr); } .profile-card__qr--sidebar img { width: 82px; } .page-article, .article-panel, .hero-panel, .callout-panel, .contact-form, .side-panel { padding: 1.2rem; } .blog-feed, .blog-rail__panel--list { padding: 1rem; } .blog-hero__media { min-height: 210px; padding: 1rem; } .blog-hero__copy p { max-width: 20rem; font-size: 0.95rem; } .blog-list-post { padding: 0.85rem 0 0.95rem; } .page-hero h1, .hero-panel h1, .article-hero h1 { font-size: var(--font-size-heading-xl-mobile); } .blog-hero__copy h1 { font-size: clamp(1.45rem, 8.2vw, 2.2rem); } .language-switcher a { width: 44px; height: 44px; } } .pagination { display: grid; gap: 1rem; margin: 2rem auto 0; padding: 1.35rem 1.5rem; border: 1px solid var(--border); border-radius: 24px; background: rgba(255, 255, 255, 0.82); -webkit-backdrop-filter: blur(16px); backdrop-filter: blur(16px); } .pagination__summary { color: var(--muted); font-weight: 500; } .pagination__links { display: flex; flex-wrap: wrap; align-items: center; gap: 0.65rem; } .pagination__page, .pagination__control, .pagination__ellipsis { display: inline-flex; align-items: center; justify-content: center; min-width: 3rem; min-height: 3rem; padding: 0.75rem 1rem; border-radius: 16px; border: 1px solid transparent; background: var(--surface-muted); color: var(--muted); font-weight: 600; transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease, transform 0.2s ease; } .pagination__page:hover, .pagination__control:hover { background: var(--accent-soft); border-color: rgba(13, 128, 242, 0.18); color: var(--accent-strong); transform: translateY(-1px); } .pagination__page.is-active { background: linear-gradient(135deg, var(--accent), var(--accent-strong)); color: #fff; box-shadow: 0 14px 30px rgba(4, 95, 194, 0.22); } .pagination__control { min-width: auto; } .pagination__control.is-disabled { background: transparent; border-color: var(--border); color: var(--muted); opacity: 0.55; } .pagination__ellipsis { min-width: 2rem; padding-inline: 0.2rem; background: transparent; color: var(--muted); } .cv-shell { display: grid; gap: 1.5rem; margin-top: 0.5rem; } .cv-hero-card, .cv-card, .cv-panel--content { padding: clamp(1.35rem, 2vw, 2.25rem); } .cv-hero { display: grid; grid-template-columns: minmax(0, 1.2fr) minmax(300px, 0.9fr); gap: 1.5rem; align-items: start; } .cv-hero__identity { display: grid; grid-template-columns: 148px minmax(0, 1fr); gap: 1.25rem; align-items: start; } .cv-hero__photo img { width: 100%; aspect-ratio: 1 / 1; object-fit: cover; border: 1px solid var(--border); border-radius: 28px; background: linear-gradient(135deg, rgba(13, 128, 242, 0.1), rgba(227, 106, 17, 0.08)); } .cv-hero__copy h1, .cv-card__header h2 { margin: 0; line-height: 1.05; letter-spacing: -0.04em; } .cv-hero__role { margin: 0.5rem 0 0; font-size: clamp(1.05rem, 2vw, 1.35rem); font-weight: 600; color: var(--text); } .cv-hero__summary { margin: 1.25rem 0 0; max-width: 65ch; color: var(--text); font-size: 1.12rem; line-height: 1.6; } .cv-contact-card { padding: 1.15rem; border: 1px solid var(--border); border-radius: 24px; background: linear-gradient(180deg, rgba(13, 128, 242, 0.06), rgba(255, 255, 255, 0.92)); } .cv-contact-list { display: grid; gap: 0.75rem; } .cv-contact-item { display: grid; gap: 0.12rem; padding: 0.85rem 0.95rem; border: 1px solid var(--border); border-radius: 18px; background: rgba(255, 255, 255, 0.84); transition: transform 0.18s ease, border-color 0.18s ease, background 0.18s ease; } .cv-contact-item:hover { transform: translateY(-1px); border-color: rgba(13, 128, 242, 0.22); background: #fff; } .cv-contact-item__label { color: var(--muted); font-size: var(--font-size-small); letter-spacing: 0.08em; text-transform: uppercase; } .cv-contact-item strong { overflow-wrap: anywhere; } .cv-overview-grid { display: grid; grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr); gap: 1.5rem; } .cv-card__header { display: flex; align-items: end; justify-content: space-between; gap: 1rem; margin-bottom: 1rem; } .cv-summary-text { margin: 0; max-width: 72ch; color: var(--text); font-size: 1rem; line-height: 1.72; } .cv-facts { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 0.85rem; margin: 0; } .cv-facts__item { padding: 0.95rem 1rem; border: 1px solid var(--border); border-radius: 18px; background: rgba(255, 255, 255, 0.76); } .cv-facts__item dt { margin: 0 0 0.3rem; color: var(--muted); font-size: var(--font-size-small); letter-spacing: 0.06em; text-transform: uppercase; } .cv-facts__item dd { margin: 0; color: var(--text); font-weight: 600; } .cv-chip-list { display: flex; flex-wrap: wrap; gap: 0.65rem; } .cv-chip { display: inline-flex; align-items: center; padding: 0.52rem 0.82rem; border: 1px solid rgba(13, 128, 242, 0.12); border-radius: 999px; background: var(--accent-soft); color: var(--accent-strong); font-size: var(--font-size-small); font-weight: 600; } .cv-card--stack { display: grid; gap: 1rem; } .cv-stack-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 1rem; } .cv-stack-group { padding: 1rem; border: 1px solid var(--border); border-radius: 22px; background: rgba(255, 255, 255, 0.76); } .cv-stack-group h3 { margin: 0 0 0.85rem; color: var(--text); } .cv-body { position: relative; color: var(--text); } .cv-body h2 { margin-top: 3rem; margin-bottom: 1.5rem; padding-top: 1.5rem; border-top: 1px solid var(--border); font-size: var(--font-size-heading-md); } .cv-body h2:first-of-type { margin-top: 0; padding-top: 0; border-top: 0; } .cv-body ul { padding-left: 0; list-style: none; display: grid; gap: 0.75rem; } .cv-body ul li { padding: 0.9rem 1rem; border: 1px solid var(--border); border-radius: 16px; background: rgba(255, 255, 255, 0.72); color: var(--text); } @media (max-width: 640px) { .pagination { padding: 1rem; } .pagination__links { gap: 0.5rem; } .pagination__page, .pagination__control { min-width: 2.75rem; min-height: 2.75rem; padding: 0.65rem 0.85rem; } .cv-hero-card, .cv-card, .cv-panel--content, .cv-contact-card { padding: 1rem; } .cv-shell { gap: 1rem; } .cv-hero__identity { grid-template-columns: 96px minmax(0, 1fr); gap: 0.95rem; } .cv-body h3 + p, .cv-body ul li { padding: 0.9rem; } } @media (max-width: 980px) { .cv-hero, .cv-overview-grid, .cv-stack-grid { grid-template-columns: 1fr; } } @media print { @page { size: A4; margin: 11mm 12mm 12mm; } *, *::before, *::after { box-shadow: none !important; text-shadow: none !important; transition: none !important; animation: none !important; } html, body { background: #fff !important; color: #111 !important; font-size: 9.25pt; line-height: 1.35; -webkit-print-color-adjust: exact; print-color-adjust: exact; } .site-header, .site-footer, .breadcrumbs, .skip-link, .site-mobile-overlay, .site-mobile-panel { display: none !important; } .page-shell, .container, .cv-shell { width: 100%; max-width: none; margin: 0; padding: 0; } .page-shell { padding: 0; } .surface-panel, .article-panel, .cv-hero-card, .cv-card, .cv-panel--content, .cv-contact-card, .cv-stack-group, .cv-facts__item, .cv-contact-item, .cv-body h3 + p, .cv-body ul li { border-radius: 0 !important; backdrop-filter: none !important; } .cv-shell { display: block; } .cv-hero-card, .cv-card, .cv-panel--content, .cv-contact-card, .cv-stack-group, .cv-facts__item, .cv-contact-item, .cv-body h3 + p, .cv-body ul li { box-shadow: none !important; background: #fff !important; break-inside: avoid; page-break-inside: avoid; } .cv-hero-card { padding: 0 0 6mm; border: 0; border-bottom: 1.5pt solid #111; } .cv-hero { display: grid; grid-template-columns: minmax(0, 1fr) 64mm; gap: 7mm; align-items: start; } .cv-hero__identity { grid-template-columns: 27mm minmax(0, 1fr); gap: 5mm; } .cv-hero__photo img { width: 27mm; height: 27mm; border: 0.75pt solid #999; border-radius: 3mm; } .section-kicker, .cv-contact-item__label, .cv-facts__item dt { color: #555 !important; font-size: 6.8pt; letter-spacing: 0.08em; } .cv-hero__copy h1 { font-size: 21pt; letter-spacing: -0.03em; } .cv-hero__role { margin-top: 1.5mm; font-size: 10.5pt; } .cv-hero__summary, .cv-summary-text { margin-top: 2.5mm; color: #222 !important; font-size: 8.7pt; line-height: 1.42; } .page-hero__meta { margin-top: 2.5mm; color: #555 !important; font-size: 7.2pt; } .cv-contact-card { padding: 0; border: 0; } .cv-contact-list { gap: 1.7mm; } .cv-contact-item { display: grid; grid-template-columns: 18mm minmax(0, 1fr); gap: 2.5mm; padding: 0; border: 0; } .cv-contact-item strong { color: #111 !important; font-size: 7.6pt; font-weight: 600; } .cv-overview-grid { display: grid; grid-template-columns: minmax(0, 1.12fr) minmax(0, 0.88fr); gap: 5mm; margin-top: 5mm; } .cv-card { padding: 4mm 0 0; border: 0; border-top: 0.75pt solid #d0d0d0; } .cv-card--summary { border-top-color: #111; } .cv-facts { grid-template-columns: 1fr 1fr; gap: 2.2mm 4mm; } .cv-facts__item { padding: 0; border: 0; } .cv-facts__item dd { color: #111 !important; font-size: 8pt; font-weight: 650; } .cv-card__header { margin-bottom: 2.5mm; } .cv-card__header h2, .cv-body h2 { color: #111 !important; font-size: 12pt; letter-spacing: -0.02em; } .cv-stack-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 4mm; } .cv-stack-group { padding: 0; border: 0; } .cv-stack-group h3 { margin-bottom: 2mm; color: #111 !important; font-size: 8.4pt; } .cv-chip-list { gap: 1.5mm; } .cv-chip { padding: 0.8mm 1.7mm; border: 0.65pt solid #bbb; border-radius: 2.2mm; background: #f7f7f7 !important; color: #111 !important; font-size: 7pt; font-weight: 600; } .cv-panel--content { margin-top: 5mm; padding: 0; border: 0; } .cv-body { color: #111 !important; font-size: 8.35pt; line-height: 1.35; } .cv-body h2 { margin: 5mm 0 2.8mm; padding-top: 3.2mm; border-top: 1.2pt solid #111; break-after: avoid; page-break-after: avoid; } .cv-body h2:first-of-type { margin-top: 0; } .cv-body h3 { margin: 3.6mm 0 1mm; color: #111 !important; font-size: 9.6pt; break-after: avoid; page-break-after: avoid; } .cv-body h3 + p { margin: 0 0 1.6mm; padding: 0; border: 0; color: #222 !important; font-size: 8pt; } .cv-body ul { display: grid; gap: 0.8mm; margin: 0 0 2.2mm; padding: 0; break-inside: avoid; page-break-inside: avoid; } .cv-body ul li { padding: 0; border: 0; color: #222 !important; font-size: 7.8pt; } .cv-body ul li::before { content: "• "; color: #555; } .cv-body p { margin-block: 0 2.2mm; } .cv-body h3 + p + ul { break-before: avoid; page-break-before: avoid; } a, a:visited { color: #000 !important; text-decoration: none; } } .home-main--legacy { gap: 1.5rem; } .legacy-home-panel, .legacy-tech-panel { overflow: hidden; } .legacy-logo-marquee { overflow: hidden; -webkit-mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent); mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent); } .legacy-logo-marquee__track { --marquee-gap: 1rem; --marquee-distance: 0px; display: flex; align-items: center; gap: var(--marquee-gap); width: max-content; } .js .legacy-logo-marquee.is-ready .legacy-logo-marquee__track { animation: legacy-logo-marquee 28s linear infinite; } .legacy-logo-marquee:hover .legacy-logo-marquee__track { animation-play-state: paused; } .legacy-logo-marquee__group { display: flex; align-items: center; gap: var(--marquee-gap); flex-shrink: 0; } .legacy-logo-marquee__group[aria-hidden="true"] { display: none; } .js .legacy-logo-marquee__group[aria-hidden="true"] { display: flex; } .legacy-logo-pill { display: flex; align-items: center; justify-content: center; min-width: clamp(148px, 17vw, 188px); min-height: 82px; padding: 1rem 1.2rem; border: 1px solid rgba(255, 255, 255, 0.12); border-radius: 24px; background: linear-gradient(135deg, rgba(11, 34, 58, 0.98), rgba(14, 96, 179, 0.92)); box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08), 0 18px 32px rgba(18, 30, 49, 0.16); } .legacy-logo-pill img { display: block; width: auto; max-width: min(140px, 100%); max-height: 42px; height: auto; object-fit: contain; } .legacy-tech-strip { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 0.85rem; } .legacy-tech-pill { display: inline-flex; align-items: center; justify-content: center; min-width: 108px; min-height: 52px; padding: 0.9rem 1.1rem; border: 1px solid var(--border); border-radius: 18px; background: var(--surface-solid); color: var(--text); font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; } .legacy-timeline { position: relative; display: grid; } .timeline-item { position: relative; display: flex; gap: 3.5rem; margin-bottom: 4rem; } .legacy-timeline__row { position: relative; display: grid; align-items: start; } .legacy-timeline__axis { position: relative; display: grid; justify-items: center; align-content: start; } .legacy-timeline__axis span { display: block; width: 20px; min-width: 20px; height: 20px; min-height: 20px; border: 4px solid rgba(255, 255, 255, 0.96); border-radius: 999px; background: linear-gradient(135deg, var(--accent), var(--warm)); box-shadow: 0 12px 24px rgba(13, 128, 242, 0.18); z-index: 1; } /*.legacy-timeline__axis span::before { content: ''; position: absolute; top: 50%; width: 2.5rem; height: 2px; background: var(--border); z-index: -1; }*/ .legacy-timeline__row.is-left .legacy-timeline__axis span::before { right: 50%; } .legacy-timeline__row.is-right .legacy-timeline__axis span::before { left: 50%; } .legacy-timeline__spacer { min-height: 1px; } .legacy-timeline__meta--mobile { display: none; margin: 0 0 0.7rem; color: var(--muted); font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; } .legacy-soft-skills { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); align-items: start; } .legacy-skill-orbit { --skill-progress: 0%; display: grid; justify-items: center; text-align: center; } .legacy-skill-orbit__ring { --skill-ring-fill: #f23b38; --skill-ring-rest: #e3eaf1; position: relative; display: grid; place-items: center; aspect-ratio: 1 / 1; border-radius: 50%; background: conic-gradient(from -90deg, var(--skill-ring-fill) 0 var(--skill-progress), var(--skill-ring-rest) var(--skill-progress) 100%); box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.52), 0 14px 26px rgba(23, 33, 52, 0.08); } .legacy-skill-orbit__ring::after { content: ''; position: absolute; inset: 16%; border-radius: 50%; background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(247, 249, 252, 0.98)); box-shadow: inset 0 0 0 1px rgba(217, 226, 236, 0.92); } .legacy-skill-orbit__ring > span { position: relative; z-index: 1; font-weight: 700; color: var(--text); } @keyframes legacy-logo-marquee { from { transform: translateX(0); } to { transform: translateX(calc(-1 * var(--marquee-distance))); } } @media (prefers-reduced-motion: reduce) { .legacy-logo-marquee { -webkit-mask-image: none; mask-image: none; } .legacy-logo-marquee__track { width: 100%; flex-wrap: wrap; justify-content: center; } .js .legacy-logo-marquee.is-ready .legacy-logo-marquee__track, .legacy-logo-marquee:hover .legacy-logo-marquee__track { animation: none; } .legacy-logo-marquee__group[aria-hidden="true"] { display: none; } } @media (max-width: 720px) { .legacy-logo-pill { min-width: 132px; min-height: 72px; padding: 0.85rem 1rem; border-radius: 20px; } .legacy-logo-pill img { max-width: 112px; max-height: 36px; } } .contact-form--home { grid-template-columns: repeat(2, minmax(0, 1fr)); padding: 0; border: 0; background: transparent; box-shadow: none; } .contact-form--home .flash, .contact-form--home .contact-form__status, .contact-form--home .contact-form__wide, .contact-form--home .contact-form__message, .contact-form--home .contact-form__consent, .contact-form--home .legacy-contact-panel__note, .contact-form--home button { grid-column: 1 / -1; } .legacy-contact-panel__note { margin: 0; color: var(--muted); } @media (max-width: 1160px) { .legacy-soft-skills { grid-template-columns: repeat(2, minmax(0, 1fr)); } } @media (max-width: 1024px) { .legacy-timeline__row, .contact-form--home { grid-template-columns: 1fr; } .legacy-blog-grid--home { grid-template-columns: 1fr; } .legacy-timeline__axis, .legacy-timeline__spacer { display: none; } .legacy-timeline__meta--mobile { display: block; } .legacy-soft-skills { grid-template-columns: repeat(2, minmax(0, 1fr)); } } @media (max-width: 720px) { .legacy-home-panel, .legacy-tech-panel { padding: 1.2rem; } .legacy-soft-skills { grid-template-columns: 1fr; } .legacy-tech-pill { min-width: 0; width: calc(50% - 0.45rem); } } /* legacy home spacing polish start */ .home-shell { margin-top: 1rem; } .home-main--legacy { gap: 1.5rem; } .home-main--legacy .surface-panel { border-radius: 28px; } .home-main--legacy .legacy-home-panel, .home-main--legacy .legacy-tech-panel { padding: clamp(1.2rem, 2.0vw, 2.0rem); } .home-main--legacy .legacy-hero-panel { position: relative; display: grid; gap: 1.05rem; overflow: hidden; isolation: isolate; padding: clamp(1.45rem, 3vw, 2.7rem); } .home-main--legacy .legacy-hero-panel::before { content: ''; position: absolute; inset: -35% -18% auto auto; width: min(560px, 72vw); height: min(560px, 72vw); border-radius: 50%; background: radial-gradient(circle at 35% 35%, rgba(13, 128, 242, 0.18), transparent 56%), radial-gradient(circle at 72% 62%, rgba(227, 106, 17, 0.13), transparent 48%); z-index: -1; } .home-main--legacy .legacy-hero-panel > * { position: relative; z-index: 1; } .home-main--legacy .legacy-hero-panel h1 { margin: 0; line-height: 0.98; letter-spacing: -0.06em; font-size: clamp(2rem, 10.5vw, 3.2rem); } .legacy-hero-panel__lead { max-width: 72ch; margin: 0; color: var(--muted); font-size: clamp(1rem, 1.45vw, 1.18rem); line-height: 1.72; } .legacy-trust-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 0.75rem; margin: 0.45rem 0 0; } .legacy-trust-grid > div { display: grid; gap: 0.28rem; min-height: 112px; align-content: start; padding: 0.9rem; border: 1px solid var(--border); border-radius: 20px; background: rgba(255, 255, 255, 0.72); } .legacy-trust-grid dt { color: var(--muted); font-size: 0.68rem; font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase; } .legacy-trust-grid dd { margin: 0; color: var(--text); font-weight: 800; line-height: 1.25; } .home-main--legacy .legacy-home-heading { display: grid; gap: 0.6rem; margin-bottom: 1.85rem; } .home-main--legacy .legacy-home-heading--center { justify-items: center; text-align: center; } .home-main--legacy .legacy-story-block { text-align: center; } .home-main--legacy .legacy-home-heading--center h2, .home-main--legacy .legacy-story-block h2 { display: inline-grid; justify-items: center; gap: 0.8rem; line-height: 1.08; } .home-main--legacy .legacy-home-heading--center h2::after, .home-main--legacy .legacy-story-block h2::after { content: ''; width: 78px; height: 6px; border-radius: 999px; background: linear-gradient(90deg, rgba(22, 34, 54, 0.12) 0 44%, var(--accent) 44% 72%, var(--warm) 72% 100%); } .home-main--legacy .legacy-home-heading__intro { max-width: 72ch; margin-top: 0; line-height: 1.72; } .home-main--legacy .legacy-home-heading__intro p { margin: 0; } .home-main--legacy .legacy-service-grid, .home-main--legacy .legacy-feature-grid, .home-main--legacy .legacy-blog-grid { gap: 1.25rem; } .home-main--legacy .legacy-service-grid { gap: 0.95rem; } .home-main--legacy .legacy-card--service { gap: 0.65rem; padding: 1.05rem 1.05rem 1rem; } .home-main--legacy .legacy-card--service .legacy-card__body { font-size: var(--font-size-small); line-height: 1.64; } .home-main--legacy .legacy-card--service .legacy-card__body > * + * { margin-top: 0.72rem; } .home-main--legacy .legacy-card--service .text-link { padding-top: 0.15rem; } .home-main--legacy .legacy-card, .home-main--legacy .legacy-blog-grid .article-card { display: flex; flex-direction: column; gap: 0.8rem; padding: 1.2rem 1.2rem 1.2rem; border-radius: 26px; } .home-main--legacy .legacy-card h3, .home-main--legacy .legacy-blog-grid .article-card h3 { margin: 0; line-height: 1.26; } .home-main--legacy .legacy-card__body, .home-main--legacy .legacy-blog-grid .article-card p, .home-main--legacy .legacy-timeline__card .content-flow, .home-main--legacy .legacy-story-block .content-flow { line-height: 1.74; } .home-main--legacy .legacy-card__body, .home-main--legacy .legacy-story-block .content-flow { text-align: justify; text-justify: inter-word; hyphens: auto; } .home-main--legacy .legacy-timeline__card .content-flow { text-align: left; text-justify: auto; hyphens: none; } .home-main--legacy .legacy-card__body strong, .home-main--legacy .legacy-timeline__card .content-flow strong, .home-main--legacy .legacy-story-block .content-flow strong { color: var(--text); font-weight: 700; } .home-main--legacy .legacy-card__body p, .home-main--legacy .legacy-card__body ul, .home-main--legacy .legacy-card__body ol, .home-main--legacy .legacy-timeline__card .content-flow p, .home-main--legacy .legacy-timeline__card .content-flow ul, .home-main--legacy .legacy-timeline__card .content-flow ol, .home-main--legacy .legacy-story-block .content-flow p, .home-main--legacy .legacy-story-block .content-flow ul, .home-main--legacy .legacy-story-block .content-flow ol, .home-main--legacy .legacy-blog-grid .article-card p { margin: 0; } .home-main--legacy .legacy-card__body > * + *, .home-main--legacy .legacy-timeline__card .content-flow > * + *, .home-main--legacy .legacy-story-block .content-flow > * + *, .home-main--legacy .legacy-blog-grid .article-card > * + * { margin-top: 0.9rem; } .home-main--legacy .legacy-card .text-link, .home-main--legacy .legacy-blog-grid .article-card .text-link { margin-top: auto; padding-top: 0.35rem; } .home-main--legacy .legacy-blog-grid .article-card { min-height: 100%; } .home-main--legacy .legacy-blog-grid .article-card__meta { margin-bottom: 0; } .home-main--legacy .legacy-blog-grid .tag-list { margin-top: 0.1rem; } .home-main--legacy .legacy-story-block { margin-top: 2.35rem; padding-top: 1.9rem; } .home-main--legacy .legacy-story-block .content-flow { max-width: none; } .home-main--legacy .legacy-timeline { gap: 1.35rem; margin-top: 0.2rem; } .home-main--legacy .legacy-timeline::before { content: ''; position: absolute; top: 1rem; bottom: 1.2rem; left: 50%; width: 2px; background: repeating-linear-gradient( to bottom, var(--accent) 0, var(--accent) 8px, transparent 8px, transparent 14px ); opacity: 0.4; transform: translateX(-50%); } .home-main--legacy .legacy-timeline__row { grid-template-columns: minmax(0, 1fr) 124px minmax(0, 1fr); gap: 1.35rem; } .home-main--legacy .legacy-timeline__axis { min-height: 2rem; padding-top: 0.25rem; } .home-main--legacy .legacy-timeline__axis strong, .home-main--legacy .legacy-timeline__meta { color: var(--text); font-weight: 600; line-height: 1.4; letter-spacing: 0; text-transform: none; } .home-main--legacy .legacy-timeline__axis strong { position: absolute; top: 0; display: inline-flex; align-items: center; white-space: nowrap; } .home-main--legacy .legacy-timeline__row.is-right .legacy-timeline__axis strong { right: calc(100% + 1rem); justify-content: flex-end; gap: 0.75rem; text-align: right; } .home-main--legacy .legacy-timeline__row.is-right .legacy-timeline__axis strong::after { content: ''; width: 2.25rem; height: 2px; border-radius: 999px; background: rgba(13, 128, 242, 0.72); } .home-main--legacy .legacy-timeline__row.is-left .legacy-timeline__axis strong { left: calc(100% + 1rem); justify-content: flex-start; gap: 0.75rem; text-align: left; } .home-main--legacy .legacy-timeline__row.is-left .legacy-timeline__axis strong::before { content: ''; width: 2.25rem; height: 2px; border-radius: 999px; background: rgba(13, 128, 242, 0.72); } .home-main--legacy .legacy-timeline__card { position: relative; overflow: visible; padding: 1.45rem 1.5rem; border-radius: 26px; } .home-main--legacy .legacy-timeline__card::before { content: ''; position: absolute; top: 1.45rem; width: 12px; height: 12px; border: 1px solid var(--border); background: #fff; transform: rotate(45deg); } .home-main--legacy .legacy-timeline__row.is-left .legacy-timeline__card::before { right: -7px; border-left: 0; border-bottom: 0; } .home-main--legacy .legacy-timeline__row.is-right .legacy-timeline__card::before { left: -7px; border-right: 0; border-top: 0; } .home-main--legacy .legacy-timeline__card h3 { margin: 0 0 0.8rem; } .home-main--legacy .legacy-home-panel--skills { padding-bottom: clamp(1.75rem, 2.5vw, 2.9rem); } .home-main--legacy .legacy-soft-skills { gap: 1rem 0.85rem; margin-top: 0.2rem; } .home-main--legacy .legacy-skill-orbit { gap: 0.8rem; padding: 0.15rem 0; } .home-main--legacy .legacy-skill-orbit__ring { width: min(184px, 100%); padding: 0.9rem; } .home-main--legacy .legacy-skill-orbit strong { max-width: 11ch; } .home-main--legacy .legacy-tech-panel { padding-block: clamp(1.4rem, 2vw, 1.9rem); } .home-main--legacy .legacy-tech-strip { gap: 1rem; } .home-main--legacy .legacy-tech-pill { min-width: 124px; min-height: 58px; padding: 1rem 1.2rem; border-radius: 20px; } .home-main--legacy .legacy-contact-panel { padding-bottom: clamp(1.6rem, 2.4vw, 2.5rem); } .home-main--legacy .contact-form--home { gap: 1rem 1.1rem; align-items: start; } .home-main--legacy .contact-form--home .contact-form__required-note { grid-column: 1 / -1; } .home-main--legacy .contact-form--home label { gap: 0.55rem; } .home-main--legacy .contact-form--home input, .home-main--legacy .contact-form--home textarea { min-height: 54px; padding: 1rem 1.05rem; } .home-main--legacy .contact-form--home textarea { min-height: 210px; } .home-main--legacy .legacy-contact-panel__note { margin-top: 0.15rem; line-height: 1.65; } .home-main--legacy .contact-form--home button { margin-top: 0.35rem; min-height: 52px; } @media (max-width: 1160px) { .home-main--legacy .legacy-timeline__row { grid-template-columns: minmax(0, 1fr) 104px minmax(0, 1fr); } .home-main--legacy .legacy-soft-skills { gap: 1.3rem; } } @media (max-width: 1024px) { .home-main--legacy { gap: 1.5rem; } .home-main--legacy .legacy-home-panel, .home-main--legacy .legacy-tech-panel { padding: 1.45rem; } .legacy-trust-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } .home-main--legacy .legacy-home-heading { margin-bottom: 1.5rem; } .home-main--legacy .legacy-story-block { margin-top: 1.75rem; padding-top: 1.45rem; } .home-main--legacy .legacy-timeline { gap: 1rem; padding-left: 0.1rem; } .home-main--legacy .legacy-timeline::before { left: 24px; top: 1rem; bottom: 1rem; transform: none; } .home-main--legacy .legacy-timeline__row { grid-template-columns: 1fr; gap: 0; padding-left: 3rem; } .home-main--legacy .legacy-timeline__axis, .home-main--legacy .legacy-timeline__spacer { display: none; } .home-main--legacy .legacy-timeline__meta--mobile { display: inline-flex; margin: 0 0 0.55rem; color: var(--accent-strong); font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; } .home-main--legacy .legacy-timeline__card { padding: 1.2rem 1.2rem 1.1rem; } .home-main--legacy .legacy-timeline__card::before { top: 1.15rem; left: -2.25rem; right: auto; width: 16px; height: 16px; border-top: 0; border-left: 0; border: 4px solid rgba(255, 255, 255, 0.96); border-radius: 999px; background: linear-gradient(135deg, var(--accent), var(--warm)); box-shadow: 0 10px 20px rgba(13, 128, 242, 0.16); transform: none; } } @media (max-width: 720px) { .home-shell { margin-top: 0.75rem; } .home-main--legacy .legacy-home-panel, .home-main--legacy .legacy-tech-panel { padding: 1.2rem; border-radius: 24px; } .home-main--legacy .legacy-hero-panel { padding: 1.25rem; } /* .home-main--legacy .legacy-hero-panel h1 { max-width: 11ch; font-size: clamp(2rem, 10.5vw, 3.2rem); }*/ .legacy-trust-grid { grid-template-columns: 1fr; } .legacy-trust-grid > div { min-height: 0; } .home-main--legacy .legacy-home-heading--center h2, .home-main--legacy .legacy-story-block h2 { font-size: var(--font-size-heading-lg-mobile); } .home-main--legacy .legacy-service-grid, .home-main--legacy .legacy-feature-grid, .home-main--legacy .legacy-blog-grid { gap: 1rem; } .home-main--legacy .legacy-soft-skills { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 0.95rem 0.7rem; } .home-main--legacy .legacy-card, .home-main--legacy .legacy-blog-grid .article-card, .home-main--legacy .legacy-timeline__card { padding: 1.1rem; } .home-main--legacy .legacy-skill-orbit { gap: 0.65rem; } .home-main--legacy .legacy-skill-orbit__ring { width: min(136px, 100%); } .home-main--legacy .legacy-timeline::before { left: 20px; } .home-main--legacy .legacy-timeline__row { padding-left: 2.5rem; } .home-main--legacy .legacy-timeline__card::before { left: calc(20px - 11px - 2.5rem); width: 14px; height: 14px; } .home-main--legacy .legacy-tech-pill { width: 100%; min-width: 0; } .home-main--legacy .contact-form--home { gap: 0.85rem; } } @media (max-width: 560px) { .home-main--legacy .legacy-skill-orbit__ring { width: min(124px, 100%); } } /* legacy home spacing polish end */ /* Shopware ads landing page */ .template-pages-shopware-ads { --ads-bg: #07111f; --ads-ink: #eef7ff; --ads-muted: #adc0d6; --ads-subtle: #6f849b; --ads-panel: rgba(9, 20, 36, 0.82); --ads-panel-strong: rgba(12, 28, 49, 0.95); --ads-line: rgba(144, 177, 214, 0.22); --ads-line-strong: rgba(107, 189, 255, 0.44); --ads-blue: #47b9ff; --ads-blue-deep: #1264f2; --ads-gold: #ffc46a; --ads-green: #76e3b5; --ads-red: #ff766d; --ads-radius: 34px; color: var(--ads-ink); background: radial-gradient(circle at 12% 8%, rgba(71, 185, 255, 0.2), transparent 32%), radial-gradient(circle at 88% 0%, rgba(255, 196, 106, 0.16), transparent 30%), linear-gradient(180deg, #07111f 0%, #0a1424 42%, #101018 100%); } .template-pages-shopware-ads .site-header { border-color: rgba(144, 177, 214, 0.18); background: rgba(6, 15, 27, 0.88); color: var(--ads-ink); } .template-pages-shopware-ads .site-header__inner { min-height: 74px; } .template-pages-shopware-ads .site-nav, .template-pages-shopware-ads .menu-cv, .template-pages-shopware-ads .language-switcher--desktop { display: none; } .template-pages-shopware-ads .nav-toggle { display: none; } .template-pages-shopware-ads .site-footer { border-color: rgba(144, 177, 214, 0.16); background: rgba(6, 15, 27, 0.86); color: var(--ads-muted); } .template-pages-shopware-ads .site-footer h2, .template-pages-shopware-ads .site-footer a, .template-pages-shopware-ads .site-footer__quote { color: var(--ads-ink); } .template-pages-shopware-ads .page-shell { position: relative; padding-top: clamp(1rem, 2vw, 2.4rem); overflow: hidden; } .template-pages-shopware-ads .page-shell::before { content: ''; position: absolute; inset: 0; pointer-events: none; background-image: linear-gradient(rgba(144, 177, 214, 0.08) 1px, transparent 1px), linear-gradient(90deg, rgba(144, 177, 214, 0.08) 1px, transparent 1px); background-size: 56px 56px; -webkit-mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.9), transparent 72%); mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.9), transparent 72%); } .ads-landing { position: relative; z-index: 1; display: grid; gap: clamp(1.2rem, 2vw, 1.8rem); } .ads-hero, .ads-section { border: 1px solid var(--ads-line); border-radius: var(--ads-radius); background: linear-gradient(135deg, rgba(12, 28, 49, 0.94), rgba(7, 17, 31, 0.82)); box-shadow: 0 30px 90px rgba(0, 0, 0, 0.28), inset 0 1px 0 rgba(255, 255, 255, 0.06); } .ads-hero { position: relative; display: grid; grid-template-columns: minmax(0, 1.08fr) minmax(320px, 0.72fr); gap: clamp(1.5rem, 4vw, 4rem); min-height: 640px; padding: clamp(1.4rem, 4vw, 4.5rem); overflow: hidden; isolation: isolate; } .ads-hero::before, .ads-hero::after { content: ''; position: absolute; pointer-events: none; z-index: -1; } .ads-hero::before { inset: -18% -8% auto auto; width: min(56vw, 680px); aspect-ratio: 1; border-radius: 50%; background: radial-gradient(circle, rgba(71, 185, 255, 0.24), transparent 58%), conic-gradient(from 120deg, transparent, rgba(255, 196, 106, 0.14), transparent, rgba(71, 185, 255, 0.16), transparent); filter: blur(2px); animation: ads-orbit-glow 12s linear infinite; } .ads-hero::after { inset: auto 7% 8% auto; width: min(44vw, 540px); height: 180px; border-radius: 999px; background: radial-gradient(ellipse, rgba(118, 227, 181, 0.16), transparent 70%); transform: rotate(-9deg); } .ads-hero__copy { display: grid; align-content: center; gap: 1.35rem; animation: ads-rise 0.72s ease both; } .ads-eyebrow { margin: 0; color: var(--ads-gold); font-size: 0.78rem; font-weight: 800; letter-spacing: 0.22em; text-transform: uppercase; } .ads-hero h1, .ads-section h2 { margin: 0; color: var(--ads-ink); line-height: 0.96; letter-spacing: -0.07em; } .ads-hero h1 { max-width: 11ch; font-size: clamp(2.45rem, 6.4vw, 5.35rem); } .ads-hero__lead { max-width: 64ch; margin: 0; color: var(--ads-muted); font-size: clamp(1.05rem, 1.5vw, 1.28rem); } .ads-hero__actions { display: flex; flex-wrap: wrap; gap: 0.85rem; margin-top: 0.35rem; } .ads-button { border-color: rgba(255, 196, 106, 0.78); background: linear-gradient(135deg, var(--ads-gold), #ff9f43); color: #142033; box-shadow: 0 18px 42px rgba(255, 165, 62, 0.25); } .ads-button:hover { border-color: #ffd89a; background: linear-gradient(135deg, #ffd99b, #ffad54); color: #142033; } .ads-button-secondary { border-color: var(--ads-line); color: var(--ads-ink); background: rgba(255, 255, 255, 0.04); } .ads-button-secondary:hover { border-color: var(--ads-line-strong); color: var(--ads-ink); background: rgba(71, 185, 255, 0.1); } .ads-proof-row { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 0.75rem; margin: 1.25rem 0 0; } .ads-proof-row > div { padding: 0.9rem; border: 1px solid var(--ads-line); border-radius: 22px; background: rgba(255, 255, 255, 0.04); } .ads-proof-row dt { margin: 0 0 0.2rem; color: var(--ads-subtle); font-size: 0.72rem; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; } .ads-proof-row dd { margin: 0; color: var(--ads-ink); font-weight: 800; } .ads-command-panel { position: relative; display: grid; align-content: end; gap: 1rem; min-height: 520px; animation: ads-rise 0.72s 0.14s ease both; } .ads-orbit { position: absolute; inset: 0; display: grid; place-items: center; pointer-events: none; } .ads-orbit span { position: absolute; width: var(--orbit-size, 78%); aspect-ratio: 1; border: 1px solid rgba(71, 185, 255, 0.2); border-radius: 50%; background: linear-gradient(90deg, transparent 48%, rgba(71, 185, 255, 0.42) 49%, transparent 51%), linear-gradient(0deg, transparent 48%, rgba(255, 196, 106, 0.26) 49%, transparent 51%); box-shadow: inset 0 0 42px rgba(71, 185, 255, 0.08); animation: ads-orbit-spin 16s linear infinite; } .ads-orbit span:nth-child(2) { --orbit-size: 58%; animation-duration: 11s; animation-direction: reverse; } .ads-orbit span:nth-child(3) { --orbit-size: 35%; animation-duration: 7s; opacity: 0.7; } .ads-profile-chip, .ads-console { position: relative; z-index: 1; border: 1px solid var(--ads-line); border-radius: 28px; background: rgba(6, 15, 27, 0.72); -webkit-backdrop-filter: blur(18px); backdrop-filter: blur(18px); } .ads-profile-chip { display: grid; gap: 1rem; justify-self: end; width: min(100%, 360px); padding: 1rem; } .ads-profile-chip img { width: 100%; aspect-ratio: 1; object-fit: cover; border-radius: 24px; border: 1px solid rgba(255, 255, 255, 0.12); filter: saturate(0.9) contrast(1.04); } .ads-profile-chip strong { display: block; color: var(--ads-ink); font-size: 1.35rem; line-height: 1.1; } .ads-profile-chip span { color: var(--ads-muted); } .ads-console { display: grid; gap: 0.7rem; padding: 1rem; } .ads-console > div { display: grid; grid-template-columns: 92px minmax(0, 1fr); gap: 0.8rem; align-items: center; padding: 0.8rem; border-radius: 18px; background: rgba(255, 255, 255, 0.04); } .ads-console span { color: var(--ads-subtle); font-size: 0.72rem; font-weight: 800; letter-spacing: 0.14em; text-transform: uppercase; } .ads-console strong { color: var(--ads-ink); } .ads-section { padding: clamp(1.4rem, 3vw, 3rem); } .ads-section--split, .ads-contact-section, .ads-fit { display: grid; grid-template-columns: minmax(0, 0.8fr) minmax(0, 1.2fr); gap: clamp(1.3rem, 3vw, 3rem); align-items: start; } .ads-section__intro, .ads-section__header, .ads-contact-copy { display: grid; gap: 0.8rem; } .ads-section h2 { max-width: 12ch; font-size: clamp(1.65rem, 3.5vw, 3.35rem); } .ads-section__header h2 { max-width: 15ch; } .ads-section__header p, .ads-contact-copy p { max-width: 64ch; margin: 0; color: var(--ads-muted); font-size: 1rem; } .ads-signal-list, .ads-card-grid { display: grid; gap: 1rem; } .ads-signal-list article, .ads-service-card, .ads-fit__note, .ads-faq__item { border: 1px solid var(--ads-line); border-radius: 24px; background: rgba(255, 255, 255, 0.045); } .ads-signal-list article { display: grid; grid-template-columns: 48px minmax(0, 1fr); gap: 0 1rem; padding: 1rem; } .ads-signal-list span { grid-row: 1 / 3; display: grid; place-items: center; width: 48px; height: 48px; border-radius: 16px; background: rgba(71, 185, 255, 0.13); color: var(--ads-blue); font-weight: 900; } .ads-signal-list h3, .ads-service-card h3 { margin: 0; color: var(--ads-ink); font-size: clamp(1.05rem, 1.35vw, 1.22rem); line-height: 1.15; } .ads-signal-list p, .ads-service-card p, .ads-fit p, .ads-check-list { margin: 0; color: var(--ads-muted); } .ads-card-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); margin-top: 1.4rem; } .ads-service-card { position: relative; min-height: 260px; padding: 1.2rem; overflow: hidden; transition: transform 0.22s ease, border-color 0.22s ease, background 0.22s ease; } .ads-service-card::before { content: ''; position: absolute; inset: 0; background: linear-gradient(135deg, rgba(71, 185, 255, 0.12), transparent 52%); opacity: 0; transition: opacity 0.22s ease; } .ads-service-card:hover { transform: translateY(-4px); border-color: var(--ads-line-strong); background: rgba(255, 255, 255, 0.065); } .ads-service-card:hover::before { opacity: 1; } .ads-service-card span { position: relative; display: inline-flex; margin-bottom: 2rem; color: var(--ads-gold); font-size: 0.72rem; font-weight: 900; letter-spacing: 0.16em; text-transform: uppercase; } .ads-service-card h3, .ads-service-card p { position: relative; } .ads-service-card p { margin-top: 0.8rem; } .ads-process-list { counter-reset: ads-step; display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 0.9rem; margin: 1.5rem 0 0; padding: 0; list-style: none; } .ads-process-list li { counter-increment: ads-step; position: relative; display: grid; gap: 0.7rem; padding: 1.1rem; border: 1px solid var(--ads-line); border-radius: 24px; background: rgba(255, 255, 255, 0.045); } .ads-process-list li::before { content: counter(ads-step, decimal-leading-zero); color: var(--ads-green); font-weight: 900; letter-spacing: 0.16em; } .ads-process-list strong { color: var(--ads-ink); font-size: 1rem; line-height: 1.16; } .ads-process-list span { color: var(--ads-muted); } .ads-fit { align-items: stretch; } .ads-check-list { display: grid; gap: 0.75rem; margin-top: 1.2rem; padding: 0; list-style: none; } .ads-check-list li { position: relative; padding-left: 1.8rem; } .ads-check-list li::before { content: ''; position: absolute; top: 0.35rem; left: 0; width: 0.9rem; height: 0.9rem; border-radius: 50%; background: radial-gradient(circle at 40% 40%, #ffffff, var(--ads-green) 36%, rgba(118, 227, 181, 0.22) 70%); box-shadow: 0 0 18px rgba(118, 227, 181, 0.32); } .ads-fit__note { display: grid; align-content: center; gap: 0.7rem; padding: clamp(1.2rem, 2.4vw, 2rem); border-color: rgba(255, 118, 109, 0.3); background: linear-gradient(135deg, rgba(255, 118, 109, 0.1), rgba(255, 255, 255, 0.035)); } .ads-fit__note strong { color: var(--ads-red); font-size: 1.25rem; } .ads-contact-section { scroll-margin-top: 7rem; border-color: rgba(255, 196, 106, 0.32); background: radial-gradient(circle at 10% 12%, rgba(255, 196, 106, 0.11), transparent 34%), linear-gradient(135deg, rgba(12, 28, 49, 0.96), rgba(6, 15, 27, 0.9)); } .ads-contact-copy h2 { max-width: 11ch; } .ads-contact-list { display: grid; gap: 0.7rem; margin: 1rem 0 0; padding: 0; list-style: none; } .ads-contact-list li { display: grid; grid-template-columns: 86px minmax(0, 1fr); gap: 0.8rem; align-items: center; padding: 0.8rem 0; border-bottom: 1px solid var(--ads-line); } .ads-contact-list span { color: var(--ads-subtle); font-size: 0.72rem; font-weight: 900; letter-spacing: 0.14em; text-transform: uppercase; } .ads-contact-list a, .ads-contact-list strong { display: flex; align-items: center; min-height: 44px; color: var(--ads-ink); font-weight: 800; word-break: break-word; } .ads-contact-promises { display: grid; gap: 0.75rem; margin-top: 1rem; } .ads-contact-promises article { padding: 0.9rem 1rem; border: 1px solid var(--ads-line); border-radius: 20px; background: rgba(255, 255, 255, 0.06); } .ads-contact-promises strong { display: block; color: var(--ads-ink); font-weight: 900; } .ads-contact-promises span { display: block; margin-top: 0.25rem; color: var(--ads-muted); font-size: var(--font-size-small); line-height: 1.55; } .ads-contact-form { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 0.95rem; padding: clamp(1rem, 2vw, 1.4rem); border: 1px solid var(--ads-line); border-radius: 28px; background: rgba(5, 13, 25, 0.72); box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06); } .ads-contact-form .flash, .ads-contact-form .contact-form__status, .ads-form-help, .ads-contact-form__message, .ads-contact-form__consent, .ads-contact-form button { grid-column: 1 / -1; } .ads-form-help { margin: 0; color: var(--ads-muted); font-size: var(--font-size-small); } .ads-form-help p { margin: 0 0 0.65rem; } .ads-form-help ul { display: flex; flex-wrap: wrap; gap: 0.45rem; margin: 0; padding: 0; list-style: none; } .ads-form-help li { padding: 0.34rem 0.58rem; border: 1px solid rgba(144, 177, 214, 0.22); border-radius: 999px; background: rgba(255, 255, 255, 0.06); color: var(--ads-ink); } .ads-form-microcopy { grid-column: 1 / -1; margin: -0.35rem 0 0; color: var(--ads-muted); font-size: 0.82rem; } .ads-contact-form label { color: var(--ads-ink); } .ads-contact-form input, .ads-contact-form textarea { min-height: 54px; border-color: rgba(144, 177, 214, 0.24); background: rgba(255, 255, 255, 0.06); color: var(--ads-ink); } .ads-contact-form textarea { min-height: 190px; resize: vertical; } .ads-contact-form input::placeholder, .ads-contact-form textarea::placeholder { color: rgba(173, 192, 214, 0.62); } .ads-contact-form input:focus, .ads-contact-form textarea:focus { border-color: rgba(255, 196, 106, 0.72); box-shadow: 0 0 0 4px rgba(255, 196, 106, 0.14); } .ads-contact-form .contact-form__consent { color: var(--ads-muted) !important; } .ads-contact-form .contact-form__consent input[type='checkbox'] { width: 44px; min-width: 44px; height: 44px; min-height: 44px; border: 0; background: transparent; } .ads-contact-form .contact-form__consent input[type='checkbox']::before { border-color: rgba(144, 177, 214, 0.42); background: rgba(255, 255, 255, 0.08); } .ads-contact-form .contact-form__consent a { color: var(--ads-gold); } .ads-faq__grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 0.9rem; margin-top: 1.4rem; } .ads-faq__item { padding: 1rem 1.1rem; } .ads-faq__item summary { display: flex; align-items: center; min-height: 44px; color: var(--ads-ink); cursor: pointer; font-weight: 800; } .ads-faq__item div { margin-top: 0.75rem; color: var(--ads-muted); } .ads-faq__item div > :first-child { margin-top: 0; } .ads-faq__item div > :last-child { margin-bottom: 0; } @keyframes ads-rise { from { opacity: 0; transform: translateY(18px); } to { opacity: 1; transform: translateY(0); } } @keyframes ads-orbit-spin { to { transform: rotate(360deg); } } @keyframes ads-orbit-glow { to { transform: rotate(360deg); } } @media (prefers-reduced-motion: reduce) { .ads-hero__copy, .ads-command-panel, .ads-orbit span, .ads-hero::before { animation: none; } .ads-service-card, .ads-button { transition: none; } } @media (max-width: 1120px) { .ads-hero, .ads-section--split, .ads-contact-section, .ads-fit { grid-template-columns: 1fr; } .ads-command-panel { min-height: auto; } .ads-profile-chip { justify-self: start; } .ads-proof-row, .ads-card-grid, .ads-process-list { grid-template-columns: repeat(2, minmax(0, 1fr)); } } @media (max-width: 760px) { .template-pages-shopware-ads .page-shell { padding-top: 0.8rem; } .ads-landing { width: min(100% - 1rem, var(--container)); } .ads-hero, .ads-section { border-radius: 26px; } .ads-hero { min-height: auto; padding: 1.1rem; } .ads-hero h1 { max-width: 10ch; font-size: clamp(2.1rem, 10.5vw, 3.35rem); } .ads-proof-row, .ads-card-grid, .ads-process-list, .ads-faq__grid, .ads-contact-form { grid-template-columns: 1fr; } .ads-signal-list article { grid-template-columns: 1fr; } .ads-signal-list span { grid-row: auto; margin-bottom: 0.8rem; } .ads-service-card { min-height: 0; } .ads-contact-list li, .ads-console > div { grid-template-columns: 1fr; gap: 0.25rem; } } /* Shopware ads landing page: keep the campaign page inside the site system */ .template-pages-shopware-ads { --ads-bg: #eef3f8; --ads-ink: var(--text); --ads-muted: var(--muted); --ads-subtle: #7a8798; --ads-panel: rgba(255, 255, 255, 0.9); --ads-panel-strong: rgba(255, 255, 255, 0.98); --ads-line: rgba(217, 226, 236, 0.92); --ads-line-strong: rgba(13, 128, 242, 0.28); --ads-blue: var(--accent); --ads-blue-deep: var(--accent-strong); --ads-gold: var(--warm); --ads-green: #168a55; --ads-red: #b84a3e; color: var(--text); background: radial-gradient(circle at 10% 6%, rgba(13, 128, 242, 0.13), transparent 30%), radial-gradient(circle at 90% 8%, rgba(227, 106, 17, 0.09), transparent 30%), linear-gradient(180deg, #eef3f8 0%, #f7f9fc 52%, #edf2f7 100%); } .template-pages-shopware-ads .site-header { border-color: rgba(217, 226, 236, 0.9); background: rgba(255, 255, 255, 0.88); color: var(--text); } .template-pages-shopware-ads .site-nav { display: block; } .template-pages-shopware-ads .menu-cv { display: grid; } .template-pages-shopware-ads .language-switcher--desktop { display: flex; } .template-pages-shopware-ads .site-footer { border-color: rgba(217, 226, 236, 0.9); background: rgba(255, 255, 255, 0.72); color: var(--muted); } .template-pages-shopware-ads .site-footer h2, .template-pages-shopware-ads .site-footer a, .template-pages-shopware-ads .site-footer__quote { color: var(--text); } .template-pages-shopware-ads .page-shell::before { background-image: linear-gradient(rgba(13, 128, 242, 0.055) 1px, transparent 1px), linear-gradient(90deg, rgba(13, 128, 242, 0.055) 1px, transparent 1px); -webkit-mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.42), transparent 70%); mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.42), transparent 70%); } .template-pages-shopware-ads .ads-hero, .template-pages-shopware-ads .ads-section { border-color: var(--ads-line); background: radial-gradient(circle at 82% 4%, rgba(13, 128, 242, 0.11), transparent 34%), radial-gradient(circle at 10% 100%, rgba(227, 106, 17, 0.08), transparent 30%), linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(247, 249, 252, 0.9)); box-shadow: var(--shadow); } .template-pages-shopware-ads .ads-hero::before { background: radial-gradient(circle, rgba(13, 128, 242, 0.16), transparent 58%), radial-gradient(circle at 70% 30%, rgba(227, 106, 17, 0.1), transparent 54%); filter: none; } .template-pages-shopware-ads .ads-hero::after { background: radial-gradient(ellipse, rgba(13, 128, 242, 0.12), transparent 70%); } .template-pages-shopware-ads .ads-proof-row > div, .template-pages-shopware-ads .ads-profile-chip, .template-pages-shopware-ads .ads-console, .template-pages-shopware-ads .ads-signal-list article, .template-pages-shopware-ads .ads-service-card, .template-pages-shopware-ads .ads-contact-promises article, .template-pages-shopware-ads .ads-fit__note, .template-pages-shopware-ads .ads-faq__item { border-color: var(--ads-line); background: rgba(255, 255, 255, 0.76); } .template-pages-shopware-ads .ads-orbit span { border-color: rgba(13, 128, 242, 0.14); background: linear-gradient(90deg, transparent 48%, rgba(13, 128, 242, 0.28) 49%, transparent 51%), linear-gradient(0deg, transparent 48%, rgba(227, 106, 17, 0.2) 49%, transparent 51%); box-shadow: inset 0 0 42px rgba(13, 128, 242, 0.08); } .template-pages-shopware-ads .ads-orbit { display: none; } .template-pages-shopware-ads .ads-hero__copy, .template-pages-shopware-ads .ads-command-panel, .template-pages-shopware-ads .ads-orbit span, .template-pages-shopware-ads .ads-hero::before { animation: none; } .template-pages-shopware-ads .ads-profile-chip, .template-pages-shopware-ads .ads-console { backdrop-filter: none; } .template-pages-shopware-ads .ads-button { border-color: var(--accent); background: var(--accent); color: #fff; box-shadow: 0 14px 28px rgba(13, 128, 242, 0.18); } .template-pages-shopware-ads .ads-button:hover { border-color: var(--accent-strong); background: var(--accent-strong); color: #fff; } .template-pages-shopware-ads .ads-button-secondary { border-color: var(--border); background: transparent; color: var(--accent-strong); } .template-pages-shopware-ads .ads-button-secondary:hover { border-color: rgba(13, 128, 242, 0.28); background: var(--accent-soft); color: var(--accent-strong); } .template-pages-shopware-ads .ads-contact-section { border-color: rgba(13, 128, 242, 0.22); background: radial-gradient(circle at 10% 12%, rgba(13, 128, 242, 0.1), transparent 34%), linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(247, 249, 252, 0.92)); } .template-pages-shopware-ads .ads-contact-form { border-color: var(--border); background: rgba(255, 255, 255, 0.84); } .template-pages-shopware-ads .ads-contact-form input, .template-pages-shopware-ads .ads-contact-form textarea { border-color: var(--border); background: var(--surface-solid); color: var(--text); } .template-pages-shopware-ads .ads-contact-form input::placeholder, .template-pages-shopware-ads .ads-contact-form textarea::placeholder { color: #98a4b7; } .template-pages-shopware-ads .ads-contact-form input:focus, .template-pages-shopware-ads .ads-contact-form textarea:focus { border-color: rgba(13, 128, 242, 0.56); box-shadow: 0 0 0 4px rgba(13, 128, 242, 0.12); } .template-pages-shopware-ads .ads-contact-form .contact-form__consent { color: var(--muted) !important; } .template-pages-shopware-ads .ads-contact-form .contact-form__consent a { color: var(--accent-strong); } @media (max-width: 1024px) { .template-pages-shopware-ads .site-nav, .template-pages-shopware-ads .language-switcher--desktop, .template-pages-shopware-ads .menu-cv { display: none; } .template-pages-shopware-ads .nav-toggle { display: inline-flex; } } /* FAQ Enhancements */ summary { display: flex; align-items: center; gap: 1rem; padding: 1rem 1.25rem; margin: -1px -1px 0; border: 1px solid var(--border); border-radius: 12px; background: var(--surface-solid); cursor: pointer; font-weight: 600; color: var(--text); list-style: none; transition: background 0.2s ease, border-color 0.2s ease; } summary::-webkit-details-marker { display: none; } summary::before { content: '+'; display: flex; align-items: center; justify-content: center; width: 24px; height: 24px; border: 1px solid var(--border); border-radius: 6px; font-size: 1.2rem; font-weight: 400; line-height: 1; color: var(--accent-strong); transition: transform 0.3s ease, background 0.2s ease; } details[open] summary::before { content: '−'; transform: rotate(180deg); background: var(--accent-soft); } summary:hover { background: var(--accent-soft-alt); border-color: var(--accent-soft); } details .prose { padding: 1.25rem 1.5rem; border: 1px solid var(--border); border-top: 0; border-bottom-left-radius: 12px; border-bottom-right-radius: 12px; background: rgba(255, 255, 255, 0.4); margin-top: -1px; } /* Capacity Page Peel (image-based, matches legacy design) */ .capacity-peel { --peel-base: 38px; --peel-peek: 50px; --peel-hover: 200px; position: fixed; top: 0; right: 0; z-index: 100; display: block; width: var(--peel-base); height: var(--peel-base); overflow: hidden; color: #fff; text-decoration: none; animation: capacity-peel-breathe 3.6s ease-in-out infinite; transition: width 0.4s cubic-bezier(0.2, 0.75, 0.18, 1), height 0.4s cubic-bezier(0.2, 0.75, 0.18, 1); } @keyframes capacity-peel-breathe { 0%, 100% { width: var(--peel-base); height: var(--peel-base); } 50% { width: var(--peel-peek); height: var(--peel-peek); } } body.nav-open .capacity-peel { display: none !important; } .capacity-peel:hover, .capacity-peel:focus-visible { width: var(--peel-hover); height: var(--peel-hover); color: #fff; outline: none; animation: none; } /* Green message area — clipped to the upper-right triangle */ .capacity-peel__bg { position: absolute; inset: 0; background-color: #46c238; clip-path: polygon(0 0, 100% 0, 100% 100%); pointer-events: none; z-index: 1; } /* Rotated headline text — centered inside the visible green triangle */ .capacity-peel__content { position: absolute; top: 33%; left: 67%; width: 110%; z-index: 4; color: #fff; font-size: 0.92rem; font-weight: 800; line-height: 1.2; text-align: center; text-shadow: 0 1px 2px rgba(0, 0, 0, 0.35); transform: translate(-50%, -50%) rotate(45deg); transform-origin: center; opacity: 0; pointer-events: none; transition: opacity 0.25s ease 0.15s; } .capacity-peel:hover .capacity-peel__content, .capacity-peel:focus-visible .capacity-peel__content { opacity: 1; } /* The curled paper corner image (sits on top of the green) */ .capacity-peel__fold { position: absolute; top: 0; right: 0; display: block; width: 100%; height: 100%; max-width: none; object-fit: fill; z-index: 3; pointer-events: none; user-select: none; -webkit-user-drag: none; vertical-align: top; /* Fallback: also paint the curl as a background so a blocked/filtered <img> still shows */ background: url('/assets/images/corner-fold.png') center/100% 100% no-repeat; } @media (max-width: 768px) { .capacity-peel { --peel-base: 32px; --peel-hover: 170px; z-index: 30; /* Below header on mobile to avoid covering the menu button */ } .capacity-peel__content { width: 110%; font-size: 0.78rem; } } @media (prefers-reduced-motion: reduce) { .capacity-peel, .capacity-peel__content { transition: none; animation: none; } }