@import"https://fonts.googleapis.com/css2?family=Montserrat:wght@400;600;700&family=DM+Serif+Text&display=swap";:root{--accent: var(--glacier-blue, #F8B179);--accent-2: var(--glacier-blue-light, #FFCDA6);--fg: var(--text, #fff);--muted: var(--warm-gray, #8B92B2);--glass: var(--surface, rgba(255,255,255,.06));--glass-border: var(--border, rgba(255,255,255,.16));--shadow-sm: var(--shadow-sm, 0 6px 14px rgba(0,0,0,.18));--shadow-lg: var(--shadow-lg, 0 16px 38px rgba(0,0,0,.28))}.about-wrap{display:grid;gap:4rem}.about-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:2rem;align-items:center}.about-grid.second{grid-template-columns:.9fr 1.1fr}@media (max-width: 900px){.about-grid,.about-grid.second{grid-template-columns:1fr}.about-media{order:2}.about-grid.second .about-media{order:1}}.card-like{background:var(--glass);border:1px solid var(--glass-border);border-radius:16px;padding:1.6rem;box-shadow:var(--shadow-sm);animation:aboutFade .5s ease both}.card-like h2{color:var(--accent);margin:0 0 .8rem;font-size:2rem;text-shadow:0 0 8px color-mix(in oklab,var(--accent),#fff 30%)}.card-like p{color:var(--fg)}.about-media{display:grid;justify-items:center}.fancy-frame{position:relative;width:min(520px,100%);border-radius:20px;transform:translateZ(0)}.fancy-frame:before{content:"";position:absolute;top:-12px;right:-12px;bottom:-12px;left:-12px;border-radius:26px;background:linear-gradient(135deg,color-mix(in oklab,var(--accent),#fff 30%),#ffffff0f);transform:rotate(-2.5deg) translateY(8px);z-index:-1;filter:blur(.5px)}.fancy-frame:after{content:"";position:absolute;top:10px;right:10px;bottom:10px;left:10px;border-radius:14px;border:2px dashed color-mix(in oklab,var(--accent),#fff 12%);pointer-events:none}.ff-inner{position:relative;border-radius:18px;overflow:hidden;background:var(--glass);border:1px solid var(--glass-border);box-shadow:var(--shadow-sm);transform-style:preserve-3d;transition:transform .25s ease,box-shadow .25s ease}.ff-inner:hover{transform:rotateX(.6deg) rotateY(.6deg);box-shadow:var(--shadow-lg)}.ff-img{display:block;width:100%;height:auto;object-fit:cover}@keyframes aboutFade{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.vertical-timeline *{box-sizing:border-box}.vertical-timeline{width:95%;max-width:1170px;margin:0 auto;position:relative;padding:2em 0}.vertical-timeline:after{content:"";display:table;clear:both}.vertical-timeline:before{content:"";position:absolute;top:0;left:18px;height:100%;width:4px;background:var(--line-color)}.vertical-timeline.vertical-timeline--one-column-right:before{right:18px;left:unset}@media only screen and (min-width:1170px){.vertical-timeline.vertical-timeline--two-columns{width:90%}.vertical-timeline.vertical-timeline--two-columns:before{left:50%;margin-left:-2px}}.vertical-timeline-element{position:relative;margin:2em 0}.vertical-timeline-element>div{min-height:1px}.vertical-timeline-element:after{content:"";display:table;clear:both}.vertical-timeline-element:first-child{margin-top:0}.vertical-timeline-element:last-child{margin-bottom:0}@media only screen and (min-width:1170px){.vertical-timeline-element{margin:4em 0}.vertical-timeline-element:first-child{margin-top:0}.vertical-timeline-element:last-child{margin-bottom:0}}.vertical-timeline-element-icon{position:absolute;top:0;left:0;width:40px;height:40px;border-radius:50%}.vertical-timeline-element-icon.shadow-size-small{box-shadow:0 0 0 2px #fff,inset 0 1px #00000014,0 2px 0 4px #0000000d}.vertical-timeline-element-icon.shadow-size-medium{box-shadow:0 0 0 3px #fff,inset 0 2px #00000014,0 3px 0 5px #0000000d}.vertical-timeline-element-icon.shadow-size-large{box-shadow:0 0 0 4px #fff,inset 0 2px #00000014,0 4px 0 6px #0000000d}.vertical-timeline--one-column-right .vertical-timeline-element-icon{right:0;left:unset}.vertical-timeline-element-icon svg{display:block;width:24px;height:24px;position:relative;left:50%;top:50%;margin-left:-12px;margin-top:-12px}@media only screen and (min-width:1170px){.vertical-timeline--two-columns .vertical-timeline-element-icon{width:60px;height:60px;left:50%;margin-left:-30px}}.vertical-timeline-element-icon{-webkit-transform:translateZ(0);-webkit-backface-visibility:hidden}.vertical-timeline--animate .vertical-timeline-element-icon.is-hidden{visibility:hidden}.vertical-timeline--animate .vertical-timeline-element-icon.bounce-in{visibility:visible;-webkit-animation:cd-bounce-1 .6s;-moz-animation:cd-bounce-1 .6s;animation:cd-bounce-1 .6s}@-webkit-keyframes cd-bounce-1{0%{opacity:0;-webkit-transform:scale(.5)}60%{opacity:1;-webkit-transform:scale(1.2)}to{-webkit-transform:scale(1)}}@-moz-keyframes cd-bounce-1{0%{opacity:0;-moz-transform:scale(.5)}60%{opacity:1;-moz-transform:scale(1.2)}to{-moz-transform:scale(1)}}@keyframes cd-bounce-1{0%{opacity:0;-webkit-transform:scale(.5);-moz-transform:scale(.5);-ms-transform:scale(.5);-o-transform:scale(.5);transform:scale(.5)}60%{opacity:1;-webkit-transform:scale(1.2);-moz-transform:scale(1.2);-ms-transform:scale(1.2);-o-transform:scale(1.2);transform:scale(1.2)}to{-webkit-transform:scale(1);-moz-transform:scale(1);-ms-transform:scale(1);-o-transform:scale(1);transform:scale(1)}}.vertical-timeline-element-content{position:relative;margin-left:60px;background:#fff;border-radius:.25em;padding:1em;box-shadow:0 3px #ddd}.vertical-timeline--one-column-right .vertical-timeline-element-content{margin-right:60px;margin-left:unset}.vertical-timeline-element--no-children .vertical-timeline-element-content{background:0 0;box-shadow:none}.vertical-timeline-element-content:after{content:"";display:table;clear:both}.vertical-timeline-element-content h2{color:#303e49}.vertical-timeline-element-content .vertical-timeline-element-date,.vertical-timeline-element-content p{font-size:13px;font-size:.8125rem;font-weight:500}.vertical-timeline-element-content .vertical-timeline-element-date{display:inline-block}.vertical-timeline-element-content p{margin:1em 0 0;line-height:1.6}.vertical-timeline-element-title,.vertical-timeline-element-subtitle{margin:0}.vertical-timeline-element-content .vertical-timeline-element-date{float:left;padding:.8em 0;opacity:.7}.vertical-timeline-element-content-arrow{content:"";position:absolute;top:16px;right:100%;height:0;width:0;border:7px solid transparent;border-right:7px solid #fff}.vertical-timeline--one-column-right .vertical-timeline-element-content-arrow{content:"";position:absolute;top:16px;right:unset;left:100%;height:0;width:0;border:7px solid transparent;border-left:7px solid #fff}.vertical-timeline--one-column-right .vertical-timeline-element-content:before{left:100%;border-left:7px solid #fff;border-right:unset}.vertical-timeline-element--no-children .vertical-timeline-element-content:before{display:none}.vertical-timeline-element--no-children .vertical-timeline-element-content-arrow{display:none}@media only screen and (min-width:768px){.vertical-timeline-element-content h2{font-size:20px;font-size:1.25rem}.vertical-timeline-element-content p{font-size:16px;font-size:1rem}.vertical-timeline-element-content .vertical-timeline-element-date{font-size:14px;font-size:.875rem}}@media only screen and (min-width:1170px){.vertical-timeline--two-columns .vertical-timeline-element-content{margin-left:0;padding:1.5em;width:44%}.vertical-timeline--two-columns .vertical-timeline-element-content-arrow{top:24px;left:100%;transform:rotate(180deg)}.vertical-timeline--two-columns .vertical-timeline-element-content .vertical-timeline-element-date{position:absolute;width:100%;left:124%;top:6px;font-size:16px;font-size:1rem}.vertical-timeline--two-columns .vertical-timeline-element.vertical-timeline-element--right .vertical-timeline-element-content,.vertical-timeline--two-columns .vertical-timeline-element:nth-child(2n):not(.vertical-timeline-element--left) .vertical-timeline-element-content{float:right}.vertical-timeline--two-columns .vertical-timeline-element.vertical-timeline-element--right .vertical-timeline-element-content-arrow,.vertical-timeline--two-columns .vertical-timeline-element:nth-child(2n):not(.vertical-timeline-element--left) .vertical-timeline-element-content-arrow{top:24px;left:auto;right:100%;transform:rotate(0)}.vertical-timeline--one-column-right .vertical-timeline-element.vertical-timeline-element--right .vertical-timeline-element-content-arrow,.vertical-timeline--one-column-right .vertical-timeline-element:nth-child(2n):not(.vertical-timeline-element--left) .vertical-timeline-element-content-arrow{top:24px;left:100%;right:auto;transform:rotate(0)}.vertical-timeline--two-columns .vertical-timeline-element.vertical-timeline-element--right .vertical-timeline-element-content .vertical-timeline-element-date,.vertical-timeline--two-columns .vertical-timeline-element:nth-child(2n):not(.vertical-timeline-element--left) .vertical-timeline-element-content .vertical-timeline-element-date{left:auto;right:124%;text-align:right}}.vertical-timeline--animate .vertical-timeline-element-content.is-hidden{visibility:hidden}.vertical-timeline--animate .vertical-timeline-element-content.bounce-in{visibility:visible;-webkit-animation:cd-bounce-2 .6s;-moz-animation:cd-bounce-2 .6s;animation:cd-bounce-2 .6s}@media only screen and (min-width:1170px){.vertical-timeline--two-columns.vertical-timeline--animate .vertical-timeline-element.vertical-timeline-element--right .vertical-timeline-element-content.bounce-in,.vertical-timeline--two-columns.vertical-timeline--animate .vertical-timeline-element:nth-child(2n):not(.vertical-timeline-element--left) .vertical-timeline-element-content.bounce-in{-webkit-animation:cd-bounce-2-inverse .6s;-moz-animation:cd-bounce-2-inverse .6s;animation:cd-bounce-2-inverse .6s}}@media only screen and (max-width:1169px){.vertical-timeline--animate .vertical-timeline-element-content.bounce-in{visibility:visible;-webkit-animation:cd-bounce-2-inverse .6s;-moz-animation:cd-bounce-2-inverse .6s;animation:cd-bounce-2-inverse .6s}}@-webkit-keyframes cd-bounce-2{0%{opacity:0;-webkit-transform:translateX(-100px)}60%{opacity:1;-webkit-transform:translateX(20px)}to{-webkit-transform:translateX(0)}}@-moz-keyframes cd-bounce-2{0%{opacity:0;-moz-transform:translateX(-100px)}60%{opacity:1;-moz-transform:translateX(20px)}to{-moz-transform:translateX(0)}}@keyframes cd-bounce-2{0%{opacity:0;-webkit-transform:translateX(-100px);-moz-transform:translateX(-100px);-ms-transform:translateX(-100px);-o-transform:translateX(-100px);transform:translate(-100px)}60%{opacity:1;-webkit-transform:translateX(20px);-moz-transform:translateX(20px);-ms-transform:translateX(20px);-o-transform:translateX(20px);transform:translate(20px)}to{-webkit-transform:translateX(0);-moz-transform:translateX(0);-ms-transform:translateX(0);-o-transform:translateX(0);transform:translate(0)}}@-webkit-keyframes cd-bounce-2-inverse{0%{opacity:0;-webkit-transform:translateX(100px)}60%{opacity:1;-webkit-transform:translateX(-20px)}to{-webkit-transform:translateX(0)}}@-moz-keyframes cd-bounce-2-inverse{0%{opacity:0;-moz-transform:translateX(100px)}60%{opacity:1;-moz-transform:translateX(-20px)}to{-moz-transform:translateX(0)}}@keyframes cd-bounce-2-inverse{0%{opacity:0;-webkit-transform:translateX(100px);-moz-transform:translateX(100px);-ms-transform:translateX(100px);-o-transform:translateX(100px);transform:translate(100px)}60%{opacity:1;-webkit-transform:translateX(-20px);-moz-transform:translateX(-20px);-ms-transform:translateX(-20px);-o-transform:translateX(-20px);transform:translate(-20px)}to{-webkit-transform:translateX(0);-moz-transform:translateX(0);-ms-transform:translateX(0);-o-transform:translateX(0);transform:translate(0)}}:root{--accent: var(--glacier-blue);--accent-2: var(--glacier-blue-light);--fg: var(--text);--muted: var(--warm-gray);--glass: var(--surface);--glass-border: var(--border);--shadow: var(--shadow-md)}.card h2{margin:0;color:var(--accent);text-shadow:0 0 8px color-mix(in oklab,var(--accent),#fff 35%);font-size:1.9rem}.card-sub{color:var(--muted);margin-top:.35rem}.page-header{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:1rem;margin-bottom:1rem}.page-actions{display:flex;gap:.5rem}.btn-ghost{background:transparent;color:var(--fg);border:1px solid var(--glass-border);padding:.6rem .9rem;border-radius:10px}.btn-ghost[aria-busy=true]{opacity:.8;pointer-events:none}.btn-ghost:hover{background:color-mix(in oklab,var(--surface),white 6%)}.auth-form{display:grid;gap:1rem;margin-top:1.5rem}.auth-input{width:100%;background:color-mix(in oklab,var(--surface),white 6%);border:1px solid transparent;color:var(--fg);padding:.9rem 1rem;border-radius:12px;transition:border-color .2s,box-shadow .2s,transform .05s}.auth-input::placeholder{color:color-mix(in oklab,var(--muted),white 10%)}.auth-input:focus-visible{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px color-mix(in oklab,var(--accent),transparent 70%)}.auth-actions{display:grid;gap:.75rem;margin-top:.25rem}.btn-primary{background:var(--accent);color:#2d3250;border:none;border-radius:12px;padding:.85rem 1.2rem;font-weight:700;transition:transform .06s,box-shadow .2s,background .2s}.btn-primary:hover{box-shadow:0 8px 22px color-mix(in oklab,var(--accent),black 35%)}.btn-primary:active{transform:translateY(1px)}.auth-error{background:#ff63471f;border:1px solid rgba(255,99,71,.35);color:#ffb1b1;padding:.7rem .9rem;border-radius:10px;font-size:.95rem}.doc-name{color:var(--fg);font-weight:600}.doc-actions{display:flex;gap:.5rem;align-items:center}.doc-open{text-decoration:none;background:transparent;color:var(--accent);border:2px solid var(--accent);padding:.55rem .9rem;border-radius:10px;font-weight:700;transition:background .2s,color .2s,transform .06s}.doc-open:hover{background:var(--accent);color:#2d3250}.doc-dl{background:color-mix(in oklab,var(--accent),white 88%);color:#2d3250;border:2px solid color-mix(in oklab,var(--accent),#000 10%);padding:.55rem .9rem;border-radius:10px;font-weight:800;transition:background .2s,transform .06s,border-color .2s}.doc-dl:hover{background:var(--accent);border-color:var(--accent)}.doc-dl:active{transform:translateY(1px)}.doc-dl[aria-busy=true]{opacity:.8;pointer-events:none}.back-link{display:inline-flex;align-items:center;gap:.5rem;background:var(--surface);border:1px solid var(--border);color:var(--text);text-decoration:none;padding:.55rem .8rem;border-radius:10px;transition:background .2s,transform .06s,box-shadow .2s}.back-link:hover{background:color-mix(in oklab,var(--surface),white 6%);box-shadow:var(--shadow-sm)}.back-link:active{transform:translateY(1px)}@media (max-width: 600px){.dokumente-page{padding-top:5rem}.doc-item{grid-template-columns:40px 1fr auto}.doc-icon{width:40px;height:40px}}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.dokumente-page{min-height:calc(100vh - 120px);display:grid;place-items:start center;padding:6rem 1.25rem 4rem}.card{width:min(820px,100%);background:var(--glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:18px;box-shadow:var(--shadow);padding:2rem;animation:fadeIn .4s ease both}.card h2{margin:0;color:var(--accent);text-shadow:0 0 8px color-mix(in oklab,var(--accent),#fff 35%);font-size:clamp(1.6rem,2.5vw,1.9rem)}.card-sub{color:var(--muted);margin-top:.35rem;font-size:.95rem}.docs-list{list-style:none;margin:1rem 0 0;padding:0;display:grid;gap:.85rem}.doc-item{display:grid;grid-template-columns:48px 1fr auto;align-items:center;gap:1rem;background:color-mix(in oklab,var(--surface),white 4%);border:1px solid var(--glass-border);border-radius:14px;padding:.85rem 1rem;transition:transform .15s,box-shadow .2s,background .2s}.doc-item:hover{transform:translateY(-2px);background:color-mix(in oklab,var(--surface),white 8%);box-shadow:var(--shadow-md)}.doc-icon{display:grid;place-items:center;width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#2d3250;font-weight:900;letter-spacing:.5px}.doc-name{color:var(--fg);font-weight:600;font-size:.95rem;word-break:break-word}.doc-open{text-decoration:none;background:var(--accent);color:#2d3250;border:none;padding:.55rem .9rem;border-radius:10px;font-weight:700;transition:background .2s,transform .06s,box-shadow .2s}.doc-open:hover{background:color-mix(in oklab,var(--accent),white 15%);box-shadow:0 6px 18px color-mix(in oklab,var(--accent),black 30%)}.doc-open:active{transform:translateY(1px)}.page-header{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem}.page-actions{display:flex;flex-wrap:wrap;gap:.75rem}.btn-download-all{background:var(--accent);color:#2d3250;border:none;border-radius:12px;padding:.75rem 1.1rem;font-weight:700;transition:background .2s,box-shadow .2s,transform .06s}.btn-download-all:hover{background:color-mix(in oklab,var(--accent),white 15%);box-shadow:0 6px 18px color-mix(in oklab,var(--accent),black 30%)}.btn-download-all:active{transform:translateY(1px)}@media (max-width: 768px){.card{padding:1.5rem}.doc-item{grid-template-columns:40px 1fr;grid-template-rows:auto auto;gap:.75rem}.doc-open{justify-self:start;padding:.5rem .8rem;font-size:.9rem}}@media (max-width: 480px){.page-header{flex-direction:column;align-items:stretch}.btn-download-all{width:100%;text-align:center}}@media (max-width: 900px){.dokumente-page{padding:5rem 1rem 3rem}.card{width:100%;padding:1.25rem;border-radius:16px}.card h2{font-size:1.6rem}.card-sub{font-size:.95rem}.auth-input{padding:.85rem .95rem;font-size:1rem;border-radius:12px}.btn-primary,.btn-ghost{padding:.75rem 1rem;font-size:1rem;border-radius:12px}}@media (max-width: 768px){.page-header{grid-template-columns:1fr;gap:.75rem}.page-actions{justify-content:flex-start;flex-wrap:wrap;gap:.5rem}.back-link{justify-self:start;padding:.5rem .7rem;border-radius:10px;font-size:.95rem}}@media (max-width: 768px){.docs-list{gap:.75rem}.doc-item{grid-template-columns:44px 1fr;grid-template-areas:"icon name" "icon actions";align-items:center;gap:.75rem .9rem;padding:.85rem .9rem;border-radius:14px}.doc-icon{grid-area:icon;width:44px;height:44px;border-radius:10px;font-size:.9rem}.doc-name{grid-area:name;font-size:1rem;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.doc-open{grid-area:actions;justify-self:start;width:100%;text-align:center;padding:.7rem 1rem;border-radius:12px;font-weight:800}}@media (max-width: 420px){.card{padding:1rem}.card h2{font-size:1.4rem}.page-actions .btn-ghost{width:100%;justify-content:center}.doc-item{grid-template-columns:40px 1fr;gap:.6rem .75rem;padding:.75rem .8rem}.doc-icon{width:40px;height:40px;border-radius:10px}.doc-name{font-size:.95rem}.doc-open{padding:.65rem .9rem;border-radius:10px}}@media (hover: none) and (pointer: coarse){.doc-item:hover{transform:none;box-shadow:var(--shadow, 0 4px 12px rgba(0,0,0,.12))}.back-link:hover,.btn-primary:hover,.btn-ghost:hover,.doc-open:hover{transform:none;box-shadow:none}}@media (prefers-reduced-motion: reduce){.doc-item,.back-link,.btn-primary,.btn-ghost,.doc-open{transition:none!important}}.doc-open{background:var(--glacier-blue);color:#2d3250;border:none;font-weight:800}.doc-open:hover,.doc-open:focus-visible{background:var(--glacier-blue-light);color:#2d3250;border:none;box-shadow:0 8px 22px color-mix(in oklab,var(--glacier-blue),black 35%);outline:none}.docs-download-all{background:var(--glacier-blue);color:#2d3250;border:none;font-weight:900;padding:.8rem 1.1rem;border-radius:12px}.docs-download-all:hover,.docs-download-all:focus-visible{background:var(--glacier-blue-light);color:#2d3250;border:none;box-shadow:0 8px 22px color-mix(in oklab,var(--glacier-blue),black 35%);outline:none}:root[data-theme=light] .doc-open,:root[data-theme=light] .doc-open:hover,:root[data-theme=light] .doc-open:focus-visible{color:#fff!important}:root{color-scheme:light dark}html,body{margin:0;min-height:100%}:root{--overcast: #1e2233;--warm-gray: #8b92b2;--ice: #3a3f5c;--glacier-blue: #f8b179;--glacier-blue-light: #ffcda6;--font-color-dark: #ffffff;--gradient-bg: linear-gradient(135deg, rgba(248,177,121,.12) 0%, rgba(30,34,51,.8) 100%);--glass-bg: rgba(255, 255, 255, .06);--border-glass: rgba(255, 255, 255, .15)}:root[data-theme=dark]{--overcast: #1e2233;--warm-gray: #8b92b2;--ice: #3a3f5c;--glacier-blue: #f8b179;--glacier-blue-light: #ffcda6;--font-color-dark: #ffffff;--gradient-bg: linear-gradient(135deg, rgba(248,177,121,.12) 0%, rgba(30,34,51,.8) 100%);--glass-bg: rgba(255,255,255,.06);--border-glass: rgba(255,255,255,.15)}:root[data-theme=light]{--overcast: #f7f8fb;--warm-gray: #58607a;--ice: #e9edf5;--glacier-blue: #f19955;--glacier-blue-light: #ffb985;--font-color-dark: #1b1f2a;--gradient-bg: linear-gradient(135deg, #ffffff 0%, #eef2f8 100%);--glass-bg: rgba(255,255,255,.85);--border-glass: rgba(27,31,42,.12)}.card,.card-like,.noten-card,.project-card,.vertical-timeline-element-content{background:var(--glass-bg);border:1px solid var(--border-glass)}a,button{color:var(--glacier-blue)}.navbar{background-color:color-mix(in oklab,var(--overcast),black 5%);border-bottom:1px solid var(--border-glass)}.projects .project-image{border:2px solid var(--glacier-blue);background:color-mix(in oklab,var(--glass-bg),white 6%)}:root[data-theme=light]{--overcast: #e8ecf3;--section-bg: linear-gradient(180deg, #eef2f7 0%, #e8ecf3 100%);--font-color-dark: #1d2230;--warm-gray: #58607a;--glass-bg: #f8fafc;--border-glass: rgba(29,34,48,.12);--card-shadow-sm: 0 6px 14px rgba(20, 25, 40, .08);--card-shadow-lg: 0 12px 28px rgba(20, 25, 40, .12);--glacier-blue: #f19955;--glacier-blue-light: #ffb985;--brand-blue: #2f6df6;--ice: #eef2f7;--gradient-bg: linear-gradient(135deg, #f4f6fb 0%, #e8ecf3 100%)}:root[data-theme=light] a{color:var(--brand-blue)}:root[data-theme=light] .navbar a.active{color:var(--brand-blue);border-color:var(--brand-blue)}:root[data-theme=light] button,:root[data-theme=light] .btn-primary{background:var(--glacier-blue);color:#1b2130;border:1px solid color-mix(in oklab,var(--glacier-blue),black 10%)}:root[data-theme=light] button:hover,:root[data-theme=light] .btn-primary:hover{background:var(--glacier-blue-light)}:root[data-theme=light] .card,:root[data-theme=light] .card-like,:root[data-theme=light] .noten-card{background:var(--glass-bg);border:1px solid var(--border-glass);box-shadow:var(--card-shadow-sm)}:root[data-theme=light] .recharts-cartesian-axis-tick-value{fill:#3b4255!important}:root[data-theme=light] .recharts-tooltip-wrapper{background:#fff!important;border:1px solid rgba(27,31,42,.12)!important;color:#1d2230!important}:root[data-theme=light]{--overcast: #f3efe9;--section-bg: linear-gradient(180deg, #f8f4ee 0%, #f3efe9 100%);--font-color-dark: #2b1f18;--warm-gray: #6f625a;--surface: #fffaf5;--surface-2: #fff4e8;--glass-bg: var(--surface);--border-glass: rgba(93, 54, 11, .15);--card-shadow-sm: 0 6px 14px rgba(93, 54, 11, .08);--card-shadow-lg: 0 14px 32px rgba(93, 54, 11, .14);--orange-700: #d9792f;--orange-600: #ea8a3e;--orange-500: #f19955;--orange-400: #ffb377;--orange-300: #ffd1a8;--orange-50: #fff7ef;--glacier-blue: var(--orange-500);--glacier-blue-light: var(--orange-400);--ice: #efe6dc;--gradient-bg: linear-gradient(135deg, #fbf7f2 0%, #f3efe9 100%)}html,body{background:var(--overcast);color:var(--font-color-dark)}:root[data-theme=light] a{color:var(--orange-600)}:root[data-theme=light] .navbar a.active{color:var(--orange-600);border-color:var(--orange-600)}:root[data-theme=light] .navbar{background:color-mix(in oklab,var(--overcast),white 6%);border-bottom:1px solid var(--border-glass)}:root[data-theme=light] button,:root[data-theme=light] .btn-primary{background:var(--orange-500);color:#2b1f18;border:1px solid color-mix(in oklab,var(--orange-500),black 12%)}:root[data-theme=light] button:hover,:root[data-theme=light] .btn-primary:hover{background:var(--orange-400)}:root[data-theme=light] .card,:root[data-theme=light] .card-like,:root[data-theme=light] .noten-card{background:var(--surface);border:1px solid var(--border-glass);box-shadow:var(--card-shadow-sm)}:root[data-theme=light] .section h2{color:var(--orange-600);text-shadow:none}:root[data-theme=light] .recharts-cartesian-axis-tick-value{fill:#473a32!important}:root[data-theme=light] .recharts-tooltip-wrapper{background:#fff!important;border:1px solid rgba(93,54,11,.15)!important;color:#2b1f18!important}:root,:root[data-theme=dark]{--overcast: #1e2233;--warm-gray: #8b92b2;--ice: #3a3f5c;--accent-700: #d9792f;--accent-600: #ea8a3e;--accent-500: #f8b179;--accent-400: #ffcda6;--accent-50: #3c405d;--glacier-blue: var(--accent-500);--glacier-blue-light: var(--accent-400);--text: #ffffff;--text-muted: #c8cee8;--surface: rgba(255,255,255,.06);--surface-2: rgba(255,255,255,.08);--border: rgba(255,255,255,.15);--gradient-bg: linear-gradient(135deg, rgba(248,177,121,.12) 0%, rgba(30,34,51,.8) 100%);--shadow-sm: 0 6px 14px rgba(0,0,0,.18);--shadow-lg: 0 16px 38px rgba(0,0,0,.28);--section-gap: clamp(48px, 8vw, 96px)}:root[data-theme=light]{--overcast: #f3efe9;--section-bg: linear-gradient(180deg, #f8f4ee 0%, #f3efe9 100%);--text: #2b1f18;--text-muted: #6f625a;--accent-700: #d9792f;--accent-600: #ea8a3e;--accent-500: #f19955;--accent-400: #ffb377;--accent-50: #fff7ef;--glacier-blue: var(--accent-500);--glacier-blue-light: var(--accent-400);--surface: #0069ff;--surface-2: #fff4e8;--border: rgba(93,54,11,.15);--gradient-bg: linear-gradient(135deg, #fbf7f2 0%, #f3efe9 100%);--shadow-sm: 0 6px 14px rgba(93,54,11,.08);--shadow-lg: 0 14px 32px rgba(93,54,11,.14);--section-gap: clamp(48px, 8vw, 96px)}html,body{background:var(--overcast);color:var(--text);font-family:Poppins,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;line-height:1.7;letter-spacing:.2px;margin:0}html{scroll-behavior:smooth}body,.card,.card-like,.project-card,.noten-card,.vertical-timeline-element-content{transition:background-color .25s ease,color .25s ease,border-color .25s ease,box-shadow .25s ease}a{color:var(--glacier-blue);text-decoration:none;transition:color .2s ease,text-shadow .2s ease}a:hover{color:var(--glacier-blue-light);text-shadow:0 0 6px rgba(248,177,121,.45)}button{cursor:pointer;background:var(--surface);border:2px solid var(--glacier-blue);color:var(--glacier-blue);padding:.6em 1.2em;border-radius:12px;font-weight:700;transition:transform .12s ease,box-shadow .2s ease,background-color .2s ease,color .2s ease,border-color .2s ease;box-shadow:0 4px 10px #0000002e}button:hover{background:var(--glacier-blue);color:#1b2130;box-shadow:0 8px 18px #f8b17959;transform:translateY(-1px)}button:active{transform:translateY(0)}.navbar a{color:var(--text-muted);padding-bottom:.25rem;border-bottom:2px solid transparent}.theme-toggle{background:transparent;border:1px solid var(--border);color:var(--text)}.section h2{font-size:clamp(1.8rem,1.2rem + 1.8vw,2.6rem);margin:0 0 1.25rem;font-weight:800;color:var(--glacier-blue);letter-spacing:.3px;position:relative}.section h2:after{content:"";display:block;height:3px;width:88px;margin-top:.6rem;background:linear-gradient(90deg,var(--glacier-blue),transparent);border-radius:999px;transform-origin:left;animation:underline-in .6s ease both}.card,.card-like,.project-card,.noten-card,.vertical-timeline-element-content{background:var(--surface);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-sm)}body:before,body:after{content:"";position:fixed;top:-20%;right:-20%;bottom:-20%;left:-20%;pointer-events:none;z-index:-1;background:radial-gradient(40% 30% at 20% 15%,color-mix(in oklab,var(--glacier-blue),#fff 10%) 0%,transparent 60%),radial-gradient(30% 25% at 85% 75%,color-mix(in oklab,var(--glacier-blue-light),#fff 25%) 0%,transparent 60%);opacity:.12;filter:blur(40px) saturate(110%);animation:floatBlobs 30s ease-in-out infinite alternate}@keyframes floatBlobs{0%{transform:translateZ(0) scale(1);opacity:.1}to{transform:translate3d(2%,-2%,0) scale(1.03);opacity:.14}}button:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:radial-gradient(240px 240px at var(--x, 50%) var(--y, 50%),rgba(255,255,255,.22),transparent 60%);opacity:0;transition:opacity .25s ease}button:hover:before{opacity:1}button{position:relative;overflow:hidden}.section h2{text-shadow:0 0 10px color-mix(in oklab,var(--glacier-blue),#000 20%)}.section h2:after{content:none!important}body:before,body:after{content:"";position:fixed;top:-20%;right:-20%;bottom:-20%;left:-20%;pointer-events:none;z-index:-1;filter:blur(42px) saturate(110%)}body:before{background:radial-gradient(38% 28% at 18% 18%,color-mix(in oklab,var(--glacier-blue),#fff 12%) 0%,transparent 60%),radial-gradient(30% 24% at 80% 82%,color-mix(in oklab,var(--glacier-blue-light),#fff 20%) 0%,transparent 60%);opacity:.14;animation:ambientFloat 36s ease-in-out infinite alternate}body:after{--angle: 0deg;background:conic-gradient(from var(--angle),rgba(255,255,255,0),rgba(255,255,255,.06) 10%,rgba(248,177,121,.1) 18%,rgba(255,255,255,0) 28%,rgba(255,255,255,.05) 45%,rgba(248,177,121,.08) 52%,rgba(255,255,255,0) 60%,rgba(255,255,255,.04) 75%,rgba(255,255,255,0) 100%);mix-blend-mode:screen;opacity:.1;animation:ambientRotate 80s linear infinite}@keyframes ambientFloat{0%{transform:translateZ(0) scale(1);opacity:.12}to{transform:translate3d(2%,-2%,0) scale(1.03);opacity:.16}}@keyframes ambientRotate{to{--angle: 360deg}}:root[data-theme=dark]{--mesh-a: rgba(248, 177, 121, .12);--mesh-b: rgba(255, 205, 166, .1);--mesh-c: rgba(255, 255, 255, .05);--grain-opacity: .06;--vignette-opacity: .22}:root[data-theme=light]{--mesh-a: rgba(241, 153, 85, .16);--mesh-b: rgba(255, 205, 166, .14);--mesh-c: rgba(0, 0, 0, .03);--grain-opacity: .04;--vignette-opacity: .12}html,body{position:relative;z-index:0}:where(html,body){background-color:var(--overcast)!important;background-image:radial-gradient(1200px 800px at 8% 12%,var(--mesh-a),transparent 60%),radial-gradient(1000px 700px at 92% 88%,var(--mesh-b),transparent 60%),radial-gradient(900px 600px at 50% 110%,var(--mesh-c),transparent 60%),var(--gradient-bg);background-repeat:no-repeat,no-repeat,no-repeat,no-repeat!important;background-attachment:fixed,fixed,fixed,fixed!important;background-position:0 0,100% 100%,50% 100%,50% 50%!important;background-size:auto,auto,auto,cover!important}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;pointer-events:none;opacity:var(--grain-opacity);background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='60' height='60' viewBox='0 0 60 60'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/><feColorMatrix type='saturate' values='0'/><feComponentTransfer><feFuncA type='table' tableValues='0 0.5'/></feComponentTransfer></filter><rect width='100%%' height='100%%' filter='url(%23n)'/></svg>");background-size:180px 180px}body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;pointer-events:none;mix-blend-mode:multiply;opacity:var(--vignette-opacity);background:radial-gradient(120% 120% at 50% 10%,transparent 60%,rgba(0,0,0,.35) 100%)}:root[data-theme=light] #projects,:root[data-theme=light] .section.projects,:root[data-theme=light] #education,:root[data-theme=light] .education-section,:root[data-theme=light] #about,:root[data-theme=light] #noten{background:var(--section-bg)!important;-webkit-backdrop-filter:none!important;backdrop-filter:none!important;border-top:1px solid var(--border-glass)}:root[data-theme=light] .project-card{background:var(--surface)!important;border:1px solid var(--border-glass)!important;box-shadow:var(--card-shadow-sm)!important;color:var(--font-color-dark)!important}:root[data-theme=light] .project-card:hover{box-shadow:var(--card-shadow-lg)!important}:root[data-theme=light] .projects .project-image{border:2px solid var(--orange-500)!important;background:var(--orange-50)!important;border-radius:16px}:root[data-theme=light] .vertical-timeline:before{background:var(--orange-500)!important}:root[data-theme=light] .vertical-timeline-element-content,:root[data-theme=light] .education-item{background:var(--surface)!important;border:1px solid var(--border-glass)!important;box-shadow:var(--card-shadow-sm)!important;color:var(--font-color-dark)!important}:root[data-theme=light] .vertical-timeline-element-content h3,:root[data-theme=light] .vertical-timeline-element-date{color:var(--orange-600)!important}:root[data-theme=light] .ff-placeholder:after{background:linear-gradient(135deg,var(--orange-500),var(--orange-300))!important;color:#3a291f!important}:root[data-theme=light] #noten .noten-card{background:var(--surface)!important;border:1px solid var(--border-glass)!important;box-shadow:var(--card-shadow-sm)!important}:root[data-theme=light] .abstract-link{border-color:var(--orange-600)!important;color:var(--orange-600)!important;background:transparent!important}:root[data-theme=light] .chip{background:var(--orange-50)!important;border:1px solid rgba(241,153,85,.35)!important;color:#3f2d23!important}:root[data-theme=light] .chip.muted{color:#7a6c63!important}:root[data-theme=light] .theme-toggle{border:1px solid var(--border-glass)!important;background:#fff7ef!important}:root[data-theme=light] .theme-toggle:hover{background:#ffe9d2!important}:root[data-theme=light] .project-card{color:var(--font-color-dark)!important}:root[data-theme=light] .project-card h3{color:var(--orange-600)!important}:root[data-theme=light] .project-card .description{color:var(--font-color-dark)!important}:root[data-theme=light] .project-card .tech{color:var(--warm-gray)!important}:root[data-theme=light] .project-card .tech strong{color:var(--font-color-dark)!important}:root[data-theme=light] .project-card .abstract{color:var(--warm-gray)!important}:root[data-theme=light] .projects .project-info,:root[data-theme=light] .projects .project-info *{color:inherit!important}:root[data-theme=light] .education-item,:root[data-theme=light] .vertical-timeline-element-content{color:var(--font-color-dark)!important}:root[data-theme=light] .education-item .year,:root[data-theme=light] .vertical-timeline-element-date{color:var(--orange-600)!important}:root[data-theme=light] .education-item .details h3,:root[data-theme=light] .vertical-timeline-element-content h3{color:var(--font-color-dark)!important}:root[data-theme=light] .education-item .details p,:root[data-theme=light] .vertical-timeline-element-content p{color:var(--font-color-dark)!important}:root[data-theme=light] .abstract-link{border-color:var(--orange-600)!important;color:var(--orange-600)!important}:root[data-theme=light] .abstract-link:hover{background:var(--orange-400)!important;color:#2b1f18!important}:root[data-theme=light] body{background:var(--overcast)}:root[data-theme=light] #projects,:root[data-theme=light] .section.projects,:root[data-theme=light] #education,:root[data-theme=light] .education-section,:root[data-theme=light] #about,:root[data-theme=light] #noten{background:var(--section-bg)!important;backdrop-filter:none!important;-webkit-backdrop-filter:none!important;border-top:1px solid var(--border)}:root[data-theme=light] .project-card{background:var(--surface)!important;border:1px solid var(--border)!important;color:var(--text)!important}:root[data-theme=light] .project-card:hover{box-shadow:var(--shadow-lg)!important}:root[data-theme=light] .projects .project-image{border:2px solid var(--glacier-blue)!important;background:var(--accent-50)!important;border-radius:16px}:root[data-theme=light] .project-card h3{color:var(--glacier-blue)!important}:root[data-theme=light] .project-card .description,:root[data-theme=light] .project-card .tech,:root[data-theme=light] .project-card .abstract,:root[data-theme=light] .projects .project-info *{color:var(--text)!important}:root[data-theme=light] .project-card .tech{opacity:.8}:root[data-theme=light] .project-card .abstract{opacity:.7}:root[data-theme=light] .vertical-timeline:before{background:var(--glacier-blue)!important}:root[data-theme=light] .vertical-timeline-element-content,:root[data-theme=light] .education-item{background:var(--surface)!important;border:1px solid var(--border)!important;color:var(--text)!important;box-shadow:var(--shadow-sm)!important}:root[data-theme=light] .vertical-timeline-element-date{color:var(--glacier-blue)!important}:root[data-theme=light] .vertical-timeline-element-content h3{color:var(--text)!important}:root[data-theme=light] .about .card-like,:root[data-theme=light] #noten .noten-card{background:var(--surface)!important;border:1px solid var(--border)!important;box-shadow:var(--shadow-sm)!important}:root[data-theme=light] .abstract-link{border-color:var(--glacier-blue)!important;color:var(--glacier-blue)!important;background:transparent!important}:root[data-theme=light] .abstract-link:hover{background:var(--glacier-blue)!important;color:#2b1f18!important}:root[data-theme=light] .fancy-frame:before{background:linear-gradient(135deg,#f1995540,#ffffff80)!important}:root[data-theme=light] .ff-inner.no-glimmer:before{content:none!important}body,.navbar,.section,.card,.card-like,.project-card,.vertical-timeline-element-content,.noten-card{transition:background-color .25s ease,color .25s ease,border-color .25s ease,box-shadow .25s ease}.hero-full{width:100%;height:100vh;background-size:cover;background-position:center;background-repeat:no-repeat;display:flex;align-items:center;justify-content:center}.hero-content{display:flex;align-items:center;gap:4rem;padding:2rem;flex-wrap:wrap;justify-content:center}.hero-img{width:450px;height:auto;object-fit:cover;border-radius:12px;box-shadow:var(--shadow-sm)}.hero-name{font-size:clamp(2.6rem,3.2vw + 1rem,5rem);font-weight:900;color:#fff;text-shadow:0 0 12px rgba(0,0,0,.6),0 0 20px rgba(248,177,121,.35)}.navbar-logo img{height:56px;width:56px;border-radius:12px}.navbar-links{display:flex;gap:clamp(10px,2vw,24px);list-style:none;padding:0;margin:0;flex-wrap:wrap}.section+.section{margin-top:var(--section-gap)}@keyframes underline-in{0%{transform:scaleX(0);opacity:.4}to{transform:scaleX(1);opacity:1}}#projects{padding:4rem 2rem}#projects h2{text-align:center}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:clamp(16px,3vw,28px);width:100%;margin:0 auto;max-width:1200px}.project-card{display:flex;flex-direction:column;overflow:hidden;position:relative;isolation:isolate}.project-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:-1;border-radius:18px;background:radial-gradient(120% 120% at -10% -10%,rgba(248,177,121,.18),transparent 60%);opacity:0;transition:opacity .3s ease}.project-card:hover:before{opacity:1}.project-info h3{margin:0;font-size:1.25rem;color:var(--glacier-blue)}.project-info .description{opacity:.95}.project-info .tech{opacity:.85}.project-info .abstract{font-style:italic;opacity:.7}.abstract-link{display:inline-flex;align-items:center;gap:8px;font-weight:800;color:var(--glacier-blue);border:2px solid var(--glacier-blue);padding:.45rem .8rem;border-radius:10px;transition:background .2s ease,transform .06s ease,border-color .2s ease,color .2s ease}.abstract-link svg{width:18px;height:18px;transform:translate(0);transition:transform .2s ease}.abstract-link:hover svg{transform:translate(3px)}.circle-skill svg{width:160px;height:160px;display:block;filter:drop-shadow(0 6px 16px rgba(0,0,0,.22))}.circle-skill p{margin-top:.6rem;font-weight:700}.noten-card{padding:2rem}.noten-buttons{display:flex;justify-content:center;gap:1rem}.noten-buttons button{border-radius:12px}.noten-buttons button.active{background:var(--glacier-blue);color:#1b2130}.recharts-tooltip-wrapper{border-radius:10px!important;background:#fff!important;border:1px solid #e5e7eb!important}.footer{text-align:center;padding:3rem 2rem;color:var(--warm-gray);background:var(--surface);border-top:1px solid var(--border)}:root[data-theme=light] .project-card,:root[data-theme=light] .education-item,:root[data-theme=light] .vertical-timeline-element-content,:root[data-theme=light] .card-like,:root[data-theme=light] .noten-card{background:var(--surface)!important;border:1px solid var(--border)!important;color:var(--text)!important;box-shadow:var(--shadow-sm)!important}:root[data-theme=light] .project-info .description,:root[data-theme=light] .project-info .tech,:root[data-theme=light] .project-info .abstract,:root[data-theme=light] .vertical-timeline-element-content p,:root[data-theme=light] .education-item .details p{color:var(--text)!important;opacity:.9}:root[data-theme=light] .projects .project-image{background:var(--accent-50)!important}:root[data-theme=light] .project-card,:root[data-theme=light] .education-item,:root[data-theme=light] .vertical-timeline-element-content{border-radius:24px!important;background:var(--surface)!important;border:1px solid var(--border)!important;box-shadow:var(--shadow-sm)!important}:root[data-theme=light] .projects .project-image{border-radius:22px!important;background:var(--accent-50)!important}:root[data-theme=light] .projects .project-image img{border-radius:16px!important}:root[data-theme=light]{--text: #151b26;--overcast: #e6eaf2;--section-bg: linear-gradient(180deg,#e9edf5 0%, #e3e7ef 100%);--surface: #edf1f7;--surface-2: #e9eef5;--glass-bg: var(--surface);--border: rgba(15, 23, 42, .12);--border-glass: var(--border);--warm-gray: #4b5567;--card-shadow-sm: 0 8px 18px rgba(15,23,42,.06);--card-shadow-lg: 0 16px 36px rgba(15,23,42,.1);--brand-blue: #3a7bd5;--brand-blue-light: #6aa8ff;--accent-50: color-mix(in oklab, var(--brand-blue), white 88%);--glacier-blue: var(--brand-blue);--glacier-blue-light: var(--brand-blue-light);--orange-700: var(--brand-blue);--orange-600: var(--brand-blue);--orange-500: var(--brand-blue);--orange-400: var(--brand-blue-light);--orange-300: color-mix(in oklab, var(--brand-blue), white 60%);--orange-50: var(--accent-50)}:root[data-theme=light] #projects,:root[data-theme=light] #education,:root[data-theme=light] #about,:root[data-theme=light] #noten,:root[data-theme=light] .section.projects,:root[data-theme=light] .education-section{background:var(--section-bg)!important;-webkit-backdrop-filter:none!important;backdrop-filter:none!important}:root[data-theme=light] .project-card,:root[data-theme=light] .education-item,:root[data-theme=light] .vertical-timeline-element-content,:root[data-theme=light] .card,:root[data-theme=light] .card-like,:root[data-theme=light] .noten-card{background:var(--surface)!important;border:1px solid var(--border)!important;box-shadow:var(--card-shadow-sm)!important;color:var(--text)!important}:root[data-theme=light] .project-card h3,:root[data-theme=light] .vertical-timeline-element-content h3,:root[data-theme=light] .education-item .details h3{color:var(--text)!important}:root[data-theme=light] .project-info .description,:root[data-theme=light] .project-info .tech,:root[data-theme=light] .project-info .abstract,:root[data-theme=light] .education-item .details p,:root[data-theme=light] .vertical-timeline-element-content p{color:var(--text)!important;opacity:.9}:root[data-theme=light] a,:root[data-theme=light] .navbar a.active,:root[data-theme=light] .navbar a:hover{color:var(--brand-blue)!important;border-color:var(--brand-blue)!important}:root[data-theme=light] button,:root[data-theme=light] .btn-primary{background:var(--brand-blue)!important;color:#fff!important;border:1px solid color-mix(in oklab,var(--brand-blue),black 12%)!important}:root[data-theme=light] button:hover,:root[data-theme=light] .btn-primary:hover{background:var(--brand-blue-light)!important}:root[data-theme=light] .projects .project-image{border-color:var(--brand-blue)!important;background:var(--accent-50)!important}:root[data-theme=light] .projects .project-image img{border-radius:12px}:root[data-theme=light] .abstract-link{border-color:var(--brand-blue)!important;color:var(--brand-blue)!important}:root[data-theme=light] .abstract-link:hover{background:var(--brand-blue)!important;color:#fff!important}:root[data-theme=light] .navbar{background:color-mix(in oklab,var(--overcast),black 6%)!important;border-bottom:1px solid var(--border)!important}:root[data-theme=light] .hero-name{text-shadow:0 0 10px rgba(15,23,42,.25)}:root[data-theme=light] .recharts-cartesian-axis-tick-value{fill:#1f2937!important}:root[data-theme=light] .recharts-tooltip-wrapper{background:#fff!important;border:1px solid var(--border)!important;color:#111827!important}:root[data-theme=light] .chip{background:var(--accent-50)!important;border:1px solid color-mix(in oklab,var(--brand-blue),black 20%)!important;color:#0f1a2a!important}:root[data-theme=light] .vertical-timeline:before{background:var(--brand-blue)!important}:root[data-theme=light] .vertical-timeline-element-icon{background:var(--surface)!important;box-shadow:0 0 0 4px var(--brand-blue)!important;color:var(--brand-blue)!important;border:none!important}:root[data-theme=light] .vertical-timeline-element-date,:root[data-theme=light] .vertical-timeline-element-content h3{color:var(--text)!important}:root[data-theme=light] .vertical-timeline-element-content .vertical-timeline-element-content-arrow{border-right-color:var(--surface)!important;border-left-color:var(--surface)!important}:root[data-theme=light] .recharts-line-curve{stroke:var(--brand-blue)!important}:root[data-theme=light] .recharts-dot,:root[data-theme=light] .recharts-line-dot circle,:root[data-theme=light] .recharts-active-dot circle{fill:var(--brand-blue)!important;stroke:var(--brand-blue)!important}:root[data-theme=light] .recharts-cartesian-axis-tick-value,:root[data-theme=light] .recharts-legend-item text{fill:#1f2937!important}:root[data-theme=light] .fancy-frame:before{background:linear-gradient(135deg,color-mix(in oklab,var(--brand-blue),#fff 20%),#ffffff0f)!important}.ff-inner.no-glimmer:before{content:none!important}:root[data-theme=light] .ff-placeholder:after{background:linear-gradient(135deg,var(--brand-blue),var(--brand-blue-light))!important;color:#0f1a2a!important}:root[data-theme=light] .section h2,:root[data-theme=light] .project-card h3,:root[data-theme=light] .vertical-timeline-element-content h3{text-shadow:0 0 10px color-mix(in oklab,var(--brand-blue, #3a7bd5),white 65%),0 1px 0 rgba(255,255,255,.65)}:root[data-theme=light] .hero-name{text-shadow:0 0 14px color-mix(in oklab,var(--brand-blue, #3a7bd5),white 55%),0 2px 10px rgba(0,0,0,.22)}.projects .project-card{padding:0!important;border-radius:24px!important;overflow:hidden!important}.projects .project-image{margin:0!important;padding:0!important;border:none!important;background:transparent!important;line-height:0;position:relative}.projects .project-image:after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:1px;background:linear-gradient(to right,transparent,color-mix(in oklab,var(--brand-blue, #3a7bd5),black 15%),transparent);opacity:.35;pointer-events:none}:root[data-theme=dark]{--card-bg: var(--glass-bg);--card-border: rgba(255,255,255,.12)}:root[data-theme=light]{--card-bg: var(--surface);--card-border: rgba(15,23,42,.14)}.projects .project-card{position:relative;padding:0!important;border-radius:24px!important;overflow:hidden!important;background:var(--card-bg)!important;border:1px solid var(--card-border)!important;box-shadow:var(--card-shadow-sm, 0 8px 18px rgba(0,0,0,.08));transition:transform .2s ease,box-shadow .25s ease}.projects .project-card:hover{transform:translateY(-2px);box-shadow:var(--card-shadow-lg, 0 16px 36px rgba(0,0,0,.12))}:root[data-theme] .projects .project-image{margin:0!important;padding:0!important;border:none!important;background:transparent!important;line-height:0;position:relative;border-radius:0!important}:root[data-theme] .projects .project-image img{display:block;width:100%;height:200px;object-fit:cover;border-radius:0!important}:root[data-theme] .projects .project-image:after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:1px;background:linear-gradient(to right,transparent,color-mix(in oklab,var(--glacier-blue, #3a7bd5),black 18%),transparent);opacity:.35;pointer-events:none}:root[data-theme=light] .projects .project-image{border:none!important;background:transparent!important}.recharts-line path{stroke:#f8b179!important;stroke-width:3px}body.dark-mode .recharts-line path{stroke:#f8b179!important}.recharts-tooltip-wrapper{border-radius:8px!important;background:#fff!important;border:1px solid #e5e7eb!important;box-shadow:0 4px 12px #0000001a!important;font-size:.9rem!important;color:#111827!important}body.dark-mode .recharts-tooltip-wrapper{background:#2d3250!important;border:1px solid #424669!important;color:#f8b179!important;box-shadow:0 4px 12px #00000080!important}body.dark-mode #noten .recharts-tooltip-item-name,body.dark-mode #noten .recharts-tooltip-item-separator,body.dark-mode #noten .recharts-tooltip-item-value{color:#f8b179!important;font-weight:600!important}body.dark-mode #noten .recharts-xAxis .recharts-cartesian-axis-tick text{fill:#fff!important;font-weight:500!important}:root{--text: #ffffff;--text-muted: #c8cee8;--overcast: #1e2233;--surface: rgba(255,255,255,.06);--surface-2: rgba(255,255,255,.08);--border: rgba(255,255,255,.15);--glacier-blue: #f8b179;--glacier-blue-light: #ffcda6;--shadow-sm: 0 6px 14px rgba(0,0,0,.18);--shadow-lg: 0 16px 38px rgba(0,0,0,.28);--section-gap: clamp(48px, 8vw, 96px)}:root[data-theme=light]{--text: #1b2130;--text-muted: #4b5567;--overcast: #e9edf5;--surface: #ffffff;--surface-2: #f6f8fc;--border: rgba(15,23,42,.12);--glacier-blue: #3a7bd5;--glacier-blue-light: #6aa8ff;--shadow-sm: 0 6px 14px rgba(15,23,42,.08);--shadow-lg: 0 16px 36px rgba(15,23,42,.12)}html,body{background:var(--overcast);color:var(--text)}a{color:var(--glacier-blue)}a:hover{color:var(--glacier-blue-light)}.navbar{position:sticky;top:0;z-index:100;background:color-mix(in oklab,var(--overcast),#000 8%);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;padding:.8rem clamp(16px,4vw,32px);box-shadow:0 6px 20px #0000002e}.navbar-links{display:flex;gap:clamp(10px,2vw,24px);list-style:none;margin:0;padding:0}.navbar a{color:var(--text-muted);padding-bottom:.25rem;border-bottom:2px solid transparent;transition:.2s}.navbar a.active,.navbar a:hover{color:var(--glacier-blue);border-color:var(--glacier-blue)}.theme-toggle{background:transparent;border:1px solid var(--border);color:var(--text);border-radius:10px;padding:.4rem .6rem}.section{width:100%;max-width:1200px;margin:var(--section-gap) auto;padding:0 clamp(16px,4vw,32px)}.section h2{margin:0 0 1.25rem;font-weight:800;font-size:clamp(1.8rem,1.2rem + 1.8vw,2.6rem);color:var(--glacier-blue)}.hero-full{height:100vh;background-size:cover;background-position:center;display:flex;align-items:flex-end;justify-content:center}.hero-content{padding:2rem}.card,.card-like,.project-card,.noten-card,.vertical-timeline-element-content{background:var(--surface);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-sm);transition:transform .2s ease,box-shadow .25s ease,border-color .25s ease,background-color .25s ease}.projects .project-card{padding:0;overflow:hidden}.projects .project-image{margin:0!important;padding:0!important;border:none!important;background:transparent!important;line-height:0}.projects .project-image img{display:block;width:100%;height:200px;object-fit:cover;border-radius:0!important}.projects .project-info{padding:1.2rem 1.2rem 1.4rem!important}:root[data-theme=light] .project-card{background:var(--surface)}.vertical-timeline-element-content{background:var(--surface)!important;border:1px solid var(--border)!important;color:var(--text)!important}.vertical-timeline-element-date{color:var(--glacier-blue)!important}.circle-skill svg{filter:drop-shadow(0 6px 16px rgba(0,0,0,.22))}.circle-skill text{fill:var(--text)}#noten .recharts-cartesian-axis-tick text{fill:color-mix(in oklab,var(--text),#000 20%)!important}#noten .recharts-legend-item text{fill:color-mix(in oklab,var(--text),#000 35%)!important}#noten .recharts-tooltip-wrapper{background:#fff!important;border:1px solid var(--border)!important;color:#111827!important}:root[data-theme=light] .navbar{background:color-mix(in oklab,var(--overcast),#000 6%)}:root[data-theme=light] a,:root[data-theme=light] .navbar a.active,:root[data-theme=light] .navbar a:hover{color:var(--glacier-blue)!important;border-color:var(--glacier-blue)!important}@media (prefers-reduced-motion: reduce){*{animation:none!important;transition:none!important}}:root{--overcast: #2d3250;--warm-gray: #676f9d;--ice: #424669;--glacier-blue: #f8b179;--font-color-dark: #ffffff;--max-width: 900px}body{margin:0;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background-color:var(--overcast);color:var(--font-color-dark);line-height:1.75}a{color:var(--glacier-blue);text-decoration:none;font-weight:500;transition:color .3s ease}a:hover{color:var(--ice);text-decoration:underline}button{cursor:pointer;background:none;border:2px solid var(--glacier-blue);color:var(--glacier-blue);padding:.5em 1.2em;border-radius:6px;font-weight:600;font-size:1rem;transition:background-color .3s ease,color .3s ease}button:hover{background-color:var(--glacier-blue);color:#fff}.navbar{position:sticky;top:0;background-color:var(--overcast);padding:1rem 2rem;border-bottom:1px solid #e5e7eb;display:flex;justify-content:center;z-index:100}.navbar a{color:var(--warm-gray);font-weight:500;font-size:1rem;padding-bottom:.25em;border-bottom:2px solid transparent;transition:border-color .3s ease,color .3s ease}.hero h1{font-size:4.5rem;margin-bottom:.5rem;color:var(--glacier-blue);font-weight:800;line-height:1.1}.section+.section{border-top:1px solid #e5e7eb;padding-top:5rem}.section h2{font-size:2.25rem;margin-bottom:1.5rem;font-weight:700;color:var(--glacier-blue)}.project-card{padding:1.5rem 0;border-bottom:1px solid #e5e7eb}.project-card h3{font-size:1.5rem;color:var(--glacier-blue);margin-bottom:.5rem}.abstract{font-style:italic;color:var(--warm-gray);margin-top:.5rem}.skills-grid{display:flex;flex-wrap:wrap;gap:2rem}.skills-grid>div{flex:1 1 45%;min-width:250px}.education-list{list-style:none;padding:0;background-color:var(--overcast)}.education-item{display:flex;gap:1rem;margin-bottom:2rem;border-left:4px solid var(--glacier-blue);padding-left:1rem;background-color:var(--overcast)}.year{font-weight:700;color:var(--glacier-blue);min-width:60px}.details h3{margin:0 0 .3rem;font-weight:600;color:var(--font-color-dark)}.footer{text-align:center;padding:3rem 0 2rem;margin-top:6rem;font-size:1rem;color:var(--warm-gray);border-top:1px solid #e5e7eb}.footer a{color:var(--glacier-blue);font-weight:500}.dokumente-page{max-width:var(--max-width);margin:5rem auto;padding:3rem 2rem;text-align:center;color:var(--font-color-dark)}@media (max-width: 700px){.skills-grid{flex-direction:column}.hero h1{font-size:3rem}.section h2{font-size:1.75rem}}.hero-content{display:flex;align-items:center;gap:4rem;padding:2rem}.hero-img{width:450px;height:auto;object-fit:cover;border-radius:12px}.hero-name{font-size:5rem;color:#fff;font-weight:900;text-shadow:2px 2px 8px rgba(0,0,0,.7)}.navbar{position:sticky;top:0;background-color:var(--overcast);padding:1rem 2rem;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center;z-index:100}.navbar-logo img{height:60px;width:60px;border-radius:10px}.navbar-links{display:flex;gap:2rem;list-style:none;padding:0;margin:0}.skills-circles{display:flex;flex-wrap:wrap;gap:2rem;justify-content:center}.circle-skill{display:flex;flex-direction:column;align-items:center;width:180px;text-align:center}.circle-skill p{margin-top:.75rem;font-weight:500;color:var(--font-color-dark)}.education{width:90%;height:90%;margin-top:1rem;border-radius:12px;box-shadow:0 4px 12px #00000026;object-fit:cover}#projects{padding:4rem 2rem;background-color:#f9fafb}#projects h2{text-align:center;font-size:2rem;margin-bottom:2rem;color:var(--glacier-blue)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;max-width:1200px;margin:0 auto}.project-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 8px 20px #0000001a;transition:transform .3s ease,box-shadow .3s ease;display:flex;flex-direction:column}.project-card:hover{transform:translateY(-8px);box-shadow:0 12px 24px #00000026}.project-image img{width:100%;height:200px;object-fit:cover;object-position:center;display:block}.project-info{padding:1rem;display:flex;flex-direction:column;gap:.4rem}.project-info h3{color:var(--glacier-blue);margin:0;font-size:1.25rem}.project-info .description{color:#555;font-size:.95rem}.project-info .tech{font-size:.85rem;color:#777}.project-info .abstract{font-style:italic;font-size:.85rem;color:#999}.project-info button{margin-top:.5rem;padding:.4rem .8rem;background-color:var(--glacier-blue);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:background-color .2s ease}.project-info button:hover{background-color:#3290a8}@media (max-width: 700px){.projects-grid{grid-template-columns:1fr}}#noten{padding:4rem 2rem;background-color:var(--overcast)}.noten-card{max-width:var(--max-width);margin:0 auto;background:#fff;border-radius:16px;box-shadow:0 8px 20px #0000001a;padding:2rem;display:flex;flex-direction:column;gap:2rem;transition:transform .3s ease,box-shadow .3s ease}.noten-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px #00000026}.noten-card h2{text-align:center;font-size:2rem;color:var(--glacier-blue);margin-bottom:1.5rem}.noten-buttons{display:flex;justify-content:center;gap:1.5rem}.noten-buttons button{padding:.6rem 1.2rem;border-radius:12px;border:2px solid var(--glacier-blue);font-weight:600;font-size:1rem;transition:background-color .3s ease,color .3s ease}.noten-buttons button.active{background-color:var(--glacier-blue);color:#fff}.noten-buttons button:not(.active){background-color:#fff;color:var(--glacier-blue)}.noten-buttons button:not(.active):hover{background-color:var(--ice);color:#fff}.noten-chart{width:100%;height:320px}.recharts-tooltip-wrapper{border-radius:8px!important;background:#fff!important;border:1px solid #e5e7eb!important;box-shadow:0 4px 12px #0000001a!important;font-size:.9rem!important}.recharts-legend-item text{font-size:.9rem;fill:var(--warm-gray)}:root{--overcast: #1e2233;--warm-gray: #8b92b2;--ice: #3a3f5c;--glacier-blue: #f8b179;--glacier-blue-light: #ffcda6;--font-color-dark: #ffffff;--max-width: 900px;--gradient-bg: linear-gradient(135deg, rgba(248,177,121,.15) 0%, rgba(30,34,51,.6) 100%);--glass-bg: rgba(255,255,255,.06);--border-glass: rgba(255,255,255,.15)}body{margin:0;font-family:Poppins,Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:var(--overcast);background-image:var(--gradient-bg);background-attachment:fixed;color:var(--font-color-dark);line-height:1.75;letter-spacing:.3px}a:hover{color:var(--glacier-blue-light);text-shadow:0 0 6px rgba(248,177,121,.6);text-decoration:underline}.navbar{position:sticky;top:0;background-color:#1e2233d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:1rem 2rem;border-bottom:1px solid var(--border-glass);display:flex;justify-content:space-between;align-items:center;z-index:100;animation:fadeInDown .6s ease}.navbar ul{display:flex;gap:2rem;list-style:none;padding:0;margin:0}.navbar a{color:var(--warm-gray);font-weight:500;font-size:1rem;padding-bottom:.25em;border-bottom:2px solid transparent;transition:all .3s ease}.hero{text-align:center;padding:6rem 2rem 4rem}.hero h1{font-size:4.5rem;margin-bottom:.5rem;color:var(--glacier-blue);font-weight:800;line-height:1.1;text-shadow:0 0 10px rgba(248,177,121,.4)}.slogan{font-size:1.5rem;color:var(--warm-gray);font-style:italic;margin-bottom:2.5rem}.section{max-width:var(--max-width);margin:5rem auto;padding:0 2rem;animation:fadeIn .8s ease}.section+.section{border-top:1px solid rgba(255,255,255,.05);padding-top:5rem}.section h2{font-size:2.5rem;margin-bottom:1.5rem;font-weight:700;color:var(--glacier-blue);text-shadow:0 0 8px rgba(248,177,121,.4)}.project-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:16px;overflow:hidden;border:1px solid var(--border-glass);transition:all .3s ease;display:flex;flex-direction:column;box-shadow:0 8px 24px #00000026}.project-info h3{color:var(--glacier-blue);font-size:1.4rem}.project-info .description{color:#ccc}.project-info .tech{font-size:.85rem;color:var(--warm-gray)}.project-info .abstract{font-style:italic;color:var(--glacier-blue-light)}.skills-circles{display:flex;flex-wrap:wrap;gap:2.5rem;justify-content:center}.circle-skill{background:var(--glass-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;padding:1rem;box-shadow:0 4px 16px #00000026;transition:transform .3s ease}.circle-skill:hover{transform:scale(1.05)}.education{border-radius:12px;box-shadow:0 6px 16px #0003;object-fit:cover;border:1px solid var(--border-glass)}.footer{text-align:center;padding:3rem 0 2rem;margin-top:6rem;font-size:1rem;color:var(--warm-gray);border-top:1px solid var(--border-glass);background:var(--glass-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.education-item{display:flex;gap:1rem;margin-bottom:2rem;border-left:4px solid #f8b179;padding-left:1rem;background-color:var(--overcast)}.project-card{background:#424669;border-radius:16px;overflow:hidden;box-shadow:0 8px 20px #00000026;transition:transform .3s ease,box-shadow .3s ease}.project-info h3{color:#f8b179}.project-info .tech{color:#676f9d}.project-info .abstract{font-style:italic;color:#676f9d}.project-info button{background-color:#f8b179;color:#2d3250;border:none}.project-info button:hover{background-color:#fff;color:#2d3250}.hero-full{width:100%;height:687px;background-size:cover;background-position:center;display:flex;align-items:center;justify-content:center}.hero-full:before{content:none!important;background:none!important}.hero-full{width:100%;height:100vh;background-size:cover;background-position:center;background-repeat:no-repeat;display:flex;align-items:center;justify-content:center;overflow:hidden}.navbar{position:sticky;top:0;background-color:#2d3250;padding:.5rem 1.5rem;display:flex;justify-content:space-between;align-items:center;z-index:100}.navbar-logo img{height:40px;width:40px;border-radius:6px}.navbar-links{display:flex;gap:1.2rem;list-style:none;padding:0;margin:0}.navbar a{color:#fff;font-weight:500;font-size:.9rem;padding:.25rem 0;transition:color .3s ease}.navbar a:hover,.navbar a.active{color:#f8b179}button{cursor:pointer;background-color:#f8b179;border:none;color:#2d3250;padding:.4em .9em;border-radius:6px;font-weight:500;font-size:.9rem;transition:background-color .2s ease,transform .15s ease}button:hover{background-color:#fff;color:#2d3250}button:active{transform:scale(.97)}.education-item{display:flex;gap:1rem;margin-bottom:2rem;border-left:4px solid #f8b179;padding:1rem;background-color:#424669;border-radius:12px;box-shadow:0 4px 12px #00000026}.year{font-weight:700;color:#f8b179;min-width:60px}.details h3{margin:0 0 .3rem;font-weight:600;color:#fff}.details p{color:#676f9d}.vertical-timeline-element-content{background-color:var(--overcast);border-radius:15px}.vertical-timeline-element-icon-shadow-size-small{background-color:var(--overcast)}#education{padding:4rem 2rem}.vertical-timeline:before{background:#f8b179!important}.vertical-timeline-element-content{background:#424669!important;color:#fff!important;box-shadow:none!important}.vertical-timeline-element-date{color:#f8b179!important}.vertical-timeline-element-content h3,.vertical-timeline-element-content p{color:#fff!important}.vertical-timeline-element-content img.education{border-radius:12px;box-shadow:0 4px 12px #00000026}#projects{padding:4rem 2rem;background-color:var(--overcast)}.projects-grid{display:grid!important;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))!important;gap:2rem!important;width:100%!important}.project-card{background:#424669;border-radius:16px;overflow:hidden;box-shadow:0 8px 20px #00000026;display:flex;flex-direction:column;transition:transform .3s ease,box-shadow .3s ease}.project-card:hover{transform:translateY(-8px);box-shadow:0 12px 24px #00000040}.project-info .description{color:#fff}.project-info .abstract{font-style:italic;color:var(--warm-gray)}#projects{padding:4rem 2rem;background-color:#2d3250d9;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}:root{--overcast: #1e2233;--warm-gray: #8b92b2;--ice: #3a3f5c;--glacier-blue: #f8b179;--glacier-blue-light: #ffcda6;--font-color-dark: #ffffff;--max-width: 1200px;--gradient-bg: linear-gradient(135deg, rgba(248,177,121,.12) 0%, rgba(30,34,51,.8) 100%);--glass-bg: rgba(255, 255, 255, .06);--border-glass: rgba(255, 255, 255, .15)}body{margin:0;font-family:Poppins,Segoe UI,Tahoma,sans-serif;background:var(--overcast);background-image:var(--gradient-bg);background-attachment:fixed;color:var(--font-color-dark);line-height:1.75;letter-spacing:.3px}a{color:var(--glacier-blue);text-decoration:none;font-weight:500;transition:all .3s ease}a:hover{color:var(--glacier-blue-light);text-shadow:0 0 6px rgba(248,177,121,.5)}button{cursor:pointer;background:var(--glass-bg);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:2px solid var(--glacier-blue);color:var(--glacier-blue);padding:.6em 1.4em;border-radius:12px;font-weight:600;font-size:1rem;transition:all .35s ease;box-shadow:0 4px 10px #0003}button:hover{background-color:var(--glacier-blue);color:#fff;box-shadow:0 6px 16px #f8b17966;transform:translateY(-2px)}.navbar{position:sticky;top:0;background-color:#1e2233d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:.8rem 2rem;border-bottom:1px solid var(--border-glass);display:flex;justify-content:space-between;align-items:center;z-index:100}.navbar-links{display:flex;gap:1.5rem;list-style:none;padding:0;margin:0}.navbar a{color:var(--warm-gray);font-size:.95rem;padding-bottom:.2rem;border-bottom:2px solid transparent;transition:all .3s ease}.navbar a:hover,.navbar a.active{color:var(--glacier-blue);border-color:var(--glacier-blue)}.hero-full{width:100%;height:100vh;background-size:cover;background-position:center;display:flex;align-items:center;justify-content:center}.hero-name{font-size:4.5rem;color:#fff;font-weight:900;text-shadow:0 0 12px rgba(0,0,0,.6),0 0 20px rgba(248,177,121,.4)}.section{max-width:var(--max-width);margin:5rem auto;padding:0 2rem}.section h2{font-size:2.5rem;margin-bottom:2rem;font-weight:700;color:var(--glacier-blue);text-align:center;text-shadow:0 0 8px rgba(248,177,121,.3)}#projects{padding:4rem 2rem;background-color:#2d3250d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;width:100%}.project-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-glass);border-radius:16px;overflow:hidden;box-shadow:0 8px 20px #00000026;transition:all .3s ease}.project-card:hover{transform:translateY(-6px) scale(1.02);box-shadow:0 12px 32px #f8b1794d}.project-image img{width:100%;height:220px;object-fit:cover}.project-info{padding:1.5rem}.project-info h3{color:var(--glacier-blue)}.project-info .description{color:#ddd}.project-info .tech{color:var(--warm-gray)}.project-info .abstract{color:var(--glacier-blue-light);font-style:italic}.noten-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid var(--border-glass);border-radius:16px;padding:2rem;box-shadow:0 8px 20px #0003;transition:transform .3s ease}.noten-card:hover{transform:translateY(-4px)}#education{padding:4rem 2rem;background-color:#2d3250d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.vertical-timeline:before{background:var(--glacier-blue)!important}.vertical-timeline-element-content{background:var(--glass-bg)!important;-webkit-backdrop-filter:blur(10px)!important;backdrop-filter:blur(10px)!important;border:1px solid var(--border-glass)!important;color:#fff!important}.vertical-timeline-element-date,.vertical-timeline-element-content h3{color:var(--glacier-blue)!important}.vertical-timeline-element-content p{color:#ddd!important}.footer{text-align:center;padding:3rem 2rem;background:var(--glass-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-top:1px solid var(--border-glass);color:var(--warm-gray)}.footer a{color:var(--glacier-blue)}:root{--color-white: #ffffff;--color-gray: #676f9d;--color-dark-gray: #424669;--color-dark: #2d3250;--color-accent: #f8b179;--max-width: 1200px;--bg-gradient: linear-gradient(135deg, rgba(248,177,121,.1), rgba(45,50,80,.95));--glass-bg: rgba(255,255,255,.04);--glass-border: rgba(255,255,255,.1)}*{box-sizing:border-box}body{margin:0;font-family:Poppins,Segoe UI,Tahoma,sans-serif;background:var(--color-dark);background-image:var(--bg-gradient);color:var(--color-white);line-height:1.6}a{color:var(--color-accent);text-decoration:none;transition:all .3s ease}a:hover{color:var(--color-white);text-shadow:0 0 6px rgba(248,177,121,.5)}button{cursor:pointer;background:var(--color-accent);color:var(--color-dark);border:none;border-radius:8px;padding:.6em 1.2em;font-weight:600;transition:all .3s ease}button:hover{background:var(--color-white);color:var(--color-dark)}.navbar{position:sticky;top:0;background:#2d3250d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--glass-border);padding:.8rem 2rem;display:flex;justify-content:space-between;align-items:center;z-index:1000}.navbar-logo img{height:48px;border-radius:6px}.navbar-links{list-style:none;display:flex;gap:1.5rem;margin:0;padding:0}.navbar a{color:var(--color-white);font-weight:500;border-bottom:2px solid transparent}.navbar a:hover,.navbar a.active{color:var(--color-accent);border-color:var(--color-accent)}.hero-full{height:100vh;background-size:cover;background-position:center;display:flex;align-items:center;justify-content:center}.hero-name{font-size:4rem;font-weight:900;color:var(--color-white);text-align:center;text-shadow:0 0 10px rgba(0,0,0,.6)}.slogan{font-size:1.4rem;color:var(--color-gray);font-style:italic;text-align:center;margin-top:1rem}.section{max-width:var(--max-width);margin:4rem auto;padding:0 2rem}.section h2{text-align:center;font-size:2.2rem;color:var(--color-accent);margin-bottom:2rem}#ueber-mich{background:var(--glass-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--glass-border);border-radius:16px;padding:2rem;box-shadow:0 8px 24px #00000026}#ueber-mich p{color:var(--color-white);text-align:center;font-size:1.05rem}.staerken-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem}.staerke-card{background:var(--color-dark-gray);padding:1.5rem;border-radius:12px;text-align:center;transition:all .3s ease}.staerke-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #f8b1794d}.staerke-card h3{color:var(--color-accent);margin-bottom:.5rem}.staerke-card p{color:var(--color-gray)}#projects{background:#2d3250d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:4rem 2rem}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}.project-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--glass-border);border-radius:16px;overflow:hidden;transition:all .3s ease}.project-card:hover{transform:translateY(-6px);box-shadow:0 12px 32px #f8b1794d}.project-image img{width:100%;height:200px;object-fit:cover}.project-info{padding:1.2rem}.project-info h3{color:var(--color-accent)}.project-info .description{color:var(--color-white);font-size:.95rem}.project-info .tech{color:var(--color-gray);font-size:.85rem}#noten{padding:4rem 2rem}.noten-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--glass-border);border-radius:16px;padding:2rem;box-shadow:0 8px 20px #00000026}.noten-buttons{display:flex;justify-content:center;gap:1rem;margin-top:1rem}.noten-buttons button{border:2px solid var(--color-accent);background:transparent;color:var(--color-accent)}.noten-buttons button.active{background:var(--color-accent);color:var(--color-dark)}#education{background:#2d3250d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:4rem 2rem}.vertical-timeline:before{background:var(--color-accent)!important}.vertical-timeline-element-content{background:var(--glass-bg)!important;-webkit-backdrop-filter:blur(6px)!important;backdrop-filter:blur(6px)!important;border:1px solid var(--glass-border)!important}.vertical-timeline-element-content h3{color:var(--color-accent)!important}.vertical-timeline-element-content p{color:var(--color-white)!important}.vertical-timeline-element-date{color:var(--color-accent)!important}.footer{text-align:center;padding:2rem;background:var(--glass-bg);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-top:1px solid var(--glass-border);color:var(--color-gray)}.footer a{color:var(--color-accent)}@media (max-width: 768px){.hero-name{font-size:3rem}.section{padding:0 1rem}}.noten-card{background:var(--glass-bg);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid var(--glass-border);border-radius:16px;padding:2rem;box-shadow:0 8px 20px #00000026}#noten{padding:4rem 2rem;background:#2d3250d9;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}#noten{padding:4rem 2rem;background:linear-gradient(135deg,#f8b17914,#2d3250d9);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-top:1px solid rgba(255,255,255,.1)}#noten{padding:4rem 2rem;background:transparent;border-top:1px solid rgba(255,255,255,.1)}.noten-card{background:#2d3250d9;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:16px;border:1px solid rgba(255,255,255,.1);box-shadow:0 8px 20px #00000026}.hero-full{width:100%;height:100vh;background-size:cover;background-position:center;background-repeat:no-repeat;display:flex;align-items:flex-end;justify-content:center;overflow:hidden}.projects .project-image{position:relative;padding:8px;border:2px solid var(--glacier-blue);border-radius:16px;background:#ffffff0a;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);transition:border-color .2s ease,box-shadow .2s ease,transform .15s ease}.projects .project-image img{display:block;width:100%;aspect-ratio:16 / 9;height:auto;object-fit:cover;border-radius:12px}.projects .project-card:hover .project-image{border-color:color-mix(in oklab,var(--glacier-blue),#fff 20%);box-shadow:0 10px 24px #00000038;transform:translateY(-2px)}.projects .project-image img{height:auto!important}.project-footer{margin-top:auto;border-top:1px solid rgba(255,255,255,.12);padding:.75rem 1rem 1rem;display:flex;justify-content:flex-end}.abstract-link{display:inline-flex;align-items:center;gap:8px;font-weight:700;text-decoration:none;color:var(--glacier-blue, #f8b179);border:2px solid var(--glacier-blue, #f8b179);padding:.45rem .8rem;border-radius:10px;transition:background .2s ease,transform .06s ease,border-color .2s ease}.abstract-link:hover{background:var(--glacier-blue, #f8b179);color:#2d3250}.abstract-link:active{transform:translateY(1px)}.repo-meta{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.35rem;margin-bottom:.2rem}.chip{display:inline-block;padding:.25rem .55rem;border-radius:999px;font-size:.85rem;line-height:1;background:#ffffff0f;border:1px solid rgba(255,255,255,.18);color:var(--font-color-dark, #fff)}.chip.muted{color:#aab0cc}.meta-skeleton{opacity:.7;font-size:.9rem}.projects .project-image{position:relative;padding:8px;border:2px solid var(--glacier-blue, #f8b179);border-radius:16px;background:#ffffff0a;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.projects .project-image img{width:100%;height:200px;object-fit:cover;border-radius:12px;display:block}.skills-circles{display:flex;gap:16px;overflow-x:auto;padding-bottom:6px;scroll-snap-type:x mandatory}.circle-skill{scroll-snap-align:start;flex:0 0 180px}.theme-toggle{background:transparent;border:1px solid var(--border-glass);color:var(--font-color-dark);padding:.4rem .6rem;border-radius:8px;display:inline-flex;align-items:center;gap:.5rem;cursor:pointer}.theme-toggle:hover{background:color-mix(in oklab,var(--glass-bg),white 8%)}.skills-circles{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:clamp(14px,2.5vw,24px);align-items:start;justify-items:center;max-width:1100px;margin:0 auto}.circle-skill{width:180px;text-align:center;display:grid;place-items:center}.circle-skill svg{width:160px;height:160px;display:block}.circle-skill p{margin-top:.6rem;font-weight:600;color:var(--font-color-dark)}@media (max-width: 520px){.circle-skill{width:150px}.circle-skill svg{width:140px;height:140px}}.project-card{position:relative;display:flex;flex-direction:column;overflow:hidden;isolation:isolate}.project-card:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;padding:1px;background:conic-gradient(from 120deg,color-mix(in oklab,var(--glacier-blue),#fff 12%),transparent 22%,transparent 60%,color-mix(in oklab,var(--glacier-blue-light),#fff 5%),transparent 85%);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;border-radius:16px;opacity:0;transition:opacity .35s ease;pointer-events:none}.project-card:hover:after{opacity:.9}.project-image{position:relative;padding:8px;border:2px solid var(--glacier-blue);border-radius:16px;background:#ffffff0a;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);transition:border-color .2s ease,box-shadow .2s ease,transform .15s ease}.project-image img{display:block;width:100%;height:200px;object-fit:cover;border-radius:12px}.project-image:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:12px;pointer-events:none;background:linear-gradient(120deg,transparent 0%,rgba(255,255,255,.18) 45%,transparent 55%);transform:translate(-120%);transition:transform .8s cubic-bezier(.22,.61,.36,1)}.project-card:hover .project-image:after{transform:translate(120%)}.project-footer{margin-top:auto;padding:.75rem 1rem 1rem;display:flex;justify-content:flex-end;border-top:1px solid var(--border)}.abstract-link{display:inline-flex;align-items:center;gap:10px;font-weight:800;color:var(--glacier-blue);border:2px solid var(--glacier-blue);padding:.5rem .9rem;border-radius:10px;transition:background .2s ease,transform .06s ease,border-color .2s ease,color .2s ease}.abstract-link:after{content:"→";display:inline-block;transform:translate(0);transition:transform .2s ease}.abstract-link:hover{background:var(--glacier-blue);color:#1f2233}.abstract-link:hover:after{transform:translate(4px)}.project-card,.education-item,.vertical-timeline-element-content,.card,.card-like,.noten-card{border-radius:24px!important}.project-card:after{border-radius:26px!important}.project-image{border-radius:22px!important}.project-image img{border-radius:16px!important}.education-item{border-left:none!important;background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.vertical-timeline-element-content{border-radius:24px!important;background:var(--surface)!important;border:1px solid var(--border)!important}.section:before{content:"";position:absolute;left:6%;right:6%;top:-28px;height:22px;border-radius:999px;background:radial-gradient(60% 100% at 50% 0%,rgba(0,0,0,.16),transparent 70%);filter:blur(10px);opacity:.16;pointer-events:none}.card,.card-like,.project-card,.education-item,.noten-card,.vertical-timeline-element-content{transition:transform .2s ease,box-shadow .25s ease,border-color .25s ease,background-color .25s ease}.card:hover,.card-like:hover,.project-card:hover,.education-item:hover,.noten-card:hover,.vertical-timeline-element-content:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}body.dark-mode #noten .recharts-tooltip-item{color:#f8b179!important;font-weight:600}body.dark-mode #noten .recharts-xAxis .recharts-cartesian-axis-tick text{fill:#fff!important;font-weight:500}body.dark-mode #noten .recharts-yAxis .recharts-cartesian-axis-tick text{fill:#fff!important;font-weight:500}body.dark-mode #noten .recharts-tooltip-item,body.dark-mode #noten .recharts-tooltip-item-name{color:#f8b179!important}body.dark-mode #noten .recharts-cartesian-axis-tick-value{fill:#fff!important}body:not(.dark-mode) #noten .recharts-tooltip-item{color:#111827!important}body:not(.dark-mode) #noten .recharts-tooltip-item-name{color:#111827!important}body:not(.dark-mode) #noten .recharts-cartesian-axis-tick-value{fill:#6b7280!important}.navbar-links a{text-decoration:none;border-bottom:2px solid transparent;padding-bottom:.25rem;transition:border-color .3s ease,color .3s ease}.navbar-links a:hover,.navbar-links a.active{border-color:var(--glacier-blue)}.navbar-links{gap:2rem}.logo-mark{display:inline-block;width:40px;height:40px;mask:var(--logo-url) no-repeat center / contain;-webkit-mask:var(--logo-url) no-repeat center / contain;background-color:currentColor}:root[data-theme=dark] .logo-mark{background-color:orange}:root[data-theme=light] .logo-mark{background-color:#00f}.logo-mark{display:inline-block;width:40px;height:40px;-webkit-mask-image:var(--logo-url);mask-image:var(--logo-url);-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center;-webkit-mask-size:contain;mask-size:contain;background-color:var(--glacier-blue)}:root[data-theme=dark] .logo-mark{background-color:var(--glacier-blue)}:root[data-theme=light] .logo-mark{background-color:var(--glacier-blue)}@media (min-width: 768px){.logo-mark{width:44px;height:44px}}.navbar{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem}:root[data-theme=light]{--logo-color: #1e90ff}:root[data-theme=dark]{--logo-color: #f6b078}.navbar-links{list-style:none;display:flex;gap:1.25rem;margin:0;padding:0;align-items:center}.logo-img{width:72px;height:auto;display:block;transition:filter .25s ease}:root[data-theme=light] .logo-img{filter:invert(36%) sepia(98%) saturate(2438%) hue-rotate(200deg) brightness(95%) contrast(96%)}:root[data-theme=dark] .logo-img{filter:invert(80%) sepia(27%) saturate(1069%) hue-rotate(329deg) brightness(96%) contrast(90%)}:root[data-theme=light] .nk-btn--primary,:root[data-theme=light] .nk-btn--primary:hover,:root[data-theme=light] .nk-btn--primary:focus{color:#fff!important}:root[data-theme=light] .section{position:relative;z-index:0}:root[data-theme=light] .section:before{content:"";position:absolute;left:-6%;right:-6%;top:-24px;height:160px;z-index:-1;background:radial-gradient(60% 120px at 20% 40%,color-mix(in oklab,var(--glacier-blue),#fff 70%) 0%,transparent 70%),radial-gradient(50% 120px at 80% 0%,color-mix(in oklab,var(--glacier-blue-light),#fff 80%) 0%,transparent 72%);filter:blur(18px) saturate(115%);opacity:.35;pointer-events:none}:root[data-theme=light] .section:after{content:"";position:absolute;left:6%;right:6%;bottom:-18px;height:20px;z-index:-1;background:radial-gradient(60% 100% at 50% 0%,rgba(0,0,0,.12),transparent 70%);filter:blur(8px);opacity:.18;pointer-events:none}:root[data-theme] .navbar a{border-bottom:2px solid transparent!important}:root[data-theme] .navbar a.active,:root[data-theme] .navbar a:hover{border-color:var(--glacier-blue)!important}.section h2{position:relative;margin-bottom:1.5rem}.section h2:after{content:"";display:block;width:88px;height:3px;margin-top:.6rem;border-radius:999px;background:linear-gradient(90deg,var(--glacier-blue),transparent);opacity:.95}.project-card h3,.vertical-timeline-element-content h3{position:relative;padding-bottom:.35rem}.project-card h3:after,.vertical-timeline-element-content h3:after{content:"";position:absolute;left:0;bottom:0;width:56px;height:2px;border-radius:999px;background:currentColor;opacity:.35}.navbar a{border-bottom:2px solid transparent!important}.navbar a.active,.navbar a:hover{border-color:var(--glacier-blue)!important}:root[data-theme=light] .navbar a{border-color:transparent!important}:root[data-theme=light]{--mesh-a: rgba(241,153,85,.16);--mesh-b: rgba(255,205,166,.14);--mesh-c: rgba(0,0,0,.03);--grain-opacity: .08;--vignette-opacity: .14;--gradient-bg: linear-gradient(135deg, #ffffff 0%, #eef2f8 100%)}:root[data-theme=light] :where(html,body){background-color:var(--overcast)!important;background-image:radial-gradient(1200px 800px at 8% 12%,var(--mesh-a),transparent 60%),radial-gradient(1000px 700px at 92% 88%,var(--mesh-b),transparent 60%),radial-gradient(900px 600px at 50% 110%,var(--mesh-c),transparent 60%),var(--gradient-bg);background-repeat:no-repeat,no-repeat,no-repeat,no-repeat!important;background-attachment:fixed,fixed,fixed,fixed!important;background-position:0 0,100% 100%,50% 100%,50% 50%!important;background-size:auto,auto,auto,cover!important}:root[data-theme=light] body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;pointer-events:none;opacity:var(--grain-opacity);background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='60' height='60' viewBox='0 0 60 60'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/><feColorMatrix type='saturate' values='0'/><feComponentTransfer><feFuncA type='table' tableValues='0 0.5'/></feComponentTransfer></filter><rect width='100%%' height='100%%' filter='url(%23n)'/></svg>");background-size:180px 180px}:root[data-theme=light] body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;pointer-events:none;mix-blend-mode:multiply;opacity:var(--vignette-opacity);background:radial-gradient(120% 120% at 50% 10%,transparent 60%,rgba(0,0,0,.28) 100%)}:root{--lead-max: 62ch}h2+.section-lead,.nk-title+.section-lead{margin:.25rem auto 1.25rem;color:var(--warm-gray, #8b92b2);font-size:clamp(.95rem,.25vw + .9rem,1.05rem);line-height:1.6;max-width:var(--lead-max);text-wrap:balance;text-align:center}.card-like h2+.section-lead,.about-text h2+.section-lead{text-align:inherit;margin-left:0}.skills-circles{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:clamp(12px,2.5vw,20px);align-items:start;justify-items:center;max-width:1100px;margin:0 auto;padding:0 .5rem}.circle-skill{width:clamp(140px,28vw,180px);text-align:center;display:grid;place-items:center}.circle-skill svg{width:100%;height:auto;max-width:160px;aspect-ratio:1 / 1}.circle-skill p{margin-top:.5rem;font-weight:600}@media (max-width: 440px){.skills-circles{grid-template-columns:repeat(2,1fr)}.circle-skill{width:clamp(120px,40vw,160px)}}@media (max-width: 330px){.skills-circles{grid-template-columns:1fr}.circle-skill{width:90%}}.imp-dialog{max-height:90vh;display:flex;flex-direction:column}.imp-content{flex:1 1 auto;min-height:0;overflow:auto;-webkit-overflow-scrolling:touch}.imp-head,.imp-foot{flex:0 0 auto}.section.skills{--skill-size: clamp(120px, 20vw, 220px);--skill-gap: clamp(12px, 2.5vw, 24px);--ring-color: var(--glacier-blue);--ring-track: color-mix(in oklab, var(--glacier-blue), #000 30%);--ring-text: var(--font-color-dark, #fff)}.skills-circles{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(44%,var(--skill-size)),1fr));gap:var(--skill-gap);justify-items:center;align-items:start;max-width:1100px;margin:0 auto;padding-inline:clamp(4px,1.5vw,12px)}.circle-skill{width:min(100%,var(--skill-size));display:grid;grid-template-rows:auto min-content;justify-items:center;background:var(--glass-bg);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border, rgba(255,255,255,.12));border-radius:16px;padding:clamp(10px,1.8vw,16px);box-shadow:0 4px 16px #0000001f;transition:transform .18s ease,box-shadow .2s ease,background-color .2s ease,border-color .2s ease}.circle-outer{width:100%;aspect-ratio:1 / 1;display:grid;place-items:center}.circle-outer svg{width:100%;height:100%;display:block}.ring-track{stroke:var(--ring-track);opacity:.25}.ring-progress{stroke:var(--ring-color)}.ring-text{fill:var(--ring-text);font-weight:800;font-size:clamp(14px,1.8vw,18px);font-family:var(--font-headline, inherit)}.circle-label{margin:.55rem 0 .1rem;font-weight:700;font-size:clamp(.9rem,1.7vw,1rem);text-align:center;color:var(--font-color-dark, #fff);max-width:22ch;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.circle-outer.is-animating .ring-progress{transition:stroke-dashoffset .9s ease-out var(--delay, 0ms)}@media (max-width: 520px){.section.skills{--skill-size: clamp(120px, 42vw, 180px)}.skills-circles{grid-template-columns:repeat(auto-fit,minmax(min(60%,var(--skill-size)),1fr));gap:clamp(10px,3vw,16px)}}@media (max-width: 380px){.skills-circles{display:flex;gap:clamp(10px,3vw,16px);overflow-x:auto;padding-bottom:6px;scroll-snap-type:x mandatory}.circle-skill{flex:0 0 var(--skill-size);scroll-snap-align:start}}.skills{padding:4rem 1rem;max-width:1200px;margin:auto;text-align:center}.skills-circles{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:2rem;justify-items:center;margin-top:2.5rem}.circle-skill{display:flex;flex-direction:column;align-items:center;animation:fadeIn .6s ease both}.circle-label{margin-top:1rem;font-weight:600;color:var(--fg)}.circle-outer{width:160px;height:160px;position:relative;animation:fadeInUp .5s ease both;animation-delay:var(--delay, 0ms)}.ring-track{fill:none;stroke:var(--glass-border);stroke-width:10}.ring-progress{fill:none;stroke:var(--accent);stroke-width:10;stroke-linecap:round;transform:rotate(-90deg);transform-origin:center;transition:stroke-dashoffset 1s ease-out}.circle-outer.is-animating .ring-progress{stroke-dashoffset:var(--offset)}.ring-text{font-size:1.1rem;font-weight:700;fill:var(--fg);dominant-baseline:middle;text-anchor:middle}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.circle-outer{width:160px;height:160px;position:relative}.ring-track{stroke:var(--glass-border, rgba(255,255,255,.2))}.ring-progress{stroke:var(--glacier-blue)}.circle-outer.is-animating .ring-progress{transition:stroke-dashoffset .9s ease-out var(--delay, 0ms);stroke-dashoffset:var(--offset)}@media (prefers-reduced-motion: reduce){.circle-outer.is-animating .ring-progress{transition:none}}.skills-circles{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:2rem;justify-items:center}.circle-skill{display:flex;flex-direction:column;align-items:center}.circle-outer{width:160px;height:160px}.ring-track,.ring-progress{fill:none;stroke-linecap:round;stroke-width:12;transform:rotate(-90deg);transform-origin:80px 80px}.ring-track{stroke:var(--glass-border, rgba(255,255,255,.18))}.ring-progress{stroke:var(--glacier-blue, #f8b179)}.ring-text{fill:var(--font-color-dark, #fff);font-weight:800;font-size:1.05rem}.circle-skill{transition:transform .18s ease,box-shadow .25s ease}.circle-skill:hover{transform:translateY(-2px);box-shadow:0 10px 22px #0000002e}@media (prefers-reduced-motion: reduce){.circle-skill{transition:none}}html{hyphens:auto;-webkit-hyphens:auto;-ms-hyphens:auto;word-break:normal;overflow-wrap:anywhere}body,p,li,blockquote,figcaption,.card,.section{-webkit-hyphens:inherit;hyphens:inherit}.ring-text{font-family:Montserrat,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-weight:700;font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1,"lnum" 1;letter-spacing:.02em;text-rendering:geometricPrecision;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;fill:var(--fg, #fff)}.ring-track{stroke:#0000002e}:root:not([data-theme=light]) .ring-track{stroke:#ffffff38}:root[data-theme=light] .ring-track{stroke:#14182347}.ring-text{font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-weight:600;font-variant-numeric:tabular-nums;fill:var(--fg, #fff)}
