/*! tailwindcss v4.1.17 | MIT License | https://tailwindcss.com */
@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-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--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;--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;-webkit-text-decoration:inherit;-webkit-text-decoration: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}:root{--radius:.625rem;--background:#fff;--foreground:#0a0a0a;--card:#fff;--card-foreground:#0a0a0a;--popover:#fff;--popover-foreground:#0a0a0a;--primary:#171717;--primary-foreground:#fafafa;--secondary:#f5f5f5;--secondary-foreground:#171717;--muted:#f5f5f5;--muted-foreground:#737373;--accent:#f5f5f5;--accent-foreground:#171717;--destructive:#e40014;--border:#e5e5e5;--input:#e5e5e5;--ring:#a1a1a1;--primary-colour-dark:#fcd5ce;--primary-colour-light:#f8f9fa;--primary-colour-black:#212529}@supports (color:lab(0% 0 0)){:root{--background:lab(100% 0 0);--foreground:lab(2.75381% 0 0);--card:lab(100% 0 0);--card-foreground:lab(2.75381% 0 0);--popover:lab(100% 0 0);--popover-foreground:lab(2.75381% 0 0);--primary:lab(7.78201% -.0000149012 0);--primary-foreground:lab(98.26% -.0000298023 0);--secondary:lab(96.52% -.0000298023 0);--secondary-foreground:lab(7.78201% -.0000149012 0);--muted:lab(96.52% -.0000298023 0);--muted-foreground:lab(48.496% 0 0);--accent:lab(96.52% -.0000298023 0);--accent-foreground:lab(7.78201% -.0000149012 0);--destructive:lab(48.4493% 77.4328 61.5452);--border:lab(90.952% 0 -.0000119209);--input:lab(90.952% 0 -.0000119209);--ring:lab(66.128% 0 0)}}.dark{--background:#0a0a0a;--foreground:#fafafa;--card:#171717;--card-foreground:#fafafa;--popover:#171717;--popover-foreground:#fafafa;--primary:#e5e5e5;--primary-foreground:#171717;--secondary:#262626;--secondary-foreground:#fafafa;--muted:#262626;--muted-foreground:#a1a1a1;--accent:#262626;--accent-foreground:#fafafa;--destructive:#ff6568;--border:#ffffff1a;--input:#ffffff26;--ring:#737373}@supports (color:lab(0% 0 0)){.dark{--background:lab(2.75381% 0 0);--foreground:lab(98.26% -.0000298023 0);--card:lab(7.78201% -.0000149012 0);--card-foreground:lab(98.26% -.0000298023 0);--popover:lab(7.78201% -.0000149012 0);--popover-foreground:lab(98.26% -.0000298023 0);--primary:lab(90.952% 0 -.0000119209);--primary-foreground:lab(7.78201% -.0000149012 0);--secondary:lab(15.204% 0 0);--secondary-foreground:lab(98.26% -.0000298023 0);--muted:lab(15.204% 0 0);--muted-foreground:lab(66.128% 0 0);--accent:lab(15.204% 0 0);--accent-foreground:lab(98.26% -.0000298023 0);--destructive:lab(63.7053% 60.745 31.3109);--border:lab(100% 0 0/.1);--input:lab(100% 0 0/.15);--ring:lab(48.496% 0 0)}}*{border-color:var(--border)}body{background-color:var(--background);color:var(--foreground);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}}@layer components;@layer utilities{.absolute{position:absolute}.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}}.flex{display:flex}.hidden{display:none}.h-5{height:calc(var(--spacing)*5)}.h-10{height:calc(var(--spacing)*10)}.w-5{width:calc(var(--spacing)*5)}.w-10{width:calc(var(--spacing)*10)}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.border{border-style:var(--tw-border-style);border-width:1px}.text-center{text-align:center}.underline{text-decoration-line:underline}.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,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))}}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}.App{text-align:center}.dark .App{background-color:var(--background)}.container{flex-direction:column;justify-content:flex-start;align-items:center;gap:0;max-width:100vw;min-height:auto;margin:0 auto;padding:4rem 2rem 2rem;display:flex}.dark .container{background-color:var(--background)}:root{--primary-colour-dark:#fcd5ce;--primary-colour-light:#f8f9fa;--primary-colour-black:#212529}*{box-sizing:border-box;margin:0;padding:0;font-family:Poppins,sans-serif}html{scroll-behavior:smooth;font-size:62.5%}body{font-weight:400;line-height:1;transition:background-color .3s,color .3s;overflow-x:hidden}@media (max-width:768px){html{font-size:50%}.container{justify-content:flex-start;min-height:auto;padding:2rem 1rem}}.theme-toggle-btn{cursor:pointer;z-index:9999;color:#333;background-color:#fcd5ce4d;border:2px solid #fcd5ce;border-radius:50%;justify-content:center;align-items:center;width:4rem;height:4rem;transition:all .2s ease-in-out;display:flex;position:fixed;top:2rem;right:2rem}.dark .theme-toggle-btn{color:#fff;background-color:#ffffff1a;border-color:#fff}.theme-toggle-btn:hover{background-color:#fcd5ce80;transform:scale(1.15)}.dark .theme-toggle-btn:hover{background-color:#fff3}.theme-toggle-btn svg{width:2rem;height:2rem}.home-footer{background-color:var(--primary-colour-dark);cursor:pointer;justify-content:center;align-items:center;width:100%;height:4.4rem;transition:background-color .3s;display:flex;position:fixed;bottom:0}.dark .home-footer{background-color:var(--card);border-top:1px solid var(--border)}.dark .scroll-down-btn{color:#fff}.flex{justify-content:center;align-items:center;display:flex}.hidden{display:none}.social-link{width:4.4rem;height:4.4rem;color:var(--foreground);background-color:#0000;border:none;text-decoration:none;transition:all .2s ease-in-out}.social-link svg{fill:currentColor}.social-link:hover{transform:scale(1.2)}.social-link-icon{width:2rem}.links-container{justify-content:center;gap:1rem;margin-bottom:4rem;display:flex}.background-container{height:100vh;position:relative}.coloured-box{background-color:var(--primary-colour-dark);z-index:0;height:1.7rem;position:absolute;top:55%}.text-with-box{text-align:center;z-index:1;justify-content:center;margin-bottom:2rem;display:flex;position:relative}.coloured-box-project{width:30.7rem}.profile-picture{aspect-ratio:1;-o-object-fit:cover;object-fit:cover;-o-object-position:center;object-position:center;border:3px solid #fcd5ce;border-radius:50%;width:50%;margin:0 auto 4rem;display:block}.row-mb{margin-bottom:4rem}.text-container{flex-direction:column;align-items:center;display:flex}.intro-text{color:var(--foreground);z-index:2;font-size:4.8rem;font-weight:600;line-height:1.4;position:relative}.body-text{color:var(--foreground);z-index:2;font-size:4rem;font-weight:600;line-height:1.5;position:relative}@media (max-width:768px){.body-text{white-space:normal;font-size:3rem}}.main-paragraph{margin-bottom:5rem}.scroll-down-btn{background-color:none;border:none;border-radius:50%;width:5rem;height:5rem;transition:all .2s ease-in-out}.scroll-down-btn:hover{transform:scale(1.2)}.animated-text{color:var(--foreground);z-index:2;font-size:4rem;font-weight:400;line-height:1.2;position:relative}@media (max-width:768px){.profile-picture{width:60%;margin-top:0;margin-bottom:2rem}.row-mb,.links-container{margin-bottom:3rem}.intro-text{font-size:3.5rem}.body-text{font-size:3rem}.main-paragraph{margin-bottom:3rem}}.dark .profile-picture{border-color:#ff9b96}.description{text-align:center;flex-grow:1;max-width:35rem;margin-bottom:auto;padding:0 1.4rem 1.4rem;font-size:1.8rem;font-weight:500;line-height:1.5;overflow:hidden}.project-img{-o-object-fit:cover;object-fit:cover;-o-object-position:top;object-position:top;border-radius:15px;flex-shrink:0;width:100%;height:20rem;margin-bottom:1.5rem}.btn-content{justify-content:center;align-items:center;display:flex}.tech-stack-container{width:35rem;margin-bottom:1rem;padding:1rem}.tech-logo{-o-object-fit:cover;object-fit:cover;border-radius:18px;width:2rem;height:2rem;margin-right:5px}.cta-group{justify-content:center;gap:2rem;margin-top:auto;margin-bottom:0;display:flex}.btn-card-cta{color:#fff;border:none;border-radius:8px;padding:.4rem 1.5rem;font-size:2.4rem;font-weight:500;text-decoration:none;transition:all .2s ease-in-out}.btn-card-cta:first-child{background-color:#d64e4a;font-weight:600}.btn-card-cta:last-child{background-color:#e8a29d}.btn-card-cta:hover{transform:scale(1.1)}.blur-card{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#fffc}.blur-card .blur-img{filter:blur(8px)}.blur-card .btn-group,.blur-card .blur-description,.blur-card .blur-btn{filter:blur(4px)}.blur-card .card-title{filter:none}@media (max-width:768px){.description{flex-grow:0;max-width:100%;margin-bottom:1rem;font-size:2.2rem}.tech-stack-container{width:100%}.tech-btn{font-size:2rem}.tech-logo{width:2.5rem;height:2.5rem}.btn-card-cta{font-size:2.8rem}.MuiTypography-h2,.MuiLink-root{font-size:3.2rem}}.dark .MuiCard-root{background-color:var(--card);color:var(--card-foreground);border:1px solid var(--border)}.dark .description{color:var(--muted-foreground)}.dark .MuiTypography-h2,.dark .MuiLink-root{color:var(--card-foreground)}.dark .blur-card{background-color:var(--card);border:1px solid var(--border)}.dark .btn-card-cta:first-child{background-color:#c03a36}.dark .btn-card-cta:last-child{background-color:#d17974}.projects{flex-direction:column;align-items:center;width:100%;padding:2rem 0;display:flex}.projects .text-with-box{margin-bottom:8rem}.projects .text-with-box .intro-text{color:var(--foreground);font-size:5rem}.projects-container{grid-template-columns:repeat(3,1fr);gap:2rem;width:100%;max-width:1400px;margin-bottom:4rem;padding:0 2rem;display:grid}@media (max-width:1024px){.projects-container{grid-template-columns:repeat(2,1fr);gap:1.5rem}}@media (max-width:768px){.projects{padding:1rem 0}.projects .text-with-box{margin-bottom:3rem}.projects-container{grid-template-columns:1fr;gap:2rem;margin-bottom:2rem;padding:0 1rem}}.dark .coloured-box{opacity:1;background-color:#d64e4a}
