@import"https://fonts.googleapis.com/css2?family=Roboto+Slab:wght@400;700&display=swap";:root{--primary-color: #4668ee;--text-color: #1a202c;--text-light-color: #555}#root{width:100vw;height:100vh}body{margin:0;font-family:Roboto Slab,serif}.interface{width:100vw;display:flex;flex-direction:column;align-items:center}.sections{max-width:1200px;width:100%}.section{height:100vh;display:flex;justify-content:center;align-items:center}.section--top{align-items:flex-start}.section--bottom{align-items:flex-end}.section--right{justify-content:flex-end}.section--left{justify-content:flex-start}.scroll-down{width:28px;height:42px;border:2px solid var(--text-color);border-radius:12px;display:flex;justify-content:center;margin-bottom:4rem}.scroll-down__wheel{background:var(--text-color);width:3px;height:10px;border-radius:2px;margin-top:4px}.skills{padding:1rem}.skill{background:rgba(255,255,255,.5);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:8px;padding:1rem;margin-bottom:1rem;width:320px;max-width:100%}.skill__label{display:flex;gap:1rem;align-items:center;margin-bottom:.5rem}.skill__label__image{height:32px;width:32px}.skill__label__name{color:var(--text-color);font-weight:700;font-size:1.25rem;margin:0}.skill__level{background:#000;height:8px;border-radius:8px;width:100%}.skill__level__bar{background:var(--primary-color);height:100%;border-radius:8px;width:0px}.projects{padding:1rem;display:grid;grid-template-columns:repeat(auto-fit,220px);width:500px;max-width:100%;justify-content:center;gap:1rem}.project{background:rgba(255,255,255,.5);overflow:hidden;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:8px;transition:transform .2s ease-in-out,background-color .2s ease-in-out}.project:hover{background:white;transform:scale(1.05);cursor:pointer}.project__image{width:100%;object-fit:cover}.project__details{padding:.5rem}.project__details__name{color:var(--text-color);font-weight:700;font-size:1.25rem;margin:0}.project__details__description{color:var(--text-light-color);font-size:1rem;margin:0}.contact{margin:1rem;padding:1rem;background:rgba(255,255,255,.5);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:8px;min-width:280px}.contact__name{color:var(--text-color);font-weight:700;font-size:1.5rem;margin:0}.contact__address{color:var(--text-light-color);font-size:1rem;margin:0}.contact__socials{display:flex;gap:1rem;margin-top:1rem}.contact__socials__icon{height:32px;width:32px}.menu{display:flex;justify-content:space-between;align-items:center;padding:1rem;position:fixed;z-index:100;top:0;left:4rem;right:4rem;background:#f5f3ef8a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.menu__logo{height:42px;width:120px;object-fit:contain}.menu__buttons{display:flex;gap:1rem;align-items:center}.menu__button{font-weight:700;color:var(--text-color)}.menu__button:hover{color:var(--primary-color);cursor:pointer}.loading-screen{position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at center,#ffffff 0%,#f5f3ee 70%),repeating-linear-gradient(0deg,rgba(0,0,0,.03),rgba(0,0,0,.03) 1px,transparent 1px,transparent 4px);display:flex;align-items:center;justify-content:center;z-index:9999;transition:opacity .6s ease,visibility .6s ease}.loading-screen--hidden{opacity:0;visibility:hidden;pointer-events:none}.loading-screen__container{width:400px;text-align:center}.loading-screen__title{font-size:1.9rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase}.loading-screen__subtitle{font-size:.75rem;letter-spacing:.25em;text-transform:uppercase;opacity:.5;margin:.75rem 0 2rem}.progress__container{width:100%;height:6px;background:rgba(0,0,0,.15);border-radius:999px;overflow:hidden;position:relative}.progress__bar{height:100%;width:0%;background:linear-gradient(90deg,#22c55e,#3b82f6,#22c55e);background-size:200% 100%;animation:shimmer 1.5s linear infinite;transition:width .3s ease}.progress__value{display:block;margin-top:.75rem;font-size:.8rem;opacity:.6}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media (max-width: 990px){.mobile--section--top{align-items:flex-start}.mobile--section--bottom{align-items:flex-end}.mobile--section--right{justify-content:flex-end}.mobile--section--left{justify-content:flex-start}.section.section--left.mobile--section--bottom{margin-top:-80px}.skills{display:flex;gap:1rem;overflow-x:auto;width:100%}.skill{padding:.5rem;min-width:220px;margin:0}.projects{display:flex;justify-content:flex-start;overflow-x:auto;width:100%}.project{min-width:220px}.contact{width:100%}.menu{flex-direction:column;gap:.5rem}.loading-screen__title{font-size:2rem}.loading-screen{padding:0}.loading-screen__container{width:320px}}.skills-header{text-align:left;margin-bottom:2rem}.skills-title{font-size:2rem;font-weight:700;color:#111}.skills-subtitle{font-size:1rem;color:#555;margin-top:.5rem}.skill-card{background:rgba(255,255,255,.6);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;padding:1rem;display:flex;flex-direction:column;justify-content:space-between;cursor:pointer}.skill-card-name{font-weight:600;color:#111;flex:1}.skill-card-level{font-weight:700;color:#4668ee}.skill-card-progress{position:relative;height:8px;background:#e2e8f0;border-radius:8px;margin-top:.5rem}.skill-card-bar{height:100%;background:#4668ee;border-radius:8px}.skill-card-impact{font-size:.75rem;color:#555;margin-top:.25rem}@media (max-width: 1300px){.skills-list{margin-right:20rem}}@media (max-width: 990px){.skills-list{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));overflow-x:auto;margin-right:0rem}.skill-card{min-width:180px}}.skills-list{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-left:50rem;padding-top:10rem}@media (max-width: 990px){.skills-list{display:flex;flex-direction:row;overflow-x:auto;gap:1rem;margin-left:0;padding-top:3rem}.skill{min-width:220px;flex-shrink:0}}.skill-card-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.skill-card-icon{width:32px;height:32px}.skill-card-name{font-weight:600;flex:1}.skill-card-impact{font-size:.8rem;color:#555;margin-bottom:.5rem}.subskills{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem}.subskill-bar-container{height:6px;background:#e2e8f0;border-radius:6px;overflow:hidden}.subskill-bar{height:100%;background:#4668ee;border-radius:6px}.skill-cert{margin-top:.5rem;font-size:.75rem;opacity:.7;font-weight:500}.cert-btn{margin-top:.6rem;background:none;border:none;font-size:.75rem;opacity:.7;cursor:pointer}.cert-btn:hover{opacity:1}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.35);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.modal-container{width:min(720px,90vw);max-height:85vh;overflow-y:auto;color:#fff;background:linear-gradient(145deg,#0f172a,#020617);border-radius:18px;border:1px solid rgba(139,92,246,.25);box-shadow:0 0 40px #8b5cf640;padding:2rem}@media (max-width: 768px){.modal-container{width:100vw;height:100vh;max-height:100vh;border-radius:0;padding:1.5rem}}.modal-title{font-size:1.5rem;margin-bottom:2rem;text-align:center}.timeline{position:relative;padding-left:24px}.timeline:before{content:"";position:absolute;left:6px;top:0;bottom:0;width:2px;background:linear-gradient(#8b5cf6,transparent)}.timeline-item{display:flex;gap:1rem;margin-bottom:1.6rem}.timeline-dot{width:14px;height:14px;border-radius:50%;background:#8b5cf6;margin-top:6px;box-shadow:0 0 12px #8b5cf6}.timeline-item.highlight .timeline-dot{background:#facc15;box-shadow:0 0 14px #facc15}.timeline-content h3{font-size:1rem;margin:.2rem 0}.timeline-content p{font-size:.85rem;opacity:.7}.timeline-year{font-size:.75rem;opacity:.6}.badge{display:inline-block;margin-top:.4rem;padding:2px 8px;font-size:.7rem;border-radius:999px;background:rgba(139,92,246,.2);border:1px solid rgba(139,92,246,.4)}.timeline-item.highlight .badge{background:rgba(250,204,21,.2);border-color:#facc1599}.modal-close{margin-top:2rem;width:100%;padding:.6rem;border-radius:10px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);color:#fff;cursor:pointer}.cert-btn{background-color:#1e40af;color:#fff;font-weight:600;font-size:1rem;padding:.6rem 1.2rem;border:2px solid #3b82f6;border-radius:.5rem;cursor:pointer;transition:all .2s ease}.cert-btn:hover{background-color:#3b82f6;color:#fff;transform:translateY(-2px);box-shadow:0 2px 6px #0003}.cert-btn:active{transform:translateY(0);box-shadow:none}
