@import"https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=Outfit:wght@300;400;500;600;700;800&display=swap";*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}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;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,[type=button],[type=reset],[type=submit]{-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]{display:none}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }.container{width:100%}@media (min-width: 640px){.container{max-width:640px}}@media (min-width: 768px){.container{max-width:768px}}@media (min-width: 1024px){.container{max-width:1024px}}@media (min-width: 1280px){.container{max-width:1280px}}@media (min-width: 1536px){.container{max-width:1536px}}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.bottom-2{bottom:.5rem}.left-2{left:.5rem}.right-2{right:.5rem}.mx-auto{margin-left:auto;margin-right:auto}.mb-0{margin-bottom:0}.mb-1{margin-bottom:.25rem}.mb-1\.5{margin-bottom:.375rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-8{margin-bottom:2rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.block{display:block}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.hidden{display:none}.h-3{height:.75rem}.h-3\.5{height:.875rem}.h-5{height:1.25rem}.h-7{height:1.75rem}.max-h-0{max-height:0px}.max-h-\[2000px\]{max-height:2000px}.min-h-\[140px\]{min-height:140px}.w-3{width:.75rem}.w-3\.5{width:.875rem}.w-5{width:1.25rem}.w-7{width:1.75rem}.w-full{width:100%}.max-w-2xl{max-width:42rem}.flex-1{flex:1 1 0%}.flex-shrink{flex-shrink:1}.rotate-180{--tw-rotate: 180deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-2\.5{gap:.625rem}.gap-4{gap:1rem}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}.justify-self-start{justify-self:start}.overflow-hidden{overflow:hidden}.rounded{border-radius:.25rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.border-2{border-width:2px}.border-t{border-top-width:1px}.border-emerald-400{--tw-border-opacity: 1;border-color:rgb(52 211 153 / var(--tw-border-opacity))}.border-gray-200{--tw-border-opacity: 1;border-color:rgb(229 231 235 / var(--tw-border-opacity))}.border-gray-300{--tw-border-opacity: 1;border-color:rgb(209 213 219 / var(--tw-border-opacity))}.border-gray-400{--tw-border-opacity: 1;border-color:rgb(156 163 175 / var(--tw-border-opacity))}.border-orange-400{--tw-border-opacity: 1;border-color:rgb(251 146 60 / var(--tw-border-opacity))}.border-purple-400{--tw-border-opacity: 1;border-color:rgb(192 132 252 / var(--tw-border-opacity))}.border-transparent{border-color:transparent}.border-white\/10{border-color:#ffffff1a}.border-white\/20{border-color:#fff3}.bg-blue-600{--tw-bg-opacity: 1;background-color:rgb(37 99 235 / var(--tw-bg-opacity))}.bg-gray-800\/50{background-color:#1f293780}.bg-transparent{background-color:transparent}.bg-white{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity))}.bg-white\/5{background-color:#ffffff0d}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-6{padding:1.5rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-4{padding-left:1rem;padding-right:1rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.pb-10{padding-bottom:2.5rem}.pt-3{padding-top:.75rem}.text-left{text-align:left}.text-center{text-align:center}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.leading-tight{line-height:1.25}.text-blue-600{--tw-text-opacity: 1;color:rgb(37 99 235 / var(--tw-text-opacity))}.text-emerald-400{--tw-text-opacity: 1;color:rgb(52 211 153 / var(--tw-text-opacity))}.text-gray-400{--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity))}.text-gray-600{--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity))}.text-gray-700{--tw-text-opacity: 1;color:rgb(55 65 81 / var(--tw-text-opacity))}.text-gray-900{--tw-text-opacity: 1;color:rgb(17 24 39 / var(--tw-text-opacity))}.text-orange-400{--tw-text-opacity: 1;color:rgb(251 146 60 / var(--tw-text-opacity))}.text-purple-400{--tw-text-opacity: 1;color:rgb(192 132 252 / var(--tw-text-opacity))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity))}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.opacity-0{opacity:0}.opacity-100{opacity:1}.shadow-lg{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.grayscale{--tw-grayscale: grayscale(100%);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.invert{--tw-invert: invert(100%);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.sepia{--tw-sepia: sepia(100%);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}:root{--font-display: "DM Serif Display", serif;--font-body: "Outfit", system-ui, sans-serif;font-family:var(--font-body);line-height:1.6;font-weight:400;--background: #faf8f5;--background-secondary: #f0ebe3;--foreground: #1a1512;--foreground-muted: #5a524c;--primary: #c85a3f;--primary-dark: #a4442d;--accent: #d4a574;--accent-light: #e8c9a0;--card: #ffffff;--card-foreground: #1a1512;--card-border: #e6dfd6;--shadow: rgba(26, 21, 18, .08);--shadow-strong: rgba(26, 21, 18, .15);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--img-position-x: 41%;--img-position-y: 50%;--img-scale: 1}.dark{--background: #0f0d0b;--background-secondary: #1a1614;--foreground: #f5f1eb;--foreground-muted: #a69d94;--primary: #e8845f;--primary-dark: #d66b46;--accent: #d4a574;--accent-light: #c49561;--card: #1a1614;--card-foreground: #f5f1eb;--card-border: #2d2721;--shadow: rgba(0, 0, 0, .3);--shadow-strong: rgba(0, 0, 0, .5)}.theme-toggle{position:absolute;top:1.5rem;right:1.5rem;width:3rem;height:3rem;border-radius:9999px;border:2px solid var(--card-border);background:var(--card);color:var(--primary);cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;transition:all .4s cubic-bezier(.34,1.56,.64,1);z-index:10;box-shadow:0 2px 8px var(--shadow);animation:slideInToggle .6s ease-out .3s backwards}@keyframes slideInToggle{0%{opacity:0;transform:translateY(-20px) rotate(-90deg)}to{opacity:1;transform:translateY(0) rotate(0)}}.theme-toggle:hover{transform:translateY(-4px) rotate(15deg);box-shadow:0 6px 20px var(--shadow-strong);border-color:var(--primary)}.theme-icon{width:1.2rem;height:1.2rem}.dark .theme-icon.sun{display:block}.dark .theme-icon.moon,.theme-icon.sun{display:none}.theme-icon.moon{display:block}body{margin:0;display:flex;min-width:320px;min-height:100vh;padding:2rem;background:var(--background);color:var(--foreground);position:relative;overflow-x:hidden}body:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;opacity:.03;z-index:0;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 400 400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E")}#app{width:100%;max-width:900px;margin:0 auto;padding:1rem 2rem;position:relative;z-index:1;animation:fadeIn .8s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.profile{margin-bottom:3rem;text-align:center;animation:slideInProfile .8s ease-out .2s backwards}@keyframes slideInProfile{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.profile img{width:160px;height:160px;border-radius:50%;margin-bottom:1.5rem;border:4px solid var(--primary);box-shadow:0 8px 24px var(--shadow-strong),0 0 0 8px var(--accent-light);-o-object-fit:cover;object-fit:cover;-o-object-position:var(--img-position-x) var(--img-position-y);object-position:var(--img-position-x) var(--img-position-y);transform:scale(var(--img-scale));transition:transform .4s cubic-bezier(.34,1.56,.64,1),box-shadow .4s ease}.profile img:hover{transform:scale(calc(var(--img-scale) * 1.05));box-shadow:0 12px 32px var(--shadow-strong),0 0 0 8px var(--accent)}.profile h1{font-family:var(--font-display);font-size:3.5em;font-weight:400;color:var(--foreground);margin:0 0 .25rem;letter-spacing:-.02em;line-height:1.1}.profile p{color:var(--foreground-muted);margin:0;font-weight:500;font-size:1.1rem;letter-spacing:.01em}.profile .location{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:.5rem;font-size:.95rem;color:var(--foreground-muted);font-weight:400}.location-icon{width:1rem;height:1rem;color:var(--primary)}.links-container{margin-top:2rem;animation:slideInLinks .8s ease-out .4s backwards}@keyframes slideInLinks{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.link-card{background:var(--card);border:1px solid var(--card-border);border-left:4px solid var(--primary);border-radius:16px;padding:1.75rem 1.5rem;margin:1.25rem 0;display:block;position:relative;text-decoration:none;color:var(--card-foreground);transition:all .4s cubic-bezier(.34,1.56,.64,1);cursor:pointer;width:100%;box-sizing:border-box;min-height:110px;box-shadow:0 2px 8px var(--shadow),0 1px 2px var(--shadow);overflow:hidden}.link-card:nth-child(1){animation:slideInCard .6s ease-out .5s backwards}.link-card:nth-child(2){animation:slideInCard .6s ease-out .6s backwards}.link-card:nth-child(3){animation:slideInCard .6s ease-out .7s backwards}.link-card:nth-child(4){animation:slideInCard .6s ease-out .8s backwards}.link-card:nth-child(5){animation:slideInCard .6s ease-out .9s backwards}.link-card:nth-child(6){animation:slideInCard .6s ease-out 1s backwards}@keyframes slideInCard{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.link-card:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,var(--primary) 0%,var(--accent) 100%);opacity:0;transition:opacity .4s ease;z-index:0;border-radius:16px}.link-card:hover:before{opacity:.08}.link-icon{position:absolute;top:1.75rem;right:1.5rem;width:24px;height:24px;opacity:.5;transition:all .4s cubic-bezier(.34,1.56,.64,1);color:var(--primary);z-index:1}.link-card:hover{transform:translate(8px) translateY(-4px);box-shadow:0 12px 32px var(--shadow-strong),0 4px 8px var(--shadow);border-left-width:6px}.link-card:hover .link-icon{opacity:1;transform:translate(4px) translateY(-4px) rotate(-5deg);color:var(--primary-dark)}.link-card h2{margin:0;font-size:1.35rem;font-weight:600;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-right:3rem;position:relative;z-index:1}.link-card p{margin:.5rem 0 0;font-size:.95rem;opacity:.85;font-weight:400;padding-right:3rem;line-height:1.5;height:3em;display:block;text-align:left;overflow:hidden;color:var(--foreground-muted);position:relative;z-index:1}.link-card:last-child{opacity:.75;border-left-color:var(--accent)}.link-card:last-child:hover{opacity:1}@media (max-width: 640px){body{padding:.25rem}#app{padding:.5rem}.link-card{padding:1rem;width:100%;min-height:90px}.theme-toggle{top:.5rem;right:.5rem}}.admin-container{display:grid;grid-template-columns:1fr 1fr;gap:2rem;padding:2rem;max-width:1200px;margin:0 auto}.preview-section,.controls-section{background:var(--card);color:var(--card-foreground);padding:2rem;border-radius:12px;box-shadow:0 2px 8px #0000001a}.control-group{margin-bottom:1.5rem}.control-group label{display:block;margin-bottom:.5rem;font-weight:500}.control-group input[type=range]{width:100%;margin:.5rem 0}.control-group span{display:inline-block;min-width:4rem;text-align:right;color:var(--muted)}.reset-button{background-color:var(--primary);color:var(--primary-foreground);border:none;padding:.75rem 1.5rem;border-radius:6px;cursor:pointer;font-weight:600;transition:all .3s ease}.reset-button:hover{opacity:.9;transform:translateY(-1px)}@media (max-width: 768px){.admin-container{grid-template-columns:1fr}}.divider{display:flex;align-items:center;justify-content:center;margin:3rem 0;opacity:.4;animation:fadeInDivider .8s ease-out 1.2s backwards}@keyframes fadeInDivider{0%{opacity:0;transform:scale(.8)}to{opacity:.4;transform:scale(1)}}.divider-icon{width:3rem;height:3rem;color:var(--accent);transition:all .4s ease}.divider:hover .divider-icon{transform:rotate(15deg) scale(1.1);opacity:.8}.tech-stack{margin-top:1rem;padding:2rem 1.75rem;border:1px solid var(--card-border);font-size:.9rem;background:var(--card);color:var(--card-foreground);border-radius:16px;width:100%;box-sizing:border-box;margin-bottom:2rem;box-shadow:0 2px 8px var(--shadow),0 1px 2px var(--shadow);position:relative;overflow:hidden;animation:slideInTech .8s ease-out 1.3s backwards}@keyframes slideInTech{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.tech-stack-header{display:flex;justify-content:space-between;align-items:center;gap:1rem}.expand-button{background:none;border:none;padding:.5rem;cursor:pointer;color:var(--primary);border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.expand-button:hover{background-color:var(--background);transform:translateY(-1px)}.expand-button .tech-icon{width:1.2rem;height:1.2rem;transition:transform .3s ease}.expand-button[aria-expanded=true] .tech-icon{transform:rotate(180deg)}.tech-stack-details{max-height:0;overflow:hidden;opacity:0;transition:all .3s ease}.tech-stack-details.expanded{max-height:2000px;opacity:1;margin-top:1.5rem}.tech-stack p{margin:0;display:flex;align-items:center;gap:.75rem;color:var(--card-foreground);font-weight:500}.tech-stack .love-note{font-size:.9rem;font-weight:500;letter-spacing:-.01em;margin:0;color:var(--card-foreground)}.tech-stack .love-note .tech-icon{width:.9rem;height:.9rem}.tech-stack .tech-icon{width:1.1rem;height:1.1rem;color:var(--card-foreground);flex-shrink:0}.tech-stack ul{list-style:none;padding:0;margin:1rem 0 0;display:flex;flex-direction:column;gap:.75rem}.tech-stack li{display:flex;align-items:center;gap:.75rem;padding:.9rem 1.1rem;border-radius:10px;border:1px solid var(--card-border);background:var(--background-secondary);color:var(--card-foreground);transition:all .3s cubic-bezier(.34,1.56,.64,1);font-size:.9rem}.tech-stack li:hover{transform:translate(4px);border-color:var(--primary);background:var(--card);box-shadow:0 4px 12px var(--shadow)}.tech-stack a{color:var(--primary);text-decoration:none;transition:all .3s ease;padding:.35rem .75rem;border-radius:6px;background-color:var(--background-secondary);border:1px solid var(--card-border);font-weight:600;font-size:.85rem;display:inline-flex;align-items:center;gap:.35rem}.tech-stack a:hover{background:var(--primary);color:var(--card);border-color:var(--primary-dark);transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow)}.tech-stack a .tech-icon{width:.9rem;height:.9rem;margin-top:1px}.tech-pill{display:inline-block;padding:.35rem .75rem;border-radius:6px;background:var(--background-secondary);border:1px solid var(--card-border);color:var(--foreground);font-weight:600;font-size:.85rem;transition:all .3s ease}.tech-pill:hover{background:var(--accent-light);border-color:var(--accent);transform:translateY(-1px)}@media (max-width: 640px){.divider{margin:1.5rem 0}.divider-icon{width:2.5rem;height:2.5rem}.tech-stack{margin-top:1rem;padding:1rem;width:100%;margin-bottom:1rem}.tech-stack ul{gap:.5rem}.tech-stack li{padding:.75rem 1rem}}.github-link{display:flex;align-items:center;gap:.75rem;margin-top:1.5rem;padding:1rem 1.25rem;border-radius:10px;border:2px solid var(--primary);background:var(--primary);color:var(--card);text-decoration:none;font-size:.9rem;font-weight:600;transition:all .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 4px 12px var(--shadow)}.github-link .tech-icon:first-child{width:1.2rem;height:1.2rem}.github-link .tech-icon:last-child{width:.9rem;height:.9rem;margin-left:.25rem;margin-top:1px}.github-link:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 8px 24px var(--shadow-strong);background:var(--primary-dark);border-color:var(--primary-dark)}@media (max-width: 640px){.divider{margin:1.5rem 0}.divider-icon{width:2.5rem;height:2.5rem}.tech-stack{margin-top:1rem;padding:1rem;width:100%;margin-bottom:1rem}.tech-stack ul{gap:.5rem}.tech-stack li,.github-link{padding:.75rem 1rem}}.social-links{display:flex;gap:1rem;margin-bottom:1.5rem;width:100%}.social-card{flex:1;display:flex;align-items:center;justify-content:center;padding:1.25rem;background:var(--card);border-radius:12px;color:var(--primary);transition:all .4s cubic-bezier(.34,1.56,.64,1);border:1px solid var(--card-border);box-shadow:0 2px 6px var(--shadow);position:relative;overflow:hidden}.social-card:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,var(--primary) 0%,var(--accent) 100%);opacity:0;transition:opacity .4s ease}.social-card:hover:before{opacity:.15}.social-card:hover{transform:translateY(-6px) scale(1.05);box-shadow:0 8px 24px var(--shadow-strong);border-color:var(--primary)}.social-icon{width:1.75rem;height:1.75rem;position:relative;z-index:1;transition:transform .4s cubic-bezier(.34,1.56,.64,1)}.social-card:hover .social-icon{transform:rotate(-10deg) scale(1.1)}.x-logo{filter:invert(1)}.dark .x-logo{filter:invert(0)}.linkedin-light{display:block}.linkedin-dark,.dark .linkedin-light{display:none}.dark .linkedin-dark{display:block}@media (max-width: 640px){.social-links{width:calc(100% - 1.5rem)}.social-card{padding:1rem}.social-icon{width:1.5rem;height:1.5rem}}.publications-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem}.publications-header-icon{width:1.5rem;height:1.5rem;color:var(--primary)}.publications-header h2{font-family:var(--font-display);font-size:1.5rem;font-weight:400;color:var(--foreground);margin:0;letter-spacing:-.01em}.publications-expand-button{background:none;border:none;padding:.5rem;cursor:pointer;color:var(--primary);border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.34,1.56,.64,1)}.publications-expand-button:hover{background:var(--background-secondary);transform:scale(1.1)}.publications-expand-button i{transition:transform .3s ease;color:var(--primary)}.mt-4.mb-8.p-3 .text-xs.text-gray-400{color:var(--foreground-muted)!important}.year-filter,.wipfli-filter{font-family:var(--font-body);font-weight:600;transition:all .3s cubic-bezier(.34,1.56,.64,1);cursor:pointer;border:2px solid var(--card-border)}.year-filter{background:var(--background-secondary);color:var(--foreground);border-color:var(--card-border)}.year-filter:hover{background:var(--primary);color:var(--card);border-color:var(--primary);transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow)}.year-filter.active-filter{background:var(--primary)!important;color:var(--card)!important;border-color:var(--primary-dark)!important;box-shadow:0 4px 12px var(--shadow)}.wipfli-toggle-container{display:inline-flex;align-items:center}.wipfli-toggle{display:flex;align-items:center;gap:.75rem;background:transparent;border:none;cursor:pointer;padding:.5rem .75rem;border-radius:8px;transition:all .3s ease;font-family:var(--font-body)}.wipfli-toggle:hover{background:var(--background-secondary)}.wipfli-toggle-label{font-size:.85rem;font-weight:600;color:var(--foreground);white-space:nowrap;transition:color .3s ease}.wipfli-toggle-switch{position:relative;width:42px;height:22px;background:var(--card-border);border-radius:11px;transition:background .3s ease;flex-shrink:0}.wipfli-toggle-slider{position:absolute;top:2px;left:2px;width:18px;height:18px;background:var(--foreground-muted);border-radius:50%;transition:all .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 2px 4px var(--shadow)}.wipfli-toggle.active .wipfli-toggle-switch{background:var(--primary)}.wipfli-toggle.active .wipfli-toggle-slider{transform:translate(20px);background:var(--card)}.wipfli-toggle.active .wipfli-toggle-label{color:var(--primary)}.wipfli-toggle:hover .wipfli-toggle-slider{box-shadow:0 4px 8px var(--shadow-strong);transform:scale(1.05)}.wipfli-toggle.active:hover .wipfli-toggle-slider{transform:translate(20px) scale(1.05)}.publication-item{background:var(--card)!important;border:1px solid var(--card-border)!important;border-left:3px solid var(--primary)!important;border-radius:12px!important;box-shadow:0 2px 6px var(--shadow)!important;transition:all .3s cubic-bezier(.34,1.56,.64,1)!important;position:relative;overflow:hidden}.publication-item:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,var(--primary) 0%,var(--accent) 100%);opacity:0;transition:opacity .3s ease;z-index:0;pointer-events:none}.publication-item:hover:before{opacity:.06}.publication-item:hover{transform:translate(4px) translateY(-3px)!important;box-shadow:0 8px 20px var(--shadow-strong)!important;border-left-width:4px!important}.publication-item h4{color:var(--foreground)!important;font-weight:600!important;position:relative;z-index:1}.publication-item p{color:var(--foreground-muted)!important;position:relative;z-index:1}.publication-item span{position:relative;z-index:1;transition:all .3s ease}.publication-item span.border-emerald-400{border-color:#34d399!important;color:#34d399!important;background:transparent!important}.publication-item span.border-purple-400{border-color:#c084fc!important;color:#c084fc!important;background:transparent!important}.publication-item span.border-orange-400{border-color:#fb923c!important;color:#fb923c!important;background:transparent!important}.publication-link-btn{background:var(--primary)!important;color:var(--card)!important;transition:all .3s cubic-bezier(.34,1.56,.64,1)!important;position:absolute;z-index:2;border-radius:6px!important}.publication-item:hover .publication-link-btn{background:var(--primary-dark)!important;transform:translateY(-3px) scale(1.08)!important;box-shadow:0 6px 16px var(--shadow-strong)!important}.publication-link-btn:hover{background:var(--primary-dark)!important;transform:translateY(-3px) scale(1.08) rotate(5deg)!important;box-shadow:0 6px 16px var(--shadow-strong)!important}.mt-4.mb-8.p-3{margin:3rem 0!important;padding:2rem 1.75rem!important;background:var(--card)!important;border:1px solid var(--card-border)!important;border-radius:16px!important;box-shadow:0 2px 8px var(--shadow),0 1px 2px var(--shadow)!important;animation:slideInPublications .8s ease-out 1.1s backwards}@keyframes slideInPublications{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 640px){.mt-4.mb-8.p-3{padding:1.5rem 1rem!important;margin:2rem 0!important}.publications-header h2{font-size:1.25rem}.publication-item{min-height:130px!important}.year-filter{font-size:.75rem;padding:.5rem .75rem}.wipfli-toggle{padding:.4rem .5rem}.wipfli-toggle-label{font-size:.75rem}.wipfli-toggle-switch{width:38px;height:20px}.wipfli-toggle-slider{width:16px;height:16px}.wipfli-toggle.active .wipfli-toggle-slider{transform:translate(18px)}.wipfli-toggle.active:hover .wipfli-toggle-slider{transform:translate(18px) scale(1.05)}}.causes-section{margin:3rem 0;padding:2rem 1.75rem;background:var(--card);border:1px solid var(--card-border);border-radius:16px;box-shadow:0 2px 8px var(--shadow),0 1px 2px var(--shadow);animation:slideInCauses .8s ease-out 1.4s backwards}.causes-expand-button{background:none;border:none;padding:.5rem;cursor:pointer;color:var(--primary);border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.34,1.56,.64,1)}.causes-expand-button:hover{background:var(--background-secondary);transform:scale(1.1)}.causes-expand-button i{transition:transform .3s ease;color:var(--primary)}@keyframes slideInCauses{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.causes-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem}.causes-header-icon{width:1.5rem;height:1.5rem;color:var(--primary)}.causes-header h2{font-family:var(--font-display);font-size:1.5rem;font-weight:400;color:var(--foreground);margin:0;letter-spacing:-.01em}.causes-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}.cause-card{display:flex;align-items:center;gap:1rem;padding:1.25rem 1rem;background:var(--background-secondary);border:1px solid var(--card-border);border-radius:12px;text-decoration:none;color:var(--card-foreground);transition:all .4s cubic-bezier(.34,1.56,.64,1);position:relative;overflow:hidden}.cause-card:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,var(--primary) 0%,var(--accent) 100%);opacity:0;transition:opacity .4s ease;z-index:0}.cause-card:hover:before{opacity:.08}.cause-card:hover{transform:translate(8px) translateY(-4px);box-shadow:0 8px 20px var(--shadow-strong);border-color:var(--primary)}.cause-icon-wrapper{display:flex;align-items:center;justify-content:center;width:3rem;height:3rem;background:var(--card);border-radius:10px;border:2px solid var(--card-border);flex-shrink:0;transition:all .4s cubic-bezier(.34,1.56,.64,1);position:relative;z-index:1}.cause-card:hover .cause-icon-wrapper{border-color:var(--primary);background:var(--primary);transform:rotate(-5deg) scale(1.05)}.cause-logo{width:2rem;height:2rem;-o-object-fit:contain;object-fit:contain;filter:brightness(0) saturate(100%) invert(48%) sepia(79%) saturate(469%) hue-rotate(333deg) brightness(91%) contrast(88%);transition:filter .4s ease}.cause-card:hover .cause-logo{filter:brightness(0) saturate(100%) invert(100%)}.cause-content{flex:1;min-width:0;position:relative;z-index:1}.cause-name{font-size:1.1rem;font-weight:600;color:var(--foreground);margin:0 0 .25rem;letter-spacing:-.01em}.cause-description{font-size:.85rem;color:var(--foreground-muted);margin:0;line-height:1.4}.cause-link-icon{width:1.25rem;height:1.25rem;color:var(--primary);opacity:.5;transition:all .4s cubic-bezier(.34,1.56,.64,1);flex-shrink:0;position:relative;z-index:1}.cause-card:hover .cause-link-icon{opacity:1;transform:translate(4px,-4px) rotate(-5deg)}@media (max-width: 640px){.causes-section{padding:1.5rem 1rem;margin:2rem 0}.causes-header h2{font-size:1.25rem}.causes-grid{grid-template-columns:1fr;gap:.75rem}.cause-card{padding:1rem .875rem}.cause-icon-wrapper{width:2.5rem;height:2.5rem}.cause-logo{width:1.5rem;height:1.5rem}.cause-name{font-size:1rem}.cause-description{font-size:.8rem}}.hover\:-translate-y-0:hover{--tw-translate-y: -0px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:-translate-y-0\.5:hover{--tw-translate-y: -.125rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:bg-blue-700:hover{--tw-bg-opacity: 1;background-color:rgb(29 78 216 / var(--tw-bg-opacity))}.hover\:bg-white\/10:hover{background-color:#ffffff1a}.hover\:text-blue-800:hover{--tw-text-opacity: 1;color:rgb(30 64 175 / var(--tw-text-opacity))}.hover\:shadow-md:hover{--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.focus\:border-blue-500:focus{--tw-border-opacity: 1;border-color:rgb(59 130 246 / var(--tw-border-opacity))}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-2:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus\:ring-blue-500:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(59 130 246 / var(--tw-ring-opacity))}.focus\:ring-offset-2:focus{--tw-ring-offset-width: 2px}@media (min-width: 640px){.sm\:p-8{padding:2rem}}@media (min-width: 1024px){.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width: 1280px){.xl\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}
