body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.retro-page{-webkit-font-smoothing:none;-moz-osx-font-smoothing:grayscale;background:teal;color:#000;font-family:"MS Sans Serif","Microsoft Sans Serif",Tahoma,Geneva,sans-serif;font-size:13px;min-height:100vh;padding:20px}.retro-page *{box-sizing:border-box}.retro-page a{color:#00e;text-decoration:underline}.retro-page a:visited{color:#551a8b}.retro-page a:hover{color:red}.retro-page hr.retro-hr{background:linear-gradient(90deg,#0000,#888,#0000);border:none;height:2px;margin:16px 0}.retro-browser-chrome{background:silver;border-color:#fff #404040 #404040 #fff;border-style:solid;border-width:2px;box-shadow:4px 4px 0 #0006;margin:0 auto;max-width:1000px}.retro-titlebar{align-items:center;background:linear-gradient(90deg,navy,#1084d0);color:#fff;display:flex;font-size:12px;font-weight:700;justify-content:space-between;padding:3px 4px}.retro-titlebar-text{align-items:center;display:flex;gap:5px}.retro-titlebar-icon{border-radius:2px;height:16px;object-fit:cover;width:16px}.retro-titlebar-buttons{display:flex;gap:2px}.retro-tb-btn{background:silver;border-color:#fff #404040 #404040 #fff;border-style:solid;border-width:1px;color:#000;cursor:pointer;font-family:inherit;font-size:10px;height:14px;line-height:1;padding:0;width:16px}.retro-tb-btn:active{border-color:#404040 #fff #fff #404040}.retro-menubar{background:silver;border-bottom:1px solid grey;display:flex;font-size:12px;gap:12px;padding:2px 6px}.retro-menubar span{cursor:default;padding:1px 4px}.retro-menubar span:hover{background:navy;color:#fff}.retro-toolbar{border-bottom:1px solid grey;gap:2px}.retro-toolbar,.retro-toolbtn{align-items:center;background:silver;display:flex;padding:4px 6px}.retro-toolbtn{border:1px solid #0000;color:#000;cursor:pointer;flex-direction:column;font-family:inherit;font-size:11px;min-width:50px}.retro-toolbtn:hover{border-color:#fff #404040 #404040 #fff}.retro-toolbtn:active{border-color:#404040 #fff #fff #404040}.retro-toolicon{font-size:18px;line-height:1;margin-bottom:2px}.retro-toolbar-spacer{flex:1 1}.retro-n-logo{align-items:center;background:linear-gradient(135deg,#039,#06c);border-color:#fff #404040 #404040 #fff;border-style:solid;border-width:2px;color:#fff;display:flex;font-size:24px;font-style:italic;font-weight:700;height:36px;justify-content:center;margin-right:4px;width:36px}.retro-locationbar{align-items:center;background:silver;border-bottom:1px solid grey;display:flex;gap:4px;padding:4px 6px}.retro-loc-label{font-size:12px;font-weight:700;padding:0 4px}.retro-loc-input{background:#fff;border-color:#404040 #fff #fff #404040;border-style:solid;border-width:1px;flex:1 1;font-family:"MS Sans Serif",Tahoma,sans-serif;font-size:12px;padding:2px 4px}.retro-loc-btn{background:silver;border-color:#fff #404040 #404040 #fff;border-style:solid;border-width:1px;cursor:pointer;font-family:inherit;font-size:11px;padding:2px 8px}.retro-loc-btn:active{border-color:#404040 #fff #fff #404040}.retro-content{background:#fff;background-image:url("data:image/svg+xml;utf8,<svg xmlns=%27http://www.w3.org/2000/svg%27 width=%2740%27 height=%2740%27><circle cx=%273%27 cy=%273%27 r=%271%27 fill=%27%23eaeaff%27 opacity=%270.4%27/></svg>");color:#000;font-size:14px;line-height:1.4;min-height:600px;padding:20px 30px}.retro-content,.retro-content a{font-family:Times New Roman,Times,serif}.retro-header{align-items:center;display:flex;gap:16px;justify-content:center;margin-bottom:4px}.retro-portrait{border:3px ridge silver;height:80px;object-fit:cover;width:80px}.retro-logo-text{-webkit-text-fill-color:#0000;background:linear-gradient(180deg,#ff6b00,#ffb700 30%,#ff0080 70%,#c00060);-webkit-background-clip:text;background-clip:text;font-family:Comic Sans MS,Comic Sans,cursive;font-size:56px;font-weight:700;letter-spacing:-1px;margin:0;text-shadow:3px 3px 0 #00000026}.retro-tagline{color:#333;font-size:16px;font-style:italic;margin:4px 0 12px;text-align:center}.retro-announce{align-items:center;background:#ff0;border:2px solid #000;display:flex;font-family:"MS Sans Serif",Tahoma,sans-serif;font-size:13px;font-weight:700;gap:8px;margin:12px 0;padding:4px 8px}.retro-announce marquee{flex:1 1}.retro-announce-icon{font-size:18px}.retro-welcome-box{background:#f0f0ff;border:1px solid #888;font-family:Times New Roman,Times,serif;font-size:14px;margin:12px 0;padding:12px 16px}.retro-blink{animation:retro-blink 1s steps(2,start) infinite;background:red;color:#ff0;font-family:"MS Sans Serif",Tahoma,sans-serif;font-size:12px;font-weight:700;padding:1px 6px}@keyframes retro-blink{to{visibility:hidden}}.retro-nav{font-family:Times New Roman,Times,serif;font-size:15px;margin:12px 0;text-align:center}.retro-h2{color:#c00060;font-size:28px;margin:16px 0 8px;text-align:center;text-shadow:2px 2px 0 #0000001a}.retro-h2,.retro-h3{font-family:Comic Sans MS,Comic Sans,cursive}.retro-h3{color:#039;font-size:18px;margin:8px 0}.retro-about-table{border-collapse:collapse;font-family:Times New Roman,Times,serif;font-size:14px;margin:8px auto}.retro-about-table td{padding:4px 12px;vertical-align:top}.retro-about-label{color:#039;font-weight:700;text-align:right;white-space:nowrap}.retro-projects-table{border:2px solid navy;border-collapse:collapse;font-family:Times New Roman,Times,serif;font-size:13px;margin:8px 0;width:100%}.retro-projects-table th{background:navy;border:1px solid #000;color:#ff0;font-family:"MS Sans Serif",Tahoma,sans-serif;font-size:12px;padding:4px 8px;text-align:left}.retro-projects-table td{border:1px solid #ccc;padding:6px 8px;vertical-align:top}.retro-row-alt{background:#f0f0ff}.retro-projects-table tr:hover{background:#ffc}.retro-cell-center{text-align:center}.retro-cell-tech{color:#555;font-family:Courier New,Courier,monospace;font-size:11px}.retro-project-desc{color:#444;font-size:12px;font-style:italic}.retro-counter-wrap{display:flex;justify-content:center;margin:8px 0}.retro-counter{background:#000;border:3px ridge #888;color:#0f0;font-family:Courier New,Courier,monospace;font-size:28px;font-weight:700;letter-spacing:4px;padding:6px 14px;text-shadow:0 0 4px #0f0}.retro-button{background:silver;border-color:#fff #404040 #404040 #fff;border-style:solid;border-width:2px;color:#000;cursor:pointer;font-family:"MS Sans Serif",Tahoma,sans-serif;font-size:12px;font-weight:700;padding:4px 14px}.retro-button:active{border-color:#404040 #fff #fff #404040}.retro-guestbook{background:ivory;border:2px ridge silver;font-family:Times New Roman,Times,serif;margin:12px 0;padding:12px}.retro-guestbook-form table{margin-bottom:12px}.retro-guestbook-form td{padding:4px 8px}.retro-input,.retro-textarea{background:#fff;border-color:#404040 #fff #fff #404040;border-style:solid;border-width:2px;font-family:Times New Roman,Times,serif;font-size:14px;padding:2px 4px;width:280px}.retro-textarea{resize:vertical}.retro-gb-entry{background:#fff;border:1px solid #ccc;font-size:13px;margin-bottom:6px;padding:6px 10px}.retro-gb-date{color:#888;font-size:11px}.retro-gb-msg{color:#333;font-style:italic;margin-top:2px}.retro-badges{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin:16px 0}.retro-badge{background:#fff;border:2px outset silver;font-family:"MS Sans Serif",Tahoma,sans-serif;font-size:11px;padding:8px;text-align:center;width:130px}.retro-badge-title{border-bottom:1px solid #888;color:navy;font-weight:700;margin-bottom:4px;padding-bottom:2px}.retro-badge-name{color:#c00060;font-family:Comic Sans MS,Comic Sans,cursive;font-size:13px;font-weight:700}.retro-badge-yellow{background:#ffc}.retro-badge-yellow .retro-badge-title{color:#a50}.retro-badge-green{background:#cfc}.retro-badge-green .retro-badge-name,.retro-badge-green .retro-badge-title{color:#060}.retro-badge-blue{background:#ccf}.retro-badge-blue .retro-badge-title{color:navy}.retro-badge-red{background:#fcc}.retro-badge-red .retro-badge-title{color:#a00}.retro-footer{color:#333;font-family:Times New Roman,Times,serif;font-size:13px;padding:12px 0;text-align:center}.retro-footer p{margin:2px 0}.retro-statusbar{background:silver;border-top:1px solid #fff;display:flex;font-family:"MS Sans Serif",Tahoma,sans-serif;font-size:11px;gap:12px;padding:3px 8px}.retro-status-item{background:silver;border-color:#404040 #fff #fff #404040;border-style:solid;border-width:1px;padding:1px 8px}.retro-status-item:first-child{flex:1 1}.retro-loading{background:teal;color:#fff;flex-direction:column;font-family:"MS Sans Serif",Tahoma,sans-serif;font-size:14px;justify-content:center;min-height:100vh}.retro-loading,.retro-mode-btn{align-items:center;display:flex}.retro-mode-btn{background:silver;border-color:#fff #404040 #404040 #fff;border-style:solid;border-width:2px;box-shadow:2px 2px 0 #0006;color:#000;cursor:pointer;font-family:"MS Sans Serif","Microsoft Sans Serif",Tahoma,sans-serif;font-size:12px;font-weight:700;gap:6px;padding:6px 14px;position:fixed;right:12px;top:12px;z-index:9999}.retro-mode-btn:hover{background:#d4d4d4}.retro-mode-btn:active{border-color:#404040 #fff #fff #404040;box-shadow:1px 1px 0 #0006}.retro-mode-btn-icon{background:linear-gradient(135deg,#039,#06c);border:1px solid #000;color:#fff;display:inline-block;font-size:13px;font-style:italic;font-weight:700;height:16px;line-height:14px;text-align:center;width:16px}@media (max-width:768px){.retro-page{padding:8px}.retro-content{padding:12px}.retro-logo-text{font-size:40px}.retro-h2{font-size:22px}.retro-toolbtn{font-size:10px;min-width:40px}.retro-projects-table{font-size:11px}.retro-projects-table td,.retro-projects-table th{padding:4px}.retro-input,.retro-textarea{width:100%}}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea,#764ba2);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;min-height:100vh}.App{overflow-x:hidden}.App,.homepage{min-height:100vh;position:relative}.homepage{padding:2rem}.hero-section{padding:6rem 0 0;position:relative;text-align:center}.hero-title{-webkit-text-fill-color:#0000;animation:gradientShift 3s ease-in-out infinite;background:linear-gradient(45deg,#ff6b6b,#4ecdc4,#45b7d1);-webkit-background-clip:text;background-clip:text;background-size:300% 300%;color:#fff;font-size:clamp(2.5rem,5vw,4rem);font-weight:700;margin-bottom:1rem}.hero-subtitle{color:#ffffffe6;font-size:clamp(1.1rem,2vw,1.3rem);line-height:1.6;margin-bottom:2rem;margin-left:auto;margin-right:auto;max-width:600px}.search-container{margin:0 auto;max-width:500px;position:relative;width:100%}.search-container input{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:2px solid #ffffff4d;border-radius:30px;box-shadow:0 4px 20px #0003;color:#fff;font-size:1rem;outline:none;padding:1rem 3rem;transition:all .3s ease;width:100%}.search-container input::placeholder{color:#fff9;font-size:.95rem}.search-container input:focus{background:#ffffff26;border-color:#ffffff80;box-shadow:0 6px 25px #0000004d;transform:scale(1.02)}.search-icon{left:1rem;pointer-events:none}.search-clear,.search-icon{color:#fff9;position:absolute;top:50%;transform:translateY(-50%)}.search-clear{align-items:center;background:#0000;border:none;border-radius:50%;cursor:pointer;display:flex;justify-content:center;padding:.25rem;right:1rem;transition:all .3s ease}.search-clear:hover{background-color:#ffffff1a;color:#fff}.search-results-info{color:#fffc;font-size:.9rem;margin-bottom:2rem;text-align:center}.no-results{color:#fff9;padding:4rem 2rem;text-align:center}.no-results h3{color:#fffc;font-size:1.5rem;margin-bottom:1rem}.suggested-tags{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-top:1rem}.suggested-tag{background:#ffffff1a;border:1px solid #fff3;border-radius:20px;color:#fff;cursor:pointer;font-size:.8rem;padding:.5rem 1rem;transition:all .3s ease}.suggested-tag:hover{background:#fff3;transform:scale(1.05)}@keyframes gradientShift{0%,to{background-position:0 50%}50%{background-position:100% 50%}}.projects-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));margin:0 auto;max-width:1400px;padding:0 1rem}.project-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:20px;cursor:pointer;overflow:hidden;padding:0;position:relative;transition:all .3s ease}.project-card:hover{border-color:#ffffff4d;box-shadow:0 20px 40px #0000004d;transform:translateY(-8px)}.project-image{border-radius:20px 20px 0 0;height:250px;object-fit:cover;width:100%}.project-content{padding:1.5rem;position:relative}.project-title{color:#fff;font-size:1.3rem;font-weight:600;line-height:1.3;margin-bottom:.5rem}.project-description{-webkit-line-clamp:3;-webkit-box-orient:vertical;color:#fffc;display:-webkit-box;line-height:1.5;margin-bottom:1rem;overflow:hidden}.tech-stack{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.tech-badge{background:linear-gradient(45deg,#ff6b6b,#4ecdc4);border-radius:20px;color:#fff;font-size:.8rem;font-weight:500;padding:.3rem .8rem}.project-link{align-items:center;color:#4ecdc4;display:inline-flex;font-weight:500;gap:.5rem;text-decoration:none;transition:color .3s ease}.project-link:hover{color:#45b7d1}.project-detail{min-height:100vh;padding:2rem;position:relative}.back-button{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:50px;color:#fff;display:inline-flex;gap:.5rem;left:2rem;padding:1rem 1.5rem;position:fixed;text-decoration:none;top:2rem;transition:all .3s ease;z-index:100}.back-button:hover{background:#fff3;transform:translateX(-5px)}.detail-container{margin:0 auto;max-width:1200px;padding-top:4rem}.detail-hero{margin-bottom:1rem;text-align:center}.detail-image{border-radius:20px;box-shadow:0 20px 40px #0000004d;height:auto;margin-bottom:2rem;max-width:800px;width:100%}.detail-title{color:#fff;font-size:clamp(2rem,4vw,3rem);font-weight:700;margin-bottom:1rem}.detail-description{color:#ffffffe6;font-size:1.1rem;line-height:1.6;margin:0 auto 2rem;max-width:700px}.detail-content{grid-gap:3rem;display:grid;gap:3rem;grid-template-columns:1fr 1fr;margin-top:3rem}.features-section,.tech-section{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:20px;padding:2rem}.section-title{color:#fff;font-size:1.5rem;font-weight:600;margin-bottom:1rem}.features-list{list-style:none}.features-list li{border-bottom:1px solid #ffffff1a;color:#ffffffe6;padding:.5rem 0 .5rem 1.5rem;position:relative}.features-list li:before{color:#4ecdc4;content:"→";font-weight:700;left:0;position:absolute}.tech-grid{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.tech-item{background:linear-gradient(45deg,#667eea,#764ba2);border-radius:10px;color:#fff;font-size:.9rem;font-weight:500;padding:.8rem;text-align:center}@media (max-width:768px){.projects-grid{gap:1.5rem;grid-template-columns:1fr;padding:0 .5rem}.detail-content{gap:2rem;grid-template-columns:1fr}.homepage{padding:1rem}.hero-section{padding:3rem 0 2rem}.back-button{left:1rem;padding:.8rem 1.2rem;top:1rem}.search-container{max-width:100%;padding:0 1rem}.search-container input{font-size:.9rem;padding:.9rem 2.5rem}.search-container input::placeholder{font-size:.85rem}.search-icon{left:.8rem}.search-clear{right:.8rem}.suggested-tags{padding:0 1rem}.suggested-tag{font-size:.75rem;padding:.4rem .8rem}}@media (max-width:480px){.projects-grid{gap:1rem;grid-template-columns:1fr}.project-card{margin:0 .5rem}.tech-stack{gap:.3rem}.tech-badge{font-size:.7rem;padding:.2rem .6rem}.search-container{padding:0 .5rem}.search-container input{font-size:.85rem;padding:.8rem 2.2rem}.search-container input::placeholder{font-size:.8rem}.search-icon{font-size:16px;left:.7rem}.search-clear{font-size:16px;right:.7rem}.no-results{padding:2rem 1rem}.suggested-tags{gap:.3rem;padding:0 .5rem}.suggested-tag{font-size:.7rem;padding:.3rem .6rem}}.loading{align-items:center;color:#fff;display:flex;font-size:1.2rem;justify-content:center;min-height:50vh}.spinner{animation:spin 1s linear infinite;border:4px solid #ffffff4d;border-radius:50%;border-top-color:#4ecdc4;height:40px;margin-right:1rem;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.lightbox-overlay{align-items:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#000c;display:flex;height:100%;justify-content:center;left:0;padding:2rem;position:fixed;top:0;width:100%;z-index:1000}.lightbox-content{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:20px;max-height:90%;max-width:90%;padding:2rem;position:relative}.lightbox-close{background:none;border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:2rem;padding:.5rem;position:absolute;right:1rem;top:1rem;transition:background .3s ease}.lightbox-close:hover{background-color:#000c;transform:scale(1.1)}.client-logos-section{overflow:hidden;padding:1rem 0 3rem;position:relative}.logos-scroll-container{height:140px;mask:linear-gradient(90deg,#0000,#fff 10%,#fff 90%,#0000);-webkit-mask:linear-gradient(90deg,#0000,#fff 10%,#fff 90%,#0000);overflow:hidden;position:relative}.logos-scroll-track{align-items:center;animation:scroll 30s linear infinite;display:flex;gap:2rem;height:100%;position:absolute;white-space:nowrap}.logos-scroll-track:hover{animation-play-state:paused}.logo-item{align-items:center;display:flex;flex-shrink:0;height:120px;justify-content:center;padding:1rem;position:relative;transition:all .3s ease;width:200px}.logo-item img{max-height:100%;max-width:100%;object-fit:contain;opacity:.8;transition:all .3s ease}.logo-item:hover img{opacity:1}.logo-item span{color:#ffffffb3;display:none;font-size:1.2rem;font-weight:600;text-align:center}@keyframes scroll{0%{transform:translateX(0)}to{transform:translateX(-50%)}}@media (max-width:768px){.client-logos-section{padding:.5rem 0 2rem}.logos-scroll-container{height:100px}.logo-item{height:90px;padding:.8rem;width:160px}.logos-scroll-track{gap:1.5rem}}@media (max-width:480px){.client-logos-section{padding:.5rem 0 1.5rem}.logos-scroll-container{height:80px}.logo-item{height:70px;padding:.6rem;width:140px}.logos-scroll-track{gap:1rem}}@media (prefers-reduced-motion:reduce){.logos-scroll-track{animation:none}.logos-scroll-container{mask:none;-webkit-mask:none}.logos-scroll-track{flex-wrap:wrap;gap:2rem;justify-content:center;padding:2rem;position:static}}
/*# sourceMappingURL=main.57366410.css.map*/