:root{--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", "Cascadia Code", monospace;--color-bg: #0f0f0f;--color-bg-secondary: #1a1a1a;--color-text: #e0e0e0;--color-text-muted: #888;--color-accent: #6ee7b7;--color-accent-hover: #34d399;--color-border: #2a2a2a;--color-link: #6ee7b7;--color-link-hover: #34d399;--max-width: 720px;--spacing-xs: 0.25rem;--spacing-sm: 0.5rem;--spacing-md: 1rem;--spacing-lg: 2rem;--spacing-xl: 4rem;--ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);--ease-elastic: cubic-bezier(0.68, -0.55, 0.265, 1.55);--glass-bg: rgba(26, 26, 26, 0.6);--glass-border: rgba(255, 255, 255, 0.08);--glass-blur: 16px;--glass-shadow: 0 8px 32px 0 rgba(0, 0, 0, 0.3)}@keyframes blob-bounce{0%{transform:translate(0, 0) scale(1)}33%{transform:translate(30px, -50px) scale(1.1)}66%{transform:translate(-20px, 20px) scale(.9)}100%{transform:translate(0, 0) scale(1)}}@keyframes blob-bounce-2{0%{transform:translate(0, 0) scale(1)}33%{transform:translate(-30px, 50px) scale(1.1)}66%{transform:translate(20px, -20px) scale(.9)}100%{transform:translate(0, 0) scale(1)}}body{position:relative;overflow-x:hidden}.blob-wrapper{position:fixed;z-index:-1;pointer-events:none;transition:transform .8s cubic-bezier(.2, .8, .2, 1);will-change:transform}.blob-1-wrapper{top:-100px;left:-100px}.blob-2-wrapper{bottom:-100px;right:-100px}.blob{border-radius:50%;filter:blur(80px)}.blob-1{width:600px;height:600px;background:radial-gradient(circle, rgba(110,231,183,.15), rgba(0,0,0,0) 70%);animation:blob-bounce 20s infinite ease-in-out alternate}.blob-2{width:500px;height:500px;background:radial-gradient(circle, rgba(52,211,153,.1), rgba(0,0,0,0) 70%);animation:blob-bounce-2 25s infinite ease-in-out alternate}@keyframes squish-in{0%{opacity:0;transform:scale(.92) translateY(20px)}60%{opacity:1;transform:scale(1.02) translateY(-4px)}80%{transform:scale(.98) translateY(2px)}100%{opacity:1;transform:scale(1) translateY(0)}}@keyframes fade-slide-up{0%{opacity:0;transform:translateY(30px)}100%{opacity:1;transform:translateY(0)}}@keyframes hero-pop{0%{opacity:0;transform:scale(.8) translateY(40px)}50%{opacity:1;transform:scale(1.03) translateY(-6px)}70%{transform:scale(.98) translateY(3px)}100%{opacity:1;transform:scale(1) translateY(0)}}@keyframes icon-wobble{0%{transform:rotate(0deg) scale(1)}25%{transform:rotate(-6deg) scale(1.1)}50%{transform:rotate(4deg) scale(1.05)}75%{transform:rotate(-2deg) scale(1.02)}100%{transform:rotate(0deg) scale(1)}}@keyframes pulse-glow{0%, 100%{box-shadow:0 0 0 0 rgba(110,231,183,0)}50%{box-shadow:0 0 20px 4px rgba(110,231,183,.15)}}.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s var(--ease-elastic),transform .7s var(--ease-spring)}.reveal.revealed{opacity:1;transform:translateY(0)}.reveal-delay-1{transition-delay:.1s}.reveal-delay-2{transition-delay:.2s}.reveal-delay-3{transition-delay:.3s}*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (hover: hover){html{cursor:none}}.cursor-dot,.cursor-outline{position:fixed;top:0;left:0;transform:translate(-50%, -50%);border-radius:50%;z-index:9999;pointer-events:none;display:none}@media (hover: hover){.cursor-dot,.cursor-outline{display:block}}.cursor-dot{width:8px;height:8px;background-color:var(--color-accent)}.cursor-outline{width:40px;height:40px;border:1px solid rgba(110,231,183,.5);transition:width .2s,height .2s,background-color .2s}body.hovering .cursor-outline{width:60px;height:60px;background-color:rgba(110,231,183,.1);border-color:rgba(0,0,0,0);backdrop-filter:blur(2px)}.char-reveal{display:inline-block;overflow:hidden;vertical-align:bottom}.char-reveal span{display:inline-block;transform:translateY(100%);transition:transform .5s var(--ease-elastic)}.char-reveal.revealed span{transform:translateY(0)}body{font-family:var(--font-sans);background-color:var(--color-bg);color:var(--color-text);line-height:1.7;min-height:100vh;display:flex;flex-direction:column}a{color:var(--color-link);text-decoration:none;transition:color .3s var(--ease-spring),transform .3s var(--ease-spring);display:inline-block}a:hover{color:var(--color-link-hover)}a:active{transform:scale(.97)}img{max-width:100%;height:auto;border-radius:4px}code{font-family:var(--font-mono);font-size:.9em;background:var(--color-bg-secondary);padding:.15em .4em;border-radius:4px}pre{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:8px;padding:var(--spacing-md);overflow-x:auto;margin:var(--spacing-lg) 0;line-height:1.5}pre code{background:none;padding:0;font-size:.85rem}.giallo-l{display:inline-block;min-height:1lh;width:100%}.giallo-ln{display:inline-block;user-select:none;margin-right:.4em;padding:.4em;min-width:3ch;text-align:right;opacity:.8}blockquote{border-left:3px solid var(--color-accent);padding-left:var(--spacing-md);margin:var(--spacing-lg) 0;color:var(--color-text-muted);font-style:italic}hr{border:none;border-top:1px solid var(--color-border);margin:var(--spacing-xl) 0}.site-header{border-bottom:1px solid var(--color-border);padding:var(--spacing-md) var(--spacing-lg)}.nav-container{max-width:var(--max-width);margin:0 auto;display:flex;justify-content:space-between;align-items:center}.site-title{font-size:1.1rem;font-weight:700;color:var(--color-text);letter-spacing:-.02em;transition:color .3s var(--ease-spring),transform .3s var(--ease-spring)}.site-title:hover{color:var(--color-accent);transform:scale(1.03)}.site-title:active{transform:scale(.96)}.nav-links{list-style:none;display:flex;gap:var(--spacing-lg)}.nav-links a{color:var(--color-text-muted);font-size:.9rem;font-weight:500;position:relative;transition:color .3s var(--ease-spring),transform .3s var(--ease-spring)}.nav-links a::after{content:"";position:absolute;bottom:-4px;left:50%;width:0;height:2px;background:var(--color-accent);border-radius:1px;transition:width .4s var(--ease-spring),left .4s var(--ease-spring)}.nav-links a:hover{color:var(--color-accent);transform:translateY(-2px)}.nav-links a:hover::after{width:100%;left:0}.nav-links a:active{transform:translateY(0) scale(.95)}.main-content{max-width:var(--max-width);margin:0 auto;padding:var(--spacing-xl) var(--spacing-lg);flex:1;width:100%}.hero{margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-xl);border-bottom:1px solid var(--glass-border);animation:hero-pop 1s var(--ease-elastic) both;position:relative}.hero h1{font-size:3.5rem;font-weight:800;letter-spacing:-.04em;line-height:1.1;margin-bottom:var(--spacing-md);color:#e0e0e0;text-shadow:0 10px 30px rgba(0,0,0,.15)}.hero .highlight{background:linear-gradient(135deg, var(--color-accent) 0%, #34d399 100%);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:rgba(0,0,0,0);display:inline-block;transition:transform .4s var(--ease-spring);text-shadow:none;color:rgba(0,0,0,0)}.hero .highlight:hover{transform:scale(1.1) rotate(-2deg)}.hero .hero-subtitle{font-size:1.25rem;color:var(--color-text-muted);line-height:1.6;margin-bottom:var(--spacing-lg);animation:fade-slide-up .8s var(--ease-elastic) both;animation-delay:.2s;max-width:600px}.hero .hero-cta{display:flex;gap:var(--spacing-md);animation:fade-slide-up .8s var(--ease-elastic) both;animation-delay:.4s}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.8rem 2rem;border-radius:9999px;font-size:.95rem;font-weight:600;cursor:pointer;transition:transform .4s var(--ease-elastic),box-shadow .4s var(--ease-spring),background .3s ease,color .3s ease;will-change:transform;position:relative;overflow:hidden;letter-spacing:.01em;z-index:1}.btn:hover{transform:translateY(-4px) scale(1.02)}.btn:active{transform:scale(.92);transition-duration:.1s}.btn-primary{background:var(--color-accent);color:var(--color-bg) !important;box-shadow:0 4px 15px rgba(110,231,183,.3)}.btn-primary:hover{background:var(--color-accent-hover);box-shadow:0 12px 30px rgba(110,231,183,.5);color:var(--color-bg) !important}.btn-secondary{background:rgba(255,255,255,.03);color:var(--color-text);border:1px solid var(--glass-border);backdrop-filter:blur(4px)}.btn-secondary:hover{border-color:var(--color-accent);color:var(--color-accent);background:rgba(110,231,183,.05);box-shadow:0 8px 25px rgba(0,0,0,.2)}.projects{margin-bottom:var(--spacing-xl)}.projects h2{font-size:1.5rem;font-weight:700;margin-bottom:var(--spacing-lg)}.project-card{border:1px solid var(--glass-border);border-radius:24px;padding:2.5rem;margin-bottom:var(--spacing-lg);background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));box-shadow:var(--glass-shadow);transition:transform .1s linear;will-change:transform;transform-style:preserve-3d;perspective:1000px;position:relative;overflow:hidden}.project-card::after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(125deg, rgba(255,255,255,.05) 0%, rgba(0,0,0,0) 40%, rgba(0,0,0,0) 100%);pointer-events:none}.project-card:hover{border-color:rgba(110,231,183,.3)}.project-card:hover .project-icon{transform:scale(1.1) rotate(-5deg);background:rgba(110,231,183,.15);box-shadow:0 0 20px rgba(110,231,183,.2)}.project-card p{color:var(--color-text-muted);font-size:1rem;line-height:1.7;margin-bottom:var(--spacing-md);transform:translateZ(20px)}.project-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;transform:translateZ(30px)}.project-header .project-icon{font-size:1.2rem;font-family:var(--font-mono);font-weight:700;color:var(--color-accent);background:rgba(110,231,183,.05);border:1px solid rgba(110,231,183,.1);width:3rem;height:3rem;display:flex;align-items:center;justify-content:center;border-radius:12px;flex-shrink:0;transition:all .4s var(--ease-elastic)}.project-header h3{font-size:1.4rem;font-weight:800;margin:0}.project-stack{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:1.5rem;transform:translateZ(25px)}.stack-tag{font-size:.8rem;font-family:var(--font-mono);color:var(--color-accent);background:rgba(110,231,183,.05);border:1px solid rgba(110,231,183,.15);padding:.3em .8em;border-radius:99px;transition:transform .3s var(--ease-spring),background .3s ease,box-shadow .3s ease;display:inline-block}.stack-tag:hover{transform:translateY(-2px) scale(1.05);background:rgba(110,231,183,.15);box-shadow:0 4px 12px rgba(110,231,183,.1)}.project-highlights{list-style:none;margin-bottom:var(--spacing-md)}.project-highlights li{position:relative;padding-left:1.2em;font-size:.9rem;color:var(--color-text-muted);margin-bottom:var(--spacing-xs)}.project-highlights li::before{content:"~";position:absolute;left:0;color:var(--color-accent);font-family:var(--font-mono)}.project-links{font-size:.85rem;font-family:var(--font-mono)}.project-links a{color:var(--color-accent);opacity:.85;transition:opacity .3s ease,transform .3s var(--ease-spring),color .3s ease}.project-links a:hover{opacity:1;transform:translateX(3px)}.project-links .link-sep{color:var(--color-text-muted);margin:0 var(--spacing-xs)}.recent-posts h2,.blog-section h1{font-size:1.5rem;font-weight:700;margin-bottom:var(--spacing-lg)}.post-list{list-style:none}.post-item{padding:var(--spacing-lg) 0;border-bottom:1px solid var(--color-border);transition:transform .3s var(--ease-spring)}.post-item:hover{transform:translateX(6px)}.post-item:last-child{border-bottom:none}.post-item time{font-size:.85rem;color:var(--color-text-muted);font-family:var(--font-mono)}.post-item h2,.post-item h3{font-size:1.2rem;font-weight:600;margin:var(--spacing-xs) 0;line-height:1.4}.post-item h2 a,.post-item h3 a{color:var(--color-text)}.post-item h2 a:hover,.post-item h3 a:hover{color:var(--color-accent)}.post-item p{color:var(--color-text-muted);font-size:.95rem;margin-top:var(--spacing-xs)}.tags{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.tag{font-size:.8rem;color:var(--color-accent);font-family:var(--font-mono);opacity:.8;transition:opacity .3s ease,transform .3s var(--ease-spring)}.tag:hover{opacity:1;transform:scale(1.1) translateY(-2px)}.tag:active{transform:scale(.95)}.blog-post .post-header{margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.blog-post .post-header h1{font-size:2rem;font-weight:800;letter-spacing:-.02em;line-height:1.3;margin-bottom:var(--spacing-sm)}.blog-post .post-meta{color:var(--color-text-muted);font-size:.9rem;font-family:var(--font-mono)}.blog-post .post-meta .reading-time{margin-left:var(--spacing-xs)}.blog-post .post-content h2{font-size:1.4rem;font-weight:700;margin-top:var(--spacing-xl);margin-bottom:var(--spacing-md)}.blog-post .post-content h3{font-size:1.2rem;font-weight:600;margin-top:var(--spacing-lg);margin-bottom:var(--spacing-sm)}.blog-post .post-content p{margin-bottom:var(--spacing-md)}.blog-post .post-content ul,.blog-post .post-content ol{margin-bottom:var(--spacing-md);padding-left:var(--spacing-lg)}.blog-post .post-content ul li,.blog-post .post-content ol li{margin-bottom:var(--spacing-xs)}.blog-post .post-content strong{font-weight:600}.blog-post .post-footer{margin-top:var(--spacing-xl);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.blog-post .post-nav{display:flex;justify-content:space-between;gap:var(--spacing-md)}.blog-post .post-nav a{color:var(--color-text-muted);font-size:.9rem}.blog-post .post-nav a:hover{color:var(--color-accent)}.blog-post .post-nav .nav-next{margin-left:auto}.section-page h1,.page h1{font-size:2rem;font-weight:800;margin-bottom:var(--spacing-lg)}.section-page .section-content h2,.section-page .page-content h2,.page .section-content h2,.page .page-content h2{font-size:1.4rem;margin-top:var(--spacing-xl);margin-bottom:var(--spacing-md)}.section-page .section-content p,.section-page .page-content p,.page .section-content p,.page .page-content p{margin-bottom:var(--spacing-md)}.section-page .section-content ul,.section-page .section-content ol,.section-page .page-content ul,.section-page .page-content ol,.page .section-content ul,.page .section-content ol,.page .page-content ul,.page .page-content ol{padding-left:var(--spacing-lg);margin-bottom:var(--spacing-md)}.taxonomy-list h1{font-size:1.5rem;font-weight:700;margin-bottom:var(--spacing-lg)}.taxonomy-list .taxonomy-items{list-style:none}.taxonomy-list .taxonomy-items li{padding:var(--spacing-sm) 0}.taxonomy-list .taxonomy-items li a{font-weight:500}.taxonomy-list .taxonomy-items li .count{color:var(--color-text-muted);font-size:.85rem}.taxonomy-single h1{font-size:1.5rem;font-weight:700;margin-bottom:var(--spacing-lg)}.taxonomy-single h1 .highlight{color:var(--color-accent)}.error-page{text-align:center;padding:var(--spacing-xl) 0}.error-page h1{font-size:5rem;font-weight:900;color:var(--color-accent);margin-bottom:var(--spacing-md)}.error-page p{color:var(--color-text-muted);margin-bottom:var(--spacing-lg)}.site-footer{border-top:1px solid var(--color-border);padding:var(--spacing-lg);margin-top:auto}.footer-container{max-width:var(--max-width);margin:0 auto;display:flex;justify-content:space-between;align-items:center;font-size:.85rem;color:var(--color-text-muted)}.footer-links{display:flex;gap:var(--spacing-md)}.footer-links a{color:var(--color-text-muted);transition:color .3s var(--ease-spring),transform .3s var(--ease-spring)}.footer-links a:hover{color:var(--color-accent);transform:translateY(-2px)}.footer-links a:active{transform:scale(.93)}@media (max-width: 640px){.hero h1{font-size:1.8rem}.hero-subtitle{font-size:1rem}.hero-cta{flex-direction:column}.nav-container{flex-direction:column;gap:var(--spacing-sm)}.footer-container{flex-direction:column;gap:var(--spacing-sm);text-align:center}.blog-post .post-header h1{font-size:1.5rem}.post-nav{flex-direction:column}}@media (prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}.reveal{opacity:1;transform:none}}