*{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary:#f8f9fa;--bg-secondary:#fff;--bg-surface:#fff;--text-primary:#111827;--text-secondary:#6b7280;--text-muted:#9ca3af;--color-primary:#172a54;--color-primary-hover:#2a5298;--color-primary-light:#3a67b4;--color-accent:#2a5298;--border-color:#e5e7eb;--border-hover:#2a5298;--shadow-color:#172a5414;--shadow-hover:#172a541f;--card-bg:#fff;--button-primary-bg:#2a5298;--button-primary-hover:#3a67b4;--button-secondary-bg:#0000;--button-secondary-hover:#eaf0ff;--input-bg:#fff;--input-border:#e5e7eb;--input-focus:#2a5298;--nav-bg:#fffffff2;--nav-border:#e5e7ebcc}.dark{--bg-primary:#0f1419;--bg-secondary:#1a1a1a;--bg-surface:#2d2d2d;--text-primary:#f9fafb;--text-secondary:#d1d5db;--text-muted:#9ca3af;--color-primary:#f87171;--color-primary-hover:#ef4444;--color-primary-light:#dc2626;--color-accent:#ef4444;--border-color:#374151;--border-hover:#f87171;--shadow-color:#0000004d;--shadow-hover:#0006;--card-bg:#2d2d2d;--button-primary-bg:#ef4444;--button-primary-hover:#dc2626;--button-secondary-bg:#0000;--button-secondary-hover:#374151;--input-bg:#374151;--input-border:#4b5563;--input-focus:#f87171;--nav-bg:#1a1a1af2;--nav-border:#374151cc}html{scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8f9fa;background-color:var(--bg-primary);color:#111827;color:var(--text-primary);font-family:Inter,sans-serif;line-height:1.7;transition:background-color .3s ease,color .3s ease}main{margin:auto;max-width:1440px}.container{margin:0 auto;max-width:1280px;padding:0 24px}.section{padding:96px 0}.section-sm{padding:64px 0}h1{font-size:56px;letter-spacing:-1.5px;line-height:1.2}h1,h2{color:#172a54;color:var(--color-primary);font-weight:700;margin-bottom:24px;transition:color .3s ease}h2{font-size:40px;letter-spacing:-1px;line-height:1.3}h3{color:#172a54;color:var(--color-primary);font-size:24px;font-weight:600;letter-spacing:-.5px;line-height:1.4}h3,p{margin-bottom:16px;transition:color .3s ease}p{color:#111827;color:var(--text-primary);font-weight:400;line-height:1.7}.btn,p{font-size:16px}.btn{align-items:center;border:none;border-radius:12px;cursor:pointer;display:inline-flex;font-family:inherit;font-weight:600;height:52px;justify-content:center;padding:0 32px;text-decoration:none;transition:all .2s ease-out}.btn-primary{background-color:#2a5298;background-color:var(--button-primary-bg);color:#fff;transition:all .2s ease}.btn-primary:hover{background-color:#3a67b4;background-color:var(--button-primary-hover);transform:scale(1.03)}.btn-primary:active{transform:scale(.98)}.btn-secondary{background-color:initial;background-color:var(--button-secondary-bg);border:1px solid #e5e7eb;border:1px solid var(--border-color);color:#172a54;color:var(--color-primary);transition:all .2s ease}.btn-secondary:hover{background-color:#eaf0ff;background-color:var(--button-secondary-hover);border-color:#2a5298;border-color:var(--border-hover)}.card{background:#fff;background:var(--card-bg);border-radius:12px;box-shadow:0 4px 12px #172a5414;box-shadow:0 4px 12px var(--shadow-color);padding:32px;transition:transform .3s cubic-bezier(.25,1,.5,1),box-shadow .3s ease,background-color .3s ease}.card:hover{box-shadow:0 10px 24px #172a541f;box-shadow:0 10px 24px var(--shadow-hover);transform:translateY(-8px)}.project-card{box-shadow:0 4px 12px #172a5414;box-shadow:0 4px 12px var(--shadow-color);transition:transform .3s cubic-bezier(.25,1,.5,1),box-shadow .3s ease,background-color .3s ease}.project-card:hover{box-shadow:0 10px 24px #172a541f;box-shadow:0 10px 24px var(--shadow-hover)}.project-image{border-radius:16px;height:200px}.project-content{padding:32px}.filter-pills{gap:16px}.filter-pill{background:var(--bg-secondary);border-radius:9999px;transition:background-color .2s ease,color .2s ease,border-color .2s ease}.filter-pill:hover{background:#f8f9fa;background:var(--bg-primary)}.filter-pill.active{background:#2a5298;background:var(--color-accent);border:none;font-weight:600}.tag{background:#eaf0ff;background:var(--button-secondary-hover);border-radius:9999px;color:#172a54;color:var(--color-primary);display:inline-block;font-size:12px;font-weight:500;margin-bottom:8px;margin-right:8px;padding:4px 12px;transition:all .2s ease}.form-group{margin-bottom:24px}.form-label{color:#6b7280;color:var(--text-secondary);display:block;font-size:14px;font-weight:500;margin-bottom:8px;transition:color .3s ease}.form-input,.form-textarea{background:#fff;background:var(--input-bg);border:1px solid #e5e7eb;border:1px solid var(--input-border);border-radius:12px;color:#111827;color:var(--text-primary);font-family:inherit;font-size:16px;height:52px;padding:0 16px;transition:border-color .2s ease,box-shadow .2s ease,background-color .3s ease,color .3s ease;width:100%}.form-input:focus,.form-textarea:focus{border:2px solid #2a5298;border:2px solid var(--input-focus);box-shadow:0 0 0 3px #3b82f626;outline:none}.form-textarea{height:120px;padding:16px;resize:vertical}.grid{grid-gap:32px;display:grid;gap:32px}.grid-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.grid-3{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.nav{background:#fff;background:var(--bg-secondary);box-shadow:0 1px 3px #172a5414;box-shadow:0 1px 3px var(--shadow-color);position:-webkit-sticky;position:sticky;top:0;transition:background-color .3s ease,box-shadow .3s ease;z-index:100}.nav-container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1280px;padding:16px 24px}.nav-logo{color:#172a54;color:var(--color-primary);font-size:24px;font-weight:700;text-decoration:none;transition:color .3s ease}.nav-links{display:flex;gap:32px;list-style:none}.nav-link{color:#6b7280;color:var(--text-secondary);font-weight:500;text-decoration:none;transition:color .2s ease}.nav-link:hover{color:#2a5298;color:var(--color-primary-hover)}.layout-photo{grid-gap:48px;align-items:flex-start;display:grid;gap:48px;grid-template-columns:300px 1fr;margin:0 auto;max-width:1000px;@media (max-width:768px){align-items:center;display:flex;flex-direction:column}}.hero{background:#f8f9fa;background:var(--bg-primary);padding:96px 0;text-align:center;transition:background-color .3s ease}.hero-subtitle{color:#6b7280;color:var(--text-secondary);font-size:20px;margin:0 auto 48px;max-width:650px;transition:color .3s ease}.hero-buttons{display:flex;flex-wrap:wrap;gap:16px;justify-content:center}.timeline{padding-left:32px;position:relative}.timeline:before{background:#e5e7eb;background:var(--border-color);bottom:0;content:"";left:0;position:absolute;top:0;transition:background-color .3s ease;width:2px}.timeline-item{margin-bottom:48px;position:relative}.timeline-item:before{background:#2a5298;background:var(--color-accent);border:3px solid #fff;border:3px solid var(--bg-secondary);border-radius:50%;box-shadow:0 0 0 3px #2a5298;box-shadow:0 0 0 3px var(--color-accent);content:"";height:12px;left:-36px;position:absolute;top:8px;transition:all .3s ease;width:12px}.timeline-date{color:#6b7280;color:var(--text-secondary);font-size:14px;font-weight:500}.timeline-date,.timeline-title{margin-bottom:8px;transition:color .3s ease}.timeline-title{color:#172a54;color:var(--color-primary);font-size:18px;font-weight:600}.timeline-company{font-size:16px;margin-bottom:16px;transition:color .3s ease}.timeline-company,.timeline-key{color:#2a5298;color:var(--color-accent)}.timeline-key-hf{color:#111827;color:var(--text-primary)}@media (max-width:767px){h1{font-size:36px}h2{font-size:28px}.container{padding:0 16px}.hero,.section{padding:48px 0}.hero-buttons{align-items:center;flex-direction:column}.btn{max-width:280px;width:100%}.grid{gap:24px}.nav-links{display:none}.timeline{padding-left:24px}.timeline-item:before{left:-30px}.nav-container>div{gap:16px!important}.nav-container button{font-size:12px!important;padding:6px 12px!important}.nav-container button span{display:none!important}}@media (max-width:480px){.nav-container{flex-direction:column;gap:12px}.nav-container>div{gap:12px!important}.nav-container button{padding:8px 12px!important}}@media (max-width:1023px){.grid-3{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}}.profile-photo{align-items:center;background:#fff;background:var(--card-bg);border:4px solid #e5e7eb;border:4px solid var(--border-color);border-radius:50%;box-shadow:0 8px 32px #172a5414;box-shadow:0 8px 32px var(--shadow-color);display:flex;height:280px;justify-content:center;overflow:hidden;position:relative;transition:all .3s ease;width:280px}.profile-photo:hover{border-color:#2a5298;border-color:var(--border-hover);box-shadow:0 12px 48px #172a541f;box-shadow:0 12px 48px var(--shadow-hover);transform:translateY(-4px)}.profile-photo img{border-radius:50%;height:100%;object-fit:cover;width:100%}.profile-placeholder{color:#9ca3af;color:var(--text-muted);height:60px;opacity:.6;width:60px}@media (max-width:768px){.about-content{gap:32px!important;grid-template-columns:1fr!important;text-align:center}.profile-photo{height:240px;margin:0 auto;width:240px}.about-skills{grid-template-columns:1fr!important}.about-skills .tag{font-size:14px;padding:12px 16px;text-align:center}}@media (max-width:480px){.profile-photo{height:200px;width:200px}}.project-card{background:#fff;background:var(--card-bg);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 4px 16px #172a5414;box-shadow:0 4px 16px var(--shadow-color);display:flex;flex-direction:column;height:100%;overflow:hidden;transition:all .3s ease}.project-card:hover{border-color:#2a5298;border-color:var(--border-hover);box-shadow:0 12px 32px #172a541f;box-shadow:0 12px 32px var(--shadow-hover);transform:translateY(-8px)}.project-image-container{height:200px;overflow:hidden;position:relative;width:100%}.project-image{height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.project-card:hover .project-image{transform:scale(1.05)}.project-image-overlay{align-items:center;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease}.project-card:hover .project-image-overlay{opacity:1}.project-view-btn{border-radius:6px;font-weight:600;padding:12px 24px;text-decoration:none;transition:all .2s ease}.project-content{flex-grow:1;padding:24px}.project-meta{display:flex;gap:8px;margin-bottom:16px}.project-main-image{img{border-radius:20px;max-height:300px;max-width:400px}}.project-title{color:#111827;color:var(--text-primary);font-size:20px;font-weight:700;line-height:1.3;margin-bottom:12px}.project-description{color:#6b7280;color:var(--text-secondary);font-size:14px;line-height:1.6;margin-bottom:20px}.project-details{margin-top:auto}.project-stats{display:flex;gap:16px;margin-bottom:16px}.stat-item{display:flex;flex-direction:column;gap:4px}.stat-label{font-size:12px}.stat-value{color:#111827;color:var(--text-primary);font-size:14px;font-weight:600}.project-tech{margin-top:16px}.tech-label{color:#6b7280;color:var(--text-secondary);display:block;font-size:13px;font-weight:600;margin-bottom:8px}.tech-tags{display:flex;flex-wrap:wrap;gap:6px}.tech-tag{background:#fff;background:var(--bg-surface);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:4px;color:#6b7280;color:var(--text-secondary);font-size:11px;font-weight:500;padding:4px 8px;transition:all .2s ease}.tech-tag:hover{background:#2a5298;background:var(--color-accent);border-color:#2a5298;border-color:var(--color-accent);color:#fff}.tag-status,.tag-type{border-radius:12px;font-size:11px;font-weight:600;letter-spacing:.5px;padding:4px 10px;text-transform:uppercase}.filter-pills{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-bottom:48px}.filter-pill{background:#fff;background:var(--bg-surface);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:25px;color:#6b7280;color:var(--text-secondary);cursor:pointer;font-size:14px;font-weight:500;padding:12px 24px;transition:all .2s ease}.filter-pill:hover{background:#2a5298;background:var(--color-accent);border-color:#2a5298;border-color:var(--color-accent);color:#fff;transform:translateY(-2px)}.filter-pill.active{background:#172a54;background:var(--color-primary);border-color:#172a54;border-color:var(--color-primary);box-shadow:0 4px 12px #172a54;box-shadow:0 4px 12px var(--color-primary);color:#fff}@media (max-width:768px){.project-content{padding:20px}.project-title{font-size:18px}.project-description{font-size:13px}.project-stats{flex-direction:column;gap:8px}.tech-tags{gap:4px}.tech-tag{font-size:10px;padding:3px 6px}}.project-detail-hero{grid-gap:8rem;align-items:center;display:grid;gap:8rem;grid-template-columns:2fr 1fr}.project-detail-content{display:flex;flex-direction:column;gap:24px}.project-detail-title{color:#111827;color:var(--text-primary);font-size:36px;font-weight:800;line-height:1.2;margin:0}.project-detail-description{color:#6b7280;color:var(--text-secondary);font-size:18px;line-height:1.6;margin:0}.project-stats-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(3,1fr)}.stat-card{background:#fff;background:var(--card-bg);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;padding:20px;text-align:center;transition:all .2s ease}.stat-card:hover{border-color:#2a5298;border-color:var(--border-hover);box-shadow:0 4px 16px #172a5414;box-shadow:0 4px 16px var(--shadow-color);transform:translateY(-2px)}.stat-label{color:#9ca3af;color:var(--text-muted);font-size:14px;font-weight:500;margin:0 0 8px}.stat-value{color:#2a5298;color:var(--color-accent);font-size:18px;font-weight:700;margin:0}.tech-section{margin-top:8px}.tech-section .tech-label{color:#6b7280;color:var(--text-secondary);display:block;font-size:14px;font-weight:600;margin-bottom:12px}.project-image-section{position:relative}.project-detail-image{border-radius:16px;box-shadow:0 20px 48px #172a5414;box-shadow:0 20px 48px var(--shadow-color);height:400px;object-fit:cover;transition:all .3s ease;width:100%}.project-detail-image:hover{box-shadow:0 25px 64px #172a541f;box-shadow:0 25px 64px var(--shadow-hover);transform:scale(1.02)}.project-detail-main{grid-gap:64px;display:grid;gap:64px;grid-template-columns:2fr 1fr}.project-content{display:flex;flex-direction:column;gap:48px}.content-section,.section-title{position:relative}.section-title{color:#111827;color:var(--text-primary);font-size:28px;font-weight:700;margin:0 0 24px;padding-bottom:12px}.section-title:after{background:linear-gradient(90deg,#2a5298,#172a54);background:linear-gradient(90deg,var(--color-accent),var(--color-primary));border-radius:2px;bottom:0;content:"";height:3px;left:0;position:absolute;width:60px}.section-text{color:#6b7280;color:var(--text-secondary);font-size:16px;line-height:1.7;margin:0;text-align:justify}.results-list{display:flex;flex-direction:column;gap:16px;list-style:none;margin:0;padding:0}.result-item{background:#fff;background:var(--card-bg);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;color:#6b7280;color:var(--text-secondary);padding:20px 20px 20px 48px;position:relative;transition:all .2s ease}.result-item:before{align-items:center;background:#2a5298;background:var(--color-accent);border-radius:50%;color:#fff;content:"✓";display:flex;font-size:12px;font-weight:600;height:24px;justify-content:center;left:16px;position:absolute;top:50%;transform:translateY(-50%);width:24px}.result-item:hover{border-color:#2a5298;border-color:var(--border-hover);box-shadow:0 4px 16px #172a5414;box-shadow:0 4px 16px var(--shadow-color);transform:translateX(4px)}.skills-sidebar{height:-webkit-fit-content;height:fit-content;position:-webkit-sticky;position:sticky;top:120px}.skills-card{background:#fff;background:var(--card-bg);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 8px 24px #172a5414;box-shadow:0 8px 24px var(--shadow-color);padding:32px}.sidebar-title{color:#111827;color:var(--text-primary);font-size:20px;font-weight:700;margin:0 0 24px;padding-bottom:12px;position:relative}.sidebar-title:after{background:linear-gradient(90deg,#2a5298,#172a54);background:linear-gradient(90deg,var(--color-accent),var(--color-primary));border-radius:2px;bottom:0;content:"";height:3px;left:0;position:absolute;width:40px}.skills-list{display:flex;flex-direction:column;gap:12px;list-style:none;margin:0;padding:0}.skill-item{background:#fff;background:var(--bg-surface);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:6px;color:#111827;color:var(--text-primary);font-size:14px;font-weight:700;padding:16px 16px 16px 40px;position:relative;transition:all .2s ease}.skill-item:before{color:#2a5298;color:var(--color-accent);content:"→";font-weight:600;left:16px;position:absolute;top:50%;transform:translateY(-50%)}.skill-item:hover{background:#2a5298;background:var(--color-accent);border-color:#2a5298;border-color:var(--color-accent);color:#fff;transform:translateX(4px)}.skill-item:hover:before{color:#fff}@media (max-width:1024px){.project-detail-hero{text-align:center}.project-detail-hero,.project-detail-main{gap:48px;grid-template-columns:1fr}.skills-sidebar{position:static}.project-stats-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:768px){.project-detail-title{font-size:28px}.project-detail-description{font-size:16px}.project-stats-grid{gap:16px;grid-template-columns:1fr}.project-detail-image{height:250px}.section-title{font-size:24px}.stat-card{padding:16px}.skills-card{padding:24px}.result-item,.skill-item{padding:16px 16px 16px 36px}.result-item:before{font-size:10px;height:20px;width:20px}.skill-item:before{font-size:14px}}.image-grid{grid-gap:3rem;display:grid;gap:3rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin:auto;padding:2rem;width:80%}.image-grid-item{aspect-ratio:4/3;background:#fff;background:var(--bg-surface);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;cursor:pointer;max-width:400px;overflow:hidden;position:relative;transition:all .3s ease}.image-grid-item:hover{box-shadow:0 8px 25px #00000026;transform:translateY(-2px)}.grid-image{height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.image-grid-item:hover .grid-image{transform:scale(1.05)}.image-overlay{align-items:center;background:#0000;bottom:0;color:#fff;display:flex;justify-content:center;left:0;opacity:0;position:absolute;right:0;top:0;transition:all .3s ease}.image-grid-item:hover .image-overlay{background:#00000080;opacity:1}.image-overlay svg{transform:scale(.8);transition:transform .3s ease}.image-grid-item:hover .image-overlay svg{transform:scale(1)}.image-modal{align-items:center;animation:modalFadeIn .3s ease;background:#000000e6;bottom:0;cursor:pointer;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}.modal-content{animation:modalSlideIn .3s ease;cursor:default;max-height:90vh;max-width:90vw;position:relative}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.modal-image{border-radius:4px;height:100%;max-height:90vh;object-fit:contain;width:100%}.modal-close{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:40px;justify-content:center;position:absolute;right:0;top:-50px;transition:all .3s ease;width:40px}.modal-close:hover{background:#fff3;transform:scale(1.1)}.modal-nav-btn{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:50px;justify-content:center;position:absolute;top:50%;transform:translateY(-50%);transition:all .3s ease;width:50px}.modal-nav-btn:hover{background:#fff3;transform:translateY(-50%) scale(1.1)}.modal-prev{left:-70px}.modal-next{right:-70px}.modal-counter{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:20px;bottom:-40px;color:#fff;font-size:14px;font-weight:500;left:50%;padding:8px 16px;position:absolute;transform:translateX(-50%)}@media (max-width:768px){.image-grid{gap:8px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.modal-nav-btn{height:40px;width:40px}.modal-prev{left:-50px}.modal-next{right:-50px}.modal-close{height:35px;top:-40px;width:35px}.modal-content{max-height:95vh;max-width:95vw}}@media (max-width:480px){.image-grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.modal-nav-btn{height:35px;width:35px}.modal-prev{left:-45px}.modal-next{right:-45px}.download-btn{font-size:13px;gap:8px;padding:8px 16px}.download-section{margin-top:16px;padding:16px}.download-info{font-size:12px;margin-top:12px}}.project-image-placeholder{align-items:center;background:#fff;background:var(--bg-surface);display:flex;height:240px;justify-content:center;width:100%}.download-section{background:#fff;background:var(--bg-secondary);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;margin-top:24px;padding:24px;text-align:center;transition:all .3s ease}.download-section:hover{background:#fff;background:var(--bg-surface);border-color:#2a5298;border-color:var(--color-accent)}.download-btn{align-items:center;background:#2a5298;background:var(--color-accent);border:none;border-radius:8px;box-shadow:0 2px 8px #e5393533;color:#fff;cursor:pointer;display:inline-flex;font-size:16px;font-weight:600;gap:12px;padding:12px 24px;transition:all .3s ease}.download-btn:hover{background:#d32f2f;background:var(--color-accent-hover,#d32f2f);box-shadow:0 4px 16px #e539354d;transform:translateY(-2px)}.download-btn:active{transform:translateY(0)}.download-btn svg{transition:transform .3s ease}.download-btn:hover svg{transform:translateY(2px)}.download-info{color:#6b7280;color:var(--text-secondary);font-size:14px;line-height:1.5;margin-left:auto;margin-right:auto;margin-top:16px;max-width:400px}
/*# sourceMappingURL=main.4e4707cf.css.map*/