@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-border-style:solid}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--color-indigo-500:oklch(58.5% .233 277.117);--color-gray-200:oklch(92.8% .006 264.531);--color-gray-600:oklch(44.6% .03 256.802);--color-gray-900:oklch(21% .034 264.665);--color-black:#000;--color-white:#fff;--spacing:.25rem;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.relative{position:relative}.container{width:100%}@media(min-width:40rem){.container{max-width:40rem}}@media(min-width:48rem){.container{max-width:48rem}}@media(min-width:64rem){.container{max-width:64rem}}@media(min-width:80rem){.container{max-width:80rem}}@media(min-width:96rem){.container{max-width:96rem}}.h-8\.5{height:calc(var(--spacing)*8.5)}.w-8\.5{width:calc(var(--spacing)*8.5)}.cursor-pointer{cursor:pointer}.rounded-full{border-radius:3.40282e38px}.border{border-style:var(--tw-border-style);border-width:1px}.border-indigo-500\/15{border-color:#625fff26}@supports (color:color-mix(in lab,red,red)){.border-indigo-500\/15{border-color:color-mix(in oklab,var(--color-indigo-500)15%,transparent)}}.border-white\/15{border-color:#ffffff26}@supports (color:color-mix(in lab,red,red)){.border-white\/15{border-color:color-mix(in oklab,var(--color-white)15%,transparent)}}.p-1\.5{padding:calc(var(--spacing)*1.5)}.text-gray-200{color:var(--color-gray-200)}.text-gray-600{color:var(--color-gray-600)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,visibility,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.dark\:bg-gray-900:where(.dark,.dark *){background-color:var(--color-gray-900)}}@font-face{font-family:GothicFont;src:url(/assets/GothicFont-D6a4LfHd.otf)format("opentype");font-weight:500}@keyframes blink{0%,50%,to{opacity:1}25%,75%{opacity:0}}html,body,div,section,header,footer,main{transition:background-color .5s,color .5s}.animate-blink{animation:1s step-end infinite blink}.panel{width:100%;height:100vh}*{font-family:GothicFont,sans-serif}body{background-color:var(--color-white);color:var(--color-black)}.dark body{color:var(--color-white)}html{scroll-behavior:smooth}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}.theme-toggle-btn{background:transparent;border:none}.theme-toggle-icon{width:2.125rem;height:2.125rem;padding:.375rem;border:1px solid #6b7280;border-radius:999px;cursor:pointer}.navbar{display:flex;justify-content:space-between;align-items:center;padding:1rem;position:sticky;top:0;z-index:50;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);font-weight:500;background:#fff}.navbar-title{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:1.125rem;font-weight:500;color:#000}.navbar-links{color:#374151;display:flex;gap:1.25rem}.navbar-link{position:relative;color:#000;transition:color .3s}.navbar-link:hover{color:#ec4899}.navbar-link:after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background:#ec4899;transition:width .3s}.navbar-link:hover:after{width:100%}.navbar-divider,.sidebar-close{display:none}.navbar-actions{display:flex;align-items:center;gap:.5rem}.menu-icon{width:2rem;cursor:pointer}.navbar-contact-btn{display:none;align-items:center;gap:.5rem;background:#db2777;font-weight:800;color:#fff;padding:.5rem 1.5rem;border-radius:.5rem;cursor:pointer;transition:.3s;border:none}.navbar-contact-btn:hover{transform:scale(1.03);box-shadow:0 10px 15px #f472b680}.contact-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:50;display:flex;align-items:center;justify-content:center;padding:1rem}.contact-modal{background:#1f2937;border-radius:.75rem;box-shadow:0 20px 25px #00000040;width:100%;max-width:28rem;padding:1.5rem}.contact-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.contact-modal-header h1{font-size:1.5rem;font-weight:700;color:#d1d5db}.contact-modal-header button{background:none;border:none}.contact-close-icon{width:1.25rem;height:1.25rem;color:#d1d5db;font-weight:800;cursor:pointer}.contact-form{display:flex;flex-direction:column;gap:1rem}.contact-form label{display:block;font-size:.875rem;font-weight:500;color:#d1d5db;margin-bottom:.25rem}.contact-form input,.contact-form textarea{width:100%;padding:.5rem 1rem;border:1px solid #4b5563;border-radius:.5rem;background:#374151;color:#f3f4f6}.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:#8b5cf6;box-shadow:0 0 0 2px #8b5cf6}.contact-submit-btn{width:100%;padding:.5rem 1rem;background:linear-gradient(to right,#1d4ed8,#6d28d9);color:#fff;transition:.3s;border-radius:.5rem;box-shadow:0 4px 6px #7c3aed66;cursor:pointer;border:none}.contact-submit-btn:hover{background:linear-gradient(to right,#2563eb,#7c3aed);box-shadow:0 10px 15px #7c3aed80}.notification{position:fixed;top:1.25rem;left:50%;transform:translate(-50%);z-index:50;padding:.75rem 1.5rem;border-radius:.5rem;box-shadow:0 10px 15px #0003;color:#fff}.notification.success{background:#22c55e}.notification.error{background:#ef4444}.dark .navbar{background:#111827}.dark .navbar-title,.dark .navbar-link{color:#fff}.dark .navbar-link:hover{color:#60a5fa}.dark .navbar-link:after{background:#60a5fa}.dark .navbar-contact-btn{background:#385796}.dark .navbar-contact-btn:hover{box-shadow:0 10px 15px #1e40af80}.dark .contact-submit-btn{background:linear-gradient(to right,#db2777,#f472b6)}.dark .contact-submit-btn:hover{background:linear-gradient(to right,#be185d,#ec4899);box-shadow:0 10px 15px #db277780}@media(min-width:640px){.navbar{padding-left:3rem;padding-right:3rem}.navbar-title{max-width:none;font-size:1.5rem}.navbar-actions{gap:1rem}.navbar-contact-btn{display:flex}.menu-icon{display:none}}@media(min-width:768px){.navbar-links{margin-right:7.5rem}.navbar-divider{display:inline}}@media(min-width:1024px){.navbar{padding-left:6rem;padding-right:6rem}}@media(min-width:1280px){.navbar{padding-left:5rem;padding-right:5rem}}@media(max-width:639px){.navbar-links{position:fixed;top:0;bottom:0;right:0;min-height:100vh;height:100%;width:0;overflow:hidden;flex-direction:column;background:#1f2937;color:#fff;padding-top:5rem;box-shadow:0 25px 50px #000000e6;transition:all .5s ease-in-out}.navbar-links.sidebar-open{width:12.5rem;padding-left:1.5rem}.sidebar-close{display:block;width:1.75rem;height:1.75rem;position:absolute;right:1rem;top:1rem;cursor:pointer}.navbar-link{color:#fff;font-size:1.125rem;padding:.5rem 0}}.intro-wrapper{background:#fff;scroll-margin-top:22.5rem}.intro-section{background:#fbf7f6;padding:2rem}.intro-content{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3rem;padding:4rem 2rem}.intro-image-container{flex-shrink:0}.intro-image{width:10rem;height:10rem;border-radius:999px;object-fit:cover;border:4px solid black}.intro-text{max-width:32rem;text-align:center}.intro-greeting{font-size:1.25rem;font-weight:600}.intro-name{font-size:1.5rem;font-weight:500;color:#111827}.intro-text hr{margin-top:.75rem;margin-left:auto;margin-right:auto;width:66.666%;border-color:#e5e7eb}.intro-text p{margin-top:1.5rem;color:#374151;width:100%;font-size:1rem}.intro-btn{margin-top:1.5rem;padding:.5rem 1.5rem;color:#000;cursor:pointer;transition:.3s;border:.16rem solid black;width:9.25rem;height:2.75rem;background:transparent;font-weight:600}.intro-btn:hover{background:#000;color:#fff;border-color:#000}.dark .intro-wrapper{background:#111827}.dark .intro-section{background:#161e2e}.dark .intro-image{border-color:#fff}.dark .intro-name{color:#fff}.dark .intro-text hr{border-color:#fff}.dark .intro-text p{color:#d1d5db}.dark .intro-btn{color:#fff;border-color:#fff}.dark .intro-btn:hover{background:#fff;color:#000;border-color:#fff}@media(min-width:768px){.intro-content{flex-direction:row;margin-right:17.5rem}.intro-image{width:25rem;height:25rem;border-radius:0;border:none}.intro-text{text-align:left}.intro-greeting{font-size:1.2rem;font-weight:400}.intro-name{font-size:2.25rem;width:50rem}.intro-text hr{margin-left:0;margin-right:0;width:37.5rem}.intro-text p{width:51rem}}.about-section{margin-top:13rem;padding:0 1.5rem;scroll-margin-top:12.5rem}.about-container{max-width:48rem;margin:0 auto;display:flex;flex-direction:column;align-items:center;text-align:center}.about-container h1{font-size:3rem;font-weight:700;margin-bottom:2rem}.about-intro{font-size:1rem;color:#374151;margin-bottom:1.5rem;max-width:36rem}.skills-list{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem;margin-bottom:1.5rem;font-size:1.125rem;max-width:42rem}.skills-heading,.skill-item{display:flex;align-items:center;gap:.5rem}.skills-heading{font-weight:600}.checkmark{display:flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;color:#15803d;font-weight:800}.about-description{font-size:1.125rem;margin-top:1.25rem;margin-bottom:1.5rem;max-width:56rem;color:#6b7280}.about-buttons{display:flex;justify-content:center;gap:1rem;margin-top:.75rem;margin-bottom:6.5rem}.about-buttons button{font-weight:600;padding:.5rem 1.5rem;cursor:pointer;transition:.3s}.projects-btn{background:#fbf7f6;color:#000;border:none}.projects-btn:hover{background:#f2eae8}.cv-btn{background:transparent;border:.13rem solid black}.cv-btn:hover{background:#000;color:#fff}@media(min-width:768px){.about-intro,.skills-list{font-size:1.1rem}}.dark .about-container h1{color:#60a5fa}.dark .about-intro{color:#e5e7eb}.dark .about-description{color:#f3f4f6}.dark .projects-btn{background:#385796;color:#fff}.dark .projects-btn:hover{background:#4b78d2}.dark .cv-btn{border-color:#fff;color:#fff}.dark .cv-btn:hover{background:#fff;color:#111827}.timeline-container{position:relative;min-height:var(--mobile-height)}.timeline-base-line{position:absolute;left:2rem;top:0;bottom:0;width:.25rem;background:#000;border-radius:.375rem}.timeline-progress-line{position:absolute;left:2rem;top:0;width:.25rem;border-radius:.375rem;transition:none}.dark .timeline-progress-line{mix-blend-mode:lighten}@media(min-width:768px){.timeline-container{min-height:var(--desktop-height)}.timeline-base-line,.timeline-progress-line{left:8rem}}.typewriter-text{white-space:pre}.typewriter-cursor{margin-left:.25rem;border-right:4px solid currentColor;animation:blink 1s step-end infinite}.typewriter-main{color:#e07b7b;font-size:4.5rem;display:block;margin-top:.5rem}.dark .typewriter-main{color:#60a5fa}@keyframes blink{50%{opacity:0}}.subheading-title{color:#000;font-size:1.875rem;font-weight:700;margin-bottom:3rem;text-align:center;width:100%}.dark .subheading-title{color:#f3f4f6}@media(min-width:768px){.subheading-title{font-size:1.875rem}}.experience-section{background:#fbf7f6;color:#f3f4f6;display:flex;flex-direction:column;align-items:center;padding-top:3rem;padding-bottom:33.75rem;margin-top:5rem;scroll-margin-top:5rem}.experience-title-container{width:100%;display:flex;flex-direction:column;align-items:center;margin-bottom:2rem;margin-top:5rem}.experience-title{font-size:2.25rem;font-weight:700;color:#000;text-align:center;margin-bottom:1rem;opacity:0}.experience-title-line{width:0;height:.25rem;background:linear-gradient(to right,#ec4899,#fbcfe8);margin-left:auto;margin-right:auto;opacity:0}.experience-timeline-wrapper{position:relative;width:100%;max-width:64rem;margin-top:6.25rem}.experience-content{position:absolute;top:1.25rem;left:0;width:100%}.experience-year-block{margin-bottom:5rem}.experience-year-header{position:relative;display:flex;align-items:center;margin-bottom:2.5rem;padding-left:3.5rem}.experience-year-dot{position:absolute;left:1.5rem;width:1.25rem;height:1.25rem;background:#f9a8d4;border-radius:999px;border:4px solid #111827}.experience-year{font-size:1.5rem;font-weight:700;color:#4b5563}.experience-cards{display:flex;flex-direction:column;width:95%;max-width:32rem;gap:2rem;padding-left:2.5rem;margin:0 auto}.experience-reveal-card{position:relative;overflow:hidden}.experience-reveal-cover{position:absolute;inset:0;background:#e07a7f;z-index:30;pointer-events:none}.experience-reveal-content{position:relative;z-index:20}.experience-card{background:#fae9e5;padding:1.5rem;border-radius:.375rem;box-shadow:0 10px 15px #00000026;display:flex;flex-direction:column;align-items:flex-start;gap:1rem;color:#111827}.experience-icon-box{display:flex;align-items:center;justify-content:center;width:4rem;height:4rem;border-radius:.75rem;background:#e07a7f}.experience-icon{width:2rem;height:2rem;color:#fff}.experience-card-content{flex:1}.experience-card-content h3{font-size:1.25rem;font-weight:600}.experience-date{font-size:.875rem;color:#4b5563;margin-top:.5rem}.experience-description{color:#374151;margin-top:.5rem}.experience-gained-title{font-weight:700;margin-top:1.25rem}.experience-bullets{list-style:disc;list-style-position:outside;color:#374151;padding-left:1.5rem;margin-top:.25rem}.experience-bullets li{margin-bottom:.25rem}.dark .experience-section{background:#161e2e}.dark .experience-title{color:#fff}.dark .experience-title-line{background:linear-gradient(to right,#3b82f6,#a855f7)}.dark .experience-year-dot{background:#50a1fe;border-color:#1f2937}.dark .experience-year{color:#d1d5db}.dark .experience-reveal-cover{background:#0ea5e9}.dark .experience-card{background:#1f2937;color:#f3f4f6}.dark .experience-icon-box{background:#50a1fe}.dark .experience-date{color:#9ca3af}.dark .experience-description,.dark .experience-bullets{color:#e5e7eb}@media(min-width:768px){.experience-section{padding-bottom:5rem}.experience-title{font-size:3rem}.experience-title-line{margin-bottom:6.25rem}.experience-year-header{padding-left:10rem}.experience-year-dot{left:7.5rem}.experience-cards{width:65rem;max-width:80rem;padding-left:10rem}.experience-card{flex-direction:row}}@media(min-width:1024px){.experience-title{font-size:3.75rem}}.education-section{color:#f3f4f6;display:flex;flex-direction:column;align-items:center;padding:3rem 0;margin-top:5rem;scroll-margin-top:5rem}.education-title-container{width:100%;display:flex;flex-direction:column;align-items:center;margin-bottom:2rem;margin-top:5rem}.education-title{font-size:2.25rem;font-weight:700;color:#000;text-align:center;margin-bottom:1rem;opacity:0}.education-title-line{width:0;height:.25rem;background:linear-gradient(to right,#ec4899,#fbcfe8);margin:0 auto 6.25rem;opacity:0}.education-timeline-wrapper{position:relative;width:100%;max-width:64rem}.education-content{position:absolute;top:1.25rem;left:0;width:100%}.education-year-block{margin-bottom:5rem}.education-year-header{position:relative;display:flex;align-items:center;margin-bottom:2.5rem;padding-left:3.5rem}.education-year-dot{position:absolute;left:1.5rem;width:1.25rem;height:1.25rem;background:#f9a8d4;border-radius:999px;border:4px solid #111827}.education-year{font-size:1.5rem;font-weight:700;color:#4b5563}.education-cards{display:flex;flex-direction:column;width:95%;max-width:32rem;gap:2rem;padding-left:2.5rem;margin:0 auto}.reveal-card{position:relative;overflow:hidden}.reveal-cover{position:absolute;inset:0;background:#e07a7f;z-index:30;pointer-events:none}.reveal-content{position:relative;z-index:20}.education-card{background:#fae9e5;padding:1.5rem;border-radius:.375rem;box-shadow:0 10px 15px #00000026;display:flex;flex-direction:column;align-items:flex-start;gap:1rem;color:#111827}.education-icon-box{display:flex;align-items:center;justify-content:center;border-radius:.75rem;background:#e07a7f;width:4rem;height:4rem}.education-icon-box-tall{width:2.5rem;height:4.2rem}.education-icon{width:2rem;height:2rem;color:#fff}.education-card-content{flex:1}.education-card-content h3{font-size:1.25rem;font-weight:600}.education-date{font-size:.875rem;color:#4b5563;margin-top:.5rem}.education-description{color:#374151;text-align:justify;margin-top:.5rem}.education-description ul{list-style:disc;list-style-position:inside;margin-left:1rem;margin-top:.25rem}.education-description li{margin-bottom:.25rem}.dark .education-section{background:#111827}.dark .education-title{color:#fff}.dark .education-title-line{background:linear-gradient(to right,#3b82f6,#a855f7)}.dark .education-year-dot{background:#50a1fe;border-color:#1f2937}.dark .education-year{color:#d1d5db}.dark .reveal-cover{background:#0ea5e9}.dark .education-card{background:#1f2937;color:#f3f4f6}.dark .education-icon-box{background:#50a1fe}.dark .education-date{color:#9ca3af}.dark .education-description{color:#e5e7eb}@media(min-width:768px){.education-title{font-size:3rem}.education-year-header{padding-left:10rem}.education-year-dot{left:7.5rem}.education-cards{width:65rem;max-width:80rem;padding-left:10rem}.education-card{flex-direction:row}}@media(min-width:1024px){.education-title{font-size:3.75rem}}.projects-section{position:relative;padding:10rem 0;background:#fff;overflow:hidden;scroll-margin-top:5rem;margin-top:17.5rem}.projects-heading-container{width:100%;max-width:80rem;margin:0 auto 4rem;padding:0 1rem;position:relative;z-index:10}.projects-heading{font-size:2.25rem;font-weight:700;color:#000;text-align:center;margin-bottom:1rem;opacity:0}.projects-heading-line{width:0;height:.25rem;background:linear-gradient(to right,#ec4899,#fbcfe8);margin:0 auto;opacity:0}.projects-list{display:flex;flex-direction:column;gap:5rem;opacity:0}.project-card{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;padding-bottom:3rem}.project-title{font-size:1.5rem;font-weight:700;color:#000;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.project-title-link{margin-top:7.5rem;cursor:pointer;transition:color .3s}.project-title-link:hover{color:#9ca3af}.project-github-icon{width:1.5rem;height:1.5rem;margin-top:7.5rem;cursor:pointer;transition:color .3s}.project-github-icon:hover{color:#9ca3af}.project-github-light{color:#000}.project-github-dark{color:#fff}.project-disabled{pointer-events:none;opacity:.5}.project-image-wrapper{position:relative;width:100%;max-width:48rem;margin-bottom:1.5rem}.project-overlay-btn{position:absolute;top:.5rem;right:.5rem;z-index:50;background:#fff;border-radius:999px;padding:.5rem;box-shadow:0 20px 25px #0003;transition:background .3s;border:none;cursor:pointer}.project-overlay-btn:hover{background:#e5e7eb}.project-overlay-btn img{width:1.5rem;height:1.5rem}.project-image,.project-overlay-image{width:100%;border-radius:1rem;object-fit:cover;box-shadow:0 4px 6px #00000026;border:1px solid #374151;transition:all .7s ease-in-out}.project-overlay-image{position:absolute;inset:0;height:100%}.project-visible{opacity:1;pointer-events:auto}.project-hidden{opacity:0;pointer-events:none}.project-overlay-content{position:absolute;inset:0;z-index:40;display:flex;flex-direction:column;align-items:flex-start;padding:1.5rem;pointer-events:auto}.project-overlay-title{font-size:1.25rem;font-weight:600;color:#000}.project-overlay-title-spaced{margin-bottom:.75rem}.project-special-text{font-size:.875rem;color:#4b5563;margin-bottom:.75rem}.project-overlay-text{color:#374151;margin-bottom:1rem}.project-overlay-text ul{list-style:disc;list-style-position:outside;padding-left:2rem;width:35rem;font-size:.82rem}.project-overlay-text li{line-height:1.625}.project-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:-.5rem}.project-tags span{padding:.25rem .75rem;font-size:.875rem;border-radius:999px;background:#1c2541;color:#e5e7eb}.dark .projects-section{background:#111827}.dark .projects-heading,.dark .project-title,.dark .project-overlay-title{color:#fff}.dark .projects-heading-line{background:linear-gradient(to right,#3b82f6,#a855f7)}.dark .project-special-text{color:#9ca3af}.dark .project-overlay-text li{color:#e5e7eb}@media(min-width:768px){.projects-section{margin-top:0}.projects-heading{font-size:3rem}.project-title{font-size:1.875rem}.project-overlay-btn{top:.75rem;left:.5rem;right:auto}.project-overlay-title{font-size:1.5rem;margin-left:5rem;margin-top:.75rem}.project-special-text{margin-left:5rem}.project-overlay-text ul{font-size:1rem;margin-left:4.75rem}}.contact-section{background:#fbf7f6;display:flex;flex-direction:column;align-items:center;text-align:center;padding:7.5rem 1.5rem;position:relative}.contact-subtitle{font-size:1.5rem;margin-bottom:1.5rem}.contact-section h1{font-size:2.25rem;font-weight:700;margin-bottom:2rem}.contact-description{max-width:600px;font-size:1rem;margin-bottom:2rem}.contact-btn{background:transparent;border:.13rem solid black;font-weight:600;padding:.5rem 1.5rem;cursor:pointer;transition:.3s}.contact-btn:hover{background:#000;color:#fff;border-color:#000}.dark .contact-section{background:#161e2e}.dark .contact-subtitle{color:#f3f4f6}.dark .contact-btn{border-color:#fff;color:#fff}.dark .contact-btn:hover{background:#fff;color:#111827;border-color:#fff}@media(min-width:768px){.contact-section h1{font-size:3rem}.contact-description{font-size:1.125rem}}.ending-section{padding:2.5rem 1rem 0}.ending-content{display:flex;justify-content:space-between;gap:2.5rem}.ending-info{display:flex;flex-direction:column;gap:1.25rem;font-size:.875rem;color:#374151}.ending-info h1{width:10rem;white-space:nowrap;font-size:1.5rem;font-weight:500;color:#000}.ending-info p{max-width:28rem}.ending-links{display:flex;gap:2rem;font-size:1rem}.ending-links a{color:#000;transition:color .3s}.ending-links a:hover{color:#ec4899}.ending-section hr{border:none;border-top:1px solid #d1d5db;margin:1.5rem 0}.ending-bottom{padding-bottom:1.5rem;font-size:.875rem;color:#6b7280;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}.ending-icons{display:flex;align-items:center;justify-content:space-between;gap:1rem}.ending-icons a{color:inherit;transition:color .3s}.ending-icons a:hover{color:#000}.dark .ending-section{background:#111827}.dark .ending-info{color:#9ca3af}.dark .ending-info h1,.dark .ending-links a{color:#fff}.dark .ending-info p,.dark .ending-links,.dark .ending-bottom p{color:#e5e7eb}.dark .ending-links a:hover{color:#60a5fa}.dark .ending-section hr{border-top-color:#4b5563}.dark .ending-icons a{color:#9ca3af}.dark .ending-icons a:hover{color:#fff}@media(min-width:640px){.ending-section{padding-left:2.5rem;padding-right:2.5rem}.ending-info h1{width:10rem}.ending-bottom{justify-content:space-between}}@media(min-width:1024px){.ending-section{padding-left:6rem;padding-right:6rem}.ending-content{align-items:center}}@media(min-width:1280px){.ending-section{padding-left:10rem;padding-right:10rem}}@media(max-width:1023px){.ending-content{flex-direction:column}}@media(max-width:639px){.ending-bottom{justify-content:center;text-align:center}.ending-links{flex-wrap:wrap;gap:1rem}}
