:root{--color-primary: #10b981;--color-primary-hover: #059669;--color-primary-rgb: 16, 185, 129;--color-text: #1f2937;--color-text-light: #6b7280;--color-text-lighter: #9ca3af;--color-bg: #ffffff;--color-bg-gray: #f9fafb;--color-bg-dark: #111827;--color-border: #e5e7eb;--color-card-bg: rgba(255, 255, 255, .92);--color-card-bg-solid: #ffffff;--color-card-hover-bg: rgba(255, 255, 255, .98);--color-card-shadow-soft: rgba(15, 23, 42, .08);--color-card-shadow-accent: rgba(var(--color-primary-rgb), .08);--color-header-bg: rgba(255, 255, 255, .85);--color-header-border: rgba(229, 231, 235, .5);--color-floating-bg: rgba(255, 255, 255, .9);--color-floating-border: rgba(0, 0, 0, .08);--color-pager-bg: rgba(255, 255, 255, .6);--color-pager-border: rgba(0, 0, 0, .08);--color-pager-disabled-bg: rgba(0, 0, 0, .05);--color-panel-shadow: rgba(0, 0, 0, .12);--color-panel-border: rgba(0, 0, 0, .06);--color-modal-close-bg: rgba(255, 255, 255, .8);--color-modal-close-border: rgba(0, 0, 0, .08);--color-pull-bg: rgba(255, 255, 255, .95);--color-preview-shadow: rgba(0, 0, 0, .15);--color-preview-border: rgba(0, 0, 0, .08);--color-shimmer-1: rgba(0, 0, 0, .03);--color-shimmer-2: rgba(0, 0, 0, .06);--color-skeleton-1: rgba(0, 0, 0, .05);--color-skeleton-2: rgba(0, 0, 0, .1);--shadow-wrapper: 0 1px 8px rgba(0, 0, 0, .35);--shadow-wrapper-mobile: 0 1px 3px rgba(0, 0, 0, .15);--color-wip-border: rgba(202, 168, 40, .5);--color-wip-bg: rgba(255, 248, 220, .4);--color-wip-badge-bg: rgba(202, 168, 40, .12);--color-wip-text: #a08520;--color-wip-overlay: rgba(255, 248, 220, .55)}[data-theme=dark]{--color-text: #e4f1e9;--color-text-light: #9cb4a8;--color-text-lighter: #6f8b7d;--color-bg: #070d0a;--color-bg-gray: #0d1511;--color-bg-dark: #040906;--color-border: #1e3229;--color-card-bg: rgba(19, 29, 24, .92);--color-card-bg-solid: #121d18;--color-card-hover-bg: rgba(26, 40, 32, .98);--color-card-shadow-soft: rgba(0, 0, 0, .45);--color-card-shadow-accent: rgba(var(--color-primary-rgb), .18);--color-header-bg: rgba(8, 13, 11, .9);--color-header-border: rgba(41, 64, 53, .55);--color-floating-bg: rgba(10, 16, 13, .93);--color-floating-border: rgba(65, 101, 82, .34);--color-pager-bg: rgba(20, 31, 25, .72);--color-pager-border: rgba(91, 131, 110, .25);--color-pager-disabled-bg: rgba(255, 255, 255, .04);--color-panel-shadow: rgba(0, 0, 0, .55);--color-panel-border: rgba(91, 131, 110, .2);--color-modal-close-bg: rgba(16, 24, 20, .88);--color-modal-close-border: rgba(91, 131, 110, .22);--color-pull-bg: rgba(14, 22, 18, .95);--color-preview-shadow: rgba(0, 0, 0, .58);--color-preview-border: rgba(91, 131, 110, .25);--color-shimmer-1: rgba(255, 255, 255, .03);--color-shimmer-2: rgba(255, 255, 255, .06);--color-skeleton-1: rgba(255, 255, 255, .05);--color-skeleton-2: rgba(255, 255, 255, .1);--shadow-wrapper: 0 1px 10px rgba(0, 0, 0, .75);--shadow-wrapper-mobile: 0 1px 4px rgba(0, 0, 0, .55);--color-wip-border: rgba(202, 168, 40, .4);--color-wip-bg: rgba(202, 168, 40, .08);--color-wip-badge-bg: rgba(202, 168, 40, .15);--color-wip-text: #c9a832;--color-wip-overlay: rgba(202, 168, 40, .1)}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:rgba(16,185,129,.15)}:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;font-weight:400;color-scheme:light;color:var(--color-text);background-color:var(--color-bg-gray);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}[data-theme=dark]{color-scheme:dark}svg{shape-rendering:geometricPrecision;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.fa,.fas,.far,.fab,.fal,.fad,.fat{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}:root{scrollbar-width:none}*,#root{scrollbar-width:none}body{margin:0;min-width:320px;height:100vh;background-color:var(--color-bg-gray);overflow:auto;transition:background-color .3s ease,color .3s ease}#root{height:100vh;position:relative;overflow:auto}body:has(.about-page){overflow:hidden}#root:has(.about-page){overflow:hidden;height:100vh}body:has(.project-detail-page){overflow:hidden}#root:has(.project-detail-page){overflow:hidden;height:100vh}@media(min-width:1025px){body:has(.app){overflow:hidden}#root:has(.app){overflow:hidden;height:100vh}}@media(max-width:768px){body,#root{height:auto;min-height:100vh;overflow:auto}}body.modal-open{position:fixed!important;width:100%!important;overflow:hidden!important;-webkit-overflow-scrolling:touch}#root.modal-open{overflow:hidden!important}.page-transition{animation:fadeInUp .8s cubic-bezier(.16,1,.3,1) forwards;flex:1}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:none}}.page-exit{animation:fadeOutDown .6s cubic-bezier(.7,0,.84,0) forwards}@keyframes fadeOutDown{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-30px)}}.language-switcher{display:flex;align-items:center;gap:.25rem;background:var(--color-bg-gray);border-radius:.5rem;padding:.25rem;border:1px solid var(--color-border);transition:all .15s ease}.language-switcher:hover{border-color:var(--color-primary);box-shadow:0 2px 8px rgba(var(--color-primary-rgb),.1)}.language-btn{background:transparent;border:none;padding:.25rem .5rem;border-radius:.25rem;font-size:.85rem;font-weight:500;color:var(--color-text-light);cursor:pointer;transition:all .15s ease;min-width:32px;text-align:center}.language-btn:hover{color:var(--color-primary);background:rgba(var(--color-primary-rgb),.1)}.language-btn.active{background:var(--color-primary);color:#fff;font-weight:600;box-shadow:0 2px 4px rgba(var(--color-primary-rgb),.3)}.language-btn:focus{outline:none;box-shadow:0 0 0 2px rgba(var(--color-primary-rgb),.3)}.separator{color:var(--color-text-lighter);font-size:.8rem;font-weight:300;-webkit-user-select:none;user-select:none}@media(max-width:768px){.language-switcher{padding:.25rem;gap:2px}.language-btn{padding:.25rem;font-size:.8rem;min-width:28px}.separator{font-size:.75rem}}.theme-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:.5rem;border:1px solid var(--color-border);background:linear-gradient(180deg,var(--color-bg-gray) 0%,var(--color-card-bg-solid) 100%);cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease;position:relative;overflow:hidden;padding:0;-webkit-tap-highlight-color:transparent}.theme-toggle:hover{border-color:var(--color-primary);box-shadow:0 2px 8px rgba(var(--color-primary-rgb),.15)}.theme-toggle:active{transform:scale(.95)}.theme-toggle:focus{outline:none}.theme-toggle:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.theme-icon{position:absolute;display:flex;align-items:center;justify-content:center;font-size:1rem;color:var(--color-text-light);transition:transform .35s cubic-bezier(.23,1,.32,1),opacity .35s cubic-bezier(.23,1,.32,1);opacity:0;transform:scale(.5) rotate(-90deg)}.theme-icon.active{opacity:1;transform:scale(1) rotate(0);color:var(--color-primary)}[data-theme=dark] .theme-toggle{border-color:rgba(var(--color-primary-rgb),.26);box-shadow:inset 0 0 0 1px rgba(var(--color-primary-rgb),.08)}@media(max-width:768px){.theme-toggle{width:33px;height:33px}.theme-icon{font-size:.9rem}}.app-header{position:sticky;top:5rem;left:0;right:0;z-index:9999;transition:background-color .25s ease,backdrop-filter .25s ease,border-color .25s ease;background-color:transparent;-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px);height:70px;display:flex;align-items:center}.app-header.scrolled{top:0;background-color:var(--color-header-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--color-header-border)}.header-content{display:flex;align-items:center;justify-content:space-between;max-width:1200px;margin:0 auto;width:100%;padding:1rem 3rem;height:100%}.header-left{flex:1;display:flex;align-items:center}.header-title{font-size:1.25rem;font-weight:600;color:var(--color-text);position:relative;overflow:hidden;height:1.5rem;display:flex;align-items:center;min-width:150px}.header-title .title-item{display:block;white-space:nowrap;animation:fadeInScale .4s cubic-bezier(.16,1,.3,1) forwards}.app-header:not(.scrolled) .header-title{display:none}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.header-center{flex:1;display:flex;justify-content:center;align-items:center}.header-right{flex:1;display:flex;justify-content:flex-end;align-items:center;gap:1rem}.about-button{display:flex;align-items:center;justify-content:center;gap:.5rem;min-width:40px;width:40px;height:33px;color:var(--color-text-light);text-decoration:none;transition:width .15s ease,padding .15s ease,background-color .15s ease,color .15s ease;border-radius:.5rem;overflow:hidden;padding:0;animation:aboutButtonEnter .4s cubic-bezier(.23,1,.32,1) forwards;-webkit-tap-highlight-color:rgba(16,185,129,.2);-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.about-button svg{font-size:1.3rem;flex-shrink:0}.about-button .button-text{opacity:0;max-width:0;overflow:hidden;white-space:nowrap;font-size:.9rem;font-weight:500;transform:translate(10px);transition:opacity .15s ease,transform .15s ease,max-width .15s ease}.about-button:hover{color:var(--color-primary);background-color:rgba(var(--color-primary-rgb),.08);padding:0 .8rem;width:auto}.about-button:hover .button-text{opacity:1;max-width:200px;transform:translate(0)}.about-button:active{transform:scale(.98)}@keyframes slideInLeft{0%{opacity:0;transform:translate(10px)}to{opacity:1;transform:translate(0)}}@keyframes slideOutRight{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(10px)}}@keyframes aboutButtonEnter{0%{opacity:0;transform:scale(.8) translate(20px)}to{opacity:1;transform:scale(1) translate(0)}}@keyframes slideInLeftText{0%{opacity:0;width:0;transform:translate(15px)}to{opacity:1;width:auto;transform:translate(0)}}.back-button{display:flex;align-items:center;gap:.5rem;color:var(--color-text-light);text-decoration:none;transition:all .15s ease;font-weight:400;-webkit-tap-highlight-color:rgba(16,185,129,.2);-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.back-button:hover{color:var(--color-primary);transform:translate(-2px)}.back-button .back-arrow{font-size:1.2rem;font-weight:600}.back-button .back-text{font-size:.9rem}.header-title{font-size:1.25rem;font-weight:600;color:var(--color-text);margin:0;text-align:center}@media(max-width:1024px){.app-header{top:1rem;left:3rem;right:3rem;z-index:9999;height:56px}.app-header.scrolled{top:0;left:0;right:0}.header-content{padding:1rem 1.5rem}.header-title{font-size:1rem}.back-button{min-width:44px;min-height:44px;padding:.5rem;margin:-.5rem;margin-right:0;border-radius:.5rem;justify-content:flex-start}.back-button:active{background-color:#10b9811a;transform:translate(-2px) scale(.98)}.back-button .back-text{display:none}.back-button .back-arrow{font-size:1.4rem}}@media(max-width:768px){.app-header{top:.5rem;left:1.5rem;right:1.5rem;z-index:9999;height:67px}.app-header.scrolled{top:0;left:0;right:0}.header-content{padding:1rem 1.5rem}.header-title{font-size:.9rem}.back-button{min-width:44px;min-height:44px;padding:.5rem;margin:-.5rem;margin-right:0;justify-content:flex-start}.back-button .back-arrow{font-size:1.4rem}}.app{height:100vh;background:var(--color-bg-gray);display:flex;flex-direction:column;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow-y:auto;overflow-x:hidden;transition:background-color .3s ease}.portfolio-container{width:100%;max-width:1200px;margin:0 auto;display:grid;grid-template-columns:minmax(320px,420px) 1fr;gap:6rem;align-items:start;padding:2rem 4rem 0;box-sizing:border-box;flex:1}.projects-section{display:flex;flex-direction:column;gap:3rem;min-height:0;height:auto;position:relative;z-index:0;overflow:visible}@media(min-width:1024px){.projects-section{max-height:calc(100vh - 12rem);overflow:visible}}.projects-header{display:flex;flex-direction:column;gap:.5rem}.projects-section:before{content:"";position:absolute;top:120px;left:0;right:0;height:36px;pointer-events:none;z-index:2;background:linear-gradient(to bottom,var(--color-bg-gray) 0%,transparent 100%);opacity:0;transition:opacity .3s ease}.projects-section.scrolled:before{opacity:1}.projects-section:after{content:"";position:absolute;bottom:0;left:0;right:10px;height:10px;pointer-events:none;z-index:2;background:linear-gradient(to bottom,transparent 0%,var(--color-bg-gray) 100%)}.projects-title{font-size:1.5rem;font-weight:600;color:var(--color-text);letter-spacing:-.01em}.projects-subtitle{max-width:34rem;font-size:1rem;color:var(--color-text-light);line-height:1.6}.projects-list{display:flex;flex-direction:column;gap:1.5rem;margin:0;padding:1rem .5rem 2rem 0;list-style:none;flex:1 1 auto;min-height:0;overflow-y:scroll;overflow-x:hidden;max-height:100%;scroll-padding:1rem;z-index:1;position:relative;scrollbar-width:auto;padding-top:0;padding-bottom:6px}.projects-list::-webkit-scrollbar{width:8px}.projects-list::-webkit-scrollbar-track{background:transparent}.projects-list::-webkit-scrollbar-thumb{background:var(--color-text-lighter);opacity:.3;border-radius:4px}.projects-list::-webkit-scrollbar-thumb:hover{opacity:.5}.projects-mobile-previews{display:flex;flex-direction:column;gap:2rem;padding:.5rem 0 2rem}.projects-mobile-preview-item{scroll-snap-align:start;scroll-snap-stop:always}.mobile-project-card{width:100%;border:1px solid var(--color-floating-border);border-radius:1rem;background:var(--color-card-bg);overflow:hidden;box-shadow:0 10px 28px var(--color-card-shadow-soft),0 8px 22px var(--color-card-shadow-accent);text-align:left;color:var(--color-text);cursor:pointer;transition:transform .15s ease,border-color .15s ease;font:inherit;appearance:none;padding:0;-webkit-tap-highlight-color:rgba(16,185,129,.12)}.mobile-project-card:hover{border-color:rgba(var(--color-primary-rgb),.38)}.mobile-project-card:active{transform:scale(.995)}.mobile-project-card:focus-visible{outline:2px solid rgba(var(--color-primary-rgb),.6);outline-offset:3px}.mobile-project-card--wip{cursor:default;border-style:dashed}.mobile-project-card__preview{position:relative;width:100%;aspect-ratio:1.24/1;background:var(--color-bg-gray);overflow:hidden}.mobile-project-card__preview.has-preview{background:var(--color-card-bg-solid)}.mobile-project-card__video{width:100%;height:100%;object-fit:cover;display:block}.mobile-project-card__video[data-loaded=false]{opacity:0}.mobile-project-card__video[data-loaded=true]{opacity:1;transition:opacity .2s ease-out}.mobile-project-card__placeholder{position:absolute;inset:0;background:linear-gradient(90deg,var(--color-skeleton-1) 0%,var(--color-skeleton-2) 50%,var(--color-skeleton-1) 100%);background-size:200% 100%;animation:skeletonLoading 1.5s infinite}.mobile-project-card__empty{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:1.25rem;color:var(--color-text-lighter);letter-spacing:.08em;text-transform:uppercase}.mobile-project-card__wip-overlay{position:absolute;inset:0;background:var(--color-wip-overlay);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center}.mobile-project-card__wip-badge{display:inline-flex;align-items:center;gap:.35rem;padding:.25rem .95rem;border-radius:999px;background:#caa8282e;color:var(--color-wip-text);font-size:.72rem;font-weight:700;letter-spacing:.09em}.mobile-project-card__info{display:flex;flex-direction:column;gap:.5rem;padding:1rem 1rem 1.5rem}.mobile-project-card__head{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.mobile-project-card__head h3{margin:0;font-size:1.25rem;font-weight:600;line-height:1.25}.mobile-project-card__head span{font-size:.75rem;color:var(--color-text-light);font-weight:600;letter-spacing:.08em;text-transform:uppercase;white-space:nowrap}.mobile-project-card__client{margin:0;color:var(--color-text-light);font-size:.88rem;letter-spacing:.04em;text-transform:uppercase}.mobile-project-card__description{margin:0;font-size:.92rem;color:var(--color-text-light);line-height:1.55}.mobile-project-card__cta{margin-top:.25rem;font-size:.78rem;font-weight:600;color:var(--color-primary);letter-spacing:.08em;text-transform:uppercase}@media(max-width:768px){.projects-list{overflow:visible;max-height:none;flex:none;padding-right:0}}.project-card{position:relative;display:flex;flex-direction:column;gap:.5rem;padding:1.5rem 2rem;border-radius:.75rem;border:1px solid var(--color-floating-border);background:var(--color-card-bg);text-align:left;color:var(--color-text);cursor:pointer;transition:border-color .15s ease,background-color .15s ease;font:inherit;appearance:none}@supports (padding: max(0px)){.project-card{padding:1.5rem 2rem}}.project-card{-webkit-tap-highlight-color:rgba(16,185,129,.1)}.project-card:not(.project-card--wip),.project-card:not(.project-card--wip) *{cursor:pointer}.project-card--wip,.project-card--wip *{cursor:default}.project-card:hover{border-color:rgba(var(--color-primary-rgb),.32);background-color:var(--color-card-hover-bg)}.project-card:focus-visible{outline:2px solid rgba(var(--color-primary-rgb),.55);outline-offset:6px;transform:translateY(-4px)}.project-card--featured{border-color:rgba(var(--color-primary-rgb),.35);background:linear-gradient(120deg,rgba(var(--color-primary-rgb),.14),var(--color-card-hover-bg));background-size:200% 200%;animation:gradientShift 8s ease-in-out infinite}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.project-card--nda{border-style:dashed}.project-card--wip{cursor:default;border:1.5px dashed var(--color-wip-border);background:var(--color-wip-bg)}.project-card--wip:hover{border-color:var(--color-wip-border);background:var(--color-wip-bg)}.project-card--wip .project-card__cta{display:none}.project-card--wip .project-card__badge--wip{display:inline-flex!important;width:fit-content;align-items:center;gap:.35rem;padding:.125rem .75rem;border-radius:999px;background:var(--color-wip-badge-bg);color:var(--color-wip-text);font-size:.75rem;font-weight:600;letter-spacing:.08em}.project-card__header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.project-card__name{font-size:1.25rem;font-weight:600;line-height:1.2}.project-card__year{font-size:.85rem;color:var(--color-text-light);font-weight:600;letter-spacing:.08em;text-transform:uppercase;white-space:nowrap}.project-card__meta{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;font-size:.95rem;color:var(--color-text-light)}.project-card__client{color:var(--color-text-light);position:relative}.project-card__badge{padding:.125rem .75rem;border-radius:999px;background:rgba(var(--color-primary-rgb),.1);color:var(--color-primary);font-size:.75rem;font-weight:600;letter-spacing:.08em;display:none}@media(max-width:768px){.project-card__badge{display:inline-block}}.project-card--nda .project-card__client .client-name{filter:blur(6px);max-width:140px;display:inline-block;overflow:hidden;white-space:nowrap}.project-card--nda .project-card__client:hover:after{content:"Protetto da NDA";position:absolute;left:50%;top:-8px;transform:translate(-50%,-100%);background:var(--color-bg-dark);color:#fff;font-size:.75rem;font-weight:600;padding:4px 8px;border-radius:6px;letter-spacing:.5px;pointer-events:none;z-index:5;white-space:nowrap;opacity:.95;box-shadow:0 6px 20px #00000026}.project-card__description{font-size:.98rem;line-height:1.65;color:var(--color-text-light)}.project-card__cta{margin-top:.25rem;font-size:.85rem;font-weight:600;color:var(--color-primary);letter-spacing:.04em;text-transform:uppercase;display:inline-flex;align-items:center;gap:.25rem;transition:transform .15s ease,color .15s ease}.project-card:hover .project-card__cta{transform:translate(4px);color:var(--color-primary-hover)}.personal-section{display:flex;flex-direction:column;align-items:flex-start;gap:2rem;padding-left:2rem}.name{font-size:2rem;font-weight:600;color:var(--color-text);line-height:1.2}.title{font-size:1.25rem;font-weight:500;color:var(--color-text);line-height:1.4;max-width:28rem}.title-accent{color:var(--color-primary)}.description{font-size:1rem;color:var(--color-text-light);line-height:1.7;max-width:34rem}.navigation{display:flex;flex-wrap:wrap;width:100%;font-size:1rem;color:var(--color-text-light);justify-content:space-between}.nav-link{position:relative;display:inline-flex;align-items:center;padding:.5rem 1.5rem;border-radius:.5rem;color:inherit;text-decoration:none;transition:color .15s ease,background-color .15s ease,transform .15s ease;min-height:44px;border:none;background:none;font:inherit;cursor:pointer}.nav-link:hover{color:var(--color-primary);background-color:rgba(var(--color-primary-rgb),.12);transform:translate(2px)}.nav-link--primary{background-color:rgba(var(--color-primary-rgb),.15);color:var(--color-primary);font-weight:600}.nav-link--primary:hover{background-color:rgba(var(--color-primary-rgb),.22);color:var(--color-primary-hover)}.sparkle-item{-webkit-user-select:none;user-select:none}.sparkle-item:active,.sparkle-item:focus,.sparkle-item:focus-visible{background-color:rgba(var(--color-primary-rgb),.15)!important;color:var(--color-primary)!important;outline:none!important;transform:none!important;-webkit-tap-highlight-color:transparent!important}.nav-icon{display:inline-flex;align-items:center;justify-content:center;color:var(--color-primary);width:1.5rem;height:1.5rem;opacity:.85;transform:translate(-6px);transition:transform .15s ease,opacity .15s ease}.nav-link:hover .nav-icon{transform:scale(1.3) translate(-8px);opacity:1}.floating-nav-content .nav-link:hover .nav-icon{transform:scale(1.2) translate(0)}.sparkle-item{position:relative;overflow:visible}.sparkle{position:absolute;display:block;pointer-events:none;color:var(--color-primary);z-index:2;opacity:0;animation:comeInOut .7s forwards,spin 1s linear forwards}@keyframes comeInOut{0%{transform:scale(0);opacity:0}50%{transform:scale(1);opacity:1}to{transform:scale(0);opacity:0}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(180deg)}}.footer{padding:1.5rem;font-size:.9rem;color:var(--color-text-lighter);display:flex;justify-content:flex-end;text-align:center}@media(max-width:768px){.footer{margin-bottom:120px}}.preview-popup{position:fixed;min-width:500px;z-index:10000;transition:transform .12s ease-out,opacity .2s ease-in-out;will-change:transform}@media(min-width:2560px){.preview-popup{min-width:700px}}@media(min-width:3840px){.preview-popup{min-width:900px}}.preview-content-wrapper{animation:fadeInPreview .25s ease;will-change:transform,opacity}@keyframes fadeInPreview{0%{opacity:0;transform:translateY(-6px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.preview-content{background:var(--color-card-bg-solid);border-radius:12px;box-shadow:0 20px 60px var(--color-preview-shadow),0 8px 25px var(--color-preview-shadow);overflow:hidden;max-width:min(500px,100vw - 40px);max-height:calc(100vh - 40px);display:flex;flex-direction:column;border:1px solid var(--color-preview-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transform:translateZ(0)}@media(min-width:2560px){.preview-content{max-width:min(700px,100vw - 40px);border-radius:16px}}@media(min-width:3840px){.preview-content{max-width:min(900px,100vw - 40px);border-radius:20px}}.preview-image-placeholder{width:100%;height:400px;background:var(--color-bg-gray);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.preview-image-placeholder.has-preview{padding:0;background:transparent;border:none;height:auto}.preview-video{max-width:100%;max-height:min(60vh,600px);width:auto;height:auto;display:block;object-fit:contain;margin:0 auto;opacity:0;transition:opacity .3s ease-in}@media(min-width:2560px){.preview-video{max-height:min(60vh,800px)}}@media(min-width:3840px){.preview-video{max-height:min(60vh,1000px)}}.preview-video[data-loaded=true]{opacity:1}.preview-skeleton{position:absolute;top:0;left:0;width:100%;height:100%;background:var(--color-bg-gray);display:flex;align-items:center;justify-content:center;z-index:1}.skeleton-pulse{width:100%;height:100%;background:linear-gradient(90deg,var(--color-skeleton-1) 0%,var(--color-skeleton-2) 50%,var(--color-skeleton-1) 100%);background-size:200% 100%;animation:skeletonLoading 1.5s infinite}@keyframes skeletonLoading{0%{background-position:200% 0}to{background-position:-200% 0}}.preview-info{padding:1.5rem;flex-shrink:0}@media(min-width:2560px){.preview-info{padding:2.1rem}}@media(min-width:3840px){.preview-info{padding:2.7rem}}.preview-info h3{font-size:1.25rem;font-weight:600;color:var(--color-text);margin-bottom:.25rem}@media(min-width:2560px){.preview-info h3{font-size:1.5rem}}@media(min-width:3840px){.preview-info h3{font-size:1.85rem}}.preview-year{font-size:.85rem;color:var(--color-text-lighter);margin-bottom:.5rem}@media(min-width:2560px){.preview-year{font-size:1.05rem}}@media(min-width:3840px){.preview-year{font-size:1.3rem}}.preview-description{font-size:.9rem;color:var(--color-text-light);line-height:1.5}@media(min-width:2560px){.preview-description{font-size:1.1rem}}@media(min-width:3840px){.preview-description{font-size:1.35rem}}@media(max-width:1024px){.app.app--projects-snap{scroll-snap-type:y proximity;scroll-padding-top:calc(60px + 1.5rem)}.portfolio-container{grid-template-columns:1fr;padding:calc(60px + 1.5rem) 3rem 4rem;gap:4rem;height:auto;overflow:visible;display:flex;flex-direction:column}.personal-section{padding-left:0;order:-1}.projects-section{width:100%;order:0}.projects-section:before,.projects-section:after{display:none}.navigation{gap:1rem}.projects-mobile-preview-item{scroll-snap-align:start}}@media(max-width:768px){.app.app--projects-snap{scroll-padding-top:calc(60px + 1rem)}.portfolio-container{padding:calc(60px + 1rem) 1.5rem 3rem;gap:3rem}.projects-section{max-height:none;height:auto}.project-card{padding:1rem 1.5rem;width:100%}.project-card__name{font-size:1rem}.project-card__description{font-size:.92rem}.name{font-size:1.5rem}.title{font-size:1rem}.description{font-size:.95rem}.projects-mobile-previews{gap:1.5rem}.mobile-project-card__head h3{font-size:1rem}.mobile-project-card__description{font-size:.88rem}.navigation{font-size:.95rem}}@media(max-width:640px){.app.app--projects-snap{scroll-padding-top:calc(67px + 1rem)}.portfolio-container{padding:calc(67px + 1rem) 1.5rem 3rem}.project-card{padding:1rem}.projects-list{gap:1rem}.navigation{gap:.5rem;justify-content:center}.navigation .nav-link{flex:0 1 calc(50% - .25rem);justify-content:center;gap:.5rem}}.contact-overlay{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;background:#0000;pointer-events:none;transition:background .35s ease}.contact-overlay--open{pointer-events:auto;background:#00000040;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.contact-panel{position:relative;background:var(--color-bg);width:100%;max-width:440px;border-radius:16px;padding:2rem 2rem 3rem;box-shadow:0 24px 80px var(--color-panel-shadow),0 8px 32px var(--color-panel-shadow);border:1px solid var(--color-panel-border);opacity:0;transform:scale(.96) translateY(8px);transition:opacity .3s cubic-bezier(.23,1,.32,1),transform .3s cubic-bezier(.23,1,.32,1)}.contact-panel--open{opacity:1;transform:scale(1) translateY(0)}.contact-handle{display:none}.contact-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.25rem}.contact-title{font-size:1.5rem;font-weight:600;color:var(--color-text);margin:0}.contact-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;border:none;background:var(--color-bg-gray);color:var(--color-text-light);cursor:pointer;font-size:1rem;transition:background .15s ease,color .15s ease}.contact-close:hover{background:var(--color-border);color:var(--color-text)}.contact-subtitle{font-size:.9rem;color:var(--color-text-light);margin:0 0 2rem;line-height:1.5}.contact-form{display:flex;flex-direction:column;gap:1rem}.form-field{display:flex;flex-direction:column;gap:.25rem}.form-field label{font-size:.8rem;font-weight:600;color:var(--color-text);letter-spacing:.02em;text-transform:uppercase}.form-field input,.form-field textarea{width:100%;padding:.5rem 1rem;border:1px solid var(--color-border);border-radius:.5rem;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:.95rem;color:var(--color-text);background:var(--color-bg);transition:border-color .15s ease,box-shadow .15s ease;outline:none;box-sizing:border-box}.form-field input::placeholder,.form-field textarea::placeholder{color:var(--color-text-lighter)}.form-field input:focus,.form-field textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.form-field textarea{resize:vertical;min-height:100px}.contact-error{font-size:.85rem;color:#dc2626;margin:0}.contact-submit{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem 2rem;margin-top:.5rem;border:none;border-radius:.5rem;background:var(--color-primary);color:#fff;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .15s ease,transform .15s ease,opacity .15s ease}.contact-submit:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-1px)}.contact-submit:active:not(:disabled){transform:translateY(0)}.contact-submit:disabled{opacity:.7;cursor:default}.contact-submit--success{background:var(--color-primary)}@media(max-width:768px){.contact-overlay{align-items:flex-end}.contact-panel{max-width:100%;border-radius:20px 20px 0 0;padding:.5rem 2rem 8rem;box-shadow:0 -8px 40px var(--color-panel-shadow);opacity:0;transform:translateY(100%);transition:opacity .4s cubic-bezier(.23,1,.32,1),transform .4s cubic-bezier(.23,1,.32,1)}.contact-panel--open{opacity:1;transform:translateY(0)}.contact-handle{display:block;width:36px;height:4px;background:var(--color-border);border-radius:2px;margin:.5rem auto 1rem}.contact-header{margin-bottom:.25rem}.contact-subtitle{margin-bottom:1.5rem}}.about-page{min-height:98vh;background:var(--color-bg-gray);font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;box-shadow:var(--shadow-wrapper-mobile);position:relative;max-height:100vh;overflow:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;transition:background-color .3s ease}.about-container{max-width:1200px;margin:0 auto;padding:4rem 3rem;padding-top:calc(9rem + 60px);padding-bottom:6rem}.bento-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:minmax(200px,auto);gap:1.5rem}@media(max-width:1024px){.bento-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:minmax(180px,auto);gap:1rem}}@media(max-width:768px){.bento-grid{grid-template-columns:1fr;gap:1rem;grid-auto-rows:auto}}.bento-card{background:var(--color-card-bg-solid);border-radius:12px;padding:2rem;border:1px solid var(--color-border);transition:all .25s ease;opacity:0;transform:translateY(60px);animation:slideUpFade .7s cubic-bezier(.16,1,.3,1) forwards}.bento-card:nth-child(1){animation-delay:0s}.bento-card:nth-child(2){animation-delay:.08s}.bento-card:nth-child(3){animation-delay:.16s}.bento-card:nth-child(4){animation-delay:.24s}.bento-card:nth-child(5){animation-delay:.32s}.bento-card:nth-child(6){animation-delay:.4s}.bento-card:nth-child(7){animation-delay:.48s}.bento-card:nth-child(8){animation-delay:.56s}.bento-card:nth-child(9){animation-delay:.64s}.bento-card:nth-child(10){animation-delay:.72s}.bento-card:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 8px 24px #00000014;border-color:var(--color-text-lighter)}@media(max-width:768px){.bento-card:hover{transform:translateY(-2px) scale(1.01);box-shadow:0 4px 12px #0000000f}}.bento-card.bento-large{grid-column:span 3;grid-row:span 1;background:var(--color-bg-dark);color:#fff;border:none;padding:1rem 2rem}@media(max-width:1024px){.bento-card.bento-large{grid-column:span 2}}@media(max-width:768px){.bento-card.bento-large{grid-column:span 1}}.bento-card.bento-medium{grid-column:span 2;grid-row:span 1}@media(max-width:1024px){.bento-card.bento-medium{grid-column:span 2}}.bento-card.bento-accent{grid-column:span 2;grid-row:span 1;background:var(--color-primary);color:#fff;border:none}@media(max-width:1024px){.bento-card.bento-accent{grid-column:span 1}}.bento-card.bento-carousel{padding:0;overflow:hidden;position:relative;display:flex;flex-direction:column}.bento-card.bento-carousel .carousel-heading{padding:2rem 2rem .5rem;margin:0;width:100%}.bento-card.bento-carousel .carousel-wrapper{flex:1;display:flex;align-items:center;overflow:hidden}.bento-card.bento-carousel .carousel-track{display:flex;width:max-content;will-change:transform}.bento-card.bento-carousel .carousel-slide{flex-shrink:0;display:flex;align-items:center;justify-content:center;padding:1rem}.bento-card.bento-carousel .carousel-slide iframe{border:none;border-radius:8px;max-width:100%}.bento-card.bento-cta{grid-column:span 2;grid-row:span 1;background:var(--color-card-bg-solid);text-align:center;border:2px solid var(--color-bg-dark)}@media(max-width:1024px){.bento-card.bento-cta{grid-column:span 2}}@media(max-width:768px){.bento-card.bento-cta{grid-column:span 1}}.bento-card.bento-links{grid-column:span 2;grid-row:span 1;background:var(--color-bg-gray)}@media(max-width:1024px){.bento-card.bento-links{grid-column:span 2}}@media(max-width:768px){.bento-card.bento-links{grid-column:span 1}}.bento-card.bento-photo{padding:0;overflow:hidden;aspect-ratio:1;grid-row:span 1}@media(max-width:768px){.bento-card.bento-photo{aspect-ratio:4/3}}.profile-photo{width:100%;height:100%;object-fit:cover;display:block}.card-icon{font-size:2.5rem;margin-bottom:1rem}.card-title{font-size:3rem;font-weight:700;margin-bottom:.5rem;line-height:1.2}@media(max-width:768px){.card-title{font-size:2rem}}.card-subtitle{font-size:1.25rem;opacity:.9;margin-bottom:1rem;font-weight:500}.card-heading{font-size:1.5rem;font-weight:600;color:var(--color-text);margin-bottom:1rem}.bento-large .card-heading,.bento-accent .card-heading{color:#fff}.card-text{font-size:1rem;color:var(--color-text-light);line-height:1.6;margin:0}.bento-large .card-text,.bento-accent .card-text{color:#fffffff2}.bento-large .card-text{font-size:1.25rem}.experience-list{display:flex;flex-direction:column;gap:1rem}.exp-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:var(--color-bg-gray);border-radius:8px;border:1px solid var(--color-border)}@media(max-width:768px){.exp-item{flex-direction:column;align-items:flex-start;gap:.25rem;padding:.5rem}}.exp-item .exp-year{font-weight:600;color:var(--color-primary);font-size:1rem}@media(max-width:768px){.exp-item .exp-year{font-size:1rem}}.exp-item .exp-desc{color:var(--color-text-light);font-size:1rem}@media(max-width:768px){.exp-item .exp-desc{font-size:1rem;line-height:1.4}}.social-links{display:flex;flex-wrap:wrap;gap:.5rem}@media(max-width:768px){.social-links{gap:.25rem}}.social-links a{padding:.5rem 1.5rem;background:var(--color-card-bg-solid);color:var(--color-text);text-decoration:none;border-radius:50px;border:1px solid var(--color-border);font-weight:500;font-size:.9rem;transition:all .15s ease}@media(max-width:768px){.social-links a{padding:.25rem 1rem;font-size:.85rem}}.social-links a:hover{background:var(--color-bg-dark);color:#fff;border-color:var(--color-bg-dark);transform:translateY(-2px)}@media(max-width:768px){.social-links a:hover{transform:translateY(-1px)}}.cta-button{display:inline-block;margin-top:1.5rem;padding:1rem 3rem;background:var(--color-bg-dark);color:#fff;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:1rem;font-weight:600;text-decoration:none;border:none;border-radius:50px;cursor:pointer;transition:all .25s ease}@media(max-width:768px){.cta-button{padding:1rem 2rem;font-size:1.25rem;margin-top:1rem;width:100%;text-align:center}}.cta-button:hover{opacity:.9;transform:translateY(-2px);box-shadow:0 4px 12px #0003}@media(max-width:768px){.cta-button:hover{transform:translateY(-1px);box-shadow:0 2px 8px #00000026}}.cta-button:active{transform:translateY(0)}@keyframes slideUpFade{0%{opacity:0;transform:translateY(60px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1024px){.about-container{padding:4rem 3rem;padding-top:calc(60px + 4rem);padding-bottom:6rem}}@media(max-width:768px){.about-container{padding:3rem 1.5rem;padding-top:calc(67px + 3rem);padding-bottom:4rem;padding-bottom:6rem}.bento-card{padding:1.5rem}.bento-card:hover{transform:none}.card-icon{font-size:2rem;margin-bottom:.5rem}.card-heading{font-size:1.25rem;margin-bottom:.5rem}.card-text{font-size:1rem;line-height:1.5}.card-title{font-size:1.5rem;margin-bottom:.25rem}.card-subtitle{font-size:1rem;margin-bottom:.5rem}}@media(max-width:480px){.about-container{padding:2rem 1rem;padding-top:calc(60px + 2rem);padding-bottom:8rem}.bento-grid{grid-template-columns:1fr;gap:.5rem;grid-auto-rows:auto}.bento-card{padding:1rem;border-radius:8px}.bento-card.bento-large,.bento-card.bento-medium,.bento-card.bento-accent,.bento-card.bento-cta,.bento-card.bento-links{grid-column:span 1}.card-icon{font-size:1.5rem}.card-title{font-size:1.25rem}.card-heading{font-size:1rem}.card-text{font-size:.8rem}.exp-item{padding:.25rem}.exp-item .exp-year,.exp-item .exp-desc{font-size:.8rem}.social-links a{padding:.25rem .5rem;font-size:.8rem}.cta-button{padding:.5rem 1.5rem;font-size:1rem;width:100%;text-align:center}}.lightbox-overlay{position:fixed;inset:-10px 0 0;background:#000000f2;z-index:10000;display:flex;align-items:center;justify-content:center;padding:3rem;cursor:pointer;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.lightbox-close{position:absolute;top:1.5rem;right:1.5rem;background:#ffffff1a;border:none;color:#fff;font-size:2.5rem;width:48px;height:48px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease;z-index:10001;line-height:1}.lightbox-close:hover{background:#fff3;transform:scale(1.1)}.lightbox-close:active{transform:scale(.95)}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:#ffffff1a;border:none;color:#fff;font-size:3rem;width:60px;height:60px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease;z-index:10001;line-height:1}.lightbox-nav:hover{background:#fff3;transform:translateY(-50%) scale(1.1)}.lightbox-nav:active{transform:translateY(-50%) scale(.95)}.lightbox-prev{left:1.5rem}.lightbox-next{right:1.5rem}.lightbox-content{max-width:60vw;max-height:90vh;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:default}.lightbox-image-wrapper{position:relative;display:inline-block}.lightbox-image{max-width:100%;max-height:calc(90vh - 80px);object-fit:contain;border-radius:8px;animation:zoomIn .3s ease-out;display:block}.lightbox-image-tag{position:absolute;bottom:1rem;right:1rem;background:#10b981f2;color:#fff;padding:.25rem 1rem;border-radius:.5rem;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 4px 16px #0006;z-index:10;pointer-events:none;animation:zoomIn .3s ease-out}.lightbox-caption{margin-top:1.5rem;padding:1rem 1.5rem;background:#ffffff1a;color:#fff;border-radius:8px;font-size:1rem;max-width:80%;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:fadeIn .3s ease-out .2s both;display:flex;justify-content:space-between;align-items:center;gap:1rem;width:100%}.lightbox-caption-text{flex:1;text-align:left}.lightbox-counter{color:#fff;font-size:1rem;white-space:nowrap;opacity:.8}@keyframes zoomIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@media(max-width:768px){.lightbox-overlay{padding:1.5rem 1rem 1rem;align-items:flex-start;top:-47px;height:100vh;height:100dvh}.lightbox-close{top:1rem;right:1rem;width:36px;height:36px;font-size:1.75rem}.lightbox-nav{width:36px;height:36px;font-size:1.5rem}.lightbox-prev{left:.25rem}.lightbox-next{right:.25rem}.lightbox-content{max-width:100vw;max-height:100vh;width:100%;height:100%;display:flex;flex-direction:column;justify-content:space-between;align-items:stretch;padding:2rem 1rem 0;box-sizing:border-box}.lightbox-image{max-width:100%;max-height:calc(100vh - 160px);width:auto;height:auto;object-fit:contain;margin:0 auto;flex-shrink:1;flex-grow:1;min-height:0;align-self:center}.lightbox-caption{padding:1rem;font-size:.9rem;max-width:100%;width:100%;margin:auto 0 0;border-radius:0;position:relative;box-sizing:border-box;flex-shrink:0}.lightbox-counter{font-size:.85rem}}.project-detail-page{height:100vh;overflow-y:auto;overflow-x:hidden;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;background:var(--color-bg-gray);transition:background-color .3s ease}.project-detail-container{max-width:1200px;margin:0 auto;padding:4rem 3rem;padding-top:calc(66px + 4rem);padding-bottom:6rem;scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.project-hero{display:grid;grid-template-columns:1.2fr 1fr;gap:3rem;align-items:center;margin-bottom:3rem}.project-hero-media-mobile{display:none}.project-detail-page .project-title{font-size:3rem;font-weight:700;color:var(--color-text);margin-bottom:.5rem}.project-logo{max-width:300px;height:auto;margin-bottom:.5rem;display:block}.project-subtitle{font-size:1.25rem;color:var(--color-text);margin-bottom:.5rem}.project-meta{display:flex;gap:1rem;align-items:center;margin-bottom:1rem}.project-tags{display:flex;gap:.5rem}.project-tags .tag{padding:.25rem .5rem;background:var(--color-card-bg-solid);color:var(--color-text);border:1px solid var(--color-border);border-radius:999px;font-size:.8rem}.status{padding:.25rem .5rem;background:var(--color-primary);color:#fff;border-radius:999px;font-size:.8rem}.project-summary{color:var(--color-text-light);line-height:1.7}.project-sections{display:flex;flex-direction:column;gap:2rem}.project-section{background:var(--color-card-bg-solid);border:1px solid var(--color-border);border-radius:12px;padding:2rem}.project-text{color:var(--color-text-light);line-height:1.7;margin:0}.hero-media{width:100%;border-radius:12px}.meta-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin:3rem 0}.meta-item{background:var(--color-card-bg-solid);border:1px solid var(--color-border);border-radius:12px;padding:1.5rem;display:flex;flex-direction:column;gap:.25rem}.meta-item .label{color:var(--color-text-lighter);font-size:.85rem}.meta-item .value{color:var(--color-text);font-weight:600}.meta-item .value.status{color:#fff;background:var(--color-primary);border-radius:999px;padding:2px 8px;width:fit-content;font-size:.85rem;font-weight:500}.meta-item .value.status--completed,.meta-item .value.status--completato{background:var(--color-primary);color:#fff}.meta-item .value.status--in-progress,.meta-item .value.status--in-corso{background:#f59e0b;color:#fff}.meta-item .value.status--planned,.meta-item .value.status--pianificato{background:#3b82f6;color:#fff}.meta-item .value.status--discontinued,.meta-item .value.status--interrotto{background:#ef4444;color:#fff}.meta-item .value.status--in-use,.meta-item .value.status--in-uso{background:#059669;color:#fff}.meta-item .value.nda{position:relative}.meta-item .value.nda .client-name{display:inline-block;filter:blur(6px)}.meta-item .value.nda:hover:after{content:"Protetto da NDA";position:absolute;left:50%;transform:translate(-50%,-140%);background:var(--color-bg-dark);color:#fff;font-size:.75rem;padding:4px 8px;border-radius:6px;white-space:nowrap;box-shadow:0 6px 20px #00000026;filter:none;z-index:1000}.meta-item.stack .stack-chips{display:flex;flex-wrap:wrap;gap:.25rem;margin-top:.25rem}.meta-item.stack .stack-chip{display:inline-block;padding:.25rem .5rem;background:var(--color-bg-gray);color:var(--color-text);border:1px solid var(--color-border);border-radius:6px;font-size:.8rem;font-weight:500;white-space:nowrap;transition:all .15s ease}.meta-item.stack .stack-chip:hover{background:rgba(var(--color-primary-rgb),.1);border-color:rgba(var(--color-primary-rgb),.3);color:var(--color-primary)}.section{background:var(--color-card-bg-solid);border:1px solid var(--color-border);border-radius:12px;padding:2rem;opacity:0;transform:translateY(30px);transition:opacity .6s ease-out,transform .6s ease-out;margin-bottom:3rem}.section.revealed{opacity:1;transform:translateY(0)}.hero-image{opacity:0;transform:translateY(30px);transition:opacity .8s ease-out,transform .8s ease-out}.hero-image.revealed{opacity:1;transform:translateY(0)}.gallery{opacity:0;transform:translateY(30px);transition:opacity .6s ease-out,transform .6s ease-out}.gallery.revealed{opacity:1;transform:translateY(0)}.gallery .gallery-item{opacity:0;transform:translateY(20px);transition:opacity .5s ease-out,transform .5s ease-out}.gallery.revealed .gallery-item{opacity:1;transform:translateY(0)}.gallery.revealed .gallery-item:nth-child(1){transition-delay:.1s}.gallery.revealed .gallery-item:nth-child(2){transition-delay:.2s}.gallery.revealed .gallery-item:nth-child(3){transition-delay:.3s}.gallery.revealed .gallery-item:nth-child(4){transition-delay:.4s}.quote-section{border:none;background:transparent;padding:3rem 0}.quote-section .quote-text{font-size:1.5rem;font-style:italic;color:var(--color-text);text-align:center;margin:0;padding:2rem;font-weight:900}.section-media{margin-top:1.5rem;border-radius:12px;overflow:hidden}.section-media video,.section-media img{width:100%;height:auto;display:block}.section-media img{transition:transform .15s ease,opacity .15s ease}.section-media img:hover{transform:scale(1.02);opacity:.9}.showcase-single-image img{width:100%;height:auto;border-radius:12px;display:block;transition:transform .15s ease,opacity .15s ease}.showcase-single-image img:hover{transform:scale(1.02);opacity:.9}.showcase-image-grid{column-count:2;column-gap:1.5rem;margin-top:1.5rem}.showcase-image-grid .showcase-image-item{break-inside:avoid;border-radius:12px;overflow:hidden;position:relative;margin-bottom:1.5rem;display:block}.showcase-image-grid .showcase-image-item img{width:100%;height:auto;display:block;transition:transform .15s ease,opacity .15s ease}.showcase-image-grid .showcase-image-item img:hover{transform:scale(1.05);opacity:.9}@media(max-width:1024px){.showcase-image-grid{column-count:2;column-gap:1.5rem}}@media(max-width:768px){.showcase-image-grid{column-count:1;column-gap:0}.showcase-image-grid .showcase-image-item{margin-bottom:1rem}}.image-wrapper{position:relative;display:inline-block;width:100%}.image-wrapper .tooltip-content{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background-color:#000000e6;color:#fff;padding:12px 16px;border-radius:6px;font-size:13px;white-space:normal;max-width:80%;text-align:center;z-index:10;pointer-events:none;box-shadow:0 4px 12px #0000004d;line-height:1.4;opacity:0;transition:opacity .2s ease-out}.image-wrapper .image-tag{position:absolute;bottom:1rem;right:1rem;background:#10b981f2;color:#fff;padding:.25rem 1rem;border-radius:.5rem;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 4px 16px #0003;z-index:10;pointer-events:none}.image-wrapper:hover .tooltip-content{opacity:1}.section-image{width:100%;height:auto;border-radius:12px;display:block}.section[id],.gallery[id],.hero-image,#overview{scroll-margin-top:66px}#overview.meta-grid{opacity:0;transform:translateY(30px);transition:opacity .6s ease-out,transform .6s ease-out}#overview.meta-grid.revealed{opacity:1;transform:translateY(0)}.section-heading{font-size:1.5rem;font-weight:700;color:var(--color-text);margin-bottom:1rem}.bullet-list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:1rem;color:var(--color-text-light);width:100%}.bullet-list li{margin:0;padding:.5rem 1rem .5rem 1.5rem;background:transparent;border:none;border-left:4px solid var(--color-primary);border-radius:0;display:block;transition:all .15s ease;position:relative;line-height:1.7}.bullet-list li:hover{padding-left:calc(1.5rem + 4px);color:var(--color-text)}.gallery{margin-top:3rem;display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.gallery-image{width:100%;height:auto;border-radius:12px;object-fit:cover;display:block;transition:transform .15s ease,opacity .15s ease}.gallery-image:hover{transform:scale(1.05);opacity:.9}.image-placeholder{width:100%;height:240px;background:var(--color-bg-gray);border:2px dashed var(--color-border);border-radius:12px}.hero-image-content{width:100%;height:auto;border-radius:12px;object-fit:contain;display:block;transition:transform .15s ease,opacity .15s ease}.hero-image-content[style*="cursor: pointer"]:hover{transform:scale(1.02);opacity:.9}.image-placeholder.nda{background:repeating-linear-gradient(-45deg,#111827e6 0 10px,#ffffff0f 10px 20px);border-color:#0003}@media(max-width:1024px){.project-detail-container{padding:4rem 3rem;padding-top:calc(56px + 4rem)}.section[id],.gallery[id],.hero-image{scroll-margin-top:56px}}@media(max-width:768px){.project-detail-container{padding:3rem 1.5rem;padding-top:calc(67px + 3rem)}.section[id],.gallery[id],.hero-image{scroll-margin-top:67px}.project-detail-page .project-title{font-size:2rem}.project-logo{max-width:250px}.project-subtitle{font-size:1rem}.project-hero{grid-template-columns:1fr;gap:1.5rem}.project-hero-media-mobile{display:block;width:100%}.hero-image-main{display:none}.hero-text{width:100%}.meta-grid,.gallery{grid-template-columns:1fr}.hero-media{max-width:100%;height:auto}.image-placeholder{max-width:100%;height:auto;min-height:180px}.section,.project-section{padding:1rem 1.5rem}.bullet-list{gap:1rem}.bullet-list li{padding:.5rem 1rem .5rem 1.5rem;line-height:1.6;font-size:.9rem}.bullet-list li:hover{padding-left:calc(1.5rem + 4px)}.project-text{line-height:1.6}.section-heading{margin-bottom:1rem}}.detail-grid{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:3rem;align-items:start}.detail-main{min-width:0}.detail-aside{position:sticky;top:calc(66px + 1.5rem);height:fit-content;display:flex;flex-direction:column;gap:2rem}.toc{background:var(--color-card-bg-solid);border:1px solid var(--color-border);border-radius:12px;padding:0;overflow:hidden}.toc-toggle{width:100%;display:none;background:none;border:none;padding:1.5rem;cursor:pointer;justify-content:space-between;align-items:center;text-align:left;transition:background-color .15s ease}.toc-toggle:hover{background-color:rgba(var(--color-primary-rgb),.05)}.toc-toggle .toc-toggle-title{font-weight:700;color:var(--color-text);margin:0}.toc-toggle .toc-icon{font-size:1.2rem;font-weight:300;color:var(--color-text-light);width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:transform .15s ease}.toc-title-static{font-weight:700;color:var(--color-text);margin-bottom:.5rem;padding:1.5rem 1.5rem .5rem}.toc-content{padding:0 1.5rem 1.5rem;max-height:none;overflow:visible}.toc-link{display:block;color:var(--color-text-light);text-decoration:none;padding:.25rem 0;transition:color .15s ease,font-weight .15s ease;position:relative}.toc-link:hover{color:var(--color-primary)}.toc-link.active{color:var(--color-primary);font-weight:600}.toc-link.active:before{content:"";position:absolute;left:-1.5rem;top:50%;transform:translateY(-50%);width:3px;height:16px;background-color:var(--color-primary);border-radius:2px}.aside-cta{text-align:left}.aside-cta .cta-button{display:block;width:100%;text-align:center;padding-top:1rem;padding-bottom:1rem;border:none;background:var(--color-bg-dark);color:#fff;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:1rem;font-weight:600;border-radius:50px;cursor:pointer;transition:all .25s ease}.aside-cta .cta-button svg{margin-left:.5rem;transition:transform .2s ease}.aside-cta .cta-button:hover svg{transform:translate(4px)}.project-pager{display:flex;justify-content:space-between;align-items:center}.pager-link{color:var(--color-text);text-decoration:none;border:1px solid var(--color-border);background:var(--color-card-bg-solid);border-radius:999px;padding:.5rem 1.5rem;transition:all .15s ease}.pager-link:hover{color:#fff;background:var(--color-bg-dark);border-color:var(--color-bg-dark)}@media(max-width:1024px){.detail-grid{grid-template-columns:1fr;display:flex;flex-direction:column}.detail-aside{position:static;order:-1;margin-bottom:3rem;width:100%;gap:1rem}.toc-toggle{display:flex!important}.toc-title-static{display:none}.toc-content{max-height:0!important;padding:0 1.5rem!important;overflow:hidden;transition:max-height .3s ease-out,padding .3s ease-out}.toc.toc-open .toc-content{max-height:1000px!important;padding:.5rem 1.5rem 1.5rem!important}.toc.toc-open .toc-icon{transform:none}}.pull-to-refresh-container{position:relative;width:100%;height:100%;overflow:hidden}.pull-indicator{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:10000;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem 2rem;background:var(--color-pull-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:.75rem;box-shadow:0 8px 24px #00000026;transition:all .15s ease;min-width:200px;will-change:transform,opacity;backface-visibility:hidden;-webkit-backface-visibility:hidden}.pull-indicator.pulling{transition:transform .15s ease,opacity .15s ease}.pull-indicator.can-refresh{background:rgba(var(--color-primary-rgb),.1);border:1px solid rgba(var(--color-primary-rgb),.2)}.pull-indicator.can-refresh .pull-icon{color:var(--color-primary)}.pull-indicator.can-refresh .pull-text{color:var(--color-primary);font-weight:500}.pull-indicator.refreshing{background:rgba(var(--color-primary-rgb),.1);border:1px solid rgba(var(--color-primary-rgb),.2)}.pull-indicator.refreshing .pull-icon{color:var(--color-primary)}.pull-indicator.refreshing .pull-text{color:var(--color-primary);font-weight:500}.pull-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;color:var(--color-text-light);transition:all .15s ease;margin-bottom:.5rem}.pull-icon svg{transition:transform .15s ease;width:32px;height:32px}.pull-text{font-size:.875rem;color:var(--color-text-light);text-align:center;transition:all .15s ease;font-weight:400}.pull-content{transition:transform .15s ease;will-change:transform;backface-visibility:hidden;-webkit-backface-visibility:hidden;transform:translateZ(0)}.pull-content.pulling{transition:transform .15s ease}.spinner{width:32px;height:32px;position:relative}.spinner-circle{width:100%;height:100%;border:2px solid transparent;border-top:2px solid currentColor;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:768px){.pull-indicator{padding:.5rem;min-width:160px}.pull-indicator .pull-text{font-size:.8rem}.pull-icon{width:28px;height:28px}}@media(min-width:1025px){.pull-to-refresh-container .pull-indicator{display:none}.pull-to-refresh-container .pull-content{transform:none!important}}.floating-project-nav{position:fixed;bottom:3rem;left:50%;z-index:10;pointer-events:none}.floating-project-nav .floating-nav-content{display:flex;align-items:center;gap:1.5rem;justify-content:center;pointer-events:auto;transform:translate(-50%)}.pager-button{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem 1.5rem;border-radius:.75rem;color:var(--color-text-light);text-decoration:none;transition:all .25s ease;font-size:.95rem;font-weight:500;border:1px solid var(--color-pager-border);background-color:var(--color-pager-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);min-height:48px;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.pager-button .pager-icon{display:flex;align-items:center;justify-content:center;font-size:1.1rem;line-height:1}.pager-button .pager-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}.pager-button:hover{color:var(--color-primary);background-color:rgba(var(--color-primary-rgb),.08);border-color:rgba(var(--color-primary-rgb),.5);transform:translateY(-2px);box-shadow:0 8px 20px rgba(var(--color-primary-rgb),.15)}.pager-button:active{transform:translateY(0)}.pager-button:focus{outline:none}.pager-button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.pager-button.prev .pager-icon{order:-1}.pager-button.disabled{color:var(--color-text-lighter);background-color:var(--color-pager-disabled-bg);border-color:var(--color-pager-border);cursor:not-allowed;pointer-events:none;opacity:.5}.pager-button.disabled:hover{color:var(--color-text-lighter);background-color:var(--color-pager-disabled-bg);border-color:var(--color-pager-border);transform:none;box-shadow:none}.pager-button.disabled:active{transform:none}.pager-button.disabled:focus-visible{outline:none}@media(max-width:1024px){.floating-project-nav{bottom:2rem}.floating-nav-content{gap:1rem}.pager-button{padding:1rem 1.5rem;font-size:.9rem}.pager-button .pager-text{max-width:100px}}@media(max-width:768px){.floating-project-nav{bottom:1.5rem}.floating-nav-content{gap:.5rem}.pager-button{padding:.5rem 1rem;font-size:.85rem}.pager-button .pager-text{display:none}.pager-button .pager-icon{font-size:1rem}}body:has(.lightbox-overlay) .floating-project-nav,body:has(.contact-overlay--open) .floating-project-nav{display:none!important}.floating-home-nav{display:none;position:fixed;bottom:2rem;left:50%;transform:translate(-50%);z-index:10;pointer-events:none;animation:slideUpFromBottom .6s cubic-bezier(.23,1,.32,1) forwards}@media(max-width:768px){.floating-home-nav{display:block}}@keyframes slideUpFromBottom{0%{opacity:0;transform:translate(-50%) translateY(80px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.floating-nav-content{display:flex;align-items:center;gap:1rem;justify-content:center;pointer-events:auto;background-color:var(--color-floating-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:.75rem;padding:.5rem 1rem;border:1px solid var(--color-floating-border)}.nav-link{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;border-radius:.5rem;color:var(--color-text-light);text-decoration:none;transition:all .25s ease;font-size:.9rem;font-weight:500;min-height:40px;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.nav-link .nav-icon{display:flex;align-items:center;justify-content:center;font-size:1rem;line-height:1}.nav-link .nav-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-link:hover{color:var(--color-primary);background-color:rgba(var(--color-primary-rgb),.08);transform:scale(1.05)}.nav-link:active{transform:scale(.95)}.nav-link:focus{outline:none}.nav-link:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.nav-link.nav-link--primary{background-color:rgba(var(--color-primary-rgb),.12);border:1px solid rgba(var(--color-primary-rgb),.3);color:var(--color-primary);min-width:120px;justify-content:center}.nav-link.nav-link--primary:hover{background-color:rgba(var(--color-primary-rgb),.18);border-color:rgba(var(--color-primary-rgb),.5);box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.15)}.nav-link.nav-link--icon-only{padding:.5rem;width:40px;height:40px}.nav-link.nav-link--icon-only .nav-text{display:none}.nav-link.nav-link--icon-only:hover{transform:scale(1.1)}.nav-link.nav-link--icon-only:active{transform:scale(.9)}body:has(.lightbox-overlay) .floating-home-nav,body:has(.contact-overlay--open) .floating-home-nav{display:none!important}.wrapper{min-height:98vh;background:var(--color-bg-gray);display:flex;flex-direction:column;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;border-radius:12px;margin:.5rem;box-shadow:var(--shadow-wrapper);position:relative;max-height:98vh;overflow:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;transition:background-color .3s ease,box-shadow .3s ease}@media(max-width:768px){.wrapper{margin-top:3rem;box-shadow:var(--shadow-wrapper-mobile)}}
