.hero-section{background:#7ebaee;align-items:center;width:100%;height:450px;max-height:450px;margin:0;padding:0;transition:background .4s ease-in-out;display:flex;position:relative;overflow:hidden}.dark .hero-section{background:#041825;transition:background .4s ease-in-out}.hero-content{z-index:2;max-width:520px;padding-left:60px;position:relative}.hero-text{flex-direction:column;gap:18px;display:flex}.hero-title{color:#fff;letter-spacing:-.02em;white-space:nowrap;min-height:79px;margin:0;font-family:Google Sans,sans-serif;font-size:72px;font-weight:400;line-height:1.1}.hero-name{color:#fff39c;font-family:Google Sans,sans-serif;font-weight:700;transition:color .4s ease-in-out}.dark .hero-name{color:#fff39c}.hero-subtitle{color:#fff;white-space:pre-line;min-height:70px;margin:0;font-family:Google Sans,sans-serif;font-size:27px;font-weight:400;line-height:1.3}.hero-role{font-weight:700}.typing-cursor{vertical-align:baseline;margin-left:2px;font-size:27px;font-weight:400;line-height:1.3;animation:.7s infinite blink;display:inline-block}.hero-social-links{gap:18px;margin-top:6px;display:flex}.hero-social-links a{opacity:0;justify-content:center;align-items:center;width:36px;height:36px;transition:transform .2s;display:flex;transform:scale(.5)}.hero-social-links.show-social .social-icon-1{animation:.4s cubic-bezier(.34,1.56,.64,1) forwards bubbleIn}.hero-social-links.show-social .social-icon-2{animation:.4s cubic-bezier(.34,1.56,.64,1) .15s forwards bubbleIn}.hero-social-links.show-social .social-icon-3{animation:.4s cubic-bezier(.34,1.56,.64,1) .3s forwards bubbleIn}.hero-social-links a:hover{transform:scale(1.1)}.hero-social-links img{-o-object-fit:contain;object-fit:contain;width:100%;height:100%}.hero-pattern-container{z-index:0;pointer-events:none;height:100%;position:absolute;top:0;left:0;right:0;overflow:hidden}.hero-pattern{-o-object-fit:cover;object-fit:cover;-o-object-position:right center;object-position:right center;width:100%;height:100%;transition:opacity .5s ease-in-out;display:block;position:absolute;top:0;left:0;right:0}.hero-pattern.visible{opacity:1}.hero-pattern.hidden{opacity:0;pointer-events:none}.hero-image-container{z-index:1;pointer-events:none;justify-content:flex-end;align-items:flex-end;height:100%;display:flex;position:absolute;bottom:0;left:0;right:0}.hero-image{-o-object-fit:contain;object-fit:contain;-o-object-position:bottom right;object-position:bottom right;width:auto;height:100%;transition:opacity .5s ease-in-out;position:absolute;bottom:0;right:0}.hero-image.visible{opacity:1}.hero-image.hidden{opacity:0;pointer-events:none}.peace-patrick-container{z-index:3;pointer-events:none;margin-left:-100px;position:absolute;left:50%}.peace-patrick-image{width:200px;height:auto;display:block}@media (max-width:1400px){.hero-content{padding-left:48px}.hero-title{font-size:64px}.hero-subtitle{font-size:24px}.peace-patrick-image{width:180px}.peace-patrick-container{margin-left:-90px}}@media (max-width:1200px){.hero-content{max-width:450px;padding-left:36px}.hero-title{font-size:56px}.hero-subtitle{font-size:22px}.hero-social-links a{width:32px;height:32px}.peace-patrick-image{width:160px}.peace-patrick-container{margin-left:-80px}}@media (max-width:992px){.hero-section{height:380px}.hero-content{max-width:380px;padding-left:28px}.hero-title{font-size:48px}.hero-subtitle{font-size:20px}.peace-patrick-image{width:140px}.peace-patrick-container{margin-left:-70px}}@media (max-width:768px){.hero-section{align-items:flex-start;height:500px}.hero-content{max-width:100%;padding-top:80px;padding-left:32px}.hero-title{font-size:56px}.hero-subtitle{font-size:24px}.hero-text{gap:14px}.hero-social-links{gap:16px;margin-top:6px}.hero-social-links a{width:40px;height:40px}.hero-pattern{width:100%;min-width:100%}.hero-image-container{height:58%;inset:auto 0 0}.hero-image{height:100%;right:20px}.peace-patrick-container{margin-left:0;top:164px;left:auto;right:auto;transform:translateY(-50%)}.peace-patrick-image{width:132px}}@media (max-width:576px){.hero-section{align-items:flex-start;height:450px}.hero-content{max-width:100%;padding-top:72px;padding-left:24px;padding-right:24px}.hero-title{font-size:48px}.hero-subtitle{font-size:20px}.hero-text{gap:12px}.hero-social-links{gap:14px;margin-top:4px}.hero-social-links a{width:36px;height:36px}.hero-pattern{width:100%;min-width:100%}.hero-image-container{height:54%;bottom:0;left:0;right:0}.hero-image{right:10px}.peace-patrick-container{top:160px}}@media (max-width:400px){.hero-section{align-items:flex-start;height:420px}.hero-content{max-width:100%;padding-top:68px;padding-left:20px;padding-right:20px}.hero-title{font-size:42px}.hero-subtitle{font-size:18px}.hero-text{gap:10px}.hero-social-links{gap:12px;margin-top:4px}.hero-social-links a{width:32px;height:32px}.hero-pattern{width:105%;min-width:105%;right:0}.hero-image-container{height:52%;bottom:0;left:0;right:0}.hero-image{right:10px}.peace-patrick-container{top:156px}}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}@keyframes bubbleIn{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}
.project-page-section{background-color:#e7f4ff;align-items:center;width:100%;padding:100px 0;transition:background-color .4s ease-in-out;display:flex}.dark .project-page-section{background-color:#041825}.project-category-controls{-moz-column-gap:36px;flex-wrap:wrap;justify-content:center;align-items:center;gap:12px 36px;padding:2px 20px 4px;display:flex}.project-category-controls-sticky{z-index:900;background-color:#e7f4ff;grid-template-columns:repeat(2,minmax(0,1fr));justify-items:center;width:100%;padding:26px 0 0;transition:opacity .1s ease-out,transform .1s ease-out;display:grid;position:fixed;top:0;left:0}.dark .project-category-controls-sticky{background-color:#041825}.project-category-tab{appearance:none;color:#56606a;cursor:pointer;background:0 0;border:0;margin:0;padding:0 0 12px;font-family:Google Sans,sans-serif;font-size:18px;font-weight:400;line-height:1.25;transition:color .2s,opacity .2s;position:relative}.project-category-controls-sticky .project-category-tab{text-align:center;justify-content:center;justify-self:center;width:fit-content;font-size:22px;display:inline-flex}.dark .project-category-tab{color:#afc2d0}.project-category-tab:after{content:"";transform-origin:50%;background:#7ebaee;border-radius:999px;width:100%;height:3px;transition:transform .34s cubic-bezier(.2,.8,.2,1);position:absolute;bottom:0;left:0;transform:scaleX(0)}.dark .project-category-tab:after{background:#224c66}.project-category-tab.active:after{transform:scaleX(1)}.project-category-tab.active{color:#07111a;opacity:1;font-weight:500}.dark .project-category-tab.active{color:#fff}.project-category-tab:hover,.project-category-tab:focus-visible{opacity:.72}.project-category-tab.active:hover,.project-category-tab.active:focus-visible{opacity:1}.project-category-tab:focus-visible{outline-offset:6px;outline:2px solid #7ebaee}.dark .project-category-tab:focus-visible{outline-color:#fff}.project-container{align-items:center;gap:120px;width:100%;max-width:1400px;margin:0 auto;padding:0 100px;display:flex}.project-left{flex-direction:column;flex:1;display:flex}.project-media-link{color:inherit;cursor:pointer;text-decoration:none;display:block}.project-media-link:focus-visible{outline-offset:8px;outline:2px solid #7ebaee}.dark .project-media-link:focus-visible{outline-color:#fff}.project-number{color:#1a1a1a;letter-spacing:-.01em;align-items:flex-start;gap:20px;margin-bottom:80px;font-size:64px;font-weight:400;transition:color .4s ease-in-out;display:flex}.project-heading-text{flex-direction:column;gap:0;min-width:0;display:flex}.dark .project-number{color:#fff}.project-number strong{min-width:0;font-weight:700}.project-title-link{color:inherit;text-decoration:none}.project-title-link:focus-visible{outline-offset:6px;outline:2px solid #7ebaee}.dark .project-title-link:focus-visible{outline-color:#fff}.project-heading-meta{flex-direction:column;gap:3px;max-width:100%;display:flex}.project-heading-role,.project-heading-year{letter-spacing:0;font-family:Google Sans,sans-serif;font-weight:400;transition:color .4s ease-in-out}.project-heading-role{color:#53616c;font-size:20px;line-height:1.3}.project-heading-year{color:#697681;white-space:nowrap;font-size:18px;line-height:1.2}.dark .project-heading-role{color:#d5e0e8}.dark .project-heading-year{color:#afc2d0}.project-laptop-container{width:100%;max-width:600px;position:relative}.laptop-frame{width:100%;height:auto;display:block;position:relative}.laptop-screen{z-index:1;border-radius:3px;width:71.6%;height:75.5%;position:absolute;top:5.8%;left:14.2%;overflow:hidden}.project-screenshot{-o-object-fit:cover;object-fit:cover;width:100%;height:100%}.project-design-system-hero{width:100%;height:auto;display:block}.project-right{flex-direction:column;flex:1;gap:20px;max-width:500px;display:flex}.project-subtitle{color:#1a1a1a;margin:0 0 8px;font-size:40px;font-weight:700;line-height:1.2;transition:color .4s ease-in-out}.dark .project-subtitle{color:#fff}.project-description{color:#1a1a1a;margin:0 0 12px;font-size:20px;font-weight:400;line-height:1.5;transition:color .4s ease-in-out}.dark .project-description{color:#fff}.project-tech-stack{color:#1a1a1a;margin:0 0 24px;font-size:20px;font-weight:700;transition:color .4s ease-in-out}.dark .project-tech-stack{color:#fff}.project-button{color:#1a1a1a;cursor:pointer;letter-spacing:1px;background-color:#0000;border:2px solid #1a1a1a;border-radius:4px;justify-content:center;align-items:center;gap:16px;width:fit-content;padding:14px 32px;font-size:14px;font-weight:700;text-decoration:none;transition:all .4s ease-in-out;display:inline-flex}.dark .project-button{color:#fff;border-color:#fff}.project-button:hover{color:#fff;background-color:#1a1a1a;transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.project-button-placeholder,.project-button-placeholder:hover{cursor:default;transform:none}.dark .project-button:hover{color:#1a1a1a;background-color:#fff;box-shadow:0 4px 12px #ffffff26}.project-button:hover .button-arrow{filter:brightness(0)invert()}.dark .project-button:hover .button-arrow{filter:brightness(0)invert(0)}.button-arrow{width:18px;height:18px;transition:opacity .4s ease-in-out,filter .3s}.button-arrow.visible{opacity:1}.button-arrow.hidden{opacity:0;pointer-events:none}.video-container{justify-content:center;align-items:center;width:100%;height:100%;margin-top:-17%;margin-left:-2.7%;display:flex;position:relative}.video-container video{-o-object-fit:fill;object-fit:fill;border-radius:3px;width:92%;height:60%}.device-container{justify-content:center;align-items:center;width:100%;display:flex;position:relative}.device-container.device-ipad{max-width:660px;margin:0 auto}.device-container.device-iphone{max-width:275px;margin:0 auto}.device-container.device-mmc{max-width:700px;margin:0 auto}.device-container.device-apple-display{max-width:750px;margin:0 auto}.device-frame{width:100%;height:auto;display:block;position:relative}.device-screen{z-index:1;position:absolute;overflow:hidden}.device-screen-ipad{border-radius:4px;width:85%;height:87%;top:6.5%;left:7.5%}.device-screen-iphone{border-radius:8px;width:88%;height:93%;top:3.5%;left:6%}.device-screen-mmc{border-radius:2px;width:94%;height:94%;top:3%;left:3%}.device-screen-apple-display{border-radius:3px;width:100%;height:70%;top:3.5%}@media (max-width:1200px){.project-container{gap:100px;padding:0 80px}.project-number{margin-bottom:60px;font-size:56px}.project-heading-role{font-size:19px}.project-heading-year{font-size:18px}.project-subtitle{font-size:36px}.project-description,.project-tech-stack{font-size:18px}}@media (max-width:992px){.project-container{flex-direction:column;gap:60px;padding:80px 60px}.project-number{margin-bottom:40px;font-size:48px}.project-heading-text{gap:0}.project-heading-role{font-size:18px}.project-heading-year{font-size:17px}.project-subtitle{font-size:32px}.project-description,.project-tech-stack{font-size:16px}}@media (max-width:768px){.project-page-section{padding:20px 0}.project-category-controls-sticky{padding:calc(max(20px, env(safe-area-inset-top)) + 2px) 0 0}.project-category-controls-sticky .project-category-tab{width:100%;font-size:18px}.project-container{gap:12px;padding:44px 40px}.project-media-link{line-height:0}.project-number{margin-bottom:20px;font-size:40px}.project-heading-text{gap:0}.project-heading-meta{gap:2px}.project-heading-role{font-size:17px;line-height:1.28}.project-heading-year{font-size:16px}.project-subtitle{margin-bottom:4px;font-size:28px}.project-right{gap:14px}.project-description{margin-bottom:6px}.project-tech-stack{margin-bottom:10px}.project-button{padding:12px 28px;font-size:13px}}@media (max-width:576px){.project-page-section{padding:24px 0}.project-category-controls{-moz-column-gap:24px;column-gap:24px}.project-category-controls-sticky .project-category-tab{font-size:15px}.project-container{gap:6px;padding:28px 24px}.project-number{margin-bottom:16px;font-size:32px}.project-heading-text{gap:0}.project-heading-role{font-size:15px}.project-heading-year{font-size:14px}.project-subtitle{margin-bottom:2px;font-size:24px}.project-description{margin-bottom:4px;font-size:14px;line-height:1.45}.project-tech-stack{margin-bottom:8px;font-size:14px}.project-button{padding:11px 24px}}
.bubble-in-container{opacity:0;transition:opacity .6s ease-out,transform .6s cubic-bezier(.34,1.56,.64,1);transform:scale(.8)}.bubble-in-container.bubble-in-visible{opacity:1;transform:scale(1)}

