*{box-sizing:border-box;margin:0;padding:0}:root{--primary:#0ea5e9;--primary-dark:#0284c7;--bg-light:#fff;--bg-dark:#0a0a0a;--text-light:#1e293b;--text-dark:#f8fafc;--gray-light:#f1f5f9;--gray-dark:#1e293b;--accent:#06b6d4;--accent-light:#22d3ee}body{background:var(--bg-light);color:var(--text-light);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.6;transition:background .3s,color .3s}body.dark{background:var(--bg-dark);color:var(--text-dark)}p{text-wrap:pretty}.bg-gradient{z-index:-1;background:radial-gradient(80% 80% at 50% -20%,#0ea5e926,#fff0);width:100%;height:100%;position:fixed;top:0;left:0}body.dark .bg-gradient{background:radial-gradient(125% 125% at 50% 10%,#000 40%,#06b5d450 100%)}header{z-index:1000;width:auto;max-width:calc(100vw - 2rem);animation:.6s ease-out slideDown;position:fixed;top:1.5rem;left:50%;transform:translate(-50%)}@keyframes slideDown{0%{opacity:0;transform:translate(-50%)translateY(-20px)}to{opacity:1;transform:translate(-50%)translateY(0)}}nav{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);white-space:nowrap;background:#fffc;border:1px solid #0ea5e91a;border-radius:50px;flex-wrap:nowrap;align-items:center;gap:.5rem;padding:.5rem 1rem;transition:all .3s;display:flex;box-shadow:0 4px 6px -1px #0000001a}body.dark nav{background:#1e293bcc;border:1px solid #06b6d433}nav a{color:var(--text-light);white-space:nowrap;border-radius:30px;padding:.5rem 1rem;font-size:.9rem;font-weight:500;text-decoration:none;transition:all .3s;position:relative}body.dark nav a{color:var(--text-dark)}nav a:hover{color:var(--primary);background:#0ea5e91a}nav a.active{color:var(--primary);background:#0ea5e926}body.dark nav a:hover,body.dark nav a.active{color:var(--accent-light);background:#06b6d426}.theme-toggle{cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;margin-left:.5rem;padding:.5rem;transition:all .3s;display:flex}.theme-toggle:hover{background:#0ea5e91a;transform:rotate(180deg)}.theme-toggle svg{width:20px;height:20px;stroke:var(--text-light)}body.dark .theme-toggle svg{stroke:var(--text-dark)}.container{max-width:1100px;margin:0 auto;padding:0 2rem}.hero{justify-content:center;align-items:center;min-height:100vh;padding:8rem 0 4rem;display:flex}.hero-content{max-width:700px}.badge{border:1px solid var(--accent);color:var(--primary-dark);background:linear-gradient(135deg,#22d3ee33,#0ea5e933);border-radius:50px;align-items:center;gap:.5rem;margin-bottom:2rem;padding:.5rem 1rem;font-size:.85rem;font-weight:500;animation:2s ease-in-out infinite pulse;display:inline-flex}body.dark .badge{color:var(--accent-light)}@keyframes pulse{0%,to{box-shadow:0 0 #0ea5e966}50%{box-shadow:0 0 0 10px #0ea5e900}}.pulse-dot{background:var(--accent);border-radius:50%;width:8px;height:8px;animation:2s ease-in-out infinite pulse-dot}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.5}}h1{background:linear-gradient(135deg, var(--text-light), var(--primary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:1.5rem;font-size:3.5rem;font-weight:800;line-height:1.2}body.dark h1{background:linear-gradient(135deg, var(--text-dark), var(--accent-light));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.subtitle{color:#64748b;margin-bottom:2rem;font-size:1.25rem;line-height:1.8}body.dark .subtitle{color:#94a3b8}.subtitle strong{color:var(--primary);font-weight:600}body.dark .subtitle strong{color:var(--accent-light)}.btn-group{flex-wrap:wrap;gap:1rem;display:flex}.btn{border:2px solid #0000;border-radius:50px;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;text-decoration:none;transition:all .3s;display:inline-flex}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover{box-shadow:0 10px 20px -10px var(--primary);background:#0096e1;transform:translateY(-2px)}.btn-secondary{color:var(--text-light);background:0 0;border-color:#e2e8f0}body.dark .btn-secondary{color:var(--text-dark);border-color:#334155}.btn-secondary:hover{border-color:var(--primary);background:#0ea5e91a;transform:translateY(-2px)}section{padding:4rem 0;scroll-margin-top:100px}.section-title{align-items:center;gap:1rem;margin-bottom:3rem;font-size:2rem;font-weight:700;display:flex}.section-title svg{width:32px;height:32px;stroke:var(--primary)}body.dark .section-title svg{stroke:var(--accent-light)}.timeline{padding-left:3rem;position:relative}.timeline:before{content:"";background:linear-gradient(180deg, var(--primary), transparent);width:2px;position:absolute;top:0;bottom:0;left:0}.timeline-item{border-bottom:1px solid #e2e8f0;margin-bottom:3rem;padding-bottom:3rem;position:relative}body.dark .timeline-item{border-bottom-color:#334155}.timeline-item:last-child{border-bottom:none}.timeline-item:before{content:"";background:var(--primary);border:3px solid var(--bg-light);border-radius:50%;width:16px;height:16px;position:absolute;top:.5rem;left:-3.5rem;box-shadow:0 0 0 4px #0ea5e933}body.dark .timeline-item:before{background:var(--accent-light);border-color:var(--bg-dark)}.timeline-header{margin-bottom:1rem}.timeline-title{color:var(--primary);margin-bottom:.25rem;font-size:1.25rem;font-weight:600}body.dark .timeline-title{color:var(--accent-light)}.timeline-company{color:var(--text-light);margin-bottom:.25rem;font-size:1.1rem;font-weight:500}body.dark .timeline-company{color:var(--text-dark)}.timeline-date{color:#64748b;font-size:.9rem}.timeline-description{color:#64748b;line-height:1.8}body.dark .timeline-description{color:#94a3b8}.timeline-link{color:inherit;text-underline-offset:4px;cursor:pointer;text-decoration:underline;text-decoration-thickness:2px;transition:opacity .3s,filter .3s}.timeline-link:hover{opacity:.6}.projects-grid{flex-direction:column;gap:4rem;display:flex}.project-card{background:0 0;border:none;border-radius:16px;flex-direction:row;gap:2rem;transition:all .5s;display:flex;overflow:visible}body.dark .project-card{background:0 0;border:none}.project-card:hover .project-image-container{transform:translateY(-8px);box-shadow:0 20px 30px -10px #0000004d}body.dark .project-card:hover .project-image-container{box-shadow:0 20px 30px -10px #0009}.project-image-container{border:1px solid #00000014;border-radius:16px;flex-shrink:0;width:50%;transition:all .5s;overflow:hidden;box-shadow:0 10px 20px -5px #00000026}body.dark .project-image-container{border:1px solid #ffffff1a;box-shadow:0 10px 20px -5px #0006}.project-image{object-fit:cover;width:100%;height:100%;min-height:300px;transition:all .5s;display:block}.project-content{flex-direction:column;flex:1;justify-content:center;padding:0;display:flex}.project-title{color:var(--text-light);margin-bottom:.75rem;font-size:1.75rem;font-weight:700}body.dark .project-title{color:var(--text-dark)}.project-tags{flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;display:flex}.tag{color:var(--primary);background:#0ea5e91a;border-radius:20px;padding:.25rem .75rem;font-size:.75rem;font-weight:500}body.dark .tag{color:var(--accent-light);background:#06b6d426}.project-description{color:#64748b;margin-bottom:1.5rem;font-size:1rem;line-height:1.7}body.dark .project-description{color:#94a3b8}.project-links{gap:.75rem;display:flex}.project-link{background:var(--gray-light);color:var(--text-light);border-radius:8px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.9rem;font-weight:500;text-decoration:none;transition:all .3s;display:inline-flex}body.dark .project-link{color:var(--text-dark);background:#334155}.project-link:hover{background:var(--primary);color:#fff;transform:translateY(-2px)}.about-content{grid-template-columns:1fr 1fr;align-items:center;gap:3rem;display:grid}.about-text p{color:#64748b;margin-bottom:1rem;line-height:1.8}body.dark .about-text p{color:#94a3b8}.about-text strong{color:var(--text-light);font-weight:600}body.dark .about-text strong{color:var(--text-dark)}.about-image{aspect-ratio:1;border-radius:20px;max-width:350px;position:relative;overflow:hidden;box-shadow:0 20px 25px -5px #0003}.about-image img{object-fit:cover;object-position:bottom;width:100%;height:100%}.social-links{justify-content:center;gap:1rem;display:flex}.social-links-start{justify-content:flex-start;margin-top:2rem}.social-link{background:var(--gray-light);width:40px;height:40px;color:var(--text-light);border-radius:50%;justify-content:center;align-items:center;text-decoration:none;transition:all .3s;display:inline-flex}body.dark .social-link{color:var(--text-dark);background:#1e293b}.social-link:hover{background:var(--primary);color:#fff;transform:translateY(-3px)}footer{margin-top:.5rem;padding-bottom:1.25rem}footer p{text-align:center;color:#64748b;margin:0;padding:0;font-size:.9rem}footer p:first-child{margin-bottom:.45rem}footer p:last-child{opacity:.6}footer a{color:var(--primary-dark);text-underline-offset:3px;text-decoration:underline;transition:color .2s}footer a:hover{color:var(--primary)}body.dark footer a{color:var(--accent-light)}@media (width<=768px){header{max-width:calc(100vw - 1.5rem);top:1rem}nav{gap:.25rem;padding:.4rem .75rem}nav a{padding:.4rem .75rem;font-size:.85rem}.theme-toggle{margin-left:.25rem;padding:.4rem}.theme-toggle svg{width:18px;height:18px}h1{font-size:2.5rem}.subtitle{font-size:1.1rem}.about-content{grid-template-columns:1fr}.about-image{max-width:250px;margin:0 auto}.projects-grid{gap:3rem}.project-card{flex-direction:column;gap:1.5rem}.project-image-container{width:100%}.project-image{min-height:250px}.project-title{font-size:1.5rem}.project-description{font-size:.95rem}}@media (width<=480px){header{max-width:calc(100vw - 1rem);top:.75rem}nav{gap:.15rem;padding:.35rem .5rem}nav a{padding:.35rem .6rem;font-size:.8rem}.theme-toggle{margin-left:.15rem;padding:.35rem}.theme-toggle svg{width:16px;height:16px}}html{scroll-behavior:smooth}.icon{width:20px;height:20px}
