:root{--bg: #ffffff;--bg-subtle: #f0fdfa;--bg-card: #ffffff;--bg-glass: rgba(255, 255, 255, .75);--text-main: #0f172a;--text-muted: #64748b;--text-accent: #0d9488;--text-gradient: linear-gradient(135deg, #0d9488 0%, #0284c7 100%);--border: #ccfbf1;--border-strong: #99f6e4;--border-hover: #14b8a6;--shadow-sm: 0 4px 6px -1px rgba(13, 148, 136, .05), 0 2px 4px -1px rgba(13, 148, 136, .03);--shadow-md: 0 10px 15px -3px rgba(13, 148, 136, .1), 0 4px 6px -2px rgba(13, 148, 136, .05);--shadow-glow: 0 0 25px rgba(20, 184, 166, .15);--hero-drop-shadow: 0 10px 30px rgba(13, 148, 136, .4);--gradient-primary: linear-gradient(135deg, #0d9488 0%, #0891b2 100%);--container-width: 1200px;--header-height: 80px;--radius: 12px}@media(prefers-color-scheme:dark){:root:not([data-theme=light]){--bg: #020617;--bg-subtle: #0f172a;--bg-card: #1e293b;--bg-glass: rgba(15, 23, 42, .6);--text-main: #f1f5f9;--text-muted: #94a3b8;--text-accent: #2dd4bf;--text-gradient: linear-gradient(135deg, #2dd4bf 0%, #38bdf8 100%);--border: rgba(45, 212, 191, .15);--border-strong: rgba(45, 212, 191, .3);--border-hover: #2dd4bf;--shadow-sm: 0 4px 6px -1px rgba(0, 0, 0, .5);--shadow-md: 0 10px 15px -3px rgba(0, 0, 0, .7);--shadow-glow: 0 0 30px rgba(45, 212, 191, .2);--hero-drop-shadow: 0 0 35px rgba(45, 212, 191, .6);--gradient-primary: linear-gradient(135deg, #115e59 0%, #0e7490 100%)}}[data-theme=dark]{--bg: #020617;--bg-subtle: #0f172a;--bg-card: #1e293b;--bg-glass: rgba(15, 23, 42, .6);--text-main: #f1f5f9;--text-muted: #94a3b8;--text-accent: #2dd4bf;--text-gradient: linear-gradient(135deg, #2dd4bf 0%, #38bdf8 100%);--border: rgba(45, 212, 191, .15);--border-strong: rgba(45, 212, 191, .3);--border-hover: #2dd4bf;--shadow-sm: 0 4px 6px -1px rgba(0, 0, 0, .5);--shadow-md: 0 10px 15px -3px rgba(0, 0, 0, .7);--shadow-glow: 0 0 30px rgba(45, 212, 191, .2);--hero-drop-shadow: 0 0 35px rgba(45, 212, 191, .6);--gradient-primary: linear-gradient(135deg, #115e59 0%, #0e7490 100%)}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth;font-size:16px}body{margin:0;background-color:var(--bg);background-image:radial-gradient(circle at 15% 50%,rgba(13,148,136,.08),transparent 25%),radial-gradient(circle at 85% 30%,rgba(14,165,233,.08),transparent 25%);background-attachment:fixed;background-size:cover;color:var(--text-main);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6;-webkit-font-smoothing:antialiased}h1,h2,h3,h4{font-weight:700;line-height:1.2;margin:0;letter-spacing:-.02em;color:var(--text-main)}a{text-decoration:none;color:inherit;transition:all .2s ease}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}::selection{background:var(--text-accent);color:#fff}.spawn-element{opacity:0;transform:translateY(30px) scale(.95);transition:opacity .8s cubic-bezier(.2,.8,.2,1),transform .8s cubic-bezier(.2,.8,.2,1);will-change:opacity,transform}.spawn-element.is-visible{opacity:1;transform:translateY(0) scale(1)}.delay-100{transition-delay:.1s}.delay-200{transition-delay:.2s}.delay-300{transition-delay:.3s}.container{max-width:var(--container-width);margin:0 auto;padding:0 2rem}.section{padding:8rem 0;border-bottom:1px solid var(--border)}.section:last-of-type{border-bottom:none}.hero-grid{display:grid;grid-template-columns:1.2fr .8fr;align-items:center;gap:4rem}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:4rem}@media(max-width:900px){.container{padding:0 1.5rem}.section{padding:5rem 0}.section:first-of-type{padding-bottom:0;padding-top:6rem}.hero-grid{grid-template-columns:1fr;gap:3rem;align-items:center}.hero-content{order:1;text-align:center;padding-bottom:4rem}.hero-image-wrapper{order:-1;width:100%;justify-content:center;align-items:flex-end;margin-bottom:0}.hero-img{max-width:350px}}.display-text{font-size:4rem;font-weight:800;background:var(--text-gradient);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:1.5rem;line-height:1.1}.section-label{font-size:.875rem;text-transform:uppercase;letter-spacing:.1em;font-weight:600;color:var(--text-accent);margin-bottom:1rem;display:block}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.8rem;font-weight:600;font-size:.95rem;border-radius:50px;transition:all .3s cubic-bezier(.4,0,.2,1);white-space:nowrap}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:0 4px 15px var(--border-strong);border:none}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 1px 15px var(--border-hover)}.btn-outline{background:transparent;border:1px solid var(--border);color:var(--text-main)}.btn-outline:hover{border-color:var(--text-accent);color:var(--text-accent);background:var(--bg-subtle)}.btn svg{width:20px;height:20px;margin-left:8px;transition:transform .3s cubic-bezier(.4,0,.2,1);display:block}.btn:hover svg{transform:translate(4px)}.navbar{position:sticky;top:0;background:var(--bg-glass);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);z-index:1000;border-bottom:1px solid var(--border);height:70px;display:flex;align-items:center}.nav-flex{display:flex;justify-content:space-between;align-items:center;width:100%}.brand{font-weight:800;font-size:1.75rem;background:var(--text-gradient);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;text-decoration:none;z-index:1005;position:relative}.desktop-menu{display:flex;align-items:center;gap:2.5rem}.desktop-menu a{font-size:.95rem;font-weight:500;color:var(--text-muted);transition:color .2s}.desktop-menu a:hover{color:var(--text-accent)}.theme-toggle{background:transparent;border:1px solid var(--border);color:var(--text-muted);width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.mobile-controls,.drawer-backdrop,.drawer-panel{display:none}@media(max-width:768px){.desktop-menu{display:none}.mobile-controls{display:flex;z-index:1002;position:relative}.hamburger-btn{width:40px;height:40px;background:transparent;border:none;cursor:pointer;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:6px;padding:0}.bar{width:24px;height:2px;background-color:var(--text-main);border-radius:2px;transition:all .3s cubic-bezier(.4,0,.2,1)}.hamburger-btn.open .top{transform:translateY(8px) rotate(45deg)}.hamburger-btn.open .middle{opacity:0;transform:translate(-10px)}.hamburger-btn.open .bottom{transform:translateY(-8px) rotate(-45deg)}.drawer-backdrop{display:block;position:fixed;inset:0;background:#0009;z-index:2000;opacity:0;pointer-events:none;transition:opacity .3s ease;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.drawer-backdrop.active{opacity:1;pointer-events:auto}.drawer-panel{display:flex;flex-direction:column;position:fixed;top:0;right:0;bottom:0;width:75%;max-width:300px;background-color:var(--bg);box-shadow:-10px 0 40px #0003;border-left:1px solid var(--border);z-index:2005;padding:2rem;transform:translate(100%);transition:transform .35s cubic-bezier(.2,.8,.2,1)}.drawer-panel.active{transform:translate(0)}.drawer-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:3rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.drawer-title{font-size:.9rem;text-transform:uppercase;font-weight:700;color:var(--text-muted);letter-spacing:.1em}.theme-toggle-drawer{background:var(--bg-subtle);border:1px solid var(--border);color:var(--text-main);width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center}.drawer-links{display:flex;flex-direction:column;gap:1.5rem}.drawer-links a{font-size:1.2rem;font-weight:600;color:var(--text-main);text-decoration:none}.drawer-links a:hover{color:var(--text-accent)}.drawer-footer{margin-top:auto;border-top:1px solid var(--border);padding-top:1.5rem;font-size:.8rem;color:var(--text-muted);text-align:center}.timeline-line,.timeline-dot{left:14px}.timeline-item{justify-content:flex-start;margin-bottom:2.5rem}.timeline-content{width:100%;padding-left:42px!important}.cert-glass-card{padding:1rem;flex-direction:row}.cert-visual img{width:42px;height:42px}.cert-grid,.hero-grid{grid-template-columns:1fr}.footer-bottom{flex-direction:column;align-items:center;gap:2.5rem}}.hero-image-wrapper{position:relative;width:100%;display:flex;justify-content:center;align-items:flex-end;z-index:1}.hero-img{width:100%;max-width:500px;height:auto;display:block;margin-bottom:-1px;filter:drop-shadow(var(--hero-drop-shadow));transition:transform .5s cubic-bezier(.34,1.56,.64,1),filter .5s ease;transform-origin:bottom center}@media(min-width:1024px){.hero-img{width:135%;max-width:850px;margin-left:-15%}}.hero-image-wrapper:hover .hero-img{transform:scale(1.05);filter:drop-shadow(0 0 50px var(--text-accent))}.project-item{display:block;padding:2.5rem 2rem;border:1px solid transparent;border-radius:var(--radius);transition:all .3s ease;background:transparent}.project-item:hover{background:var(--bg-subtle);border-color:var(--border);transform:translateY(-2px)}.project-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:1rem}.project-title{font-size:1.75rem;font-weight:700;color:var(--text-main);line-height:1.2}.project-tech{font-family:JetBrains Mono,monospace;color:var(--text-accent);font-size:.85rem;background:#0d94881a;padding:4px 8px;border-radius:4px}.project-desc{max-width:600px;color:var(--text-muted);font-size:1.1rem;line-height:1.6}.skills-header{margin-bottom:4rem}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}@media(min-width:1024px){.skills-grid{grid-template-columns:repeat(3,1fr)}}.skill-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;transition:all .3s ease;display:flex;flex-direction:column;gap:1.25rem;height:100%;box-shadow:var(--shadow-sm)}.skill-card:hover{transform:translateY(-5px);border-color:var(--text-accent);box-shadow:var(--shadow-glow)}.skill-icon-wrapper{width:50px;height:50px;background:var(--bg-subtle);border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--text-accent)}.skill-title{font-size:1.25rem;font-weight:700;margin-bottom:.5rem}.skill-desc{color:var(--text-muted);font-size:.95rem;line-height:1.6}.skill-tags{display:flex;flex-wrap:wrap;gap:.6rem}.skill-tag{font-size:.85rem;font-weight:500;padding:.4rem 1rem;background:var(--border);color:var(--text-muted);border:1px solid var(--border);border-radius:20px;transition:all .2s}.skill-tag:hover{background:var(--text-accent);color:#fff;border-color:var(--text-accent)}.footer{margin-top:0rem;padding:2rem 0 3rem;border-top:1px solid var(--border);background:linear-gradient(to bottom,var(--bg) 0%,var(--bg-subtle) 100%);overflow:hidden}.footer-title{font-size:1.5rem;font-weight:800;color:var(--text-main)}.email-link{display:inline-flex;align-items:center;gap:1rem;color:var(--text-muted);text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);border-bottom:1px solid transparent}.email-link svg{width:40px;height:40px;transition:transform .3s ease}.email-link:hover{color:var(--text-accent);padding-left:10px}.email-link:hover svg{transform:translate(10px) rotate(-45deg)}.footer-bottom{display:flex;justify-content:space-between;align-items:flex-end;border-top:1px solid var(--border);padding-top:3rem;flex-wrap:wrap;gap:2rem}.footer-brand-col{display:flex;flex-direction:column;gap:.5rem}.copyright{color:var(--text-muted);font-size:.9rem}.footer-nav-links{display:flex;gap:2rem;flex-wrap:wrap;justify-content:center}.footer-nav-links a{color:var(--text-muted);font-weight:500;font-size:.95rem;transition:color .2s ease}.footer-nav-links a:hover{color:var(--text-accent)}.footer-socials{display:flex;gap:1rem}.email-link-btn{background:none;border:none;padding:0;font-family:inherit;font-size:inherit;font-weight:inherit;line-height:1;color:var(--text-muted);cursor:pointer;display:inline-flex;align-items:center;gap:.75rem;transition:all .3s cubic-bezier(.4,0,.2,1);border-bottom:2px solid transparent}.icon-wrapper{display:flex;align-items:center;justify-content:center;height:1em}.icon-wrapper svg{width:1.2em;height:1.2em;transition:transform .4s cubic-bezier(.34,1.56,.64,1)}.email-link-btn:not(.copied):hover{color:var(--text-accent);padding-left:10px}.email-link-btn:not(.copied):hover .icon-wrapper svg{transform:translate(5px) rotate(-45deg)}.email-link-btn.copied{color:#10b981;padding-left:10px;cursor:default}.email-link-btn.copied .icon-wrapper svg{transform:scale(1.1)}@media(max-width:768px){.footer{padding:4rem 0 2rem}.footer-title{font-size:2.5rem}.footer-bottom{flex-direction:column;align-items:center;text-align:center;gap:2.5rem}.footer-nav-links{justify-content:center;width:100%}.footer-socials{width:100%;justify-content:center}.footer-brand-col{align-items:center}}.social-link{display:flex;align-items:center;justify-content:center;color:var(--text-muted);padding:12px;border-radius:50%;background:transparent;border:1px solid transparent;transition:all .3s cubic-bezier(.4,0,.2,1)}.social-link svg{width:24px;height:24px;stroke-width:2px}.social-link:hover{color:var(--text-accent);background:var(--bg-subtle);border-color:var(--border);transform:translateY(-4px);box-shadow:var(--shadow-sm)}.page-header{text-align:center;max-width:800px;margin:0 auto 3rem}.page-desc{font-size:1.25rem;color:var(--text-muted);line-height:1.6}.filter-bar{display:flex;justify-content:center;gap:1rem;margin-bottom:4rem;flex-wrap:wrap}.filter-btn{background:transparent;border:1px solid var(--border);color:var(--text-muted);padding:.6rem 1.5rem;border-radius:50px;font-weight:500;cursor:pointer;transition:all .3s ease;font-size:.95rem}.filter-btn:hover{border-color:var(--text-accent);color:var(--text-accent)}.filter-btn.active{background:var(--text-accent);color:#fff;border-color:var(--text-accent);box-shadow:0 4px 15px var(--border-strong)}.projects-grid{margin-top:0}.mosaic-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;margin-top:1rem}.mosaic-card{position:relative;border-radius:var(--radius);overflow:hidden;background:var(--bg-subtle);isolation:isolate;transition:transform .3s cubic-bezier(.4,0,.2,1);border:1px solid var(--border);height:280px}.mosaic-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--text-accent)}.mosaic-bg{position:absolute;inset:0;z-index:0}.mosaic-bg img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease;filter:grayscale(20%)}.mosaic-card:hover .mosaic-bg img{transform:scale(1.08);filter:grayscale(0%)}.mosaic-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,#0000001a,#0009 60%,#000000f2);transition:opacity .3s ease}.mosaic-content{position:relative;z-index:1;height:100%;display:flex;flex-direction:column;justify-content:space-between;padding:1.5rem;color:#fff}.mosaic-top{display:flex;justify-content:space-between;align-items:flex-start;transform:translateY(-10px);opacity:0;transition:all .3s ease}.mosaic-card:hover .mosaic-top{transform:translateY(0);opacity:1}.mosaic-cat{background:var(--text-accent);color:#fff;font-size:.7rem;font-weight:700;text-transform:uppercase;padding:4px 8px;border-radius:4px;letter-spacing:.05em}.mosaic-links a{color:#fff;background:#fff3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:8px;border-radius:50%;margin-left:.5rem;display:inline-flex;transition:background .2s}.mosaic-links a:hover{background:var(--text-accent)}.mosaic-info{transform:translateY(20px);transition:transform .3s ease}.mosaic-card:hover .mosaic-info{transform:translateY(0)}.mosaic-title{font-size:1.4rem;font-weight:700;margin:0 0 .5rem;text-shadow:0 2px 4px rgba(0,0,0,.5);color:#fff}.mosaic-desc{font-size:.95rem;color:#ffffffe6;line-height:1.5;margin-bottom:1rem;max-height:0;opacity:0;overflow:hidden;transition:all .4s ease}.mosaic-card:hover .mosaic-desc{max-height:100px;opacity:1;margin-bottom:1rem}.mosaic-tech{display:flex;flex-wrap:wrap;gap:.5rem}.mosaic-tech span{font-family:JetBrains Mono,monospace;font-size:.75rem;color:#fffc;border:1px solid rgba(255,255,255,.3);padding:2px 8px;border-radius:4px}@media(max-width:768px){.display-text{font-size:2.5rem}.project-title{font-size:1.4rem}.navbar{height:auto;padding:1rem 0}.nav-flex{flex-direction:column;gap:1rem}.nav-links{width:100%;justify-content:center;gap:1.5rem}.mosaic-grid{grid-template-columns:1fr}.mosaic-desc{max-height:100px;opacity:1}.mosaic-top{opacity:1;transform:translateY(0)}}.timeline-wrapper{position:relative;padding:1rem 0;width:100%}.timeline-line{position:absolute;left:50%;top:0;bottom:0;width:2px;background:var(--border);transform:translate(-50%);z-index:0}.timeline-line:after{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,var(--bg) 0%,transparent 10%,transparent 90%,var(--bg) 100%)}.timeline-item{display:flex;justify-content:center;align-items:center;margin-bottom:2rem;position:relative;width:100%}.timeline-dot{position:absolute;left:50%;width:16px;height:16px;background:var(--bg);border:2px solid var(--border);border-radius:50%;transform:translate(-50%);z-index:2;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.dot-inner{width:6px;height:6px;background:var(--text-muted);border-radius:50%;transition:all .3s ease}.timeline-item:hover .timeline-dot{border-color:var(--text-accent);box-shadow:0 0 10px var(--text-accent)}.timeline-item:hover .dot-inner{background:var(--text-accent);transform:scale(1.2)}.timeline-content{width:45%;position:relative;z-index:1}.timeline-date{position:absolute;top:50%;transform:translateY(-50%);width:45%;font-family:JetBrains Mono,monospace;font-size:1.1rem;font-weight:700;color:var(--border-hover);opacity:1;transition:all .3s ease}.timeline-item.left .timeline-content{margin-right:auto;padding-right:2rem}.timeline-item.left .timeline-date{right:0;text-align:left;padding-left:2rem}.timeline-item.right .timeline-content{margin-left:auto;padding-left:2rem}.timeline-item.right .timeline-date{left:0;text-align:right;padding-right:2rem}.timeline-item:hover{opacity:1;color:var(--text-accent)}.cert-glass-card{display:flex;gap:1rem;background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:1rem;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;align-items:center}.cert-glass-card:hover{transform:translateY(-2px);border-color:var(--text-accent);box-shadow:var(--shadow-sm);background:var(--bg-subtle)}.cert-visual img{width:48px;height:48px;border-radius:8px;object-fit:cover;border:1px solid var(--border)}.cert-details{flex-grow:1;display:flex;flex-direction:column;justify-content:center}.cert-top{display:flex;justify-content:space-between;margin-bottom:.1rem;align-items:center}.cert-issuer{font-size:.7rem;text-transform:uppercase;font-weight:700;letter-spacing:.05em;color:var(--text-accent)}.cert-name{font-size:1rem;font-weight:700;margin-bottom:.4rem;color:var(--text-main);line-height:1.2}.cert-tags{display:flex;flex-wrap:wrap;gap:.4rem}.cert-tags span{font-size:.65rem;background:var(--bg);border:1px solid var(--border);padding:1px 6px;border-radius:4px;color:var(--text-muted)}.cert-icon{color:var(--text-muted);transition:.2s;padding:4px}.cert-glass-card:hover .cert-icon{color:var(--text-accent)}@media(max-width:768px){.timeline-line,.timeline-dot{left:16px}.timeline-item{justify-content:flex-start;margin-bottom:2rem}.timeline-content{width:100%;margin:0!important;padding-left:40px!important;padding-right:0!important}.timeline-date{position:static;transform:none;width:100%;text-align:left!important;padding:0 0 .25rem 40px!important;font-size:.85rem;opacity:1;margin-bottom:.25rem}.cert-glass-card{padding:.85rem;gap:.85rem}}.milestone-card{background:var(--bg);border-left:3px solid var(--border-hover);border-radius:0 12px 12px 0;padding:1.25rem;position:relative;transition:all .3s ease;box-shadow:var(--shadow-sm);border:1px solid var(--border);border-left-width:4px;border-left-color:var(--text-muted)}.timeline-item.right .milestone-card{border-radius:12px 0 0 12px;border-left:1px solid var(--border);border-right:4px solid var(--text-muted)}.milestone-card:hover{transform:translateY(-2px);border-left-color:var(--text-accent);border-right-color:var(--text-accent);box-shadow:var(--shadow-md)}.milestone-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.milestone-month{font-family:JetBrains Mono,monospace;font-size:.85rem;font-weight:700;text-transform:uppercase;color:var(--text-accent);background:var(--bg-subtle);padding:2px 6px;border-radius:4px}.milestone-line{flex-grow:1;height:1px;background:var(--border)}.milestone-title{font-size:1.1rem;font-weight:700;color:var(--text-main);margin:0 0 .25rem;line-height:1.3}.milestone-desc{font-size:.9rem;color:var(--text-muted);line-height:1.5;margin:0}html,body{overflow-x:hidden;width:100%}@media(max-width:768px){.display-text{font-size:clamp(1.8rem,8vw,2.5rem);line-height:1.2;word-break:keep-all;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.section-label{white-space:normal;display:block;font-size:.75rem;line-height:1.5;max-width:100%}.container{width:100%;padding:0 1.25rem;overflow:hidden}.hero-content{width:100%;max-width:100%;margin:0 auto;text-align:center}}.footer-cta{width:100%;overflow-wrap:break-word}.footer-title{font-size:clamp(1.5rem,6vw,2.5rem)}
