@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Source+Sans+3:wght@300;400;500;600&display=swap";*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #1b3c6b;--primary-dark: #142a4d;--secondary: #0f766e;--accent: #f59e0b;--success: #16a34a;--bg-body: #f2f5fb;--bg-card: #ffffff;--bg-alt: #e8edf5;--bg-soft: #f9fbff;--bg-gradient-start: #e9efff;--bg-gradient-end: #f2f5fb;--text-main: #0f172a;--text-muted: #4b5563;--text-light: #94a3b8;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .06);--shadow: 0 8px 20px rgba(15, 23, 42, .08);--shadow-lg: 0 16px 40px rgba(15, 23, 42, .12);--radius: 14px}[data-theme=dark]{--primary: #8ab4f8;--primary-dark: #6b9cf3;--secondary: #2dd4bf;--bg-body: #0a1220;--bg-card: #101b2f;--bg-alt: #1b2742;--bg-soft: #0f1a2b;--bg-gradient-start: #111b2d;--bg-gradient-end: #0a1220;--text-main: #e2e8f0;--text-muted: #b0bdd1;--text-light: #94a3b8;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--shadow: 0 8px 24px rgba(0, 0, 0, .5);--shadow-lg: 0 18px 42px rgba(0, 0, 0, .6)}body{font-family:"Source Sans 3",Segoe UI,sans-serif;background:radial-gradient(circle at top,var(--bg-gradient-start) 0%,var(--bg-gradient-end) 58%);color:var(--text-main);line-height:1.7;letter-spacing:.1px;overflow-x:hidden;transition:background-color .3s ease,color .3s ease}h1,h2,h3,.logo,.section-title{font-family:Space Grotesk,Segoe UI,sans-serif;letter-spacing:-.5px}.app-container{background-image:radial-gradient(circle at 12% 8%,color-mix(in srgb,var(--primary) 16%,transparent),transparent 45%),radial-gradient(circle at 88% 12%,color-mix(in srgb,var(--secondary) 14%,transparent),transparent 42%)}.navbar{position:fixed;top:0;width:100%;background:color-mix(in srgb,var(--bg-card) 92%,transparent);border-bottom:1px solid color-mix(in srgb,var(--bg-alt) 80%,transparent);z-index:1000;padding:.85rem 0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease}.navbar.scrolled{box-shadow:var(--shadow-sm)}.nav-container{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;padding:0 2rem}.nav-right{display:flex;align-items:center;gap:2rem}.mobile-menu-btn{display:none;background:none;border:1px solid var(--bg-alt);color:var(--text-main);width:38px;height:38px;border-radius:8px;cursor:pointer}.logo{font-size:1.6rem;font-weight:700;color:var(--primary);text-decoration:none}.nav-menu{display:flex;list-style:none;gap:2rem}.nav-link{color:var(--text-muted);text-decoration:none;font-weight:500;font-size:.95rem;transition:color .2s ease;cursor:pointer}.nav-link:hover{color:var(--primary)}.nav-controls{display:flex;align-items:center;gap:1rem;border-left:1px solid var(--bg-alt);padding-left:1.5rem}.icon-btn{background:none;border:none;color:var(--text-muted);font-size:1.1rem;cursor:pointer;padding:.5rem;border-radius:50%;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.icon-btn:hover{background:var(--bg-alt);color:var(--primary)}.text-btn{background:none;border:1px solid var(--bg-alt);color:var(--text-main);font-size:.85rem;font-weight:600;cursor:pointer;padding:.25rem .5rem;border-radius:4px;transition:all .2s ease;min-width:2.5rem}.text-btn:hover{border-color:var(--primary);color:var(--primary)}.hero{min-height:86vh;display:flex;align-items:center;padding-top:80px;background:transparent}.hero-grid{max-width:1200px;margin:0 auto;padding:0 2rem;display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}.hero-content h1{font-size:clamp(2.5rem,4vw,3.5rem);font-weight:800;color:var(--text-main);margin-bottom:1rem;line-height:1.2}.hero-subtitle{font-size:1.15rem;color:var(--secondary);font-weight:600;margin-bottom:1.5rem;display:block}.hero-description{font-size:1.05rem;color:var(--text-muted);margin-bottom:2rem;max-width:500px}.btn-group{display:flex;gap:1rem}.btn{padding:.75rem 1.4rem;border-radius:999px;font-weight:600;text-decoration:none;transition:all .2s ease;display:inline-flex;align-items:center;gap:.5rem;font-size:.95rem;cursor:pointer;border:none}.btn-primary{background:var(--primary);color:#fff;border:1px solid var(--primary);box-shadow:0 10px 24px #1b3c6b33}.btn-primary:hover{background:var(--primary-dark);border-color:var(--primary-dark)}.btn-secondary{background:var(--bg-card);color:var(--text-main);border:1px solid var(--bg-alt)}.btn-secondary:hover{background:var(--bg-alt);border-color:var(--text-muted)}.btn-ghost{background:transparent;color:var(--text-main);border:1px solid color-mix(in srgb,var(--primary) 25%,transparent)}.btn-ghost:hover{border-color:var(--primary);color:var(--primary)}.hero-visual{display:flex;justify-content:center}.hero-card{background:linear-gradient(160deg,var(--bg-card),var(--bg-soft));padding:2rem;border-radius:20px;box-shadow:var(--shadow-lg);border:1px solid var(--bg-alt);max-width:380px;width:100%;text-align:left}.hero-card-title{font-size:1.1rem;font-weight:700;margin-bottom:1rem}.hero-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem}.metric-value{display:block;font-size:1.4rem;font-weight:700;color:var(--primary)}.metric-label{font-size:.85rem;color:var(--text-muted)}.hero-card-note{font-size:.95rem;color:var(--text-muted)}.section{padding:5rem 2rem;max-width:1160px;margin:0 auto}.section-alt{background:linear-gradient(135deg,var(--bg-soft),var(--bg-alt));border:1px solid color-mix(in srgb,var(--bg-alt) 70%,transparent);border-radius:18px;box-shadow:var(--shadow-sm)}.section-header{text-align:center;margin-bottom:3.5rem}.section-title{font-size:2.2rem;font-weight:700;color:var(--text-main);margin-bottom:.5rem}.section-subtitle{color:var(--text-muted);font-size:1.05rem}.reveal{opacity:0;transform:translateY(18px)}.reveal.is-visible{opacity:1;transform:translateY(0);transition:opacity .6s ease,transform .6s ease}.about-grid{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,.8fr);gap:2rem}.about-card{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--bg-alt);padding:2rem;box-shadow:var(--shadow);text-align:left}.about-card h3{font-size:1.4rem;margin-bottom:.75rem}.about-card p{color:var(--text-muted);margin-bottom:1.5rem}.about-actions{display:flex;flex-wrap:wrap;gap:.75rem}.about-panel{background:var(--bg-soft);border-radius:var(--radius);border:1px solid var(--bg-alt);padding:2rem;text-align:left}.about-panel-title{font-weight:700;margin-bottom:1rem}.about-tags{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:1.5rem}.tag{background:var(--bg-card);border:1px solid var(--bg-alt);border-radius:999px;padding:.35rem .85rem;font-size:.85rem;font-weight:600}.about-highlights{display:flex;flex-direction:column;gap:.75rem}.about-highlight{display:flex;gap:.75rem;align-items:center;color:var(--text-muted);font-size:.95rem}.about-highlight i{color:var(--secondary)}.skills-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:2rem}.skill-category{background:var(--bg-card);padding:1.75rem;border-radius:var(--radius);border:1px solid var(--bg-alt);box-shadow:var(--shadow-sm)}.skill-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.skill-icon{width:40px;height:40px;background:var(--bg-alt);color:var(--primary);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.2rem}.skill-title{font-weight:700;font-size:1.1rem;color:var(--text-main)}.skill-items{display:flex;flex-wrap:wrap;gap:.75rem}.skill-item{background:var(--bg-alt);padding:.5rem 1rem;border-radius:4px;font-size:.9rem;color:var(--text-main);font-weight:500;display:flex;align-items:center;gap:.5rem}.skill-item.strong{background:color-mix(in srgb,var(--primary) 12%,transparent);color:var(--primary);border:1px solid color-mix(in srgb,var(--primary) 18%,transparent)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem}.project-card{background:var(--bg-card);border-radius:16px;border:1px solid var(--bg-alt);overflow:hidden;display:block;transition:transform .2s ease,box-shadow .2s ease}.project-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.project-card-interactive{height:100%;display:flex;flex-direction:column}.project-card-link{cursor:pointer}.project-card-link:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.project-header{padding:1.4rem;background:linear-gradient(120deg,var(--bg-alt),var(--bg-soft));border-bottom:1px solid var(--bg-alt);display:flex;justify-content:space-between;align-items:center}.project-icon{color:var(--text-main);font-size:1.2rem}.project-status{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;font-weight:700;padding:.25rem .5rem;border-radius:4px}.status-complete{background:#16a34a1f;color:#166534;border:1px solid rgba(22,163,74,.2)}.status-featured{background:#f59e0b29;color:#b45309;border:1px solid rgba(245,158,11,.3)}.status-progress{background:#1b3c6b1f;color:var(--primary);border:1px solid rgba(27,60,107,.2)}.status-soon{background:#0f766e1f;color:#0f766e;border:1px solid rgba(15,118,110,.25)}.project-content{padding:1.6rem;display:flex;flex-direction:column;gap:1rem;height:100%}.project-title{font-size:1.25rem;font-weight:700;margin-bottom:0;color:var(--text-main)}.project-description{color:var(--text-muted);font-size:.95rem;margin-bottom:0}.project-tech{display:flex;flex-wrap:wrap;gap:.5rem}.tech-tag{font-size:.8rem;color:var(--text-muted);background:var(--bg-alt);padding:.25rem .75rem;border-radius:20px}.project-actions{margin-top:auto;display:flex;flex-wrap:wrap;gap:.6rem}.project-action{display:inline-flex;align-items:center;gap:.45rem;text-decoration:none;padding:.5rem .85rem;border-radius:999px;background:var(--bg-alt);color:var(--text-main);border:1px solid var(--bg-alt);font-size:.85rem;font-weight:700;transition:all .2s ease}.project-action.primary{background:var(--primary);color:#fff;border-color:var(--primary)}.project-action:hover{transform:translateY(-1px)}.project-action.muted{background:transparent;border:1px dashed var(--bg-alt);color:var(--text-light)}.certifications-compact{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,.85fr);gap:1.75rem;align-items:start}.cert-summary{background:linear-gradient(150deg,var(--bg-card),var(--bg-soft));border:1px solid color-mix(in srgb,var(--bg-alt) 80%,transparent);border-radius:var(--radius);padding:1.6rem;box-shadow:var(--shadow);text-align:left;display:flex;flex-direction:column;gap:1rem}.cert-summary-header{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:1.25rem}.cert-summary-title{font-size:1.3rem;font-weight:700;color:var(--text-main)}.cert-summary-meta{display:flex;gap:.6rem;color:var(--text-muted);font-size:.9rem;font-weight:600}.cert-summary-image{width:150px;height:auto;border-radius:14px;background:var(--bg-card);border:1px solid var(--bg-alt);padding:.4rem;box-shadow:var(--shadow-sm)}.cert-summary-desc{color:var(--text-muted);font-size:.98rem}.cert-summary-actions{display:flex;flex-wrap:wrap;gap:.75rem}.cert-badges-compact{background:var(--bg-card);border:1px solid var(--bg-alt);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:1.1rem}.cert-badges-header h3{font-size:1.15rem;margin-bottom:.25rem}.cert-badges-header p{color:var(--text-muted);font-size:.92rem}.cert-badges-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.85rem}.cert-badges-grid.compact{grid-template-columns:repeat(2,minmax(0,1fr))}.badge-chip{display:grid;grid-template-columns:44px 1fr;align-items:center;gap:.75rem;padding:.7rem .8rem;border-radius:12px;background:var(--bg-soft);border:1px solid color-mix(in srgb,var(--bg-alt) 85%,transparent);box-shadow:var(--shadow-sm);font-size:.88rem;font-weight:600;color:var(--text-main)}.badge-chip img{width:40px;height:40px;object-fit:contain;background:var(--bg-card);border-radius:10px;padding:.3rem;border:1px solid var(--bg-alt)}.certifications-page{display:grid;gap:2.5rem;margin-top:3rem}.cert-page-card{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);gap:2rem;align-items:center;background:var(--bg-card);border:1px solid var(--bg-alt);border-radius:var(--radius);padding:1.8rem;box-shadow:var(--shadow)}.cert-media{background:var(--bg-alt);padding:1.25rem;border-radius:14px;display:flex;justify-content:center}.cert-media img{width:min(100%,420px);height:auto;border-radius:12px;box-shadow:var(--shadow-sm);background:var(--bg-card)}.cert-body{display:flex;flex-direction:column;gap:1rem;text-align:left}.cert-body h2{font-size:1.5rem;color:var(--text-main)}.cert-body p{color:var(--text-muted);font-size:1rem}.cert-meta{display:flex;flex-wrap:wrap;gap:.5rem}.cert-tag{background:var(--bg-alt);color:var(--text-muted);font-size:.8rem;padding:.35rem .75rem;border-radius:999px;font-weight:600}.cert-badges-full{background:var(--bg-card);border:1px solid var(--bg-alt);border-radius:var(--radius);padding:1.8rem;box-shadow:var(--shadow-sm)}.cert-badges-grid.full{grid-template-columns:repeat(2,minmax(0,1fr))}.badge-card.full{background:var(--bg-body);border:1px solid var(--bg-alt);border-radius:var(--radius);padding:1.3rem;text-align:left;box-shadow:none;display:flex;flex-direction:column;gap:.75rem}.badge-image{background:var(--bg-alt);border-radius:12px;padding:.75rem;display:flex;justify-content:center;align-items:center;width:fit-content}.badge-image img{width:120px;height:auto}.badge-title{font-size:1rem;font-weight:700;color:var(--text-main)}.badge-desc{color:var(--text-muted);font-size:.92rem}.project-details-hero{text-align:center;margin-top:4rem}.project-details-grid{display:grid;grid-template-columns:minmax(0,2fr) minmax(280px,1fr);gap:3rem;margin-top:3rem;align-items:start}.details-content,.details-sidebar{min-width:0}.project-image-placeholder{background:var(--bg-alt);height:300px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;margin-bottom:2rem}.info-card{background:var(--bg-card);padding:1.5rem;border-radius:var(--radius);border:1px solid var(--bg-alt)}.timeline{max-width:800px;margin:0 auto;position:relative;padding-left:2rem;border-left:2px solid var(--bg-alt)}.timeline-item{margin-bottom:3rem;position:relative}.timeline-item:before{content:"";position:absolute;left:-2.6rem;top:.25rem;width:1rem;height:1rem;background:var(--bg-card);border:3px solid var(--primary);border-radius:50%}.timeline-date{font-size:.9rem;color:var(--primary);font-weight:600;margin-bottom:.25rem}.timeline-title{font-size:1.2rem;font-weight:700;margin-bottom:.25rem;color:var(--text-main)}.timeline-subtitle{font-size:1rem;color:var(--text-muted);margin-bottom:1rem}.timeline-content p{color:var(--text-muted);font-size:.95rem}.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem}.contact-item{display:flex;align-items:flex-start;gap:1rem;margin-bottom:2rem}.contact-icon{width:42px;height:42px;background:var(--bg-alt);color:var(--primary);border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.contact-label{font-size:.85rem;color:var(--text-light);font-weight:600;text-transform:uppercase;margin-bottom:.25rem}.contact-value{font-size:1rem;color:var(--text-main);font-weight:500}.contact-form{background:var(--bg-card);padding:2rem;border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--bg-alt)}.form-group{margin-bottom:1.5rem}.form-label{display:block;margin-bottom:.5rem;font-weight:500;font-size:.9rem;color:var(--text-main)}.form-input{width:100%;padding:.75rem;background:var(--bg-body);border:1px solid var(--bg-alt);border-radius:10px;font-family:inherit;color:var(--text-main);transition:border-color .2s}.form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.form-textarea{min-height:120px;resize:vertical}.footer{padding:2.5rem 2rem 2rem;color:var(--text-light);font-size:.9rem;border-top:1px solid var(--bg-alt);margin-top:4rem}.footer-content{max-width:1160px;margin:0 auto 1.5rem;display:flex;justify-content:space-between;align-items:center;gap:1.5rem;flex-wrap:wrap}.footer-name{font-weight:700;font-size:1.1rem;color:var(--text-main)}.footer-note{color:var(--text-muted);font-size:.9rem}.footer-links{display:flex;gap:1rem;flex-wrap:wrap}.footer-links a{color:var(--text-muted);text-decoration:none;font-weight:600}.footer-links a:hover{color:var(--primary)}.footer-copy{text-align:center}.diagram-shell{background:linear-gradient(135deg,#2563eb0f,#0ea5e90d);border:1px solid var(--bg-alt);border-radius:var(--radius);padding:.9rem;overflow:hidden;margin-bottom:2rem;width:100%;max-width:100%}.diagram-canvas{width:100%;min-width:100%;--zoom: 1;--pan-x: 0px;--pan-y: 0px;touch-action:none}.diagram-canvas .architecture-svg{width:100%;height:auto;min-height:340px;display:block;transform-origin:0 0;transform:translate(var(--pan-x),var(--pan-y)) scale(var(--zoom));transition:transform .16s ease-out;will-change:transform;cursor:zoom-in}.diagram-canvas .architecture-svg text{font-size:14px!important;font-weight:600}.diagram-canvas .architecture-svg .edgePath path,.diagram-canvas .architecture-svg path.flowchart-link{stroke:#0ea5e9!important;stroke-width:2.6px!important}.diagram-canvas .architecture-svg marker path{fill:#0ea5e9!important;stroke:#0ea5e9!important}.diagram-mobile-controls{display:none;margin-top:.85rem;gap:.5rem}.diagram-control-btn{width:34px;height:34px;border:1px solid var(--bg-alt);background:var(--bg-card);color:var(--text-main);border-radius:8px;cursor:pointer}@media(max-width:1024px){.section,.section-alt{padding:4rem 1.5rem}.hero-grid{gap:2.5rem}.about-grid,.certifications-compact,.cert-page-card{grid-template-columns:1fr}.project-details-grid{grid-template-columns:1fr!important;gap:2rem!important}.project-details-hero{margin-top:2.75rem}.project-image-placeholder{height:250px}}@media(max-width:768px){.navbar{padding:.75rem 0}.nav-container{padding:0 1rem;position:relative}.hero-grid{grid-template-columns:1fr;text-align:center;gap:2rem;padding:0 1rem}.section{padding:3.25rem 1rem}.section-title{font-size:1.6rem}.section-subtitle{font-size:1rem}.hero-visual{display:none}.btn-group{justify-content:center}.contact-grid{grid-template-columns:1fr;gap:2rem}.nav-right{gap:1rem}.mobile-menu-btn{display:inline-flex;align-items:center;justify-content:center}.nav-menu{display:none;position:absolute;top:calc(100% + .5rem);left:1rem;right:1rem;background:var(--bg-card);border:1px solid var(--bg-alt);border-radius:10px;box-shadow:var(--shadow-lg);padding:.75rem;gap:.5rem;flex-direction:column;z-index:1001}.nav-menu.open{display:flex}.nav-menu .nav-link{display:block;padding:.65rem .75rem;border-radius:8px;background:var(--bg-body)}.project-details-grid{grid-template-columns:1fr!important}.project-details-hero{margin-top:2rem}.project-image-placeholder{height:220px}.info-card{padding:1.2rem}.projects-grid,.skills-container,.cert-badges-grid.compact,.cert-badges-grid.full{grid-template-columns:1fr}.project-header,.project-content,.skill-category,.contact-form{padding:1.2rem}.about-card,.about-panel{padding:1.5rem}.diagram-canvas{min-width:100%}.diagram-canvas .architecture-svg{min-height:280px}.diagram-mobile-controls{display:inline-flex}}@media(max-width:480px){.logo{font-size:1.2rem}.hero-content h1{font-size:2rem}.hero-subtitle{font-size:1.05rem}.hero-description{font-size:.98rem}.btn-group{flex-direction:column;align-items:stretch}.btn{justify-content:center}.diagram-shell{padding:.65rem}.diagram-canvas{min-width:100%}.cert-summary-header{grid-template-columns:1fr;justify-items:start}.cert-summary-image{width:140px}}
