.footer{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0206178c;border-top:1px solid #ffffff0d;margin-top:auto}.footer-inner{justify-content:space-between;align-items:center;gap:1rem;width:100%;max-width:1100px;margin:0 auto;padding:1.1rem 1.25rem;display:flex}.footer-copy{color:#e2e8f0bf;font-size:.9rem}.footer-links{align-items:center;gap:.75rem;display:flex}.social{color:#e2e8f0e6;background:#0f172a8c;border:1px solid #38bdf82e;border-radius:12px;place-items:center;width:38px;height:38px;transition:transform .18s,background .18s,border-color .18s,filter .18s;display:grid}.social:hover{filter:brightness(1.06);background:#38bdf81a;border-color:#38bdf859;transform:translateY(-1px)}.social:active{transform:translateY(0)scale(.98)}@media (max-width:520px){.footer-inner{flex-direction:column;align-items:flex-start}}.layout{width:100%;min-height:100dvh;display:flex;overflow:hidden}.sidebar{background:linear-gradient(#020617,#020617);border-right:1px solid #ffffff08;flex-direction:column;width:240px;min-width:240px;min-height:100dvh;padding:2rem 1.5rem;display:flex;position:sticky;top:0;overflow:hidden}.logo{color:var(--primary);margin-bottom:2rem;font-size:1.3rem;font-weight:700}.sidebar nav{flex-direction:column;gap:.5rem;display:flex}.sidebar a{color:var(--text);border-radius:10px;padding:.85rem 1rem;font-size:.95rem;text-decoration:none;transition:all .25s;display:block;position:relative}.sidebar a:hover{background:#38bdf814}.sidebar a.active{color:var(--primary);background:linear-gradient(90deg,#38bdf82e,#38bdf80d);box-shadow:inset 0 0 0 1px #38bdf840,0 0 20px #38bdf826}.sidebar a.active:after{content:"";background:linear-gradient(90deg,#38bdf8e6,#38bdf800);width:32px;height:2px;position:absolute;top:50%;right:-32px;transform:translateY(-50%)}.content{background:radial-gradient(circle at 0,#38bdf80f,#0000 45%);flex-direction:column;flex:1;min-height:100dvh;padding:1.25rem 3rem .5rem 2.5rem;display:flex;overflow-y:auto}.content::-webkit-scrollbar{width:8px}.content::-webkit-scrollbar-thumb{background:#38bdf840;border-radius:8px}.content h1{margin-bottom:1rem;font-size:2.2rem}.content p{color:var(--muted);max-width:650px;line-height:1.6}.menu-btn{z-index:1001;color:#fff;cursor:pointer;background:#020617e6;border:none;border-radius:10px;padding:.6rem .8rem;font-size:1.4rem;display:none;position:fixed;top:1rem;left:1rem}@media (max-width:768px){.layout{height:auto;overflow:visible}.menu-btn{display:block}.sidebar{z-index:1000;width:100%;height:100%;transition:transform .3s;position:fixed;inset:0;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.content{height:auto;padding:4.25rem 1.25rem .5rem;overflow:visible}.topbar{margin:0 -1.25rem 1rem}.collapse-btn,.sidebar a.active:after{display:none}}@media (max-width:1023px) and (min-width:769px){.sidebar{width:190px;min-width:190px;padding:1.5rem 1rem}.content{padding:2.5rem 2rem}.sidebar a{padding:.75rem .9rem;font-size:.9rem}}@supports (padding:max(0px)){.menu-btn{padding-top:max(.6rem,env(safe-area-inset-top))}}.sidebar-backdrop{opacity:0;pointer-events:none;z-index:900;background:#00000073;transition:opacity .25s;position:fixed;inset:0}.sidebar-backdrop.show{opacity:1;pointer-events:auto}.sidebar-top{justify-content:space-between;align-items:center;gap:.75rem;display:flex}.sidebar nav a{align-items:center;gap:.75rem;display:flex}.nav-ico{filter:saturate(.9);place-items:center;width:26px;display:inline-grid}.sidebar.collapsed{width:84px;min-width:84px;padding:1.5rem .9rem}.sidebar.collapsed .logo{text-align:center;font-size:1rem}.sidebar.collapsed .nav-label{display:none}.sidebar.collapsed nav a{justify-content:center;padding:.85rem .6rem}.sidebar.collapsed a.active:after{display:none}.topbar{z-index:10;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0206178c;border-bottom:1px solid #ffffff0d;justify-content:space-between;align-items:center;gap:1rem;margin:0 -3rem 1.25rem -2.5rem;padding:.9rem 1.25rem;display:flex;position:sticky;top:0}.topbar-left{align-items:center;gap:.85rem;display:flex}.topbar-title{color:#e2e8f0d9;letter-spacing:.2px;font-size:.95rem}.collapse-btn{color:#e2e8f0f2;cursor:pointer;background:#0f172a8c;border:1px solid #38bdf82e;border-radius:12px;place-items:center;width:40px;height:40px;transition:transform .18s,background .18s,border-color .18s,filter .18s;display:grid}.collapse-btn:hover{filter:brightness(1.06);background:#38bdf81a;border-color:#38bdf859;transform:translateY(-1px)}.collapse-btn:active{transform:translateY(0)scale(.98)}.collapse-ico{transition:transform .22s;display:inline-block}.collapse-ico.is-collapsed{transform:rotate(180deg)}.clock{color:#e2e8f0f2;font-variant-numeric:tabular-nums;background:#38bdf81a;border:1px solid #38bdf838;border-radius:999px;align-items:center;gap:.5rem;padding:.55rem .75rem;display:flex}.clock-text{letter-spacing:.2px;font-size:.9rem;font-weight:600}.page{flex:1;width:100%;max-width:1140px;margin:0 auto;padding-bottom:1.25rem}.img-modal-backdrop{z-index:4000;background:#000000c7;justify-content:center;align-items:center;padding:18px;display:flex;position:fixed;inset:0}.img-modal{place-items:center;width:min(1080px,96vw);height:min(720px,86vh);display:grid;position:relative}.img-modal-title{color:#e2e8f0f2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);text-overflow:ellipsis;white-space:nowrap;background:#020617a6;border:1px solid #38bdf82e;border-radius:12px;max-width:calc(100% - 110px);padding:.55rem .75rem;font-size:.95rem;font-weight:600;position:absolute;top:10px;left:10px;overflow:hidden}.img-modal-media{object-fit:contain;background:#020617a6;border:1px solid #38bdf82e;border-radius:16px;width:100%;height:100%}.img-modal-media:focus-visible{outline-offset:3px;outline:2px solid #38bdf8e6}.img-modal-close{color:#e2e8f0f2;cursor:pointer;background:#020617d9;border:1px solid #38bdf838;border-radius:999px;width:42px;height:42px;position:absolute;top:10px;right:10px}.img-modal-arrow{color:#e2e8f0f2;cursor:pointer;background:#020617d9;border:1px solid #38bdf82e;border-radius:999px;place-items:center;width:44px;height:44px;font-size:1.9rem;display:grid;position:absolute;top:50%;transform:translateY(-50%)}.img-modal-arrow.left{left:10px}.img-modal-arrow.right{right:10px}.img-modal-arrow:focus-visible,.img-modal-close:focus-visible{outline-offset:3px;outline:2px solid #38bdf8e6}@media (max-width:480px){.img-modal-backdrop{padding:10px}.img-modal{width:96vw;height:82vh}.img-modal-title{max-width:calc(100% - 100px);font-size:.9rem}}.home-hero{margin-bottom:4rem}.home-hero h1{text-align:center;margin-bottom:3rem;font-size:clamp(1.9rem,3.4vw,2.55rem);line-height:1.25}.home-hero h1 span{color:#38bdf8}.home-hero p{max-width:620px;color:var(--muted);text-align:center;margin:0 auto;line-height:1.6}.home-section{margin-bottom:3.5rem}.home-section h2{margin-bottom:1.5rem}.certificates{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;display:grid}.certificate-card{cursor:pointer;text-align:left;width:100%;font:inherit;background:linear-gradient(#0f172af2,#020617fa);border:1px solid #38bdf82e;border-radius:16px;outline:none;padding:1rem;transition:all .3s;display:block;position:relative;overflow:hidden}.certificate-card:hover{transform:translateY(-4px);box-shadow:0 10px 30px #38bdf82e}.certificate-card img{object-fit:contain;width:100%;height:clamp(160px,22vw,220px)}.certificate-hint{color:#94a3b8f2;margin-top:.75rem;font-size:.85rem;display:inline-block}.certificate-card:focus-visible{outline-offset:3px;outline:2px solid #38bdf8e6}.skills{flex-wrap:wrap;gap:.6rem;display:flex}.skill{color:#38bdf8;background:#38bdf81f;border:1px solid #38bdf840;border-radius:999px;padding:.5rem .9rem;font-size:.95rem}.skill:hover{transform:translateY(-2px);box-shadow:0 10px 30px #38bdf82e}.home-cta{text-align:center;background:linear-gradient(#0f172af2,#12205ffa);border:1px solid #38bdf833;border-radius:20px;padding:2.5rem}.home-cta h2{margin-bottom:.6rem}.home-cta p{color:var(--muted);margin-bottom:1.5rem;padding:0}.cta-btn{color:#020617;background:#38bdf8;border-radius:999px;padding:.75rem 1.6rem;font-weight:600;text-decoration:none;display:inline-block}@media (max-width:480px){.home-hero h1{margin-bottom:1.5rem}.certificate-card img{height:170px}.home-cta{border-radius:16px;padding:1.6rem}}.about-hero{text-align:center;margin-bottom:4rem}.about-hero h1{margin-bottom:1rem;font-size:2.4rem}.about-hero span{color:var(--muted);font-size:1.05rem;line-height:1.7}.about-section{margin-bottom:4rem}.about-section h2{margin-bottom:1.2rem;font-size:1.6rem}.about-section p{color:var(--muted);margin-bottom:1rem;line-height:1.7}.skills-grid{flex-wrap:wrap;gap:.75rem;display:flex}.skill{color:#38bdf8;cursor:default;background:#38bdf81f;border:1px solid #38bdf840;border-radius:999px;padding:.45rem .9rem;font-size:.8rem}.timeline{flex-direction:column;gap:1.8rem;display:flex;position:relative}.timeline-item{gap:1.2rem;display:flex;position:relative}.timeline .dot{background:#38bdf8;border-radius:50%;width:12px;height:12px;margin-top:.35rem}.about-cta{text-align:center;background:linear-gradient(#38bdf81f,#020617e6);border:1px solid #38bdf840;border-radius:20px;padding:3rem 2rem}.about-cta h2{margin-bottom:.8rem}.about-cta span{color:var(--muted)}.cta-btn{color:#020617;background:#38bdf8;border-radius:12px;margin-top:20px;padding:.75rem 1.6rem;font-weight:600;text-decoration:none;display:inline-block}.cta-btn:hover{filter:brightness(1.05)}@media (max-width:640px){.about{padding:0 .5rem}.about-hero h1{font-size:2rem}}.projects-header h1{text-align:center}.projects-header p{color:var(--muted);text-align:center;margin:3rem 0;line-height:1.6}.projects-header p strong{color:#e2e8f0f2;font-weight:700}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem;display:grid}.project-card{background:linear-gradient(#0f172ae6,#020617f2);border:1px solid #38bdf826;border-radius:18px;flex-direction:column;padding:1.5rem;display:flex}.carousel{border:1px solid #38bdf833;border-radius:12px;height:clamp(160px,20vw,220px);margin-bottom:1.2rem;position:relative;overflow:hidden}.carousel .carousel-media{object-fit:cover;width:100%;height:100%}.carousel video.carousel-media{display:block}.arrow{color:#fff;cursor:pointer;background:#020617d9;border:none;border-radius:50%;width:34px;height:34px;font-size:1.5rem;position:absolute;top:50%;transform:translateY(-50%)}.arrow.left{left:8px}.arrow.right{right:8px}.view-btn{cursor:pointer;color:#fff;background:#020617d9;border:none;border-radius:50%;width:34px;height:34px;position:absolute;bottom:8px;right:8px}.project-card h2{margin-bottom:.5rem;font-size:1.15rem}.project-card p{color:var(--muted);margin-bottom:1.25rem;font-size:.95rem;line-height:1.6}.techs{flex-wrap:wrap;gap:.5rem;margin-bottom:1.25rem;display:flex}.techs span{color:#38bdf8;background:#38bdf81f;border:1px solid #38bdf840;border-radius:999px;padding:.35rem .6rem;font-size:.75rem}.github-link{color:#38bdf8;margin-top:auto;font-size:.9rem;font-weight:500;text-decoration:none}.github-link:hover{text-decoration:underline}.arrow:focus-visible,.view-btn:focus-visible{outline-offset:3px;outline:2px solid #38bdf8e6}.arrow:hover,.view-btn:hover{filter:brightness(1.08)}.github-link.disabled{opacity:.65;cursor:default;text-decoration:none}@media (max-width:640px){.projects-header p{margin:1.5rem 0}.carousel{height:200px}.arrow{width:40px;height:40px;font-size:1.8rem}.view-btn{width:40px;height:40px}}@media (max-width:480px){.carousel{height:190px}.projects-grid{grid-template-columns:1fr}}.contact{grid-template-columns:2fr 1fr;gap:2.5rem;display:grid}.contact-main h1{margin-bottom:1rem;font-size:2.1rem}.contact-main p{color:var(--muted);margin-bottom:2rem;line-height:1.6}.contact-actions{gap:1rem;margin-bottom:1.5rem;display:flex}.btn{border-radius:12px;padding:.75rem 1.4rem;font-weight:500;text-decoration:none;transition:all .25s}.btn.whatsapp{color:#052e16;background:#22c55e}.btn.whatsapp:hover{filter:brightness(1.05)}.btn.gmail{color:#38bdf8;background:#38bdf826;border:1px solid #38bdf859}.btn.gmail:hover{background:#38bdf840}.contact-note{color:var(--muted);font-size:.85rem}.contact-info{background:linear-gradient(#0f172af2,#020617fa);border:1px solid #38bdf82e;border-radius:18px;align-self:start;width:100%;min-width:0;max-width:420px;padding:1.8rem}.contact-info h2{margin-bottom:1.2rem}.contact-info ul{margin-bottom:1.6rem;list-style:none}.contact-info li{justify-content:space-between;margin-bottom:.8rem;display:flex}.contact-info span{color:var(--muted)}.socials{gap:1rem;display:flex}.socials a{color:#38bdf8;font-weight:500;text-decoration:none}.socials a:hover{text-decoration:underline}@media (max-width:1023px){.contact{grid-template-columns:1fr;gap:2rem}.contact-info{align-self:start;min-width:auto;max-width:100%}}@media (max-width:640px){.contact{margin-bottom:3rem}.contact-main h1{font-size:1.8rem}.contact-actions{flex-direction:column}.btn{text-align:center;width:100%}.contact-info{border-radius:14px;align-self:start;padding:1.4rem}.contact-info li{flex-direction:column;gap:.3rem}.socials{flex-wrap:wrap}.contact-note{font-size:.8rem}}:root{--bg:#020617;--bg-card:#020617;--border:#1e293b;--text:#e5e7eb;--muted:#94a3b8;--primary:#38bdf8}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%}body{background:var(--bg);color:var(--text);font-family:Inter,system-ui,sans-serif}a{color:var(--primary);text-decoration:none}main{padding:2rem 1rem}html{scroll-behavior:smooth}body{-webkit-text-size-adjust:100%;line-height:1.5}img{max-width:100%;height:auto}button,a{-webkit-tap-highlight-color:transparent}:focus-visible{outline-offset:3px;outline:2px solid #38bdf8e6}#root{overflow-x:hidden}a,button,input,textarea{transition:background-color .18s,border-color .18s,color .18s,transform .18s,filter .18s,box-shadow .18s}a:hover{filter:brightness(1.06)}button:hover{filter:brightness(1.05)}button:active{transform:translateY(0)scale(.98)}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}
