:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}body{background-color:#000}.layout{display:grid;grid-template-columns:250px 1fr;height:100vh;width:100vw}.sidebar{background:transparent;color:#fff;padding:2rem;font-size:clamp(1rem,2vw,1.5rem)}.content{position:relative}@media(max-width:768px){.layout{grid-template-columns:1fr;grid-template-rows:auto 1fr}.sidebar{text-align:center}}.scene{width:100%;height:100%;position:relative;z-index:2}.app-container{position:relative;overflow:hidden;min-height:100vh;width:100vw;background:transparent;color:#fff}.navbar{position:fixed;top:0;width:100%;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffff08;z-index:20}.nav-logo{font-size:1.4rem;color:#7fe7cc;font-weight:700;text-shadow:0 0 10px rgba(127,231,204,.4)}.nav-links{display:flex;gap:1.5rem;margin-right:5%}.nav-links a{color:#fff;opacity:.85;transition:.2s}.nav-links a:hover{opacity:1;color:#7fe7cc;text-shadow:0 0 8px rgba(127,231,204,.4)}.navbar button{background:none;border:none;padding:.4rem .6rem;font-size:.95rem;color:#fff;cursor:pointer;white-space:nowrap;transition:color .25s ease,transform .25s ease}.navbar button:hover{color:#4ea1ff;transform:translateY(-1px)}.welcome-container{min-height:100vh;width:100vw;background:transparent;color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center;z-index:5;position:fixed}.welcome-inner{max-width:700px;padding:2rem;background:#ffffff0d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;box-shadow:0 0 30px #00ffc81a;animation:fadeIn 1.6s ease;transition:transform .4s cubic-bezier(.22,1,.36,1)}.welcome-inner:hover{background:#ffffff4d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;box-shadow:0 0 30px #bd239f1a;color:#000;transform:scale(1.05);transition:transform .4s cubic-bezier(.22,1,.36,1)}.welcome-title{font-size:3rem;color:#7fe7cc;margin-bottom:1rem;text-shadow:0 0 15px rgba(127,231,204,.4)}.welcome-subtitle{font-size:1.4rem;opacity:.9;margin-bottom:1rem}.welcome-desc{opacity:.7;font-size:1.1rem;line-height:1.7}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.three-bg{position:fixed!important;inset:0;z-index:0}.color-picker{position:fixed;width:230px;top:80px;left:85%;z-index:10!important;padding:10px;border-radius:10px}#inicio.hidden{display:none}.section{min-height:100vh;padding:4rem;transition:opacity .5s ease,transform .5s ease;position:fixed;z-index:5;width:95vw}.section.hidden{opacity:0;pointer-events:none;transform:translateY(40px);height:0;overflow:hidden}.section.visible{opacity:1;pointer-events:auto;transform:translateY(0);height:auto}html{scroll-behavior:smooth}.grid{display:flex;flex-wrap:wrap;flex-direction:row;overflow-y:scroll;justify-content:center;align-content:center;align-items:flex-start;width:100vw}.tarjeta{background:#2f47a179;margin-right:10px;border-radius:12px;display:flex;overflow:hidden;cursor:pointer;transition:transform .35s cubic-bezier(.22,1,.36,1),box-shadow .35s ease;flex-direction:column;align-items:center;width:300px;height:490px}.tarjeta:hover{transform:scale(1.05);box-shadow:0 20px 40px #00000080;background:#1136c379}.tarjeta-img img{width:300px;height:200px;object-fit:cover}.tarjeta-content{padding:0 1.5rem;display:flex;flex-direction:column;flex-wrap:wrap;align-content:center;justify-content:space-between;align-items:center}.tarjeta-techs{display:flex;flex-wrap:wrap;gap:.5rem;margin:1rem 0;padding:0;list-style:none}.tarjeta-techs li{background:#222;padding:.3rem .6rem;border-radius:6px;font-size:.8rem}.tarjeta-links{background:#fff;border-radius:10%;margin:10px}#contenedor_about{display:flex;flex-direction:row;justify-content:center;align-items:center;width:100vw}.footer{position:absolute;bottom:0;left:0;width:95%;padding:10px 3rem;background:#0f0f0f99;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid rgba(255,255,255,.08);color:#fff;display:flex;flex-direction:column;z-index:100}.footer-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:2rem}.footer-brand h3{margin:0;font-size:1.2rem;font-weight:600}.footer-brand p{margin:.3rem 0 0;font-size:.9rem;opacity:.7}.footer-links{display:flex;gap:1.5rem}.footer-links a{color:#fff;text-decoration:none;font-size:.9rem;opacity:.75;transition:all .3s ease}.footer-links a:hover{opacity:1;transform:translateY(-2px)}.footer-bottom{text-align:center;font-size:.8rem;opacity:.6}.about-skills{margin-top:3rem;display:grid;grid-template-columns:repeat(3,minmax(300px,1fr));gap:2rem}.skills-group{padding:2rem;background:#1414148c;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.06);border-radius:16px;transition:transform .35s cubic-bezier(.22,1,.36,1),box-shadow .35s ease,border .35s ease}.skills-group:hover{transform:translateY(-8px);border:1px solid rgba(255,255,255,.15);box-shadow:0 20px 40px #00000080}.skills-group h5{margin:0 0 1.2rem;font-size:1.1rem;font-weight:600;color:#fff;letter-spacing:.5px}.skills-group ul{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:.6rem}.skills-group li{padding:.4rem .8rem;font-size:.85rem;background:#ffffff14;border-radius:999px;color:#fff;opacity:.85;transition:all .25s ease}.skills-group li:hover{background:#4ea1ff33;color:#4ea1ff;transform:translateY(-2px)}.skills-group{opacity:0;transform:translateY(40px);animation:fadeUp .8s ease forwards}@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}.contact-card{margin:3rem auto 0;max-width:600px;padding:2.5rem;background:#1414148c;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-radius:18px;border:1px solid rgba(255,255,255,.08);text-align:center;transition:transform .35s ease,box-shadow .35s ease}.contact-card:hover{transform:translateY(-6px);box-shadow:0 20px 45px #00000080}.contact-text{color:#fff;opacity:.8;margin-bottom:2rem;line-height:1.6}.contact-items{display:flex;justify-content:center;flex-wrap:wrap;gap:1.5rem}.contact-item{padding:.8rem 1.5rem;background:#ffffff0f;border-radius:12px;text-decoration:none;color:#fff;font-size:.95rem;transition:all .3s ease}.contact-item:hover{background:#4ea1ff33;color:#4ea1ff;transform:translateY(-3px)}@media(max-width:480px){.navbar{padding:5px 1rem}.skills-group{padding:1.5rem}.skills-group h5{font-size:1rem}.contact-card{padding:1.5rem}.contact-items{flex-direction:column}.welcome-inner{max-width:none;width:80vw}.welcome-container{padding:0}.color-picker{left:16%}.footer{padding:10px 1rem}#contenedor_about{overflow-y:scroll;height:60vh;width:90vw;flex-direction:column;align-items:center;align-content:center;justify-content:flex-start;flex-wrap:nowrap}.tarjeta{width:300px;height:416px;margin-top:20px}}@media(max-width:768px){.footer-content{flex-direction:column;text-align:center}.section{padding:4rem 1.2rem}.nav-links{overflow-x:auto;gap:1rem}.navbar{padding:5px 1rem}.navbar button{font-size:.85rem}.welcome-inner{max-width:none;width:80vw}.welcome-container{padding:0}.color-picker{left:30%}.footer{padding:10px 1rem}#contenedor_about{overflow-x:scroll}}
