@import "https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;700&family=Playfair+Display:wght@700;800&display=swap";*{box-sizing:border-box}body{color:#111;background:#e4e4e4;min-height:100vh;margin:0;font-family:DM Sans,sans-serif}#root{min-height:100vh}h1{font-family:Playfair Display,serif;font-weight:700}.home-page{width:min(1280px,94%);min-height:100vh;margin:0 auto;padding:1.8rem 4.8rem 4rem;position:relative;overflow:hidden}.background-art{pointer-events:none;position:absolute;inset:0}.blob{filter:blur(34px);border-radius:50%;position:absolute}.blob-top{opacity:.95;background:radial-gradient(circle at 38% 42%,#5a7cf5 0%,#df4a64 67%);width:36rem;height:12.5rem;top:-3.2rem;right:-1.8rem}.blob-main{background:radial-gradient(circle at 38% 28%,#f1dfa4 0%,#f8a030 28%,#0000 49%),radial-gradient(circle at 35% 60%,#ae202c 0%,#d33f80 30%,#0000 53%),radial-gradient(circle at 73% 44%,#8f49f4 0%,#cd95fb 40%,#0000 69%);width:29rem;height:29rem;top:7.2rem;left:12rem}.blob-projects{background:radial-gradient(circle at 35% 35%,#d6baffcc 0%,#0000 34%),radial-gradient(circle at 50% 55%,#6f55f0 0%,#b364f7 37%,#e7536f 66%,#0000 86%);width:40rem;height:40rem;top:5.5rem;left:50%;transform:translate(-50%)}.nav{z-index:2;justify-content:space-between;align-items:center;display:flex;position:relative}.brand{align-items:center;gap:.8rem;display:flex}.brand-link{color:inherit;text-decoration:none}.brand-mark{letter-spacing:-.03em;border:2px solid #131313;place-items:center;width:2.25rem;height:2.25rem;font-size:.7rem;font-weight:700;display:grid}.name{margin:0;font-size:1.5rem;font-weight:700;line-height:1}.role{letter-spacing:.18em;margin:.2rem 0 0;font-size:.65rem}.menu{gap:3.4rem;display:flex}.menu a{color:#1a1a1a;font-size:1rem;text-decoration:none}.linkedin{color:#000;font-size:2.8rem;font-weight:700;text-decoration:none}.hero{z-index:1;max-width:52rem;margin-top:8rem;position:relative}.hero h1{letter-spacing:-.02em;margin:0;font-family:Playfair Display,serif;font-size:clamp(4rem,8.2vw,7rem);font-weight:700;line-height:.94}.hero p{letter-spacing:-.015em;max-width:47rem;margin:2rem 0 0;font-size:clamp(2rem,3.7vw,3.2rem);line-height:1.16}.projects-btn{color:#1c1c1c;letter-spacing:.04em;align-items:center;gap:1.3rem;margin-top:3rem;font-size:1.9rem;text-decoration:none;display:inline-flex}.projects-btn span{border:2px solid #111;border-radius:50%;place-items:center;width:5rem;height:5rem;font-size:2.1rem;display:grid}.home-projects{z-index:1;margin-top:6.3rem;gap:4.2rem;width:min(980px,100%);margin-inline:auto;padding-bottom:4rem;display:grid;position:relative}.home-project-row{grid-template-columns:1.05fr .95fr;align-items:center;gap:1.4rem;display:grid}.home-project-row img{width:100%;display:block}.home-project-row h3{max-width:18ch;margin:.45rem 0 .5rem;font-family:DM Sans,sans-serif;font-size:2.18rem;font-weight:500;line-height:1.16}.home-project-row .project-desc{max-width:47ch;font-size:.82rem;line-height:1.5}.home-project-row.reverse{grid-template-columns:1fr 1.1fr}.home-project-row.reverse img{order:2}.home-project-row.reverse div{padding-right:.8rem}.site-footer{z-index:2;margin-top:2rem;padding-bottom:1.3rem;position:relative}.footer-line{border-top:2px solid #111111d9;width:100%;margin-bottom:1rem}.footer-content{justify-content:space-between;align-items:center;gap:1rem;display:flex}.footer-content p{color:#141414e6;margin:0;font-size:.95rem}.footer-content a{color:#111}.footer-linkedin{font-size:2.8rem;font-weight:700;line-height:1;text-decoration:none}.projects-page{width:min(1040px,94%);min-height:100vh;margin:0 auto;padding:1.8rem 0 3.2rem;position:relative;overflow:visible}.case-page{width:min(980px,94%);min-height:100vh;margin:0 auto;padding:1.8rem 0 3rem;position:relative;overflow:hidden}.case-page .background-art{display:none}.projects-content{z-index:1;margin-top:1.5rem;position:relative}.projects-page .background-art{inset:-2rem -8rem -8rem}.projects-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:1.8rem 1rem;display:grid}.project-card{max-width:350px}.project-card-link{color:inherit;text-decoration:none;display:block}.project-thumb{aspect-ratio:16/10;border-radius:2px;width:100%;margin-bottom:.55rem}.project-thumb-image{aspect-ratio:1;object-fit:contain;background:#ffffff73;padding:.1rem;display:block}.thumb-one{background:linear-gradient(145deg,#f2d8c8,#bdc5d2 55%,#101826)}.thumb-two{background:linear-gradient(145deg,#dedede,#c2c2c2 35%,#e8f3dc)}.thumb-three{background:linear-gradient(145deg,#f5efe0,#dbcfac 40%,#8b9db6)}.thumb-four{background:linear-gradient(145deg,#f3d77c,#f7a2b8 45%,#9dc0f5)}.project-tag{letter-spacing:.12em;color:#1f1f1fcc;margin:0;font-size:.53rem}.project-card h3{margin:.32rem 0 .35rem;font-family:DM Sans,sans-serif;font-size:1.2rem;font-weight:500;line-height:1.24}.project-desc{color:#141414bf;max-width:44ch;margin:0;font-size:.72rem;line-height:1.45}.project-link{color:#201f22;margin-top:.36rem;font-size:.72rem;text-decoration:none;display:inline-block}.case-content{z-index:1;width:min(620px,100%);margin:2rem auto 0;position:relative}.case-kicker{text-align:center;letter-spacing:.12em;color:#141414b3;margin:0;font-size:.65rem}.case-title{text-align:center;margin:.25rem 0 1rem;font-family:DM Sans,sans-serif;font-size:2rem;font-weight:500;line-height:1.2}.case-hero-image{border-radius:2px;width:100%;display:block}.case-section{border-top:1px solid #00000024;margin-top:1.2rem;padding-top:1rem}.case-section h2{margin:0 0 .4rem;font-family:DM Sans,sans-serif;font-size:1rem;font-weight:500}.case-section p{color:#141414c7;margin:0;font-size:.85rem;line-height:1.55}.case-meta{border-top:1px solid #00000024;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;margin-top:1rem;padding-top:.85rem;display:grid}.case-meta h3{letter-spacing:.08em;text-transform:uppercase;color:#141414bd;margin:0;font-size:.65rem}.case-meta p{margin:.2rem 0 0;font-size:.8rem}.case-two-col{grid-template-columns:220px 1fr;gap:2rem;margin-top:1.6rem;display:grid}.case-label{color:#7d3cad;letter-spacing:.06em;margin:0 0 .5rem;font-size:.8rem}.case-label-col h3{margin:0;font-family:DM Sans,sans-serif;font-size:1.95rem;font-weight:500;line-height:1.2}.case-text-col p{color:#141414d1;margin:0;font-size:.98rem;line-height:1.65}.case-text-col p+p{margin-top:.8rem}.case-process{margin-top:2.1rem}.case-process h2{margin:0 0 1rem;font-family:DM Sans,sans-serif;font-size:2rem;font-weight:500}.process-steps{grid-template-columns:repeat(5,minmax(0,1fr));gap:.8rem;display:grid}.process-step{text-align:center}.process-step span{color:#fff;border-radius:50%;place-items:center;width:56px;height:56px;margin:0 auto .35rem;font-size:1rem;font-weight:600;display:grid}.process-step:first-child span{background:#3eaf7b}.process-step:nth-child(2) span{background:#3f80a9}.process-step:nth-child(3) span{background:#8d56b5}.process-step:nth-child(4) span{background:#b88421}.process-step:nth-child(5) span{background:#bb4639}.process-step p{color:#141414cc;margin:0;font-size:.8rem}.wireframes-section{margin-top:2.4rem}.wireframes-header{justify-content:space-between;align-items:center;gap:1rem;display:flex}.wireframes-header h2{margin:0;font-family:DM Sans,sans-serif;font-size:1.35rem;font-weight:500}.wireframes-chip{color:#fff;letter-spacing:.04em;background:#111;border-radius:999px;padding:.3rem .75rem;font-size:.62rem}.wireframes-copy{color:#141414c7;margin:.45rem 0 0;font-size:.78rem}.wireframes-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:.45rem;margin-top:.8rem;display:grid}.simplepark-wireframe-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:.6rem;margin-top:.8rem;display:grid}.simplepark-wireframe-grid img{cursor:pointer;border-radius:10px;width:100%;display:block}.wireframe-card{aspect-ratio:3/5.8;background:linear-gradient(#f7e2bb 0%,#f8b577 100%);border:1px solid #0000001f;border-radius:8px}.wireframe-card:nth-child(2n){background:linear-gradient(#f7f3e8 0%,#ffb18c 100%)}.wireframe-card:nth-child(5),.wireframe-card:nth-child(9){background:linear-gradient(#cfe3ff 0%,#a8c6f2 100%)}.openremote-wireframes{margin-top:1.9rem}.openremote-wireframes .wireframes-header h2{color:#7d3cad;letter-spacing:.06em;text-transform:uppercase;margin:0;font-size:.8rem;font-weight:500}.openremote-wireframe-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:.8rem;margin-top:.85rem;display:grid}.openremote-wireframe-grid img{cursor:pointer;border-radius:10px;width:100%;display:block}.citric-wireframes{margin-top:1.9rem}.citric-wireframes .wireframes-header h2{color:#7d3cad;letter-spacing:.06em;text-transform:uppercase;margin:0;font-size:.8rem;font-weight:500}.citric-wireframe-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:.8rem;margin-top:.85rem;display:grid}.citric-wireframe-grid img{cursor:pointer;border-radius:10px;width:100%;display:block}.lightbox{z-index:9999;background:#000c;place-items:center;padding:1.5rem;display:grid;position:fixed;inset:0}.lightbox-image{border-radius:10px;max-width:min(1100px,95vw);max-height:90vh}.lightbox-close{color:#fff;cursor:pointer;background:#fff3;border:0;border-radius:999px;width:2.2rem;height:2.2rem;font-size:1.5rem;line-height:1;position:absolute;top:1rem;right:1rem}.usability-section{margin-top:2.1rem}.usability-section h2{margin:0;font-family:DM Sans,sans-serif;font-size:1.75rem;font-weight:500}.results-section{margin-top:2.2rem}.results-section h2{margin:0 0 .9rem;font-family:DM Sans,sans-serif;font-size:1.7rem;font-weight:500}.results-row{grid-template-columns:130px 130px 1fr;align-items:center;gap:1.1rem;display:grid}.result-circle{text-align:center;color:#111;background:#f27f56;border-radius:50%;place-content:center;width:130px;height:130px;display:grid}.result-circle strong{font-size:1.35rem}.result-circle span{font-size:.63rem}.results-note{color:#141414c7;margin:0;font-size:.79rem;line-height:1.5}.feedback-section{margin-top:1.8rem}.feedback-section h2{margin:0 0 .8rem;font-family:DM Sans,sans-serif;font-size:1.45rem;font-weight:500}.feedback-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;display:grid}.feedback-grid blockquote{color:#141414d1;margin:0;font-size:.77rem;line-height:1.55}.feedback-grid span{margin-bottom:.25rem;font-size:2rem;line-height:1;display:block}@media (width<=960px){.home-page{width:94%;padding:1.2rem 1.4rem 2.2rem}.nav{grid-template-columns:1fr auto;align-items:start;gap:.5rem .8rem;display:grid}.menu{flex-wrap:wrap;grid-column:1/-1;gap:1rem;display:flex}.menu a{font-size:.9rem}.name{font-size:1.05rem}.linkedin{font-size:1.9rem}.hero{margin-top:5.4rem}.hero p{margin-top:1.4rem}.projects-btn{margin-top:2rem;font-size:1.2rem}.projects-btn span{width:3.9rem;height:3.9rem;font-size:1.5rem}.home-projects{gap:2.2rem;margin-top:3rem}.home-project-row,.home-project-row.reverse{grid-template-columns:1fr;gap:.8rem}.home-project-row.reverse img{order:0}.home-project-row h3{max-width:100%;font-size:1.45rem}.footer-content p{font-size:.82rem}.footer-linkedin{font-size:2rem}.blob-main{width:21rem;height:21rem;top:11rem;left:2rem}.blob-projects{width:24rem;height:24rem;top:11rem}.projects-page,.case-page{width:94%;padding:1.2rem 0 2rem}.projects-grid{grid-template-columns:1fr;gap:1.4rem}.project-card{max-width:100%}.case-meta,.case-two-col{grid-template-columns:1fr;gap:.7rem}.case-label-col h3{font-size:1.45rem}.process-steps,.wireframes-grid,.simplepark-wireframe-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.openremote-wireframe-grid,.citric-wireframe-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.results-row{grid-template-columns:1fr;gap:.8rem}.result-circle{margin:0 auto}.feedback-grid{grid-template-columns:1fr}}.about-page{width:min(930px,92%);min-height:100vh;margin:0 auto;padding:1.6rem 0 2.4rem}.about-page .nav{margin-bottom:1.2rem}.about-hero{grid-template-columns:1fr 320px;align-items:center;gap:2rem;margin-bottom:1.5rem;padding-bottom:.9rem;display:grid}.intro-copy h1{letter-spacing:-.02em;max-width:16ch;margin:0;font-family:DM Sans,sans-serif;font-size:clamp(1.55rem,2.6vw,2.25rem);font-weight:500;line-height:1.25}.profile-wrap img{object-fit:cover;border-radius:50%;width:320px;height:320px;display:block}.about-body{gap:2rem;display:grid}.about-grid{grid-template-columns:82px 1fr;gap:2rem;display:grid}.label{letter-spacing:.01em;color:#2f2f2f;text-align:right;margin:0;font-size:.96rem;line-height:1.1}.bio-text{color:#222;text-align:left;max-width:78ch;margin-left:0;font-size:.97rem;line-height:1.58}.bio-text p{margin:0}.bio-text p+p{margin-top:.8rem}.skills-grid{align-items:start}.skills-columns{text-align:left;grid-template-columns:1.25fr .75fr;column-gap:4rem;display:grid}.tools-column{text-align:right}.skills-columns p{margin:0 0 .3rem;font-size:.95rem;line-height:1.45}.sub-label{letter-spacing:.03em;margin-bottom:.16rem!important;font-size:.95rem!important}.edu-list{text-align:left;gap:0;display:grid}.edu-row{grid-template-columns:1fr auto;align-items:center;gap:1rem;padding:.75rem 0;display:grid}.edu-row+.edu-row{border-top:1px solid #ececec}.edu-row p{margin:0;font-size:.93rem}.edu-row span{color:#666;white-space:nowrap;text-align:right;font-size:.9rem}.resume-btn{color:#fff;letter-spacing:.04em;background:#0f0f0f;border-radius:999px;width:fit-content;margin-top:.1rem;padding:.7rem 1.4rem;font-size:.72rem;text-decoration:none}@media (width<=900px){.about-page{width:min(640px,92%);padding-top:1.2rem}.about-hero{grid-template-columns:1fr;gap:1.2rem}.profile-wrap img{width:220px;height:220px}.about-grid{grid-template-columns:1fr;gap:.6rem}.bio-text,.skills-columns p,.edu-row p,.edu-row span{font-size:.88rem}.label{font-size:.72rem}.skills-columns{grid-template-columns:1fr;row-gap:.7rem}.edu-row{grid-template-columns:1fr;gap:.2rem}.edu-row span{white-space:normal}}@media (width<=1200px){.home-page{padding:1.4rem 2.4rem 2.6rem}.hero{max-width:44rem;margin-top:5.5rem}.menu{gap:2.2rem}.menu a{font-size:.9rem}.name{font-size:1.2rem}.linkedin{font-size:2.1rem}}@media (width<=768px){.home-page,.projects-page,.about-page{width:92%;padding:1rem 0 1.8rem}.home-page{padding-inline:.4rem}.nav{gap:.8rem}.menu{gap:.75rem}.menu a{font-size:.82rem}.brand{gap:.5rem}.brand-mark{width:1.8rem;height:1.8rem;font-size:.58rem}.name{font-size:.92rem}.role{letter-spacing:.12em;font-size:.5rem}.linkedin{font-size:1.4rem}.hero{max-width:100%;margin-top:3rem}.hero h1{font-size:clamp(2.5rem,11vw,4rem)}.hero p{font-size:clamp(1.15rem,5.1vw,1.8rem);line-height:1.25}.projects-btn{gap:.7rem;font-size:1rem}.projects-btn span{width:3.2rem;height:3.2rem;font-size:1.25rem}.about-hero{grid-template-columns:1fr;gap:1.1rem}.intro-copy h1{max-width:100%;font-size:clamp(1.8rem,8vw,2.5rem)}.profile-wrap img{width:220px;height:220px}.about-grid{grid-template-columns:1fr;gap:.6rem}.skills-columns{grid-template-columns:1fr;row-gap:.7rem}.edu-row{grid-template-columns:1fr;gap:.2rem}.edu-row span{white-space:normal}.projects-grid{grid-template-columns:1fr;gap:1.2rem}.project-card{max-width:100%}.blob-main,.blob-projects{width:18rem;height:18rem}}
