*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:#0f172a;color:#e2e8f0;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.6}.container{margin:0 auto;max-width:1200px;padding:20px}.App{min-height:100vh;padding-top:70px}.section{background:linear-gradient(135deg,#1e293b,#334155);border:1px solid #3b82f633;border-radius:12px;box-shadow:0 4px 20px #0000004d;margin:20px 0;padding:30px}.section-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#3b82f6,#06b6d4);-webkit-background-clip:text;background-clip:text;border-bottom:3px solid #3b82f6;color:#f1f5f9;font-size:2rem;margin-bottom:20px;padding-bottom:10px}@media (max-width:768px){.section{margin:10px 0;padding:20px}.section-title{font-size:1.5rem}}.navbar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0f172af2;border-bottom:1px solid #3b82f633;box-shadow:0 2px 20px #0000004d;left:0;position:fixed;right:0;top:0;z-index:1000}.navbar-container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;padding:15px 20px}.navbar-logo{color:#f1f5f9;cursor:pointer;font-size:1.8rem;gap:10px;transition:transform .3s ease}.navbar-logo,.navbar-logo:before{align-items:center;display:flex;font-weight:700}.navbar-logo:before{background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:50%;box-shadow:0 4px 15px #3b82f666;color:#fff;content:"L";font-size:1.3rem;height:40px;justify-content:center;width:40px}.navbar-logo:hover{transform:scale(1.05)}.navbar-menu{display:flex;gap:30px;list-style:none;margin:0;padding:0}.navbar-menu li a{color:#cbd5e1;cursor:pointer;font-size:1.1rem;font-weight:500;position:relative;text-decoration:none;transition:color .3s ease}.navbar-menu li a:after{background:linear-gradient(90deg,#3b82f6,#06b6d4);bottom:-5px;content:"";height:2px;left:0;position:absolute;transition:width .3s ease;width:0}.navbar-menu li a:hover{color:#3b82f6}.navbar-menu li a:hover:after{width:100%}.menu-toggle{background:none;border:none;cursor:pointer;display:none;flex-direction:column;padding:5px;z-index:1001}.menu-toggle span{background:#f1f5f9;border-radius:3px;height:3px;margin:3px 0;transition:.3s;width:25px}@media (max-width:768px){.menu-toggle{display:flex}.navbar-menu{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0f172afa;border-bottom:1px solid #3b82f633;box-shadow:0 5px 20px #00000080;flex-direction:column;gap:0;left:0;max-height:0;overflow:hidden;padding:0;position:absolute;right:0;top:100%;transition:max-height .3s ease}.navbar-menu.active{max-height:400px}.navbar-menu li{border-bottom:1px solid #3b82f61a;padding:0}.navbar-menu li:last-child{border-bottom:none}.navbar-menu li a{color:#cbd5e1;display:block;padding:20px}.navbar-menu li a:hover{background:#3b82f61a;color:#3b82f6}.menu-toggle.active span:first-child{transform:rotate(-45deg) translate(-5px,6px)}.menu-toggle.active span:nth-child(2){opacity:0}.menu-toggle.active span:nth-child(3){transform:rotate(45deg) translate(-5px,-6px)}}.header{align-items:center;background:linear-gradient(135deg,#0f172a,#1e293b 50%,#334155);display:flex;min-height:90vh;overflow:hidden;padding:100px 20px 80px;position:relative}.header:before{background:linear-gradient(90deg,#3b82f61a 1px,#0000 0),linear-gradient(#3b82f61a 1px,#0000 0);background-size:50px 50px;bottom:0;content:"";left:0;opacity:.3;position:absolute;right:0;top:0}.header-content{grid-gap:60px;align-items:center;display:grid;gap:60px;grid-template-columns:1fr 1fr;margin:0 auto;max-width:1200px;position:relative;z-index:1}.hero-left{text-align:left}.greeting{color:#94a3b8;font-size:2rem;font-weight:400;letter-spacing:.5px;margin-bottom:10px}.name{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#3b82f6,#06b6d4);-webkit-background-clip:text;background-clip:text;color:#f1f5f9;font-size:3.5rem;font-weight:700;line-height:1.2;margin-bottom:20px}.tagline{color:#cbd5e1;font-size:1.1rem;line-height:1.8;margin-bottom:30px}.contact-info{color:#94a3b8;font-size:1rem;margin-bottom:30px}.contact-info p{align-items:center;display:flex;gap:8px;margin:8px 0}.highlight{color:#3b82f6}.cta-button,.highlight{font-weight:600;position:relative}.cta-button{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:8px;box-shadow:0 4px 15px #3b82f666;color:#fff;cursor:pointer;font-size:1.1rem;overflow:hidden;padding:15px 35px;transition:all .3s ease}.cta-button:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s;width:100%}.cta-button:hover:before{left:100%}.cta-button:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 6px 25px #3b82f680;transform:translateY(-2px)}.stats{display:flex;gap:40px;margin-top:50px}.stat-item{text-align:left}.stat-item h3{color:#2c3e50;font-size:2.5rem;font-weight:700;margin-bottom:5px}.stat-item p{color:#7f8c8d;font-size:.95rem}.hero-right{align-items:center;display:flex;justify-content:center}.profile-image-container{background:linear-gradient(135deg,#1e293b,#334155);border:2px solid #3b82f64d;border-radius:20px;box-shadow:0 20px 60px #00000080;height:500px;overflow:hidden;position:relative;width:400px}.profile-image-container:before{background:linear-gradient(135deg,#3b82f6,#06b6d4,#3b82f6);border-radius:20px;bottom:-2px;content:"";filter:blur(10px);left:-2px;opacity:.5;position:absolute;right:-2px;top:-2px;z-index:-1}.profile-image{height:100%;object-fit:cover;pointer-events:none;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;width:100%}@media (max-width:968px){.header-content{gap:40px;grid-template-columns:1fr}.hero-left{text-align:center}.greeting{font-size:1.5rem}.name{font-size:2.5rem}.stats{justify-content:center}.stat-item{text-align:center}.profile-image-container{height:400px;width:300px}}@media (max-width:480px){.name{font-size:2rem}.stats{flex-direction:column;gap:20px}.profile-image-container{height:350px;width:250px}}.work-experience .job{border-bottom:1px solid #3b82f633;margin-bottom:30px;padding-bottom:30px}.work-experience .job:last-child{border-bottom:none}.job-header{align-items:center;display:flex;flex-wrap:wrap;justify-content:space-between;margin-bottom:10px}.company{color:#f1f5f9;font-size:1.5rem;margin:0}.date-range{color:#94a3b8;font-size:.95rem;font-weight:600}.position{color:#3b82f6;font-size:1.2rem;font-weight:600;margin:5px 0}.location{color:#94a3b8;font-style:italic;margin-bottom:15px}.responsibilities{list-style-position:inside;padding-left:20px}.responsibilities li{color:#cbd5e1;line-height:1.6;margin:8px 0}@media (max-width:768px){.job-header{align-items:flex-start;flex-direction:column}.date-range{margin-top:5px}}.education .education-item{border-bottom:1px solid #3b82f633;margin-bottom:25px;padding-bottom:25px}.education .education-item:last-child{border-bottom:none}.edu-header{align-items:center;display:flex;flex-wrap:wrap;justify-content:space-between;margin-bottom:10px}.institution{color:#f1f5f9;font-size:1.3rem;margin:0}.course{color:#3b82f6;font-size:1.1rem;font-weight:600;margin:5px 0}.level{color:#94a3b8;font-style:italic}@media (max-width:768px){.edu-header{align-items:flex-start;flex-direction:column}}.skills-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.skill-item{background:linear-gradient(135deg,#1e40af,#3b82f6);border:1px solid #3b82f64d;border-radius:8px;color:#fff;font-weight:500;padding:15px 20px;text-align:center;transition:transform .3s ease,box-shadow .3s ease}.skill-item:hover{background:linear-gradient(135deg,#2563eb,#06b6d4);box-shadow:0 8px 25px #3b82f680;transform:translateY(-5px)}@media (max-width:768px){.skills-grid{grid-template-columns:1fr}}.freelance-projects .projects-list{list-style:none;padding:0}.project-item{background:#1e293b80;border:1px solid #3b82f633;border-radius:8px;color:#cbd5e1;margin:10px 0;padding:15px 20px;transition:transform .2s ease,box-shadow .2s ease}.project-item:hover{background:#1e293bcc;border-left-color:#06b6d4;box-shadow:0 4px 20px #3b82f64d;transform:translateX(5px)}.gallery-project{background:linear-gradient(135deg,#1e293b,#334155);border:1px solid #3b82f633;border-radius:12px;margin-bottom:20px;padding:25px;transition:all .3s ease}.gallery-project:hover{border-color:#3b82f666;box-shadow:0 4px 20px #0000004d}.gallery-header{align-items:center;cursor:pointer;display:flex;gap:20px;justify-content:space-between}.gallery-header-content{flex:1 1}.gallery-title{color:#f1f5f9;font-size:1.5rem;margin-bottom:8px}.gallery-subtitle{color:#94a3b8;font-size:1rem;margin-bottom:15px}.tech-tags{display:flex;flex-wrap:wrap;gap:8px}.tech-tag{background:#3b82f61a;border:1px solid #3b82f64d;border-radius:12px;color:#3b82f6;font-size:.8rem;font-weight:500;padding:5px 12px}.expand-button{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:8px;box-shadow:0 4px 15px #3b82f64d;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;padding:12px 24px;transition:all .3s ease;white-space:nowrap}.expand-button:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 6px 20px #3b82f666;transform:translateY(-2px)}.gallery-grid{grid-gap:20px;animation:slideDown .3s ease;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-top:25px}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.gallery-item{background:linear-gradient(135deg,#0f172a,#1e293b);border:1px solid #3b82f633;border-radius:10px;cursor:pointer;overflow:hidden;transition:all .3s ease}.gallery-item:hover{border-color:#3b82f680;box-shadow:0 10px 30px #3b82f64d;transform:translateY(-5px)}.gallery-image{align-items:center;background:#0f172a;color:#64748b;display:flex;font-size:.9rem;height:200px;justify-content:center;object-fit:cover;width:100%}.gallery-image img{height:100%;object-fit:cover;pointer-events:none;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;width:100%}.gallery-caption{color:#cbd5e1;font-size:.9rem;padding:12px;text-align:center}.modal-overlay{background:#000000e6;bottom:0;justify-content:center;left:0;padding:60px 80px 20px;position:fixed;right:0;top:0;z-index:2000}.modal-content,.modal-overlay{align-items:center;display:flex}.modal-content{flex-direction:column;max-height:90%;max-width:90%;position:relative}.modal-image{border-radius:8px;max-height:75vh;max-width:100%;object-fit:contain;pointer-events:none;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.modal-close{background:#3b82f6e6;border:none;border-radius:8px;box-shadow:0 4px 15px #00000080;color:#fff;cursor:pointer;font-size:24px;font-weight:700;padding:12px 24px;position:fixed;right:20px;top:20px;transition:all .3s ease;z-index:2001}.modal-close:hover{background:#3b82f6;transform:scale(1.1)}.modal-nav{background:#3b82f6e6;border:none;border-radius:8px;box-shadow:0 4px 15px #00000080;color:#fff;cursor:pointer;font-size:40px;font-weight:700;line-height:1;padding:20px 25px;position:fixed;top:50%;transform:translateY(-50%);transition:all .3s ease;z-index:2001}.modal-nav:hover{background:#3b82f6;transform:translateY(-50%) scale(1.1)}.modal-prev{left:20px}.modal-next{right:20px}.modal-caption{color:#94a3b8;font-size:16px;margin-top:15px;text-align:center}.modal-counter{color:#64748b;font-size:14px;margin-top:10px;text-align:center}@media (max-width:768px){.gallery-header{flex-wrap:wrap;gap:15px}.expand-button{font-size:.9rem;max-width:200px;padding:10px 20px;width:100%}.gallery-title{font-size:1.3rem}.gallery-subtitle{font-size:.95rem}.modal-overlay{padding:60px 60px 20px}.modal-close{font-size:20px;padding:10px 20px;right:10px;top:10px}.modal-nav{font-size:32px;padding:15px 18px}.modal-prev{left:10px}.modal-next{right:10px}.modal-image{max-height:70vh}}@media (max-width:480px){.gallery-project{padding:15px}.gallery-header{align-items:flex-start!important;flex-direction:column!important;gap:12px}.gallery-header-content{width:100%}.expand-button{align-self:stretch;font-size:.85rem;max-width:100%!important;padding:10px 18px;width:100%!important}.gallery-title{font-size:1.2rem}.gallery-subtitle{font-size:.9rem}.tech-tags{margin-bottom:0}.tech-tag{font-size:.75rem;padding:4px 10px}.modal-overlay{padding:50px 50px 20px}.modal-close{font-size:18px;padding:8px 16px;right:5px;top:5px}.modal-nav{font-size:28px;padding:12px 15px}.modal-prev{left:5px}.modal-next{right:5px}}.api-tester{background:linear-gradient(135deg,#1e293b,#334155);border:1px solid #3b82f633;border-radius:12px;margin-bottom:20px;padding:30px}.api-title{color:#f1f5f9;font-size:1.8rem;margin-bottom:8px}.api-subtitle{color:#94a3b8;font-size:1rem;margin-bottom:20px}.api-info{background:#0f172a80;border-radius:8px;margin-bottom:20px;padding:15px}.api-url{color:#cbd5e1;font-size:.9rem;margin:0}.api-url code{background:#3b82f61a;border-radius:4px;color:#3b82f6;font-family:Courier New,monospace;padding:4px 8px}.token-status{color:#10b981;font-weight:600;margin:10px 0 0}.token-status-wrapper{align-items:center;display:flex;flex-wrap:wrap;gap:15px}.token-expiry{color:#f59e0b;font-family:Courier New,monospace;font-size:.9rem;font-weight:600;margin:10px 0 0}.api-buttons{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-bottom:20px}.api-btn{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;padding:12px 20px;transition:all .3s ease}.api-btn:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 4px 15px #3b82f666;transform:translateY(-2px)}.api-btn:disabled{cursor:not-allowed;opacity:.5}.start-btn{background:linear-gradient(135deg,#10b981,#059669)}.start-btn:hover:not(:disabled){background:linear-gradient(135deg,#059669,#047857)}.login-btn{background:linear-gradient(135deg,#f59e0b,#d97706)}.login-btn:hover:not(:disabled){background:linear-gradient(135deg,#d97706,#b45309)}.loading{align-items:center;color:#3b82f6;display:flex;font-size:1rem;gap:12px;justify-content:center;padding:20px}.spinner{animation:spin .8s linear infinite;border:3px solid #3b82f64d;border-radius:50%;border-top-color:#3b82f6;height:20px;width:20px}.instance-starting{background:#10b9811a;border:1px solid #10b9814d;border-radius:8px;margin:20px 0;padding:30px;text-align:center}.spinner-large{animation:spin 1s linear infinite;border:4px solid #10b9814d;border-radius:50%;border-top-color:#10b981;height:50px;margin:0 auto 20px;width:50px}@keyframes spin{to{transform:rotate(1turn)}}.starting-message{color:#10b981;font-size:1.1rem;font-weight:600;margin:0 0 10px}.starting-info{color:#94a3b8;font-size:.9rem;margin:0 0 20px}.startup-logs{background:#0f172acc;border:1px solid #10b9814d;border-radius:8px;margin-top:20px;overflow:hidden;text-align:left}.logs-header{background:#10b98133;border-bottom:1px solid #10b9814d;color:#10b981;font-size:.9rem;font-weight:600;padding:10px 15px}.logs-content{max-height:200px;overflow-y:auto;padding:15px}.log-entry{animation:fadeIn .3s ease;color:#cbd5e1;font-family:Courier New,monospace;font-size:.85rem;line-height:1.6;padding:4px 0}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.error-box{background:#ef44441a;border:1px solid #ef44444d;border-radius:8px;color:#fca5a5;margin-bottom:20px;padding:15px}.response-box{background:#0f172acc;border:1px solid #3b82f64d;border-radius:8px;margin-bottom:20px;overflow:hidden}.response-header{align-items:center;background:#3b82f61a;border-bottom:1px solid #3b82f633;color:#3b82f6;display:flex;font-weight:600;justify-content:space-between;padding:12px 15px}.clear-btn{background:#ef444433;border:1px solid #ef44444d;border-radius:4px;color:#fca5a5;cursor:pointer;font-size:.85rem;padding:4px 12px;transition:all .3s ease}.clear-btn:hover{background:#ef44444d}.response-box pre{color:#cbd5e1;font-family:Courier New,monospace;font-size:.85rem;line-height:1.6;margin:0;overflow-x:auto;padding:15px}.api-tech{border-top:1px solid #3b82f633;display:flex;flex-wrap:wrap;gap:10px;margin-top:20px;padding-top:20px}.tech-badge{background:#3b82f61a;border:1px solid #3b82f64d;border-radius:12px;color:#3b82f6;font-size:.85rem;font-weight:500;padding:6px 14px}@media (max-width:768px){.api-tester{padding:20px}.api-buttons{grid-template-columns:1fr}.api-title{font-size:1.5rem}.response-box pre{font-size:.75rem}}.token-input-section{background:#0f172a80;border:1px solid #3b82f633;border-radius:8px;margin-bottom:20px;padding:20px}.token-label{color:#cbd5e1;display:block;font-size:.9rem;font-weight:600;margin-bottom:10px}.token-input-wrapper{align-items:center;display:flex;gap:8px;position:relative}.token-input{background:#0f172acc;border:1px solid #3b82f64d;border-radius:6px;color:#f1f5f9;flex:1 1;font-family:Courier New,monospace;font-size:.85rem;padding:12px 40px 12px 15px;transition:all .3s ease;width:100%}.token-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.token-input::placeholder{color:#64748b}.clear-token-btn{align-items:center;background:#ef444433;border:1px solid #ef44444d;border-radius:50%;color:#fca5a5;cursor:pointer;display:flex;font-size:.9rem;height:28px;justify-content:center;position:absolute;right:10px;transition:all .3s ease;width:28px}.clear-token-btn:hover{background:#ef444466;transform:scale(1.1)}.token-hint{color:#94a3b8;font-size:.85rem;font-style:italic;margin:10px 0 0}@media (max-width:768px){.token-input{font-size:.75rem;padding:10px 35px 10px 12px}.token-hint{font-size:.8rem}}.request-details-box{background:#10b9810d;border:1px solid #10b9814d;border-radius:8px;margin-bottom:20px;overflow:hidden}.request-header{background:#10b9811a;border-bottom:1px solid #10b98133;color:#10b981;font-weight:600;justify-content:space-between;padding:12px 15px}.copy-btn,.request-header{align-items:center;display:flex}.copy-btn{background:#3b82f633;border:1px solid #3b82f64d;border-radius:4px;color:#3b82f6;cursor:pointer;font-size:.85rem;gap:5px;padding:6px 12px;transition:all .3s ease}.copy-btn:hover{background:#3b82f64d;transform:translateY(-1px)}.request-content{padding:15px}.request-line{align-items:flex-start;display:flex;gap:10px;margin-bottom:12px}.request-line:last-child{margin-bottom:0}.request-label{color:#94a3b8;flex-shrink:0;font-size:.85rem;font-weight:600;min-width:120px}.request-value{background:#0f172a99;border-radius:4px;color:#10b981;flex:1 1;font-family:Courier New,monospace;font-size:.8rem;padding:6px 10px;word-break:break-all}@media (max-width:768px){.request-line{flex-direction:column;gap:5px}.request-label{min-width:auto}.copy-btn{font-size:.75rem;padding:5px 10px}}.request-value-with-copy{align-items:center;display:flex;flex:1 1;gap:8px}.request-value-with-copy .request-value{flex:1 1;margin:0}.copy-inline-btn{align-items:center;background:#3b82f633;border:1px solid #3b82f64d;border-radius:4px;color:#3b82f6;cursor:pointer;display:flex;flex-shrink:0;font-size:1rem;height:32px;justify-content:center;transition:all .3s ease;width:32px}.copy-inline-btn:hover{background:#3b82f666;transform:scale(1.1)}.token-masked{color:#f59e0b}.token-expired-warning{animation:pulse 2s ease-in-out infinite;background:#f59e0b1a;border:2px solid #f59e0b80;border-radius:8px;color:#fbbf24;margin-bottom:20px;padding:20px;text-align:center}.token-expired-warning strong{color:#f59e0b;display:block;font-size:1.1rem;margin-bottom:8px}.token-expired-warning p{color:#fcd34d;font-size:.9rem;margin:0}@keyframes pulse{0%,to{background:#f59e0b1a;border-color:#f59e0b80}50%{background:#f59e0b26;border-color:#f59e0bcc}}.footer{background:linear-gradient(135deg,#0f172a,#1e293b);border-top:2px solid #3b82f64d;margin-top:60px;padding:40px 20px}.footer-content{margin:0 auto;max-width:1200px;text-align:center}.footer-title{color:#94a3b8;font-size:.95rem;letter-spacing:1px;margin-bottom:15px;text-transform:uppercase}.tech-stack{display:flex;flex-wrap:wrap;gap:15px;justify-content:center;margin-bottom:30px}.tech-item{background:#3b82f61a;border:1px solid #3b82f64d;border-radius:20px;color:#3b82f6;font-size:.9rem;font-weight:500;padding:8px 20px;transition:all .3s ease}.tech-item:hover{background:#3b82f633;border-color:#3b82f6;transform:translateY(-2px)}.copyright{border-top:1px solid #64748b4d;color:#64748b;font-size:.9rem;margin-top:20px;padding-top:20px}@media (max-width:768px){.footer{padding:30px 20px}.tech-stack{gap:10px}.tech-item{font-size:.85rem;padding:6px 15px}}
/*# sourceMappingURL=main.a1fd951f.css.map*/