:root{--paper:#fafbfc;--ink:#1a1a1a;--ink-light:#52575d;--ink-muted:#8a8a8a;--accent:#3A3F45;--accent-light:#5a6270;--pop:#4F46E5;--pop-light:#6366f1;--border:#dfe2e6;--border-light:#eceef0;--shadow:rgba(26,26,26,0.06);--serif:'Cormorant Garamond',Georgia,serif;--sans:'DM Sans',Helvetica,sans-serif}
*{margin:0;padding:0;box-sizing:border-box}
html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{background:#dfe2e6;font-family:var(--sans);color:var(--ink);display:flex;justify-content:center;padding:40px 20px;min-height:100vh}
.a4-page{width:210mm;max-width:100%;background:var(--paper);box-shadow:0 1px 3px var(--shadow),0 8px 40px rgba(26,26,26,0.1),0 20px 80px rgba(26,26,26,0.06);position:relative;padding:52px 48px;animation:pageIn .8s cubic-bezier(.22,1,.36,1) both}
@keyframes pageIn{from{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}
.lang-toggle{position:absolute;top:20px;right:20px;display:flex;border:1px solid var(--border);overflow:hidden;border-radius:2px}
.lang-btn{padding:4px 10px;font-size:9.5px;font-weight:600;font-family:var(--sans);letter-spacing:1px;background:none;border:none;color:var(--ink-muted);cursor:pointer;transition:all .2s;text-transform:uppercase}
.lang-btn.active{background:var(--pop);color:#fff}
.lang-btn:not(.active):hover{color:var(--ink)}
.cv-header{display:flex;align-items:flex-start;gap:32px;padding-bottom:22px;border-bottom:1.5px solid var(--border);margin-bottom:22px}
.avatar-wrapper{flex-shrink:0;width:84px;height:84px;border-radius:50%;overflow:hidden;border:2px solid var(--border)}
.avatar-wrapper img{width:100%;height:100%;object-fit:cover}
.header-info{flex:1}
.header-info h1{font-family:var(--serif);font-size:30px;font-weight:400;letter-spacing:-.5px;line-height:1.1;color:var(--ink)}
.header-info h1 strong{font-weight:700}
.header-info h1::after{content:'';display:block;width:52px;height:2px;background:var(--pop);margin-top:7px;border-radius:1px}
.header-info .title{font-family:var(--sans);font-size:12px;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:var(--accent);margin-top:5px}
.header-info .subtitle{font-size:11.5px;color:var(--ink-light);margin-top:7px;line-height:1.55}
.contact-row{display:flex;flex-wrap:wrap;gap:14px;margin-top:10px}
.contact-item{display:flex;align-items:center;gap:4px;font-size:10.5px;color:var(--ink-muted);text-decoration:none;transition:color .2s}
.contact-item:hover{color:var(--pop)}
.contact-item svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:1.8}
.cv-section{margin-bottom:18px;animation:sectionIn .6s cubic-bezier(.22,1,.36,1) both}
.cv-section:nth-child(3){animation-delay:.1s}
.cv-section:nth-child(4){animation-delay:.15s}
.cv-section:nth-child(5){animation-delay:.2s}
.cv-section:nth-child(6){animation-delay:.25s}
.cv-section:nth-child(7){animation-delay:.3s}
.cv-section:nth-child(8){animation-delay:.35s}
@keyframes sectionIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.section-title{font-family:var(--serif);font-size:15px;font-weight:600;letter-spacing:.5px;color:var(--ink);margin-bottom:10px;position:relative;display:inline-block}
.section-title::after{content:'';display:block;width:45%;height:1.5px;background:var(--pop);margin-top:3px;border-radius:1px}
.exp-item{display:grid;grid-template-columns:108px 1fr;gap:12px;margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid var(--border-light)}
.exp-item:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.exp-date{font-size:10px;color:var(--ink-muted);padding-top:2px;font-weight:500;letter-spacing:.3px}
.exp-content h3{font-size:12px;font-weight:600;color:var(--ink);line-height:1.3}
.exp-content .company{font-size:10.5px;color:var(--accent);font-weight:500;margin-top:1px}
.exp-content p{font-size:10.5px;color:var(--ink-light);line-height:1.5;margin-top:3px}
.consulting-header{display:grid;grid-template-columns:108px 1fr;gap:12px;margin-bottom:8px}
.consulting-header h3{font-size:12px;font-weight:600;color:var(--ink);line-height:1.3}
.consulting-bullets{padding-left:122px;margin:0}
.consulting-bullets li{font-size:10.5px;color:var(--ink-light);line-height:1.55;margin-bottom:2px;padding-left:12px;position:relative;list-style:none}
.consulting-bullets li::before{content:'\2014';position:absolute;left:0;color:var(--pop);font-size:9px}
.skills-grid{display:flex;flex-wrap:wrap;gap:5px}
.skill-tag{font-size:10px;padding:3px 10px;background:var(--border-light);border:1px solid var(--border);border-radius:2px;color:var(--ink-light);font-weight:500;letter-spacing:.2px;transition:all .2s}
.skill-tag.core{border-color:var(--pop);color:var(--pop);background:rgba(79,70,229,.04)}
.skill-tag.core:hover{background:var(--pop);color:#fff;border-color:var(--pop)}
.skill-tag:hover{background:var(--pop);color:#fff;border-color:var(--pop)}
.edu-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.edu-card{display:grid;grid-template-columns:108px 1fr;gap:12px}
.edu-card h3{font-size:12px;font-weight:600}
.edu-card .school{font-size:10.5px;color:var(--accent);font-weight:500}
.projects-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.project-card{border:1px solid var(--border);padding:13px;cursor:pointer;transition:all .3s cubic-bezier(.22,1,.36,1);position:relative;background:var(--paper)}
.project-card:hover{border-color:var(--pop-light);box-shadow:0 4px 20px var(--shadow);transform:translateY(-2px)}
.project-card .project-number{font-family:var(--serif);font-size:22px;font-weight:300;color:var(--border-light);position:absolute;top:10px;right:14px;line-height:1;opacity:.6}
.project-card h4{font-size:12px;font-weight:700;color:var(--ink);margin-bottom:3px}
.project-card .project-type{font-size:9px;text-transform:uppercase;letter-spacing:1.5px;color:var(--pop);font-weight:500;margin-bottom:4px}
.project-card p{font-size:10px;color:var(--ink-muted);line-height:1.5}
.project-card .project-tags{display:flex;flex-wrap:wrap;gap:3px;margin-top:7px}
.project-card .project-tags span{font-size:8.5px;padding:2px 6px;border:1px solid var(--border);color:var(--ink-muted);font-weight:500;letter-spacing:.3px}
.project-card .arrow-icon{position:absolute;bottom:11px;right:11px;width:14px;height:14px;opacity:0;transform:translate(-4px,4px);transition:all .3s;color:var(--pop)}
.project-card:hover .arrow-icon{opacity:1;transform:translate(0,0)}
.projects-note{font-size:10px;color:var(--ink-muted);font-style:italic;margin-top:10px;padding-left:2px}
.modal-overlay{position:fixed;inset:0;background:rgba(26,26,26,.4);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:40px;opacity:0;pointer-events:none;transition:opacity .35s cubic-bezier(.22,1,.36,1)}
.modal-overlay.active{opacity:1;pointer-events:auto}
.modal-content{background:var(--paper);width:580px;max-width:100%;max-height:80vh;overflow-y:auto;padding:44px;position:relative;box-shadow:0 20px 80px rgba(26,26,26,.2);transform:translateY(20px) scale(.96);transition:transform .4s cubic-bezier(.22,1,.36,1)}
.modal-overlay.active .modal-content{transform:translateY(0) scale(1)}
.modal-close{position:absolute;top:18px;right:18px;width:30px;height:30px;border:1px solid var(--border);background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--ink-muted);transition:all .2s;font-size:14px}
.modal-close:hover{border-color:var(--ink);color:var(--ink)}
.modal-number{font-family:var(--serif);font-size:56px;font-weight:300;color:var(--border-light);line-height:1;margin-bottom:6px;opacity:.5}
.modal-type{font-size:9px;text-transform:uppercase;letter-spacing:2px;color:var(--pop);font-weight:600;margin-bottom:5px}
.modal-content h2{font-family:var(--serif);font-size:26px;font-weight:600;color:var(--ink);margin-bottom:14px;line-height:1.2}
.modal-desc{font-size:12.5px;color:var(--ink-light);line-height:1.75;margin-bottom:20px}
.modal-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}
.modal-detail-item label{display:block;font-size:9px;text-transform:uppercase;letter-spacing:1.5px;color:var(--ink-muted);font-weight:600;margin-bottom:3px}
.modal-detail-item span{font-size:12px;color:var(--ink);font-weight:500}
.modal-tags{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:20px}
.modal-tags span{font-size:10px;padding:3px 10px;background:var(--border-light);border:1px solid var(--border);color:var(--ink-light);font-weight:500}
.modal-features h4{font-size:11px;font-weight:600;color:var(--ink);margin-bottom:7px}
.modal-features ul{list-style:none;padding:0}
.modal-features li{font-size:11.5px;color:var(--ink-light);line-height:1.6;padding-left:16px;position:relative;margin-bottom:3px}
.modal-features li::before{content:'\2014';position:absolute;left:0;color:var(--pop)}
.cv-footer{margin-top:18px;padding-top:12px;border-top:1.5px solid var(--border);display:flex;justify-content:space-between;align-items:center}
.cv-footer .location{font-size:10px;color:var(--ink-muted);display:flex;align-items:center;gap:4px}
.cv-footer .location svg{width:11px;height:11px;stroke:currentColor;fill:none;stroke-width:2}
.cv-footer .updated{font-size:9px;color:var(--ink-muted);font-style:italic}
@media print{body{background:#fff;padding:0}.a4-page{box-shadow:none;padding:40px}.project-card:hover{transform:none;box-shadow:none}.lang-toggle{display:none}}
@media(max-width:800px){.a4-page{padding:28px 20px}.cv-header{flex-direction:column;gap:16px;text-align:center}.contact-row{justify-content:center}.exp-item,.edu-card,.consulting-header{grid-template-columns:1fr;gap:4px}.consulting-bullets{padding-left:0}.projects-grid,.edu-grid{grid-template-columns:1fr}.modal-content{padding:28px 20px}.modal-detail-grid{grid-template-columns:1fr}}
.modal-content::-webkit-scrollbar{width:4px}
.modal-content::-webkit-scrollbar-track{background:transparent}
.modal-content::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}