:root{--bg:#f0f0f1;--surface:#fff;--surface-soft:#f5f5f6;--ink:#2b2e35;--muted:#2b2e35;--slate-400:#7a8787;--slate-300:#a3b0b0;--line:#2b2e351a;--soft-line:#2b2e3512;--accent:#4e5757;--accent-soft:#4e57571f;--warm:#7a8787;--dark:#2b2e35;--dark-deep:#1a1d22;--dot:#2b2e350d;--dot-light:#ffffff0d;--radius:18px;--radius-sm:12px;--shadow:0 18px 48px -24px #1a1d226b;--shadow-soft:0 10px 30px -18px #1a1d2252}*{box-sizing:border-box}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;margin:0;font-family:Manrope,Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:16px;line-height:1.6}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button{font:inherit}main{overflow-x:clip}.site-header{z-index:20;border:1px solid var(--soft-line);width:min(980px,100% - 48px);min-height:42px;box-shadow:var(--shadow-soft);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffffb8;border-radius:12px;justify-content:space-between;align-items:center;gap:18px;margin:16px auto 0;padding:2px 8px;display:flex;position:sticky;top:16px}.brand{letter-spacing:.02em;align-items:center;min-height:38px;padding:0 3px;font-weight:700;display:inline-flex}.brand-mark{background:0 0;border-radius:8px;place-items:center;width:42px;height:42px;display:grid;overflow:visible}.brand-mark img{object-fit:contain;width:38px;height:38px}.header-actions{flex:1;justify-content:flex-end;align-items:center;gap:10px;min-width:0;margin-left:auto;display:flex}.nav-links{color:#25292f;justify-content:center;align-items:center;gap:2px;font-size:.88rem;font-weight:500;display:flex;position:absolute;left:50%;transform:translate(-50%)}.nav-links a{white-space:nowrap;border-radius:8px;align-items:center;min-height:32px;padding:0 10px;transition:color .16s,background .16s;display:inline-flex}.nav-links a:hover,.nav-links a:focus-visible{color:var(--ink);background:var(--surface-soft)}.language-picker{flex-shrink:0;position:relative}.language-trigger{border:1px solid var(--soft-line);background:var(--surface-soft);min-height:36px;color:var(--ink);cursor:pointer;border-radius:8px;grid-template-columns:16px minmax(62px,1fr) 13px;align-items:center;gap:6px;padding:0 8px 0 10px;font-size:.92rem;font-weight:700;display:grid}.language-trigger svg{color:var(--ink)}.language-trigger:hover,.language-trigger:focus-visible{background:#eceeef}.language-chevron{pointer-events:none}.language-menu{z-index:30;border:1px solid var(--soft-line);background:var(--surface);min-width:100%;box-shadow:var(--shadow-soft);border-radius:8px;display:grid;position:absolute;top:calc(100% + 6px);right:0;overflow:hidden}.language-option{min-height:38px;color:var(--ink);cursor:pointer;text-align:left;background:0 0;border:0;padding:0 13px;font-weight:700}.language-option:hover,.language-option:focus-visible,.language-option.active{background:var(--surface-soft)}.language-trigger-label{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.mobile-menu{flex-shrink:0;display:none;position:relative}.mobile-menu-trigger{width:40px;height:40px;color:var(--ink);cursor:pointer;background:0 0;border:0;border-radius:10px;justify-content:center;align-items:center;display:inline-flex}.mobile-menu-panel{z-index:30;border:1px solid var(--soft-line);transform-origin:100% 0;background:#fff;border-radius:18px;flex-direction:column;gap:2px;width:min(320px,100vw - 28px);padding:8px;animation:.22s cubic-bezier(.16,1,.3,1) menuPanelIn;display:flex;position:absolute;top:calc(100% + 10px);right:-2px;box-shadow:0 22px 50px #1a1d2229,0 2px 8px #1a1d220f}.mobile-menu-item{min-height:48px;color:var(--ink);opacity:0;border-radius:12px;justify-content:space-between;align-items:center;padding:12px 14px;font-size:.95rem;font-weight:600;transition:background .16s;animation:.28s cubic-bezier(.16,1,.3,1) forwards menuItemIn;display:flex}.mobile-menu-item svg{color:var(--slate-400);flex-shrink:0}.mobile-menu-item:active{background:#2b2e351a}@media (hover:hover){.mobile-menu-item:hover{background:#2b2e350f}}@keyframes menuPanelIn{0%{opacity:0;transform:translateY(-6px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes menuItemIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion:reduce){.mobile-menu-panel,.mobile-menu-item{opacity:1;animation:none}}.hero{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:56px;width:min(1160px,100% - 48px);min-height:calc(100vh - 96px);margin:0 auto;padding:72px 0 60px;display:grid}.hero-copy{max-width:720px}h1,h2,h3,p{overflow-wrap:anywhere}h1{letter-spacing:0;max-width:760px;margin:0;font-size:clamp(2.7rem,5.6vw,4.6rem);font-weight:800;line-height:1.02}.hero-role{max-width:600px;color:var(--ink);margin:20px 0 0;font-size:clamp(1.1rem,2vw,1.4rem);font-weight:700;line-height:1.25}h2{letter-spacing:0;margin:0;font-size:clamp(1.9rem,4vw,3rem);font-weight:800;line-height:1.05}h3{margin:0;font-size:1.06rem;font-weight:700;line-height:1.25}.hero-intro{max-width:580px;color:var(--muted);margin:18px 0 0;font-size:1.1rem}.hero-intro,.about-intro p,.section-heading p,.experience-text,.credential-list p,.competency-card p,.featured-card p,.category-summary p,.project-body p,.contact p{text-align:justify;text-justify:inter-word;-webkit-hyphens:auto;hyphens:auto}.hero-actions,.about-actions,.contact-actions{flex-wrap:wrap;gap:12px;margin-top:32px;display:flex}.button{border:1px solid var(--line);border-radius:8px;justify-content:center;align-items:center;gap:10px;min-height:50px;padding:0 22px;font-size:.97rem;font-weight:700;transition:transform .16s,box-shadow .16s,background .16s;display:inline-flex}.button:hover{transform:translateY(-1px)}.button.primary{border-color:var(--dark);background:var(--dark);color:#fff;box-shadow:var(--shadow-soft)}.button.secondary{background:var(--surface);color:var(--ink)}.button.secondary:hover{background:var(--surface-soft)}.button.disabled{cursor:not-allowed;opacity:.55}.hero-brand-mark{aspect-ratio:1;opacity:.94;justify-self:end;place-items:center;width:clamp(214px,27vw,360px);display:grid;position:relative;transform:translateY(-18px)}.hero-brand-image{filter:drop-shadow(0 22px 28px #1a1d2214);width:100%!important;height:auto!important}.section{border-top:1px solid var(--soft-line);padding:92px max(24px,50vw - 580px)}.section-heading{max-width:820px;margin-bottom:40px}.section-heading.compact{max-width:920px}.section-heading p{color:var(--muted);margin:16px 0 0;font-size:1.04rem}.about-section{background:var(--surface);grid-template-columns:minmax(0,1fr) minmax(280px,.46fr);align-items:start;gap:56px;display:grid}.about-intro{max-width:720px}.about-intro p{color:var(--muted);margin:22px 0 0;font-size:1.06rem}.about-aside{gap:10px;margin-top:72px;display:grid}.about-photo-card{border:1px solid var(--soft-line);background:var(--bg);border-radius:10px;justify-self:start;width:min(100%,330px);padding:9px}.about-photo-frame{aspect-ratio:1;background:#fff;border:1px solid #2b2e3514;border-radius:7px;display:block;position:relative;overflow:hidden}.about-photo-frame img{object-fit:cover;object-position:center center;transform:translateY(24px)scale(1.12)}.about-panel{box-sizing:border-box;border:1px solid var(--soft-line);border-radius:var(--radius);background:var(--surface);justify-self:start;width:min(100%,330px);padding:16px 18px}.about-panel h3{letter-spacing:.05em;text-transform:uppercase;color:var(--accent);margin-bottom:12px;font-size:.82rem;font-weight:700}.interest-list{gap:8px;margin:0;padding:0;list-style:none;display:grid}.interest-list li{box-sizing:border-box;border:0;border:1px solid var(--soft-line);background:var(--surface-soft);width:100%;color:var(--ink);text-align:justify;text-justify:inter-word;-webkit-hyphens:auto;hyphens:auto;border-radius:8px;padding:8px 12px;font-size:.92rem;font-weight:600;line-height:1.28;position:relative;overflow:hidden}.interest-list li:before{content:none}.location{border:1px solid var(--soft-line);background:var(--surface-soft);width:fit-content;color:var(--ink);border-radius:8px;align-items:center;gap:8px;margin-top:47px;padding:9px 14px;font-size:.94rem;font-weight:600;display:inline-flex}.location svg{color:var(--accent)}.about-actions{margin-top:47px}.experience-section{background:var(--surface-soft)}.education-section{background:var(--surface)}.experience-list{gap:16px;display:grid}.experience-card{border:1px solid var(--soft-line);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow-soft);padding:28px}.experience-head{grid-template-columns:auto minmax(0,1fr) auto;align-items:start;gap:8px 18px;display:grid}.experience-headline{min-width:0}.experience-head h3{font-size:1.2rem}.experience-company{color:var(--ink);margin:6px 0 0;font-weight:600}.experience-period{color:var(--muted);white-space:nowrap;font-size:.88rem;font-weight:600}.experience-location{color:var(--muted);margin:12px 0 0;font-size:.9rem}.brand-logo{border:1px solid var(--soft-line);background:var(--surface-soft);border-radius:10px;flex-shrink:0;place-items:center;width:52px;height:52px;display:grid;overflow:hidden}.brand-logo img{object-fit:cover;border-radius:9px;width:100%;height:100%}.brand-logo-fallback{letter-spacing:.02em;color:var(--muted);font-size:.82rem;font-weight:800}.experience-text{color:var(--muted);margin:16px 0 0;font-size:1rem;line-height:1.6}.education-tfg strong{color:var(--ink);font-weight:800}.experience-skill-block{margin:34px 0 8px}.experience-skill-block h4{color:var(--ink);letter-spacing:.04em;text-transform:uppercase;margin:0 0 22px;font-size:.78rem;font-weight:800}.experience-skill-groups{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.experience-skill-group{border:1px solid var(--soft-line);border-radius:var(--radius-sm);background:var(--surface-soft);padding:16px}.experience-skill-group h5{color:var(--ink);margin:0 0 18px;font-size:.88rem;font-weight:800;line-height:1.25}.experience-skill-group .skill-list{justify-content:flex-start;margin-top:0}.credentials-section{background:var(--surface-soft)}.credentials-grid{grid-template-columns:minmax(0,.82fr) minmax(300px,.58fr);gap:16px;display:grid}.credential-panel{border:1px solid var(--soft-line);border-radius:var(--radius);background:var(--surface-soft);padding:26px}.credential-list,.language-list{gap:12px;margin-top:20px;display:grid}.credential-list article,.language-list article{border:1px solid var(--soft-line);border-radius:var(--radius-sm);background:var(--surface);padding:16px}.credential-list article{grid-template-columns:auto minmax(0,1fr);align-items:start;gap:14px;display:grid}.credential-body{min-width:0}.credential-list strong,.language-list strong{font-weight:700;line-height:1.3;display:block}.credential-list span,.language-list span,.credential-list p{color:var(--muted);margin:8px 0 0;font-size:.92rem;display:block}.language-row{flex-direction:column;gap:4px;display:flex}.language-head{align-items:center;gap:10px;display:flex}.language-list .language-flags{align-items:center;gap:6px;margin:0;display:inline-flex}.language-flag{border:1px solid #2b2e351f;border-radius:3px;width:auto;height:20px;display:block}.language-list .language-level{margin:0}.competencies-section{background:var(--surface-soft)}.competency-layout{gap:18px;display:grid}.competency-list{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;display:grid}.competency-card{border:1px solid var(--soft-line);border-radius:var(--radius);background:var(--surface);min-height:190px;padding:26px;transition:transform .18s,box-shadow .18s}.competency-card:hover{box-shadow:var(--shadow-soft);transform:translateY(-3px)}.competency-card svg{background:var(--accent-soft);color:var(--accent);box-sizing:content-box;border-radius:12px;padding:9px;display:grid}.competency-card h3{margin-top:20px}.competency-card p{color:var(--muted);margin:12px 0 0}.tech-panel{grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;display:grid}.tech-group{border:1px solid var(--soft-line);border-radius:var(--radius);background:var(--surface);padding:24px;box-shadow:0 18px 38px -34px #1a1d2273}.tech-group h3{color:var(--ink);margin-bottom:16px;font-size:.95rem;font-weight:700}.skill-list{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.skill-list span{min-height:30px;color:var(--muted);letter-spacing:0;text-align:center;background:#fff;border:1px solid #2b2e351a;border-radius:8px;justify-content:center;align-items:center;padding:0 10px;font-size:.75rem;font-weight:700;line-height:1;display:inline-flex;box-shadow:0 10px 24px -22px #1a1d2280}.tech-list{flex-wrap:wrap;gap:8px;display:flex}.tech-list span{border:1px solid var(--soft-line);background:var(--surface-soft);min-height:31px;color:var(--muted);letter-spacing:0;border-radius:8px;align-items:center;padding:6px 10px;font-size:.84rem;font-weight:600;display:inline-flex}.top-skill-list{color:var(--ink);flex-wrap:wrap;margin:0;padding:0;font-weight:600;line-height:1.7;list-style:none;display:flex}.top-skill-list li{align-items:center;display:inline-flex}.top-skill-list li:not(:last-child):after{content:"•";color:var(--slate-300);margin:0 10px}.featured{background:var(--dark-deep);color:#fff}.featured .section-heading p{color:#ffffffa8}.featured-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;display:grid}.featured-card{border-radius:var(--radius);background:#ffffff0d;border:1px solid #ffffff1f;transition:transform .18s,background .18s;display:grid;position:relative;overflow:hidden}.featured-card:hover{background:#ffffff14;transform:translateY(-3px)}.featured-card-body{color:inherit;padding:20px;display:block;position:relative}.featured-meta{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:10px;display:flex}.featured-category-chip{color:#14181a;letter-spacing:.04em;text-transform:uppercase;background:#fff;border-radius:6px;align-items:center;min-height:26px;padding:0 9px;font-size:.74rem;font-weight:700;display:inline-flex}.featured-card h3{margin-top:0}.featured-card p{color:#ffffffad;margin:11px 0 0}.projects-section{background:var(--surface)}.category-jump{flex-wrap:wrap;gap:10px;margin-bottom:40px;display:flex}.category-pill{border:1px solid var(--soft-line);background:var(--surface-soft);min-height:44px;color:var(--ink);border-radius:8px;justify-content:center;align-items:center;gap:9px;padding:0 15px;font-size:.92rem;font-weight:700;transition:transform .16s,box-shadow .16s;display:inline-flex}.category-pill:hover{box-shadow:var(--shadow-soft);transform:translateY(-1px)}.category-pill>svg{color:var(--muted)}.project-groups{gap:60px;display:grid}.project-group{scroll-margin-top:100px}.category-summary{border-bottom:1px solid var(--soft-line);justify-content:space-between;align-items:center;gap:24px;margin-bottom:22px;padding-bottom:18px;display:flex}.category-title{grid-template-columns:38px minmax(0,1fr);align-items:start;gap:14px;display:grid}.category-title>svg{color:var(--ink);margin-top:2px}.category-summary p{max-width:820px;color:var(--muted);margin:7px 0 0}.playlist-link{border:1px solid var(--line);background:var(--surface);min-height:42px;color:var(--ink);white-space:nowrap;border-radius:8px;align-items:center;gap:8px;padding:0 16px;font-size:.92rem;font-weight:700;transition:background .16s;display:inline-flex}.playlist-link:hover{background:var(--surface-soft)}.project-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;display:grid}.project-card{border:1px solid var(--soft-line);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow-soft);cursor:pointer;flex-direction:column;scroll-margin-top:100px;transition:transform .18s,box-shadow .18s;display:flex;overflow:hidden}.project-card:hover{box-shadow:var(--shadow);transform:translateY(-3px)}.project-card:focus-visible{outline:2px solid var(--ink);outline-offset:2px}.project-media{aspect-ratio:16/9;background:var(--surface-soft);cursor:pointer;display:block;position:relative;overflow:hidden}.project-media img{object-fit:cover;width:100%;height:100%;transition:transform .22s}.project-media iframe{border:0;width:100%;height:100%;position:absolute;inset:0}.project-card:hover .project-media img{transform:scale(1.04)}.project-media-overlay{color:#fff;pointer-events:none;background:linear-gradient(#0e12180a,#0e12184d);justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.project-media-overlay>svg{box-sizing:border-box;background:#0e12189e;border:1px solid #ffffff47;border-radius:999px;width:54px;height:54px;padding:14px;transition:transform .18s,background .18s;box-shadow:0 14px 34px -22px #000000e6}.project-card:hover .project-media-overlay>svg,.project-media:focus-visible .project-media-overlay>svg{background:#0e1218d1;transform:scale(1.08)}.project-body{padding:20px}.project-body p{color:var(--muted);margin:12px 0 0}.skill-list{margin:18px auto 0}.contact{background:var(--surface-soft);gap:18px;display:grid}.contact-row{grid-template-columns:minmax(0,.78fr) auto;align-items:center;gap:32px;display:grid}.contact-row p{max-width:760px;color:var(--muted);margin:0;font-size:1.04rem}.contact-actions{justify-content:flex-end;align-items:stretch;gap:12px;margin:0;display:flex}.contact-actions .button{min-width:150px}@media (max-width:1120px){.hero,.about-section,.contact,.contact-row{grid-template-columns:1fr}.hero{gap:44px;min-height:auto}.hero-brand-mark{justify-self:start;max-width:305px;margin:0}.credentials-grid,.featured-grid,.project-grid,.competency-list,.tech-panel,.experience-skill-groups{grid-template-columns:1fr 1fr}.contact-actions{justify-content:flex-start}.contact-actions .button{min-width:150px}.about-aside{margin-top:0}}@media (max-width:860px){.site-header{border-radius:16px;justify-content:space-between;align-items:center;gap:10px;width:calc(100% - 24px);margin-top:10px;padding:4px 8px 4px 12px;display:flex;position:sticky;top:8px}.header-actions{align-items:center;gap:8px;margin-left:auto;display:flex}.brand{min-height:34px}.brand-mark{width:40px;height:40px}.brand-mark img{width:37px;height:37px}.language-picker{width:auto}.nav-links{display:none}.mobile-menu{display:block}.language-trigger{background:0 0;border:0;border-radius:10px;grid-template-columns:none;justify-content:center;align-items:center;gap:0;width:44px;height:44px;min-height:44px;padding:0;display:inline-flex}.language-trigger svg{width:21px;height:21px}.language-trigger-label,.language-chevron{display:none}.language-trigger:hover,.language-trigger:focus-visible{background:#2b2e350f}.mobile-menu-trigger{width:44px;height:44px}.mobile-menu-trigger svg{width:24px;height:24px}.language-menu{border-radius:14px;gap:3px;min-width:210px;max-width:calc(100vw - 28px);padding:8px}.language-option{border-radius:10px;min-height:48px;padding:0 16px;font-size:1rem}.hero,.section{width:auto;padding-left:20px;padding-right:20px;scroll-margin-top:74px}.hero{gap:22px;padding-top:42px}.hero-copy{max-width:100%}.hero-actions{margin-top:24px}.hero-brand-mark{justify-self:center;width:clamp(142px,46vw,210px);transform:none}.section{padding-top:64px;padding-bottom:64px}.competency-layout,.competency-list,.credentials-grid,.featured-grid,.project-grid,.tech-panel,.experience-skill-groups{grid-template-columns:1fr}.experience-head{grid-template-columns:auto minmax(0,1fr)}.experience-period{white-space:normal;grid-column:2}.category-summary{flex-direction:column;align-items:flex-start}.category-jump{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:30px;display:grid}.category-pill{justify-content:flex-start;gap:7px;min-height:38px;padding:0 10px;font-size:.82rem}.category-pill>svg{flex:none;width:16px;height:16px}.experience-card{padding:22px 18px}.about-photo-card,.about-panel{justify-self:center;width:min(100%,360px)}.credential-panel{padding:20px 18px}.tech-group,.competency-card{padding:20px}.playlist-link{justify-content:center;width:100%}.contact-row{gap:22px}}@media (max-width:560px){h1{font-size:2.4rem}h2{font-size:1.9rem}.section{padding-top:52px;padding-bottom:52px}.hero-intro,.about-intro p,.section-heading p,.experience-text,.credential-list p,.competency-card p,.featured-card p,.category-summary p,.project-body p,.contact p{text-align:justify;text-justify:inter-word;-webkit-hyphens:auto;hyphens:auto}.hero{padding-top:34px}.button{width:100%}.hero-actions,.about-actions,.contact-actions{grid-template-columns:1fr;gap:10px;display:grid}.contact-actions .button{min-width:0}.experience-card,.credential-panel,.competency-card,.tech-group,.project-body,.featured-card-body{padding:18px 16px}.experience-list,.credentials-grid,.competency-list,.tech-panel,.featured-grid,.project-grid{gap:12px}.credential-list article{grid-template-columns:1fr}.credential-list article .brand-logo{margin-bottom:4px}}@media (max-width:380px){h1{font-size:2.1rem}.hero,.section{padding-left:16px;padding-right:16px}}
