.navbar{position:sticky;top:0;z-index:1000;background:#0a0a0fcc;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border-color);padding:1rem 0}.navbar .container{display:flex;justify-content:space-between;align-items:center}.nav-brand{display:flex;align-items:center;text-decoration:none;transition:opacity .3s ease}.nav-brand:hover{opacity:.8}.nav-logo{height:55px;width:auto}.nav-links{display:flex;gap:2rem;align-items:center}.nav-link{color:var(--text-secondary);text-decoration:none;font-weight:500;font-size:.95rem;transition:color .3s ease;position:relative}.nav-link:hover{color:var(--text-primary)}.nav-link:after{content:"";position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--accent-primary);transition:width .3s ease}.nav-link:hover:after{width:100%}@media (max-width: 768px){.nav-links{gap:1rem}.nav-link{font-size:.85rem}}.hero{position:relative;min-height:90vh;display:flex;align-items:center;padding:4rem 0;overflow:hidden}.hero-background{position:absolute;top:0;left:0;right:0;bottom:0;z-index:0}.grid-pattern{position:absolute;top:0;left:0;right:0;bottom:0;background-image:linear-gradient(rgba(59,130,246,.1) 1px,transparent 1px),linear-gradient(90deg,rgba(59,130,246,.1) 1px,transparent 1px);background-size:50px 50px;opacity:.3}.gradient-orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.4;animation:float 20s ease-in-out infinite}.orb-1{width:400px;height:400px;background:var(--gradient-1);top:-200px;left:-200px;animation-delay:0s}.orb-2{width:300px;height:300px;background:var(--gradient-3);bottom:-150px;right:-150px;animation-delay:5s}.orb-3{width:250px;height:250px;background:var(--gradient-2);top:50%;right:20%;animation-delay:10s}@keyframes float{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-30px) scale(1.1)}66%{transform:translate(-20px,20px) scale(.9)}}.hero-content{position:relative;z-index:1;text-align:center;max-width:900px;margin:0 auto}.hero-logo-container{margin-bottom:2rem;display:flex;justify-content:center}.hero-logo{height:140px;width:auto;filter:drop-shadow(0 0 20px rgba(59,130,246,.3))}.hero-title{font-size:clamp(2.5rem,6vw,4.5rem);font-weight:700;line-height:1.2;margin-bottom:1.5rem;letter-spacing:-.02em}.gradient-text{background:var(--gradient-1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-description{font-size:clamp(1rem,2vw,1.25rem);color:var(--text-secondary);max-width:700px;margin:0 auto 3rem;line-height:1.8}.hero-stats{display:flex;justify-content:center;gap:4rem;flex-wrap:wrap}.stat-item{text-align:center}.stat-number{font-size:2.5rem;font-weight:700;background:var(--gradient-1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-family:JetBrains Mono,monospace;margin-bottom:.5rem}.stat-label{font-size:.9rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.1em}@media (max-width: 768px){.hero{min-height:80vh;padding:2rem 0}.hero-logo{height:100px}.hero-stats{gap:2rem}.stat-number{font-size:2rem}}.project-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;overflow:hidden;transition:all .3s ease;display:flex;flex-direction:column}.project-card:hover{transform:translateY(-4px);border-color:var(--accent-primary);box-shadow:0 8px 32px #3b82f633}.project-card{flex-direction:row;min-height:400px}.project-image-container{position:relative;overflow:hidden;background:var(--bg-tertiary);background-image:linear-gradient(rgba(59,130,246,.1) 1px,transparent 1px),linear-gradient(90deg,rgba(59,130,246,.1) 1px,transparent 1px);background-size:30px 30px;display:flex;align-items:center;justify-content:center;padding:2rem}.project-image-container{width:40%;min-width:350px;max-width:500px;flex-shrink:0;align-self:stretch;height:auto}.project-image{max-width:85%;max-height:130%;width:auto;height:auto;object-fit:contain;object-position:center;transition:transform .5s ease;border-radius:8px;box-shadow:0 4px 20px #0000004d}.project-image[src*=placeholder]{max-width:100%;max-height:100%;width:100%;height:100%;object-fit:cover;border-radius:0;box-shadow:none}.project-card:hover .project-image{transform:scale(1.05)}.project-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease;border-radius:8px}.project-card:hover .project-overlay{opacity:1}.project-link{color:#fff;text-decoration:none;font-weight:600;font-size:1.1rem;padding:.75rem 1.5rem;border:2px solid white;border-radius:8px;transition:all .3s ease}.project-link:hover{background:#fff;color:var(--bg-primary)}.project-content{padding:2rem;display:flex;flex-direction:column;flex:1}.project-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;gap:1rem}.project-title{font-size:1.75rem;font-weight:700;margin-bottom:.5rem;color:var(--text-primary)}.project-subtitle{font-size:1rem;color:var(--accent-primary);font-weight:500}.project-year{font-family:JetBrains Mono,monospace;font-size:.9rem;color:var(--text-tertiary);white-space:nowrap}.project-description{color:var(--text-secondary);line-height:1.7;margin-bottom:1.5rem}.project-description-detailed{margin-top:1rem;margin-bottom:2rem}.project-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:1px solid var(--border-color)}.tab-button{padding:.75rem 1.5rem;background:transparent;border:none;color:var(--text-secondary);font-size:.95rem;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .3s ease;font-family:Inter,sans-serif}.tab-button:hover{color:var(--text-primary)}.tab-button.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary)}.project-details{margin-bottom:1.5rem;min-height:200px}.features-list{list-style:none;display:flex;flex-direction:column;gap:.75rem}.feature-item{display:flex;align-items:flex-start;gap:.75rem;color:var(--text-secondary);line-height:1.6}.feature-check{color:var(--accent-primary);font-weight:700;flex-shrink:0;margin-top:2px}.tech-stack{display:flex;flex-direction:column;gap:1.5rem}.tech-category{display:flex;flex-direction:column;gap:.75rem}.tech-category-title{font-size:.9rem;font-weight:600;color:var(--accent-primary);text-transform:uppercase;letter-spacing:.05em;font-family:JetBrains Mono,monospace}.tech-tags{display:flex;flex-wrap:wrap;gap:.5rem}.tech-tag{padding:.4rem .9rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;font-size:.85rem;color:var(--text-primary);font-family:JetBrains Mono,monospace;transition:all .3s ease}.tech-tag:hover{background:var(--bg-card-hover);border-color:var(--accent-primary);transform:translateY(-2px)}.project-footer{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:1.5rem;border-top:1px solid var(--border-color)}.project-button{padding:.75rem 1.5rem;background:var(--accent-primary);color:#fff;text-decoration:none;border-radius:8px;font-weight:600;transition:all .3s ease;display:inline-block}.project-button:hover{background:var(--accent-secondary);transform:translateY(-2px);box-shadow:0 4px 12px #3b82f666}.project-category{font-family:JetBrains Mono,monospace;font-size:.75rem;color:var(--text-tertiary);padding:.4rem .8rem;background:var(--bg-tertiary);border-radius:6px;letter-spacing:.1em}@media (max-width: 1024px){.project-card{flex-direction:column;min-height:auto}.project-image-container{width:100%;min-width:unset;max-width:100%;aspect-ratio:16 / 9}}@media (max-width: 768px){.project-content{padding:1.5rem}.project-header{flex-direction:column}.project-title{font-size:1.5rem}.project-footer{flex-direction:column;gap:1rem;align-items:stretch}.project-button{width:100%;text-align:center}}.projects-section{padding:6rem 0;position:relative}.section-header{text-align:center;margin-bottom:4rem}.section-title{font-size:clamp(2rem,4vw,3rem);font-weight:700;margin-bottom:1rem;display:flex;align-items:center;justify-content:center;gap:1rem}.section-subtitle{font-size:1.1rem;color:var(--text-secondary);margin-bottom:2rem}.projects-grid{display:flex;flex-direction:column;gap:3rem}@media (max-width: 768px){.projects-section{padding:4rem 0}}.about-section{padding:6rem 0;background:var(--bg-secondary);position:relative}.about-content{max-width:900px;margin:0 auto}.about-text{margin-bottom:3rem}.section-title{font-size:clamp(2rem,4vw,3rem);font-weight:700;margin-bottom:2rem;display:flex;align-items:center;gap:1rem}.section-number{font-family:JetBrains Mono,monospace;color:var(--accent-primary);font-size:.8em}.about-paragraphs{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:3rem}.about-paragraphs p{font-size:1.1rem;line-height:1.8;color:var(--text-secondary)}.about-skills{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin-bottom:2rem}.skill-category h3{font-size:1rem;font-weight:600;color:var(--accent-primary);margin-bottom:1rem;font-family:JetBrains Mono,monospace;text-transform:uppercase;letter-spacing:.05em}.skill-tags{display:flex;flex-wrap:wrap;gap:.75rem}.skill-tags span{padding:.5rem 1rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;font-size:.9rem;color:var(--text-primary);transition:all .3s ease}.skill-tags span:hover{border-color:var(--accent-primary);transform:translateY(-2px);box-shadow:0 4px 12px #3b82f633}.about-cta{text-align:center}.contact-button{display:inline-block;padding:1rem 2.5rem;background:var(--accent-primary);color:#fff;text-decoration:none;border-radius:8px;font-weight:600;font-size:1.1rem;transition:all .3s ease;border:2px solid var(--accent-primary)}.contact-button:hover{background:transparent;color:var(--accent-primary);transform:translateY(-2px);box-shadow:0 8px 24px #3b82f64d}@media (max-width: 768px){.about-section{padding:4rem 0}.about-skills{grid-template-columns:1fr}}.footer{background:var(--bg-secondary);border-top:1px solid var(--border-color);padding:4rem 0 2rem;margin-top:4rem}.contact-section{margin-bottom:4rem;text-align:center}.contact-title{font-size:clamp(2rem,4vw,3rem);font-weight:700;margin-bottom:1rem;display:flex;align-items:center;justify-content:center;gap:1rem}.contact-subtitle{font-size:1.1rem;color:var(--text-secondary);margin-bottom:3rem;max-width:600px;margin-left:auto;margin-right:auto}.footer-content{display:grid;grid-template-columns:2fr 1fr 1fr;gap:3rem;margin-bottom:3rem}.footer-brand{display:flex;flex-direction:column;gap:1rem;align-items:flex-start}.footer-logo{height:200px;width:auto;max-width:100%;object-fit:contain;opacity:.9}.footer-tagline{color:var(--text-secondary);font-size:.95rem}.footer-links{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem}.footer-section h4{font-size:.9rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem;text-transform:uppercase;letter-spacing:.05em;font-family:JetBrains Mono,monospace}.footer-section a{display:block;color:var(--text-secondary);text-decoration:none;margin-bottom:.75rem;font-size:.95rem;transition:color .3s ease}.footer-section a:hover{color:var(--accent-primary)}.footer-bottom{padding-top:2rem;border-top:1px solid var(--border-color);text-align:center}.footer-bottom p{color:var(--text-tertiary);font-size:.9rem}@media (max-width: 768px){.footer-content{grid-template-columns:1fr;gap:2rem}.footer-logo{height:150px}.footer-links{grid-template-columns:1fr}}.contact-form{max-width:600px;margin:0 auto}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:var(--text-primary);font-weight:500;font-size:.95rem}.form-group input,.form-group textarea{width:100%;padding:.75rem 1rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:1rem;font-family:Inter,sans-serif;transition:all .3s ease}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #3b82f61a}.form-group input:disabled,.form-group textarea:disabled{opacity:.6;cursor:not-allowed}.form-group textarea{resize:vertical;min-height:120px}.form-message{padding:1rem;border-radius:8px;margin-bottom:1rem;font-size:.95rem}.form-message-success{background:#22c55e1a;border:1px solid rgba(34,197,94,.3);color:#4ade80}.form-message-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#f87171}.form-submit{width:100%;padding:1rem 2rem;background:var(--accent-primary);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;font-family:Inter,sans-serif}.form-submit:hover:not(:disabled){background:var(--accent-secondary);transform:translateY(-2px);box-shadow:0 4px 12px #3b82f666}.form-submit:disabled{opacity:.6;cursor:not-allowed;transform:none}.app{min-height:100vh;display:flex;flex-direction:column}main{flex:1}.container{max-width:1200px;margin:0 auto;padding:0 2rem}@media (max-width: 768px){.container{padding:0 1rem}}:root{--bg-primary: #0a0a0f;--bg-secondary: #111118;--bg-tertiary: #1a1a24;--bg-card: #151520;--bg-card-hover: #1d1d2a;--text-primary: #e8e8f0;--text-secondary: #a0a0b0;--text-tertiary: #707080;--accent-primary: #3b82f6;--accent-secondary: #8b5cf6;--accent-glow: rgba(59, 130, 246, .3);--border-color: #252530;--gradient-1: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--gradient-2: linear-gradient(135deg, #f093fb 0%, #f5576c 100%);--gradient-3: linear-gradient(135deg, #4facfe 0%, #00f2fe 100%)}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;overflow-x:hidden}code{font-family:JetBrains Mono,Fira Code,Courier New,monospace}#root{min-height:100vh}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:var(--border-color)}::selection{background:var(--accent-primary);color:#fff}
