@import "https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;600&family=Space+Grotesk:wght@400;500;600;700&display=swap";:root{--text:#bcc9e6;--text-h:#f3f8ff;--bg:#060914;--bg-elev:#0c1326;--border:#85aaff42;--code-bg:#172240b8;--accent:#4dd9ff;--accent-alt:#ff8f70;--accent-bg:#4dd9ff2e;--accent-border:#4dd9ff85;--social-bg:#0b1326c7;--shadow:#02061694 0 18px 40px -12px, #0e1a365c 0 8px 22px -14px;--sans:"Space Grotesk", "Trebuchet MS", "Segoe UI", sans-serif;--heading:"Space Grotesk", "Trebuchet MS", "Segoe UI", sans-serif;--mono:"JetBrains Mono", Consolas, monospace;font:18px/1.5 var(--sans);letter-spacing:.15px;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body,#root{min-height:100%}body{color:var(--text);background:radial-gradient(circle at 18% 14%,#4dd9ff33,#0000 28%),radial-gradient(circle at 82% 20%,#ff8f702e,#0000 30%),radial-gradient(circle at 50% 78%,#7e57ff2b,#0000 34%),linear-gradient(170deg,#03050d 0%,#0a1230 52%,#060914 100%);margin:0;position:relative}body:before{content:"";pointer-events:none;opacity:.55;background-image:radial-gradient(1px 1px at 10% 12%,#ffffffb8,#0000),radial-gradient(1px 1px at 72% 28%,#4dd9ffbd,#0000),radial-gradient(1px 1px at 36% 68%,#ffbe91b3,#0000),radial-gradient(1px 1px at 86% 82%,#ffffff9e,#0000),radial-gradient(1px 1px at 24% 84%,#99e6ffad,#0000);animation:18s linear infinite drift;position:fixed;inset:0}#root{border:1px solid var(--border);width:min(1126px,100% - 24px);min-height:calc(100svh - 28px);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(7px);backdrop-filter:blur(7px);background:linear-gradient(165deg,#070d1de6,#060a18d1);border-radius:22px;flex-direction:column;margin:14px auto;display:flex;overflow:hidden}a{color:var(--accent)}h1,h2,h3{font-family:var(--heading);color:var(--text-h);font-weight:600}h1{letter-spacing:-.04em;margin:24px 0;font-size:clamp(2rem,5.2vw,3.5rem)}h2{letter-spacing:-.02em;margin:0 0 8px;font-size:clamp(1.2rem,2.6vw,1.6rem);line-height:1.25}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:6px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:.85rem;line-height:1.3}@keyframes drift{0%{transform:translateY(0)}to{transform:translateY(-16px)}}@media (width<=1024px){:root{font-size:16px}#root{border-inline:none;border-radius:0;width:100%;min-height:100svh;margin:0}}.navbar{z-index:30;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:linear-gradient(#080e20eb,#080e20b8);padding:14px 20px;position:sticky;top:0}.nav-list{flex-wrap:wrap;justify-content:center;align-items:center;gap:10px;margin:0;padding:0;list-style:none;display:flex}.nav-item{margin:0}.nav-item a{min-height:38px;color:var(--text);border:1px solid #0000;border-radius:999px;justify-content:center;align-items:center;padding:8px 14px;font-size:.95rem;font-weight:600;text-decoration:none;transition:all .24s;display:inline-flex}.nav-item a:hover{color:var(--text-h);border-color:var(--accent-border);background:var(--accent-bg)}.nav-item a.active{color:var(--text-h);border-color:var(--accent);background:linear-gradient(135deg,#4dd9ff42,#ff8f7033);box-shadow:0 0 0 1px #4dd9ff4d,0 10px 24px #080d246b}.counter{color:var(--accent);background:var(--accent-bg);border:2px solid #0000;border-radius:5px;margin-bottom:24px;padding:5px 10px;font-size:16px;transition:border-color .3s}.counter:hover{border-color:var(--accent-border)}.counter:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.hero{position:relative}.hero .base,.hero .framework,.hero .vite{margin:0 auto;inset-inline:0}.hero .base{z-index:0;width:170px;position:relative}.hero .framework,.hero .vite{position:absolute}.hero .framework{z-index:1;height:28px;top:34px;transform:perspective(2000px)rotate(300deg)rotateX(44deg)rotateY(39deg)scale(1.4)}.hero .vite{z-index:0;width:auto;height:26px;top:107px;transform:perspective(2000px)rotate(300deg)rotateX(40deg)rotateY(39deg)scale(.8)}#center{flex-direction:column;flex-grow:1;place-content:center;place-items:center;gap:25px;display:flex}@media (width<=1024px){#center{gap:18px;padding:32px 20px 24px}}#next-steps{border-top:1px solid var(--border);text-align:left;display:flex}#next-steps>div{flex:1 1 0;padding:32px}@media (width<=1024px){#next-steps>div{padding:24px 20px}}#next-steps .icon{width:22px;height:22px;margin-bottom:16px}@media (width<=1024px){#next-steps{text-align:center;flex-direction:column}}#docs{border-right:1px solid var(--border)}@media (width<=1024px){#docs{border-right:none;border-bottom:1px solid var(--border)}}#next-steps ul{gap:8px;margin:32px 0 0;padding:0;list-style:none;display:flex}#next-steps ul .logo{height:18px}#next-steps ul a{color:var(--text-h);background:var(--social-bg);border-radius:6px;align-items:center;gap:8px;padding:6px 12px;font-size:16px;text-decoration:none;transition:box-shadow .3s;display:flex}#next-steps ul a:hover{box-shadow:var(--shadow)}#next-steps ul a .button-icon{width:18px;height:18px}@media (width<=1024px){#next-steps ul{flex-wrap:wrap;justify-content:center;margin-top:20px}#next-steps ul li{flex:calc(50% - 8px)}#next-steps ul a{box-sizing:border-box;justify-content:center;width:100%}}#spacer{border-top:1px solid var(--border);height:88px}@media (width<=1024px){#spacer{height:48px}}.ticks{width:100%;position:relative}.ticks:before,.ticks:after{content:"";border:5px solid #0000;position:absolute;top:-4.5px}.ticks:before{border-left-color:var(--border);left:0}.ticks:after{border-right-color:var(--border);right:0}.skills-container{flex-wrap:wrap;justify-content:center;gap:24px;margin:48px 0;display:flex}@media (width<=1024px){.skills-container{gap:16px;margin:32px 0}}.skill-card{border:2px solid var(--border);background:var(--bg);border-radius:8px;flex:1;min-width:250px;max-width:300px;padding:24px;transition:all .3s}.skill-card:hover{border-color:var(--accent);box-shadow:var(--shadow)}.skill-card h2{color:var(--text-h);margin:0 0 16px;font-size:20px}.skill-card ul{margin:0;padding:0;list-style:none}.skill-card ul li{color:var(--text);padding:8px 0;font-size:16px}.skill-card ul li:before{content:"• ";color:var(--accent);margin-right:8px;font-weight:700}@media (width<=1024px){.skill-card{min-width:200px;max-width:none;padding:16px}.skill-card h2{font-size:18px}}#home{text-align:left;gap:26px;padding:42px 34px 56px;display:grid}.shortPresentation,.homePresentation{max-width:1000px;margin:0 auto}.shortPresentation{gap:14px;display:grid}.mePicture{border:1px solid var(--border);box-shadow:var(--shadow);border-radius:14px}.homePresentation p,.shortPresentation p{line-height:1.7}.presentation-page{text-align:left;padding:32px 20px 64px}.presentation-hero{max-width:860px;margin:0 auto 28px}.eyebrow{border:1px solid var(--border);background:var(--social-bg);color:var(--text-h);letter-spacing:.08em;text-transform:uppercase;border-radius:999px;align-items:center;gap:8px;margin-bottom:12px;padding:6px 12px;font-size:14px;display:inline-flex}.intro-text{max-width:74ch;color:var(--text);line-height:1.8}.skills-marquee{border-block:1px solid var(--border);margin:28px 0 36px;padding:18px 0;overflow:hidden}.marquee-track{gap:14px;width:max-content;animation:30s linear infinite marquee;display:flex}.marquee-track.is-static{flex-wrap:wrap;width:100%;animation:none}.tech-pill{border:1px solid var(--border);color:var(--text-h);white-space:nowrap;background:linear-gradient(165deg,#0e1830f2,#0c1226e6);border-radius:999px;align-items:center;gap:10px;padding:12px 16px;display:inline-flex;box-shadow:0 12px 26px #02081c6b}.tech-pill__mark{background:var(--accent-bg);min-width:2.1rem;height:2.1rem;color:var(--accent);letter-spacing:.03em;border-radius:999px;justify-content:center;align-items:center;font-size:.78rem;font-weight:700;display:inline-flex}.tech-pill__label{font-size:.98rem;font-weight:600}.tone-java .tech-pill__mark{color:var(--text-h);background:#e15d5024}.tone-js .tech-pill__mark{color:var(--text-h);background:#f7df1e2e}.tone-ts .tech-pill__mark{color:var(--text-h);background:#3178c629}.tone-react .tech-pill__mark{color:var(--text-h);background:#61dafb2e}.tone-sql .tech-pill__mark{color:var(--text-h);background:#3741511f}.tone-html .tech-pill__mark{color:var(--text-h);background:#f1652929}.tone-css .tech-pill__mark{color:var(--text-h);background:#264de424}.tone-git .tech-pill__mark{color:var(--text-h);background:#f0503324}.tone-next .tech-pill__mark{color:var(--text-h);background:#1111111a}.tone-node .tech-pill__mark{color:var(--text-h);background:#53b43f2e}.tone-spring .tech-pill__mark{color:var(--text-h);background:#6db33f2e}.tone-csharp .tech-pill__mark{color:var(--text-h);background:#68217a33}.skills-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:20px;margin-bottom:28px;display:grid}.skill-card--expanded,.skill-card--summary{border-radius:16px;max-width:none}.skill-card--expanded h2,.skill-card--summary h2{margin-bottom:10px}.skill-card__description{color:var(--text);margin-bottom:20px;line-height:1.7}.skill-meter-list{gap:16px;margin:0;padding:0;list-style:none;display:grid}.skill-meter-item{gap:8px;display:grid}.skill-meter-item__header{color:var(--text-h);justify-content:space-between;gap:12px;font-size:15px;display:flex}.skill-meter-item__header span:last-child{color:var(--text)}.skill-meter{background:var(--code-bg);border-radius:999px;height:10px;overflow:hidden}.skill-meter span{border-radius:inherit;background:linear-gradient(90deg, var(--accent), #aa3bff73);height:100%;display:block}.presentation-summary{grid-template-columns:repeat(3,minmax(0,1fr));gap:20px;display:grid}.skill-card--summary ul{margin-top:0}.skill-card--summary li{padding:8px 0}@keyframes marquee{0%{transform:translate(0)}to{transform:translate(-50%)}}@media (prefers-reduced-motion:reduce){.marquee-track{flex-wrap:wrap;width:100%;animation:none}}@media (width<=1024px){#home{gap:20px;padding:28px 16px 44px}.presentation-page{padding:24px 16px 48px}.skills-grid,.presentation-summary{grid-template-columns:1fr}.marquee-track{gap:10px}.tech-pill{padding:10px 14px}}.projects-page{text-align:left;padding:32px 20px 64px}.projects-page__hero{max-width:860px;margin:0 auto 28px}.projects-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:20px;margin-bottom:28px;display:grid}.project-card{border:1px solid var(--border);background:linear-gradient(165deg,#0b1328f2,#090e1ee6);border-radius:16px;gap:14px;padding:64px 24px 24px;display:grid;position:relative;box-shadow:0 14px 30px #01051473}.project-card__badge{min-height:30px;color:var(--text-h);letter-spacing:.06em;text-transform:uppercase;background:linear-gradient(135deg,#4dd9ff33,#ff8f7033);border:1px solid #4dd9ff8c;border-radius:999px;justify-content:center;align-items:center;margin:0;padding:4px 10px;font-size:12px;font-weight:700;display:inline-flex;position:absolute;top:20px;left:24px}.project-card h2{margin:0}.project-card__context{color:var(--text);line-height:1.7}.project-card__highlights{gap:8px;margin:0;padding-left:18px;display:grid}.project-card__highlights li{color:var(--text)}.project-card__stack{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.project-card__stack span{border:1px solid var(--border);color:var(--text-h);background:linear-gradient(#374870b3,#2c3858a8);border-radius:999px;justify-content:center;align-items:center;padding:7px 13px;font-size:14px;font-weight:600;line-height:1.15;display:inline-flex}.project-card__link{color:var(--accent);width:fit-content;font-weight:600;text-decoration:none}.project-card__link:hover{text-decoration:underline}.projects-experience{border:1px solid var(--border);background:var(--bg);border-radius:16px;padding:24px}.projects-experience h2{margin-bottom:10px}.projects-experience>p{max-width:74ch;color:var(--text);margin-bottom:18px;line-height:1.8}.experience-list{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;display:grid}.experience-item{border:1px solid var(--border);background:var(--social-bg);border-radius:12px;padding:16px}.experience-item__period{color:var(--accent);margin-bottom:6px;font-size:14px;font-weight:600}.experience-item h3{color:var(--text-h);margin:0 0 8px;font-size:18px}.experience-item p{color:var(--text);line-height:1.7}.experience-item__stack{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}.experience-item__stack span{border:1px solid var(--border);color:var(--text-h);background:var(--bg);border-radius:999px;padding:4px 10px;font-size:13px}.experience-item__result{color:var(--accent);margin-top:12px;font-weight:600}@media (width<=1024px){.navbar{padding:12px}.nav-list{justify-content:flex-start}.nav-item{flex:calc(50% - 10px)}.nav-item a{width:100%}.projects-page{padding:24px 16px 48px}.projects-grid,.experience-list{grid-template-columns:1fr}}.formation-page{text-align:left;padding:32px 20px 64px}.formation-page__hero{max-width:860px;margin:0 auto 48px}.formation-timeline{gap:32px;max-width:860px;margin:0 auto 64px;display:grid}.formation-item{grid-template-columns:auto 1fr;align-items:start;gap:24px;display:grid}.formation-item__marker{background:var(--accent-bg);border:2px solid var(--accent);width:48px;height:48px;color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;font-weight:700;display:flex}.formation-item__content{border-left:2px solid var(--border);padding-left:24px;position:relative}.formation-item__period{color:var(--accent);margin-bottom:8px;font-size:14px;font-weight:600}.formation-item h2{color:var(--text-h);margin:0 0 8px}.formation-item__specialization{color:var(--text);margin-bottom:4px;font-size:15px;font-style:italic}.formation-item__school{color:var(--text-h);margin-bottom:12px;font-weight:600}.formation-item__description{color:var(--text);margin:0;line-height:1.7}.formation-summary{border:1px solid var(--border);background:var(--bg);border-radius:16px;max-width:860px;margin:0 auto;padding:32px}.formation-summary h2{margin-bottom:24px}.formation-skills-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:24px;display:grid}.formation-skill-group{border:1px solid var(--border);background:var(--social-bg);border-radius:12px;padding:16px}.formation-skill-group h3{color:var(--text-h);margin:0 0 12px;font-size:16px}.formation-skill-group ul{gap:8px;margin:0;padding:0;list-style:none;display:grid}.formation-skill-group li{color:var(--text);padding-left:16px;font-size:14px;line-height:1.6;position:relative}.formation-skill-group li:before{content:"▸";color:var(--accent);position:absolute;left:0}.contact-page{text-align:left;padding:32px 20px 64px}.contact-page__hero{max-width:860px;margin:0 auto 48px}.contact-container{grid-template-columns:1fr 1fr;gap:40px;max-width:1200px;margin:0 auto;display:grid}.contact-form-section h2,.contact-info h2{margin-bottom:24px}.contact-form{gap:20px;display:grid}.form-group{flex-direction:column;gap:8px;display:flex}.form-group label{color:var(--text-h);font-size:14px;font-weight:600}.form-group input,.form-group textarea{border:1px solid var(--border);background:var(--bg);color:var(--text-h);border-radius:8px;padding:12px 16px;font-family:inherit;font-size:14px;transition:border-color .2s,box-shadow .2s}.form-group input:focus,.form-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg);outline:none}.form-group textarea{resize:vertical;min-height:120px}.contact-form__submit{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;margin-top:8px;padding:12px 24px;font-size:16px;font-weight:600;transition:all .2s}.contact-form__submit:hover:not(:disabled){background:var(--accent-border);box-shadow:var(--shadow)}.contact-form__submit:disabled{opacity:.6;cursor:not-allowed}.form-feedback{border-radius:8px;margin-top:8px;padding:12px 16px;font-size:14px;font-weight:500}.form-feedback--success{color:var(--text-h);background:linear-gradient(135deg,#22c55e26,#22c55e14);border:1px solid #22c55e66}.form-feedback--success:before{content:"✓ ";color:#16a34a;font-weight:700}.form-feedback--error{color:var(--text-h);background:linear-gradient(135deg,#ef444426,#ef444414);border:1px solid #ef444466}.form-feedback--error:before{content:"✕ ";color:#dc2626;font-weight:700}.contact-methods{gap:16px;margin-bottom:40px;display:grid}.contact-method{border:1px solid var(--border);background:var(--social-bg);border-radius:12px;gap:16px;padding:16px;text-decoration:none;transition:all .2s;display:flex}.contact-method:hover{border-color:var(--accent);box-shadow:var(--shadow)}.contact-method__icon{font-size:28px;line-height:1}.contact-method__label{color:var(--text);text-transform:uppercase;letter-spacing:.05em;margin:0;font-size:12px;font-weight:600}.contact-method__value{color:var(--text-h);margin:4px 0 0;font-weight:600}.contact-cv{border:2px solid var(--accent);background:var(--accent-bg);border-radius:12px;margin-bottom:32px;padding:20px}.contact-cv h3{color:var(--text-h);margin:0 0 12px}.contact-cv__link{background:var(--accent);color:#fff;border-radius:6px;padding:10px 16px;font-size:14px;font-weight:600;text-decoration:none;transition:all .2s;display:inline-block}.contact-cv__link:hover{background:var(--accent-border);box-shadow:var(--shadow)}.contact-cv__note{color:var(--text);margin:10px 0 0;font-size:13px}.contact-cta{border:1px solid var(--border);background:var(--bg);border-radius:12px;padding:20px}.contact-cta h3{color:var(--text-h);margin:0 0 10px}.contact-cta p{color:var(--text);margin:0;line-height:1.7}.site-footer{border-top:1px solid var(--border);text-align:center;background:linear-gradient(#f4f3ec59,#0000);margin-top:auto;padding:20px 24px 24px}.site-footer p{color:var(--text);margin:0;font-size:14px;line-height:1.6}.site-footer p+p{margin-top:4px}@media (width<=1024px){.contact-page{padding:24px 16px 48px}.contact-container{grid-template-columns:1fr;gap:32px}.contact-page__hero{margin-bottom:32px}.site-footer{padding:16px 16px 20px}.formation-page{padding:24px 16px 48px}.formation-item{grid-template-columns:1fr}.formation-item__marker{width:40px;height:40px;font-size:16px}.formation-item__content{border-left:none;padding-left:0}.formation-skills-grid{grid-template-columns:1fr}.formation-summary{padding:20px}}
