@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,100..1000;1,9..40,100..1000&family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&display=swap";*{box-sizing:border-box}:root{font-family:Inter,sans-serif;line-height:1.5;font-weight:400;font-optical-sizing:auto;font-style:normal;color-scheme:light dark;color:#ffffffde;background:#0047ab;background:-webkit-gradient(linear,left top,left bottom,from(#1ca9c9),to(#0047ab)) no-repeat;background:linear-gradient(180deg,#1ca9c9,#0047ab) no-repeat;background-size:cover;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;min-width:320px;min-height:100vh;color:#fff}h1,.heading-1{font-family:DM Sans,sans-serif;font-size:3.2rem;line-height:3.6rem;font-weight:900}h2,.heading-2{font-family:DM Sans,sans-serif;font-size:2.6rem;line-height:3rem;font-weight:900}h3,.heading-3{font-family:DM Sans,sans-serif;font-size:2.2rem;line-height:2.6rem;font-weight:900}h4,.heading-4{font-family:DM Sans,sans-serif;font-size:1.8rem;line-height:2.2rem;font-weight:900}h5,.heading-5{font-family:DM Sans,sans-serif;font-size:1.4rem;line-height:1.8rem;font-weight:900}h6,.heading-6{font-family:DM Sans,sans-serif;font-size:1.2rem;line-height:1.6rem;font-weight:900}p{font-size:1rem;line-height:1.4rem;font-weight:400;margin:0 0 1.125rem}ul.no-styling{list-style:none;margin:0;padding:0}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#cdc871}button{background-color:#f9f9f9}}.font-300{font-weight:300}.font-400{font-weight:400}.font-500{font-weight:500}.font-600{font-weight:600}.font-700{font-weight:700}.font-800{font-weight:800}.font-900{font-weight:900}.fade-mask{width:100%;height:400px;object-fit:cover;object-position:top;mask-image:linear-gradient(to bottom,black 60%,transparent 100%);-webkit-mask-image:linear-gradient(to bottom,black 60%,transparent 100%)}.title-separate{width:100%;max-width:80px;margin:0 0 20px;border-bottom:1px solid #fff}header img.logo-main{width:75px}header{display:flex;justify-content:center;align-items:center}header .logo-heading{font-family:DM Sans,sans-serif;font-size:30px;font-weight:600;padding:0 8px}footer a{color:#fff;text-decoration:none}footer a:hover{color:#fff;text-decoration:underline}footer .links{font-size:40px;margin-bottom:30px}footer span{padding:0 10px}.intro-section,.projects-section,.skills-section{margin-block:80px}.narrow-row{max-width:768px;margin:20px auto 0}.intro-section{margin-top:0}.intro-section .narrow-row{margin-top:40px}section .hero-section img{max-width:400px}.fader-stage{position:relative;height:100%;overflow:hidden;font-size:2em;display:flex;justify-content:center;align-items:center;height:258px}.fader-slide{width:100%;max-width:300px;position:absolute;top:14%;left:0;right:0;margin:0 auto;opacity:0;animation:fade-in-out 15s infinite}.fader-slide i{font-size:4em}@keyframes fade-in-out{0%,to{opacity:0}10%{opacity:1}40%{opacity:0}}.fader-slide--1{animation-delay:0s}.fader-slide--2{animation-delay:3s}.fader-slide--3{animation-delay:6s}.fader-slide--4{animation-delay:9s}.fader-slide--5{animation-delay:12s}.projects-section .flex-container{display:flex;flex-wrap:wrap;gap:1rem}.projects-section .flex-container .column-two{width:100%;padding:1rem}.projects-section article{text-align:left}.projects-section .skills{margin-bottom:50px}@media(min-width:768px){.projects-section .flex-container .column-two{width:calc(50% - .5rem)}}.cards{display:flex;flex-wrap:wrap;gap:2rem;align-items:stretch;margin-bottom:80px}.card{flex:1 1 calc(50% - 2rem);display:grid;row-gap:.25rem;grid-template-rows:400px auto 1fr auto;margin-bottom:40px}@media(max-width:768px){.card{flex:1 1 100%}}.card-image-wrapper{position:relative;cursor:pointer;overflow:hidden;border-radius:8px;--mouse-x: 50%;--mouse-y: 50%;will-change:transform}.card-image{width:100%;height:400px;object-fit:cover;object-position:top;-webkit-mask-image:linear-gradient(to bottom,#000 75%,#0000);mask-image:linear-gradient(to bottom,#000 75%,#0000);display:block;cursor:pointer;transition:transform .55s cubic-bezier(.22,1,.36,1)}.image-overlay{position:absolute;inset:0;display:flex;justify-content:center;align-items:center;background:#00000047;color:#fff;font-weight:700;letter-spacing:.3px;opacity:0;transition:opacity .3s ease}.image-overlay span{display:inline-block;background-color:#0047ab;padding:.5rem .625rem;border-radius:.5rem}.card-image-wrapper:hover{transform:translateY(-6px);box-shadow:0 12px 30px #0000002e}.card-image-wrapper:hover .image-overlay{opacity:1}.card-image-wrapper:hover .card-image{transform:scale(1.06)}.image-light{position:absolute;inset:0;pointer-events:none;background:radial-gradient(400px circle at var(--mouse-x) var(--mouse-y),rgba(255,255,255,.18),transparent 40%);opacity:0;transition:opacity .3s ease}.card-image-wrapper:hover .image-light{opacity:1}.card-title{padding:1rem 1rem 0;margin:0;height:100%}.card-content{width:100%;max-width:400px;margin:0 auto;padding:1rem 1rem 0}.card-content p{font-size:20px}.card-content .skills-tags{font-size:14px;font-weight:500}.card-button{font-weight:700;letter-spacing:.3px;padding:.5rem 1.25rem;margin:0;color:#fff;cursor:pointer;justify-self:center}.card-button:hover{color:#b8b4b4}.modal-overlay{position:fixed;inset:0;background:#000000bf;overflow-y:auto;display:flex;justify-content:center;align-items:flex-start;padding:3rem 1rem;z-index:999;animation:fadeIn .25s ease}.modal-content{position:relative;max-width:56.25rem;width:100%;padding-right:2.8rem}.modal-content img{width:100%;height:auto;display:block;border:1px solid #efefef;border-radius:8px}.modal-close{position:absolute;top:0;right:0;background:#fff9;color:#000;border:none;font-size:2rem;line-height:1;padding:.125rem .625rem .5rem;cursor:pointer;border-radius:4px;transition:background .2s ease;opacity:0;animation:fadeIn .3s ease forwards;animation-delay:.1s}.modal-close:hover{background:#ffffffd9;color:#1a1a1a}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.skills{padding:80px 20px;background:transparent;color:#fff;font-family:sans-serif}.skills-container{max-width:1100px;margin:0 auto}.skills-header{text-align:center;max-width:700px;margin:0 auto 60px}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}.skill-card{border:1px solid #1ca9c9;border-radius:14px;padding:28px;transition:transform .25s ease,box-shadow .25s ease;background:#0006}.skill-card:hover{transform:translateY(-4px);box-shadow:0 10px 24px #00000014}.skill-card h3{margin-bottom:12px}.skill-description{font-size:.9rem;color:#fff;margin-bottom:18px;line-height:1.5}.skill-tags{display:flex;flex-wrap:wrap;gap:8px}.skill-tag.core{background:#61dafb;color:#111;font-weight:600}.skill-tag.wordpress{background:#21759b;color:#fff;font-weight:600}.skill-tag{background:#f3f3f3;color:#333;padding:6px 12px;border-radius:20px;font-size:.85rem}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}
