*{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:#1f2937;background-color:#f9fafb;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}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:#f9fafb;overflow:auto}#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)}}.project-modal-overlay{position:fixed!important;inset:0!important;width:100vw;height:100vh;height:100dvh;background:#000000d9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:9999;display:flex;align-items:center;justify-content:center;padding:2rem;animation:fadeInOverlay .3s ease;overflow:hidden;transform:translateZ(0);isolation:isolate}@media(max-width:768px){.project-modal-overlay{padding:0}}@keyframes fadeInOverlay{0%{opacity:0}to{opacity:1}}.modal-content-wrapper{display:flex;flex-direction:column;justify-content:center;align-items:center;width:100%;max-width:600px;height:90vh;height:90dvh;padding:2rem;position:relative;animation:slideUpModal .4s cubic-bezier(.16,1,.3,1)}@media(max-width:768px){.modal-content-wrapper{max-width:100%;height:100vh;height:100dvh;padding:0;justify-content:flex-start}}@keyframes slideUpModal{0%{opacity:0;transform:translateY(40px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.project-modal{border-radius:16px;width:100%;height:100%;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;position:relative;overflow:hidden;will-change:transform;transform:translateZ(0);background:#fff}@media(max-width:768px){.project-modal{border-radius:0;height:100%}}.modal-close-btn{position:absolute;top:16px;right:16px;width:44px;height:44px;border-radius:50%;background:#fffc;border:1px solid rgba(0,0,0,.08);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease;color:#6b7280;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:20;-webkit-tap-highlight-color:transparent}.modal-close-btn:hover{color:#10b981;background:#10b98114;border-color:#10b98180;transform:rotate(90deg) scale(1.05)}.modal-close-btn:active{transform:rotate(90deg) scale(.95)}.modal-close-btn svg{width:20px;height:20px}@media(max-width:768px){.modal-close-btn{top:12px;right:12px;background:#ffffffe6;box-shadow:0 2px 8px #0000001a}}.modal-scroll-container{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;width:100%;scroll-snap-type:y mandatory;scroll-behavior:smooth;overscroll-behavior-y:contain;will-change:scroll-position}.modal-scroll-container::-webkit-scrollbar{width:6px}.modal-scroll-container::-webkit-scrollbar-track{background:transparent}.modal-scroll-container::-webkit-scrollbar-thumb{background:#0003;border-radius:3px}.modal-project-item-wrapper{height:fit-content;width:100%;scroll-snap-align:start;scroll-snap-stop:always;display:flex;flex-direction:column;justify-content:center;padding:60px 16px 100px;box-sizing:border-box}@media(max-width:768px){.modal-project-item-wrapper{height:100%;width:100%;scroll-snap-align:start;scroll-snap-stop:always;display:flex;flex-direction:column;justify-content:center;padding:60px 16px 100px;box-sizing:border-box}}.modal-project-item{background:#fff;width:100%;display:flex;flex-direction:column;justify-content:center;border-radius:16px;overflow:hidden;box-shadow:0 10px 30px #0000001a}.modal-preview{width:100%}.modal-image-placeholder{width:100%;height:350px;background:#f9fafb;display:flex;align-items:center;justify-content:center}.modal-image-placeholder .placeholder-text{color:#9ca3af;font-size:2rem;font-weight:600;text-transform:uppercase;letter-spacing:2px}.modal-image-placeholder.has-preview{padding:0;background:transparent;height:auto;display:flex;align-items:center;justify-content:center;min-height:0}.modal-image-placeholder .modal-video{width:100%;max-width:100%;height:auto;max-height:min(60vh,600px);display:block;object-fit:contain;margin:0 auto;opacity:0;transition:opacity .3s ease-in}.modal-image-placeholder .modal-video[data-loaded=true]{opacity:1}.modal-image-placeholder .modal-video:not([data-loaded=true]){animation:fadeInVideo .5s ease-in .2s forwards}@keyframes fadeInVideo{to{opacity:1}}@media(max-width:768px){.modal-image-placeholder{aspect-ratio:1.24/1;height:auto;min-height:unset;max-height:unset}.modal-image-placeholder .modal-video{width:100%;height:auto;aspect-ratio:1.24/1;object-fit:cover;max-height:unset}.modal-image-placeholder .placeholder-text{font-size:1.25rem;letter-spacing:1px}}.modal-info{padding:.5rem;position:relative;z-index:2}.modal-info h2{font-size:3rem;font-weight:700;color:#1f2937;margin-bottom:.25rem}.modal-info .modal-year{font-size:1rem;color:#9ca3af;margin-bottom:1rem;font-weight:500}.modal-info .modal-description{font-size:1rem;color:#6b7280;line-height:1.7;margin:0}@media(max-width:768px){.modal-info{padding:1.5rem 1rem}.modal-info h2{font-size:1.5rem;line-height:1.3}.modal-info .modal-year,.modal-info .modal-description{font-size:.85rem;line-height:1.5}.modal-info .modal-year{margin-bottom:.25rem}}.modal-view-btn{display:flex;align-items:center;justify-content:center;width:100%;padding:1rem 2rem;background:#10b9811f;color:#10b981;font-size:1rem;font-weight:600;border-top:1px solid rgba(0,0,0,.05);cursor:pointer;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;min-height:60px;flex-shrink:0;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;border-radius:0;border-left:none;border-right:none;border-bottom:none}.modal-view-btn:active{background:#10b98133}@media(max-width:1024px){.modal-view-btn{display:flex;align-items:center;justify-content:center;font-size:1rem;padding:1rem;background:#fff;box-shadow:0 -4px 20px #0000000d;z-index:10}}@media(max-width:768px){.modal-view-btn{position:absolute;bottom:1rem;left:1rem;right:1rem;width:auto;margin:0;box-shadow:0 4px 12px #0000001a;background:#fffffff2;border:1px solid rgba(16,185,129,.3);border-radius:50px}}.language-switcher{display:flex;align-items:center;gap:.25rem;background:#f9fafb;border-radius:.5rem;padding:.25rem;border:1px solid #e5e7eb;transition:all .15s ease}.language-switcher:hover{border-color:#10b981;box-shadow:0 2px 8px #10b9811a}.language-btn{background:transparent;border:none;padding:.25rem .5rem;border-radius:.25rem;font-size:.85rem;font-weight:500;color:#6b7280;cursor:pointer;transition:all .15s ease;min-width:32px;text-align:center}.language-btn:hover{color:#10b981;background:#10b9811a}.language-btn.active{background:#10b981;color:#fff;font-weight:600;box-shadow:0 2px 4px #10b9814d}.language-btn:focus{outline:none;box-shadow:0 0 0 2px #10b9814d}.separator{color:#9ca3af;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}}.app-header{position:sticky;top:5rem;left:0;right:0;z-index:9999;transition:all .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:#ffffffd9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(229,231,235,.5)}.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:#1f2937;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:#6b7280;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;width:0;min-width:0;overflow:hidden;white-space:nowrap;font-size:.9rem;font-weight:500;transform:translate(10px);flex:0 0 auto}.about-button:hover{color:#10b981;background-color:#10b98114;padding:0 .8rem;width:auto}.about-button:hover .button-text{animation:slideInLeftText .4s cubic-bezier(.23,1,.32,1) forwards}.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:#6b7280;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:#10b981;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:#1f2937;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:#f9fafb;display:flex;flex-direction:column;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow-y:auto;overflow-x:hidden}.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-y:scroll;overflow-x:hidden;scrollbar-width:auto}.projects-section::-webkit-scrollbar{width:8px}.projects-section::-webkit-scrollbar-track{background:transparent}.projects-section::-webkit-scrollbar-thumb{background:#6b72804d;border-radius:4px}.projects-section::-webkit-scrollbar-thumb:hover{background:#6b728080}}.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,#f9fafb,#f9fafb99 60%,#f9fafb00);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,#f9fafb00,#f9fafb99 60%,#f9fafb)}.projects-title{font-size:1.5rem;font-weight:600;color:#1f2937;letter-spacing:-.01em}.projects-subtitle{max-width:34rem;font-size:1rem;color:#6b7280;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:#6b72804d;border-radius:4px}.projects-list::-webkit-scrollbar-thumb:hover{background:#6b728080}@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 rgba(15,23,42,.08);background:#ffffffeb;text-align:left;color:#1f2937;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:hover{border-color:#10b98152;background-color:#fffffffa}.project-card:focus-visible{outline:2px solid rgba(16,185,129,.55);outline-offset:6px;transform:translateY(-4px)}.project-card--featured{border-color:#10b98159;background:linear-gradient(120deg,#10b98124,#fffffff2);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__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:#6b7280;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:#6b7280}.project-card__client{color:#6b7280;position:relative}.project-card__badge{padding:.125rem .75rem;border-radius:999px;background:#10b9811a;color:#10b981;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:#111827;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:#6b7280}.project-card__cta{margin-top:.25rem;font-size:.85rem;font-weight:600;color:#10b981;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:#059669}.personal-section{display:flex;flex-direction:column;align-items:flex-start;gap:2rem;padding-left:2rem}.name{font-size:2rem;font-weight:600;color:#1f2937;line-height:1.2}.title{font-size:1.25rem;font-weight:500;color:#1f2937;line-height:1.4;max-width:28rem}.title-accent{color:#10b981}.description{font-size:1rem;color:#6b7280;line-height:1.7;max-width:34rem}.navigation{display:flex;flex-wrap:wrap;width:100%;font-size:1rem;color:#6b7280;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}.nav-link:hover{color:#10b981;background-color:#10b9811f;transform:translate(2px)}.nav-link--primary{background-color:#10b98126;color:#10b981;font-weight:600}.nav-link--primary:hover{background-color:#10b98138;color:#059669}.sparkle-item{-webkit-user-select:none;user-select:none}.sparkle-item:active,.sparkle-item:focus,.sparkle-item:focus-visible{background-color:#10b98126!important;color:#10b981!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:#10b981;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:#10b981;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:#9ca3af;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:30;top:50%;left:50%;transform:translate(-50%,-50%);transition:opacity .2s ease-in-out}.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:#fff;border-radius:12px;box-shadow:0 20px 60px #00000026,0 8px 25px #0000001a;overflow:hidden;max-width:min(500px,100vw - 40px);max-height:calc(100vh - 40px);display:flex;flex-direction:column;border:1px solid rgba(0,0,0,.08);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transform:translateZ(0)}.preview-image-placeholder{width:100%;height:400px;background:#f9fafb;border-bottom:1px solid #e5e7eb;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}.preview-video[data-loaded=true]{opacity:1}.preview-skeleton{position:absolute;top:0;left:0;width:100%;height:100%;background:#f9fafb;display:flex;align-items:center;justify-content:center;z-index:1}.skeleton-pulse{width:100%;height:100%;background:linear-gradient(90deg,#0000000d,#0000001a,#0000000d);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}.preview-info h3{font-size:1.25rem;font-weight:600;color:#1f2937;margin-bottom:.25rem}.preview-year{font-size:.85rem;color:#9ca3af;margin-bottom:.5rem}.preview-description{font-size:.9rem;color:#6b7280;line-height:1.5}@media(max-width:1024px){.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}.navigation{gap:1rem}}@media(max-width:768px){.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,.navigation{font-size:.95rem}}@media(max-width:640px){.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}}.about-page{min-height:98vh;background:#f9fafb;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;border-radius:12px;margin:.5rem;box-shadow:0 1px 3px #00000026;position:relative;max-height:100vh;overflow:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.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:#fff;border-radius:12px;padding:2rem;border:1px solid #e5e7eb;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:#c8ccd5}@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:#111827;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:#10b981;color:#fff;border:none}@media(max-width:1024px){.bento-card.bento-accent{grid-column:span 1}}.bento-card.bento-cta{grid-column:span 2;grid-row:span 1;background:#fff;text-align:center;border:2px solid #111827}@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:#f9fafb}@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;filter:grayscale(100%);transition:filter .25s ease}.bento-photo:hover .profile-photo{filter:grayscale(0%)}.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:#1f2937;margin-bottom:1rem}.bento-large .card-heading,.bento-accent .card-heading{color:#fff}.card-text{font-size:1rem;color:#6b7280;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:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}@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:#10b981;font-size:1rem}@media(max-width:768px){.exp-item .exp-year{font-size:1rem}}.exp-item .exp-desc{color:#6b7280;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:#fff;color:#1f2937;text-decoration:none;border-radius:50px;border:1px solid #e5e7eb;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:#111827;color:#fff;border-color:#111827;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:#111827;color:#fff;font-size:1rem;font-weight:600;text-decoration:none;border-radius:50px;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{background:#090d15;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)}}@media(max-width:768px){.about-container{padding:3rem 1.5rem;padding-top:calc(67px + 3rem);padding-bottom:4rem}.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)}.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}.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-detail-page .project-title{font-size:3rem;font-weight:700;color:#1f2937;margin-bottom:.5rem}.project-logo{max-width:300px;height:auto;margin-bottom:.5rem;display:block}.project-subtitle{font-size:1.25rem;color:#1f2937;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:#fff;color:#1f2937;border:1px solid #e5e7eb;border-radius:999px;font-size:.8rem}.status{padding:.25rem .5rem;background:#10b981;color:#fff;border-radius:999px;font-size:.8rem}.project-summary{color:#6b7280;line-height:1.7}.project-sections{display:flex;flex-direction:column;gap:2rem}.project-section{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:2rem}.project-text{color:#6b7280;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:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:1.5rem;display:flex;flex-direction:column;gap:.25rem}.meta-item .label{color:#9ca3af;font-size:.85rem}.meta-item .value{color:#1f2937;font-weight:600}.meta-item .value.status{color:#fff;background:#10b981;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:#10b981;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:#111827;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:#f9fafb;color:#1f2937;border:1px solid #e5e7eb;border-radius:6px;font-size:.8rem;font-weight:500;white-space:nowrap;transition:all .15s ease}.meta-item.stack .stack-chip:hover{background:#10b9811a;border-color:#10b9814d;color:#10b981}.section{background:#fff;border:1px solid #e5e7eb;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:#1f2937;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:#1f2937;margin-bottom:1rem}.bullet-list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:1rem;color:#6b7280;width:100%}.bullet-list li{margin:0;padding:.5rem 1rem .5rem 1.5rem;background:transparent;border:none;border-left:4px solid #10b981;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:#1f2937}.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:#f9fafb;border:2px dashed #e5e7eb;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,.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:#fff;border:1px solid #e5e7eb;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:#10b9810d}.toc-toggle .toc-toggle-title{font-weight:700;color:#1f2937;margin:0}.toc-toggle .toc-icon{font-size:1.2rem;font-weight:300;color:#6b7280;width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:transform .15s ease}.toc-title-static{font-weight:700;color:#1f2937;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:#6b7280;text-decoration:none;padding:.25rem 0;transition:color .15s ease,font-weight .15s ease;position:relative}.toc-link:hover{color:#10b981}.toc-link.active{color:#10b981;font-weight:600}.toc-link.active:before{content:"";position:absolute;left:-1.5rem;top:50%;transform:translateY(-50%);width:3px;height:16px;background-color:#10b981;border-radius:2px}.aside-cta{text-align:left}.aside-cta .cta-button{display:block;width:100%;text-align:center}.project-pager{display:flex;justify-content:space-between;align-items:center}.pager-link{color:#1f2937;text-decoration:none;border:1px solid #e5e7eb;background:#fff;border-radius:999px;padding:.5rem 1.5rem;transition:all .15s ease}.pager-link:hover{color:#fff;background:#111827;border-color:#111827}@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:rotate(45deg)}}.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:#fffffff2;-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:#10b9811a;border:1px solid rgba(16,185,129,.2)}.pull-indicator.can-refresh .pull-icon{color:#10b981}.pull-indicator.can-refresh .pull-text{color:#10b981;font-weight:500}.pull-indicator.refreshing{background:#10b9811a;border:1px solid rgba(16,185,129,.2)}.pull-indicator.refreshing .pull-icon{color:#10b981}.pull-indicator.refreshing .pull-text{color:#10b981;font-weight:500}.pull-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;color:#6b7280;transition:all .15s ease;margin-bottom:.5rem}.pull-icon svg{transition:transform .15s ease;width:32px;height:32px}.pull-text{font-size:.875rem;color:#6b7280;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:#6b7280;text-decoration:none;transition:all .25s ease;font-size:.95rem;font-weight:500;border:1px solid rgba(0,0,0,.08);background-color:#fff9;-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:#10b981;background-color:#10b98114;border-color:#10b98180;transform:translateY(-2px);box-shadow:0 8px 20px #10b98126}.pager-button:active{transform:translateY(0)}.pager-button:focus{outline:none}.pager-button:focus-visible{outline:2px solid #10b981;outline-offset:2px}.pager-button.prev .pager-icon{order:-1}.pager-button.disabled{color:#9ca3af;background-color:#0000000d;border-color:#00000014;cursor:not-allowed;pointer-events:none;opacity:.5}.pager-button.disabled:hover{color:#9ca3af;background-color:#0000000d;border-color:#00000014;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{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:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:.75rem;padding:.5rem 1rem;border:1px solid rgba(0,0,0,.08)}.nav-link{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;border-radius:.5rem;color:#6b7280;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:#10b981;background-color:#10b98114;transform:scale(1.05)}.nav-link:active{transform:scale(.95)}.nav-link:focus{outline:none}.nav-link:focus-visible{outline:2px solid #10b981;outline-offset:2px}.nav-link.nav-link--primary{background-color:#10b9811f;border:1px solid rgba(16,185,129,.3);color:#10b981;min-width:120px;justify-content:center}.nav-link.nav-link--primary:hover{background-color:#10b9812e;border-color:#10b98180;box-shadow:0 4px 12px #10b98126}.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{display:none!important}.wrapper{min-height:98vh;background:#f9fafb;display:flex;flex-direction:column;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;border-radius:12px;margin:.5rem;box-shadow:0 1px 8px #00000059;position:relative;max-height:98vh;overflow:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}@media(max-width:768px){.wrapper{margin-top:3rem;box-shadow:0 1px 3px #00000026}}
