:root{--bg-primary: #0a0c10;--bg-secondary: #111318;--bg-card: #161920;--bg-card-hover: #1c2028;--border-color: #1e2330;--border-hover: #2e3a4e;--accent: #3b82f6;--accent-hover: #2563eb;--accent-muted: rgba(59, 130, 246, .12);--accent-border: rgba(59, 130, 246, .25);--text-primary: #e8eaf0;--text-secondary: #8892a4;--text-muted: #525f75;--text-accent: #3b82f6;--green: #10b981;--green-muted: rgba(16, 185, 129, .1);--font-sans: "Inter", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--section-padding: 6rem 0;--container-max: 1100px;--container-pad: 0 1.5rem;--transition: .2s ease;--transition-slow: .35s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-sans);background-color:var(--bg-primary);color:var(--text-primary);line-height:1.7;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}a{color:var(--text-accent);text-decoration:none;transition:color var(--transition)}a:hover{color:var(--accent-hover)}img{max-width:100%;display:block}ul{list-style:none}.container{max-width:var(--container-max);margin:0 auto;padding:var(--container-pad)}.section{padding:var(--section-padding)}.section-label{font-family:var(--font-mono);font-size:.75rem;font-weight:500;color:var(--accent);letter-spacing:.15em;text-transform:uppercase;margin-bottom:.75rem}.section-title{font-size:clamp(1.75rem,4vw,2.25rem);font-weight:700;color:var(--text-primary);letter-spacing:-.025em;line-height:1.2;margin-bottom:1rem}.section-subtitle{font-size:1rem;color:var(--text-secondary);max-width:560px;line-height:1.7}.section-header{margin-bottom:3.5rem}.section-divider{width:3rem;height:2px;background:var(--accent);margin-top:1rem;border-radius:2px}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.7rem 1.5rem;border-radius:6px;font-family:var(--font-sans);font-size:.875rem;font-weight:600;letter-spacing:.01em;cursor:pointer;transition:all var(--transition);border:1px solid transparent;white-space:nowrap}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover);color:#fff;transform:translateY(-1px);box-shadow:0 4px 16px #3b82f64d}.btn-outline{background:transparent;color:var(--text-primary);border-color:var(--border-color)}.btn-outline:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}.btn-ghost{background:transparent;color:var(--text-secondary);border-color:transparent}.btn-ghost:hover{color:var(--text-primary)}.tag{display:inline-block;padding:.2rem .65rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;font-size:.7rem;font-family:var(--font-mono);font-weight:500;color:var(--text-secondary);letter-spacing:.04em}.tag-accent{background:var(--accent-muted);border-color:var(--accent-border);color:var(--accent)}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;padding:1.75rem;transition:border-color var(--transition),background var(--transition)}.card:hover{border-color:var(--border-hover);background:var(--bg-card-hover)}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}.mono{font-family:var(--font-mono)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:#1e2330;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--accent)}::selection{background:var(--accent-muted);color:var(--accent)}@media(max-width:768px){:root{--section-padding: 4rem 0;--container-pad: 0 1.25rem}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.section-title{font-size:1.75rem}}@media(max-width:480px){:root{--container-pad: 0 1rem}}.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;transition:background .3s ease,border-color .3s ease,box-shadow .3s ease;border-bottom:1px solid transparent}.navbar--scrolled{background:#0a0c10eb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom-color:var(--border-color);box-shadow:0 4px 24px #0000004d}.navbar__inner{display:flex;align-items:center;justify-content:space-between;height:64px}.navbar__logo{font-size:1.2rem;font-weight:800;color:var(--text-primary);letter-spacing:-.02em}.navbar__logo:hover{color:var(--text-primary)}.navbar__logo-dot{color:var(--accent)}.navbar__nav{display:flex;align-items:center;gap:.25rem}.navbar__link{padding:.4rem .85rem;font-size:.85rem;font-weight:500;color:var(--text-secondary);border-radius:6px;transition:color .2s ease,background .2s ease}.navbar__link:hover{color:var(--text-primary);background:#ffffff0a}.navbar__hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:.4rem}.navbar__hamburger span{display:block;width:22px;height:2px;background:var(--text-secondary);border-radius:2px;transition:all .25s ease}@media(max-width:768px){.navbar__hamburger{display:flex}.navbar__nav{position:absolute;top:64px;left:0;right:0;flex-direction:column;align-items:flex-start;gap:0;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:.75rem 1.25rem 1rem;display:none}.navbar__nav--open{display:flex}.navbar__link{width:100%;padding:.6rem .5rem}}.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:7rem 0 4rem;position:relative;background:radial-gradient(ellipse 60% 50% at 70% 40%,rgba(59,130,246,.06) 0%,transparent 70%),var(--bg-primary)}.hero__inner{display:grid;grid-template-columns:1fr 380px;gap:4rem;align-items:center}.hero__eyebrow{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--font-mono);font-size:.75rem;color:var(--text-muted);margin-bottom:1.5rem;letter-spacing:.04em}.dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.dot--green{background:var(--green);box-shadow:0 0 8px #10b98180;animation:pulse-green 2.5s ease-in-out infinite}@keyframes pulse-green{0%,to{box-shadow:0 0 8px #10b98180}50%{box-shadow:0 0 14px #10b981e6}}.hero__name{font-size:clamp(2.2rem,5vw,3.5rem);font-weight:800;letter-spacing:-.04em;line-height:1.1;color:var(--text-primary);margin-bottom:.75rem}.hero__role{font-family:var(--font-mono);font-size:1rem;color:var(--accent);margin-bottom:1.75rem;letter-spacing:.02em}.hero__statement{font-size:1.05rem;color:var(--text-secondary);line-height:1.8;max-width:540px;margin-bottom:2.5rem}.hero__actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:2.5rem}.hero__meta{padding-top:2rem;border-top:1px solid var(--border-color)}.hero__meta-item{display:flex;flex-direction:column;gap:.5rem}.hero__tags{display:flex;flex-wrap:wrap;gap:.4rem}.hero__visual{display:flex;flex-direction:column;align-items:center;gap:1.25rem}.hero__photo-wrapper{width:260px;height:320px;border-radius:12px;overflow:hidden;border:1px solid var(--border-color);background:var(--bg-card);position:relative}.hero__photo-wrapper:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(10,12,16,.4) 100%)}.hero__photo{width:100%;height:100%;object-fit:cover;object-position:top center;filter:grayscale(15%)}.hero__card-stat{display:flex;align-items:center;gap:1.5rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;padding:1rem 1.5rem;width:100%}.stat{display:flex;flex-direction:column;gap:.1rem}.stat__num{font-size:1.5rem;font-weight:800;color:var(--accent);letter-spacing:-.04em}.stat__label{font-size:.7rem;color:var(--text-muted);font-family:var(--font-mono)}.stat-divider{width:1px;height:36px;background:var(--border-color)}.hero__scroll-hint{position:absolute;bottom:2rem;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:.5rem}.hero__scroll-line{width:1px;height:40px;background:linear-gradient(180deg,var(--accent) 0%,transparent 100%);animation:scroll-line 1.8s ease-in-out infinite}@keyframes scroll-line{0%{opacity:0;transform:scaleY(0);transform-origin:top}50%{opacity:1;transform:scaleY(1)}to{opacity:0}}@media(max-width:900px){.hero__inner{grid-template-columns:1fr}.hero__visual{display:none}.hero{padding-top:8rem}}@media(max-width:480px){.hero__actions{flex-direction:column}.hero__actions .btn{width:100%;justify-content:center}}.about__content{display:flex;flex-direction:column;gap:3rem}.about__text{display:flex;flex-direction:column;gap:1.5rem;max-width:800px}.about__paragraph p{color:var(--text-secondary);line-height:1.85;font-size:.975rem}.about__paragraph strong{color:var(--text-primary);font-weight:600}.about__paragraph em{color:var(--accent);font-style:normal}.about__cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;align-items:stretch}.about__info-list{display:flex;flex-direction:column;gap:.85rem}.about__info-list li{display:flex;flex-direction:column;gap:.15rem}.about__info-key{font-family:var(--font-mono);font-size:.65rem;color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase}.about__info-val{font-size:.875rem;color:var(--text-secondary);font-weight:500}.about__focus-list{display:flex;flex-direction:column;gap:.6rem}.about__focus-list li{display:flex;align-items:center;gap:.6rem;font-size:.85rem;color:var(--text-secondary)}.about__focus-bullet{color:var(--accent);font-family:var(--font-mono);font-size:.75rem;flex-shrink:0}.stack__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-bottom:2rem}.stack__card{padding:1.75rem}.stack__card-header{display:flex;align-items:center;gap:.6rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.stack__icon{font-size:1rem;color:var(--accent);line-height:1}.stack__category{font-weight:700;font-size:.9rem;color:var(--text-primary);letter-spacing:-.01em}.stack__items{display:flex;flex-direction:column;gap:.65rem}.stack__item{display:flex;align-items:center;justify-content:space-between}.stack__item-name{font-size:.85rem;color:var(--text-secondary)}.stack__level{font-family:var(--font-mono);font-size:.65rem;letter-spacing:.04em;font-weight:500}.stack__disclaimer{font-size:.7rem;color:var(--text-muted);text-align:center;margin-top:.5rem}@media(max-width:768px){.stack__grid{grid-template-columns:1fr}}.projects__list{display:flex;flex-direction:column;gap:1.5rem}.project-card{padding:2rem}.project-card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.75rem;flex-wrap:wrap}.project-card__num{font-size:.7rem;color:var(--accent);display:block;margin-bottom:.3rem;letter-spacing:.06em}.project-card__name{font-size:1.2rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em;line-height:1.3}.project-card__links{display:flex;flex-wrap:wrap;gap:.5rem;flex-shrink:0}.project-card__body{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-color)}.project-card__key{display:block;font-family:var(--font-mono);font-size:.65rem;color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase;margin-bottom:.5rem}.project-card__text{font-size:.875rem;color:var(--text-secondary);line-height:1.7}.project-card__highlights{margin-bottom:1.5rem}.project-card__hl-list{margin-top:.6rem;display:flex;flex-direction:column;gap:.4rem}.project-card__hl-list li{font-size:.85rem;color:var(--text-secondary);line-height:1.6}.project-card__footer{padding-top:1rem;border-top:1px solid var(--border-color)}.project-card__stack{display:flex;flex-wrap:wrap;gap:.4rem}@media(max-width:768px){.project-card__body{grid-template-columns:1fr}.project-card__header{flex-direction:column;gap:1rem}}.experience__list{display:flex;flex-direction:column;gap:1.25rem}.exp-card{display:grid;grid-template-columns:180px 1fr;gap:2rem}.exp-card__aside{display:flex;flex-direction:column;gap:.4rem;padding-top:.15rem}.exp-card__year{font-size:.75rem;color:var(--text-muted);letter-spacing:.04em}.exp-card__type{font-size:.7rem;font-family:var(--font-mono);color:var(--accent);background:var(--accent-muted);border:1px solid var(--accent-border);padding:.15rem .5rem;border-radius:4px;width:fit-content}.exp-card__role{font-size:1rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em;margin-bottom:.2rem}.exp-card__org{font-size:.825rem;color:var(--text-muted);margin-bottom:1rem;font-family:var(--font-mono)}.exp-card__desc{display:flex;flex-direction:column;gap:.5rem}.exp-card__desc li{display:flex;gap:.5rem;align-items:flex-start;font-size:.875rem;color:var(--text-secondary);line-height:1.65}.exp-card__desc li span{flex-shrink:0;margin-top:.05rem}@media(max-width:768px){.exp-card{grid-template-columns:1fr;gap:.75rem}}.contact__inner{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}.contact__channels{display:flex;flex-direction:column}.contact__cards{display:flex;flex-direction:column;gap:.6rem;margin-bottom:1.25rem}.contact-card{display:flex;align-items:center;gap:1rem;padding:.9rem 1.25rem;text-decoration:none;color:inherit;transition:border-color var(--transition),background var(--transition),transform var(--transition)}.contact-card:hover{border-color:var(--accent-border);background:var(--accent-muted);transform:translate(4px)}.contact-card__label{font-size:.6rem;color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase;width:68px;flex-shrink:0}.contact-card__value{flex:1;font-size:.85rem;color:var(--text-primary);font-weight:500;word-break:break-all}.contact-card__value.mono{font-family:var(--font-mono);font-size:.775rem}.contact-card__arrow{font-family:var(--font-mono);color:var(--text-muted);font-size:.8rem;opacity:0;transition:opacity var(--transition),color var(--transition);flex-shrink:0}.contact-card:hover .contact-card__arrow{opacity:1;color:var(--accent)}.contact__wa-btn{width:100%;justify-content:center;gap:.6rem}.contact-form{display:flex;flex-direction:column;gap:1.1rem;padding:1.75rem}.contact-form__group{display:flex;flex-direction:column;gap:.35rem}.contact-form__label{font-size:.72rem;font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase}.contact-form__input{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;padding:.65rem .9rem;font-size:.875rem;font-family:var(--font-sans);color:var(--text-primary);outline:none;transition:border-color var(--transition),box-shadow var(--transition);width:100%}.contact-form__input::placeholder{color:var(--text-muted);font-size:.825rem}.contact-form__input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-muted)}.contact-form__input:disabled{opacity:.5;cursor:not-allowed}.contact-form__textarea{resize:vertical;min-height:120px;font-family:var(--font-sans)}.contact-form__feedback{font-size:.825rem;padding:.65rem .9rem;border-radius:6px;font-weight:500}.contact-form__feedback--error{background:#ef444414;border:1px solid rgba(239,68,68,.2);color:#f87171}.contact-form__feedback--success{background:var(--green-muted);border:1px solid rgba(16,185,129,.25);color:var(--green)}@media(max-width:900px){.contact__inner{grid-template-columns:1fr;gap:2rem}}.cert-page{padding-top:5.5rem;padding-bottom:5rem;min-height:100vh}.cert-page__back{margin-bottom:2.5rem}.cert-page__header{margin-bottom:3rem}.cert-card{margin-bottom:2rem}.cert-card__body{display:grid;grid-template-columns:1fr 380px;gap:2.5rem;align-items:start}.cert-card__info{display:flex;flex-direction:column;gap:1.25rem}.cert-card__title{font-size:1.4rem;font-weight:800;color:var(--text-primary);letter-spacing:-.03em;margin-bottom:.3rem}.cert-card__issuer{font-size:.875rem;color:var(--text-secondary)}.cert-card__issuer strong{color:var(--text-primary)}.cert-card__meta{display:flex;gap:2rem}.cert-meta-item{display:flex;flex-direction:column;gap:.15rem}.cert-meta-label{font-size:.65rem;color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase}.cert-meta-val{font-size:.9rem;font-weight:600;color:var(--text-primary)}.cert-card__desc{font-size:.9rem;color:var(--text-secondary);line-height:1.8}.cert-card__actions{display:flex;gap:.75rem}.cert-card__image-wrap{border-radius:8px;overflow:hidden;border:1px solid var(--border-color)}.cert-card__image{width:100%;height:auto;display:block}.cert-page__note{font-size:.7rem;color:var(--text-muted);text-align:center;margin-top:1rem}@media(max-width:900px){.cert-card__body{grid-template-columns:1fr}}.project-detail{padding-top:5.5rem;padding-bottom:5rem;min-height:100vh}.project-detail__container{max-width:860px}.project-detail__back{margin-bottom:2rem}.project-detail__header{margin-bottom:3.5rem;padding-bottom:2.5rem;border-bottom:1px solid var(--border-color)}.project-detail__meta{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1rem}.project-detail__title{font-size:clamp(1.6rem,3.5vw,2.2rem);font-weight:800;color:var(--text-primary);letter-spacing:-.03em;line-height:1.2;margin-bottom:1rem}.project-detail__lead{font-size:1rem;color:var(--text-secondary);line-height:1.8;max-width:680px;margin-bottom:1.5rem}.project-detail__links{display:flex;flex-wrap:wrap;gap:.75rem}.pd-section{padding:2.5rem 0;border-bottom:1px solid var(--border-color)}.pd-section--last{border-bottom:none}.pd-section__title{display:flex;align-items:center;gap:.75rem;font-size:1.2rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em;margin-bottom:1.75rem}.pd-section__num{font-size:.7rem;color:var(--accent);letter-spacing:.06em;background:var(--accent-muted);border:1px solid var(--accent-border);padding:.2rem .5rem;border-radius:4px}.pd-block{margin-bottom:1.75rem}.pd-block:last-child{margin-bottom:0}.pd-block__heading{font-size:.85rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em;margin-bottom:.65rem;padding-bottom:.4rem;border-bottom:1px solid var(--border-color)}.pd-block p{font-size:.9rem;color:var(--text-secondary);line-height:1.8}.pd-block p strong{color:var(--text-primary)}.pd-block p code,.pd-block li code{font-family:var(--font-mono);font-size:.8rem;background:var(--bg-card);border:1px solid var(--border-color);padding:.1rem .35rem;border-radius:3px;color:var(--accent)}.pd-list{display:flex;flex-direction:column;gap:.55rem;padding-left:0}.pd-list li{font-size:.875rem;color:var(--text-secondary);line-height:1.7;padding-left:1rem;position:relative}.pd-list li:before{content:"›";position:absolute;left:0;color:var(--accent);font-family:var(--font-mono)}.pd-list li strong{color:var(--text-primary);font-weight:600}.pd-code-block{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;overflow:auto}.pd-code-block pre{font-family:var(--font-mono);font-size:.775rem;color:var(--text-secondary);line-height:1.7;padding:1.25rem 1.5rem;white-space:pre;overflow-x:auto;margin:0}.pd-arch-diagram{display:flex;flex-direction:column;align-items:flex-start;gap:0;max-width:540px;border:1px solid var(--border-color);border-radius:10px;overflow:hidden}.pd-arch-node{display:flex;flex-direction:column;width:100%;padding:1rem 1.5rem;border-bottom:1px solid var(--border-color)}.pd-arch-node:last-of-type{border-bottom:none}.pd-arch-node--client{background:var(--bg-secondary)}.pd-arch-node--server{background:#3b82f60d}.pd-arch-node--app{background:#10b9810d}.pd-arch-node--db{background:#f59e0b0d}.pd-arch-label{font-family:var(--font-mono);font-size:.8rem;font-weight:600;color:var(--text-primary);margin-bottom:.2rem}.pd-arch-desc{font-size:.775rem;color:var(--text-muted)}.pd-arch-arrow{font-family:var(--font-mono);font-size:.75rem;color:var(--accent);padding:.3rem 1.5rem;background:var(--bg-card);border-bottom:1px solid var(--border-color);width:100%}.pd-arch-note{padding:.6rem 1.5rem;background:var(--bg-card);width:100%}.pd-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:1.75rem}.pd-table-wrap{overflow-x:auto;border-radius:8px;border:1px solid var(--border-color);margin-top:.75rem}.pd-table{width:100%;border-collapse:collapse;font-size:.85rem}.pd-table th{text-align:left;padding:.75rem 1rem;font-size:.7rem;font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase;background:var(--bg-card);border-bottom:1px solid var(--border-color)}.pd-table td{padding:.7rem 1rem;color:var(--text-secondary);border-bottom:1px solid var(--border-color);vertical-align:middle}.pd-table tr:last-child td{border-bottom:none}.pd-table td code{font-family:var(--font-mono);font-size:.775rem;background:var(--bg-secondary);border:1px solid var(--border-color);padding:.1rem .35rem;border-radius:3px;color:var(--accent)}.pd-priority{font-family:var(--font-mono);font-size:.7rem;font-weight:600;letter-spacing:.04em}.pd-priority--high{color:#f87171}.pd-priority--medium{color:#fbbf24}.pd-priority--low{color:var(--green)}.project-detail__footer{display:flex;gap:.75rem;padding-top:2.5rem;border-top:1px solid var(--border-color);margin-top:1rem}@media(max-width:768px){.pd-grid-2{grid-template-columns:1fr}.pd-arch-diagram{max-width:100%}}
