*{box-sizing:border-box}html:lang(de){hyphens:auto;-webkit-hyphens:auto;-ms-hyphens:auto}html:lang(en){hyphens:auto;-webkit-hyphens:auto;-ms-hyphens:auto}:root{--color-primary: #007fff;--color-secondary: #005a9d;--color-dark: #001f4a;--color-text: #1f2937;--color-text-secondary: #6b7280;--color-background: #ffffff;--color-surface: #f8fafc;--color-border: #e5e7eb;--font-family: var(--font-montserrat, system-ui, -apple-system, sans-serif);--max-width: 64rem;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--border-radius: .375rem;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--text-role: var(--font-size-xl);--text-section-title: var(--font-size-2xl);--text-meta: var(--font-size-sm);--text-tag: var(--font-size-sm);--text-small: .9rem}@media(prefers-color-scheme:dark){:root{--color-primary: #3b82f6;--color-secondary: #1d4ed8;--color-dark: #1e293b;--color-text: #f8fafc;--color-text-secondary: #cbd5e1;--color-background: #0f172a;--color-surface: #1e293b;--color-border: #334155}}body{margin:0;font-family:var(--font-family);line-height:1.6;color:var(--color-text);background-color:var(--color-background);min-height:100vh;display:flex;flex-direction:column}main{flex:1;padding-top:4rem}h1,h2,h3,h4,h5,h6{margin:0 0 var(--spacing-md) 0;font-weight:600;line-height:1.3}h1{font-size:2.25rem}h2{font-size:1.875rem}h3{font-size:1.5rem}h4{font-size:1.25rem}h5{font-size:1.125rem}h6{font-size:1rem}p{margin:0 0 var(--spacing-md) 0}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}.container{max-width:var(--max-width);margin:0 auto;padding:0 var(--spacing-md)}.hidden{display:none}.section{padding:var(--spacing-xl) 0}.site-header{position:fixed;top:0;left:0;right:0;z-index:50;background:var(--color-background);border-bottom:1px solid var(--color-border);box-shadow:0 1px 3px #0000001a}.nav-wrapper{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) 0;min-height:4rem}.logo{height:2rem;width:auto}.nav-brand{display:flex;align-items:center;gap:var(--spacing-md);font-weight:600;font-size:1.125rem;color:var(--color-text);text-decoration:none}.nav-brand:hover{text-decoration:none}.brand-text{display:block;color:var(--color-text)}.nav-right{display:flex;align-items:center;gap:var(--spacing-md)}.nav-menu{display:flex;list-style:none;margin:0;padding:0;gap:var(--spacing-lg)}.nav-menu li{margin:0}.nav-link{color:var(--color-text);font-weight:500;text-decoration:none;transition:color .2s ease;padding:var(--spacing-sm) 0;display:block;font-size:1rem}.nav-link:hover{color:var(--color-primary);text-decoration:none}.nav-link.active{color:var(--color-primary);font-weight:600}.language-selector{display:flex;border-radius:var(--border-radius);overflow:hidden;border:1px solid var(--color-border)}.language-link{display:flex;align-items:center;justify-content:center;min-width:2.25rem;height:1.75rem;padding:0 var(--spacing-xs);font-size:.75rem;font-weight:600;letter-spacing:.05em;transition:all .2s ease;text-decoration:none;background:transparent;color:var(--color-text-secondary);border:none;border-right:1px solid var(--color-border)}.language-link:last-child{border-right:none}.language-link:hover{background:var(--color-surface);color:var(--color-text);text-decoration:none}.language-link.active{background:var(--color-secondary);color:#fff}.hero{padding:var(--spacing-2xl) 0}.card{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--border-radius);padding:var(--spacing-lg);margin-bottom:var(--spacing-md)}.skill-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-md)}.project-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--spacing-lg)}.blog-post-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:var(--spacing-xl);margin:var(--spacing-xl) 0}.prose{max-width:none;line-height:1.7}.prose p{color:var(--color-text-secondary);margin-bottom:var(--spacing-md)}.prose strong{color:var(--color-text);font-weight:600}.prose ul,.prose ol{padding-left:var(--spacing-lg);color:var(--color-text-secondary)}.prose li{margin-bottom:var(--spacing-xs)}.prose code{background:var(--color-surface);padding:var(--spacing-xs);border-radius:var(--border-radius);font-size:.9em;color:var(--color-primary)}.prose pre{background:#f6f8fa!important;color:#24292f!important;border:1px solid #d0d7de;padding:var(--spacing-md);border-radius:var(--border-radius);overflow-x:auto;font-size:.875rem}.prose pre.astro-code{background:#fff!important;color:#24292f!important;border:1px solid #d0d7de}.prose pre.astro-code span{color:inherit!important}.prose pre.astro-code .line span[style*="color:#6A737D"]{color:#6a737d!important}.prose pre.astro-code .line span[style*="color:#F97583"]{color:#d73a49!important}.prose pre.astro-code .line span[style*="color:#B392F0"]{color:#6f42c1!important}.prose pre.astro-code .line span[style*="color:#E1E4E8"]{color:#24292f!important}.prose pre.astro-code .line span[style*="color:#FFAB70"]{color:#e36209!important}.prose pre.astro-code .line span[style*="color:#9ECBFF"]{color:#032f62!important}@media(prefers-color-scheme:dark){.prose pre,.prose pre.astro-code{background:#0d1117!important;color:#e6edf3!important;border:1px solid #30363d}.prose pre.astro-code .line span[style*="color:#6A737D"]{color:#8b949e!important}.prose pre.astro-code .line span[style*="color:#F97583"]{color:#ff7b72!important}.prose pre.astro-code .line span[style*="color:#B392F0"]{color:#d2a8ff!important}.prose pre.astro-code .line span[style*="color:#E1E4E8"]{color:#e6edf3!important}.prose pre.astro-code .line span[style*="color:#FFAB70"]{color:#ffa657!important}.prose pre.astro-code .line span[style*="color:#9ECBFF"]{color:#a5d6ff!important}}@media print{.prose code{background:#f9f9f9!important;color:#333!important}.prose pre,.prose pre.astro-code{background:#fff!important;border:1px solid #ddd!important;color:#333!important}.prose pre.astro-code .line span,.prose pre.astro-code .line span[style*="color:"]{color:#333!important}}.prose .mermaid{background:var(--color-background);border-radius:var(--border-radius);padding:var(--spacing-md);margin:var(--spacing-lg) 0;overflow-x:auto}@media(prefers-color-scheme:dark){.prose .mermaid{background:var(--color-surface)!important;filter:brightness(1.2) contrast(.8)}.prose .mermaid svg{background:transparent!important}.prose .mermaid .node rect,.prose .mermaid .node circle,.prose .mermaid .node polygon{fill:var(--color-surface)!important;stroke:var(--color-text)!important;stroke-width:2px!important}.prose .mermaid .edgePath .path{stroke:var(--color-text)!important;stroke-width:2px!important}.prose .mermaid .edgeLabel{background:var(--color-surface)!important;color:var(--color-text)!important}.prose .mermaid text{fill:var(--color-text)!important}}@media print{.prose .mermaid{background:#fff!important;border:1px solid #ddd!important;filter:none!important}}.prose blockquote{border-left:4px solid var(--color-primary);padding-left:var(--spacing-md);margin:var(--spacing-lg) 0;font-style:italic;color:var(--color-text-secondary)}.form-group{margin-bottom:var(--spacing-md)}.form-label{display:block;font-weight:500;margin-bottom:var(--spacing-xs);color:var(--color-text)}.form-input,.form-textarea,.form-select{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--border-radius);font-family:inherit;font-size:1rem;background:var(--color-background);color:var(--color-text);transition:border-color .2s ease,box-shadow .2s ease}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #007fff1a}.form-textarea{resize:vertical;min-height:120px}.btn{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);border:none;border-radius:var(--border-radius);font-family:inherit;font-size:1rem;font-weight:500;text-decoration:none;cursor:pointer;transition:all .2s ease}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-secondary);text-decoration:none}.btn-secondary{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-border);text-decoration:none}@media(min-width:768px){.brand-text{display:inline-block}.nav-right{gap:var(--spacing-lg)}.nav-menu{gap:var(--spacing-xl)}}@media(max-width:767px){.nav-right{gap:var(--spacing-sm)}.nav-menu{gap:var(--spacing-md)}.nav-link{font-size:.875rem;padding:var(--spacing-xs) 0}.language-link{width:1.75rem;height:1.75rem;font-size:1rem}}@media(max-width:640px){.container{padding:0 var(--spacing-sm)}.blog-post-grid{grid-template-columns:1fr}.page-title h1{font-size:2rem}.brand-text{display:none}.nav-wrapper{padding:var(--spacing-sm) 0}}@media(max-width:480px){h1{font-size:1.875rem}h2{font-size:1.5rem}h3{font-size:1.25rem}}@media print{body{background:#fff;color:#000}main{padding-top:0}header,.no-print{display:none!important}a:after{content:" (" attr(href) ")"}h1,h2,h3,h4,h5,h6{page-break-after:avoid;color:#000}.page-break{page-break-before:always}.prose p,.prose li{color:#333}.prose strong{color:#000}}.blog-intro{margin-bottom:var(--spacing-xl)}.intro-text{font-size:1.125rem;color:var(--color-text-secondary);line-height:1.6}.posts-grid{display:grid;grid-template-columns:1fr;gap:var(--spacing-xl);align-items:stretch}@media(min-width:768px){.posts-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1200px){.posts-grid{grid-template-columns:repeat(3,1fr)}}.post-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;overflow:hidden;transition:all .3s ease;height:100%;display:flex;flex-direction:column}.post-card:hover{transform:translateY(-4px);box-shadow:0 8px 25px #00000026;border-color:var(--color-primary)}.card-content{padding:var(--spacing-lg);display:flex;flex-direction:column;height:100%;gap:var(--spacing-md)}.post-meta-top{display:flex;justify-content:space-between;align-items:center;font-size:.875rem;color:var(--color-text-secondary);margin-bottom:var(--spacing-xs)}.post-date{color:var(--color-primary);font-weight:500}.post-reading-time{color:var(--color-text-secondary)}.post-title{margin:0;line-height:1.3}.post-link{color:var(--color-text);text-decoration:none;font-size:1.25rem;font-weight:700;transition:color .2s ease;display:block}.post-link:hover{color:var(--color-primary)}.post-description{color:var(--color-text-secondary);line-height:1.6;margin:0;font-size:.95rem;flex:1}.post-tags{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.post-tag{background:#4f46e51a;color:var(--color-primary);font-size:.75rem;padding:var(--spacing-xs) calc(var(--spacing-xs) * 1.5);border-radius:20px;font-weight:500}.post-meta-bottom{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--color-border);padding-top:var(--spacing-md);margin-top:auto}.post-author{color:var(--color-text-secondary);text-decoration:none;font-size:.875rem;font-weight:500;transition:color .2s ease}.post-author:hover{color:var(--color-primary)}.read-more{color:var(--color-primary);text-decoration:none;font-size:.875rem;font-weight:600;transition:all .2s ease}.read-more:hover{color:var(--color-secondary);transform:translate(2px)}.empty-state{text-align:center;padding:var(--spacing-2xl) 0}.empty-state p{color:var(--color-text-secondary);font-style:italic}@media(max-width:640px){.post-meta-top{flex-direction:column;align-items:flex-start;gap:var(--spacing-xs)}}.site-footer[data-astro-cid-sz7xmlte]{background-color:var(--color-secondary);color:#fff}.site-footer[data-astro-cid-sz7xmlte].with-margin{margin-top:var(--spacing-2xl)}.footer-content[data-astro-cid-sz7xmlte]{padding:var(--spacing-2xl) 0;display:flex;flex-direction:column;gap:var(--spacing-lg)}.footer-nav[data-astro-cid-sz7xmlte]{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--spacing-xl) var(--spacing-sm);list-style:none;margin:0;padding:0}.footer-link[data-astro-cid-sz7xmlte]{color:#fffc;text-decoration:none;font-size:.875rem;transition:color .2s ease}.footer-link[data-astro-cid-sz7xmlte]:hover{color:#fff;text-decoration:none}.copyright[data-astro-cid-sz7xmlte]{text-align:center;color:#fffc;font-size:.875rem;margin:0}@media print{html{color-scheme:light!important}body{font-family:var(--font-montserrat);color:#000!important;background:#fff!important}main{padding-top:0!important}.no-print{display:none!important}}
