@import "https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&display=swap";:root{--bg-color:#0b0f19;--bg-card:#161c2d99;--primary:#38bdf8;--primary-glow:#38bdf866;--primary-half:#38bdf880;--primary-faint:#38bdf81a;--text-main:#fff;--text-muted:#94a3b8;--border:#ffffff14;--text-gradient-start:#fff;--font-main:"Plus Jakarta Sans", sans-serif}body.light-mode{--bg-color:#f8fafc;--bg-card:#fff;--primary:#2563eb;--primary-glow:#2563eb33;--primary-half:#2563eb80;--primary-faint:#2563eb0d;--text-main:#0f172a;--text-muted:#475569;--border:#0000001a;--text-gradient-start:#0f172a}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);color:var(--text-main);font-family:var(--font-main);-webkit-font-smoothing:antialiased;background-image:radial-gradient(circle at 15% 50%, var(--primary-faint), transparent 25%), radial-gradient(circle at 85% 30%, var(--primary-faint), transparent 25%);flex-direction:column;height:100vh;line-height:1.6;display:flex;overflow:hidden}.app,main{flex-direction:column;flex:1;display:flex;overflow:hidden}.container{max-width:1200px;margin:0 auto;padding:0 2rem}.main-container{flex-direction:column;flex:1;display:flex;overflow:hidden}.sticky-header{z-index:100;background-color:#0000;border-bottom:1px solid #0000;width:100%;height:70px;transition:all .3s;position:sticky;top:0}.header-inner{justify-content:space-between;align-items:center;width:100%;max-width:1200px;margin:0 auto;padding:1.5rem 2rem;display:flex}body:not(.light-mode) .sticky-header{background-color:#0f172a99;border-bottom:1px solid #ffffff0d}body.light-mode .sticky-header{background-color:#f8fafc99;border-bottom:1px solid #0000000d}.mobile-dropdown{background:var(--bg-main);z-index:90;border-bottom:1px solid var(--border);width:100%;position:fixed;top:4.5rem;left:0;box-shadow:0 10px 30px #0000001a}header{z-index:100;justify-content:space-between;align-items:center;padding:1.5rem 0;display:flex;position:relative}.logo{color:var(--text-main);letter-spacing:-.02em;font-size:1.25rem;font-weight:800;text-decoration:none}nav{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);gap:2.5rem;padding:.75rem 2rem;display:flex}nav a{color:var(--text-muted);font-size:.9rem;font-weight:600;text-decoration:none;transition:all .3s}nav a:hover,nav a.active{color:var(--primary);text-shadow:0 0 10px var(--primary-glow)}.btn-primary{background-color:var(--primary);color:#000;cursor:pointer;font-size:.95rem;font-weight:700;font-family:var(--font-main);box-shadow:0 0 20px var(--primary-glow);border:none;border-radius:8px;padding:.875rem 1.75rem;transition:all .3s cubic-bezier(.4,0,.2,1)}.btn-primary:hover{box-shadow:0 8px 30px var(--primary-glow);transform:translateY(-2px)scale(1.02)}.btn-outline{color:var(--text-main);border:1px solid var(--border);cursor:pointer;font-size:.95rem;font-weight:600;font-family:var(--font-main);background-color:#0000;border-radius:8px;padding:.875rem 1.75rem;transition:all .3s}.btn-outline:hover{background-color:#ffffff0d;border-color:#fff3}.mobile-menu-btn{color:var(--text-main);cursor:pointer;z-index:101;background:0 0;border:none;padding:.5rem;display:none}.header-actions{align-items:center;gap:1rem;display:flex}.theme-toggle-btn{background:var(--bg-card);border:1px solid var(--border);color:var(--text-main);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;transition:all .3s;display:flex}.theme-toggle-btn:hover{background:#ffffff1a;transform:scale(1.05)}.hero{flex:1;grid-template-columns:1fr 1fr;align-items:center;gap:4rem;padding-bottom:0;display:grid}.hero-content .badge{color:var(--primary);letter-spacing:.1em;text-transform:uppercase;box-shadow:0 0 20px var(--primary-glow);background-color:#3bf68614;border:1px solid #3bf68633;border-radius:100px;margin-bottom:2rem;padding:.5rem 1rem;font-size:.75rem;font-weight:700;display:inline-block}.hero-title{letter-spacing:-.03em;margin-bottom:.5rem;font-size:4rem;font-weight:800;line-height:1.08}.text-gradient{background:linear-gradient(to right, var(--text-gradient-start), var(--primary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero-subtitle{color:var(--primary);letter-spacing:.1em;text-transform:uppercase;text-shadow:0 0 20px var(--primary-glow);margin-bottom:1rem;font-size:1.3rem;font-weight:600}.hero-desc{color:var(--text-muted);max-width:520px;margin-bottom:2rem;font-size:1.05rem;font-weight:400;line-height:1.7}.hero-actions{gap:1rem;display:flex}.hero-image-wrapper{justify-content:center;align-items:center;display:flex;position:relative}.glow-sphere{background:var(--primary);filter:blur(120px);opacity:.15;z-index:0;border-radius:50%;width:300px;height:300px;animation:4s ease-in-out infinite alternate pulse;position:absolute}@keyframes pulse{0%{opacity:.1;transform:scale(1)}to{opacity:.2;transform:scale(1.1)}}.hero-card{z-index:1;flex-direction:column;align-items:center;width:100%;max-width:400px;transition:transform .3s;display:flex;position:relative}.hero-card:hover{transform:translateY(-5px)}.avatar-container{justify-content:center;align-items:center;width:280px;height:280px;margin-bottom:1rem;display:flex;position:relative}.avatar-ring{pointer-events:none;border:1px solid #0000;border-radius:50%;width:100%;height:100%;position:absolute}.avatar-ring-1{border-top-color:var(--primary);border-bottom-color:var(--primary);opacity:.6;box-shadow:inset 0 5px 15px var(--primary-faint);animation:10s linear infinite spin}.avatar-ring-2{border-left-color:var(--primary-half);border-right-color:var(--primary-half);width:110%;height:110%;animation:15s linear infinite reverse spin}.avatar-ring-3{border:1px dashed #fff3;width:90%;height:90%;animation:20s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.hero-card .avatar{object-fit:cover;object-position:center 25%;z-index:2;border:none;border-radius:50%;width:230px;height:230px;margin-bottom:0;transition:transform .4s cubic-bezier(.175,.885,.32,1.275);position:relative;box-shadow:0 10px 30px #00000080}.hero-card:hover .avatar{box-shadow:0 0 30px var(--primary-glow);transform:scale(1.05)}.floating-badge{background:var(--bg-card);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border);color:var(--text-main);z-index:3;letter-spacing:.05em;white-space:nowrap;border-radius:100px;align-items:center;gap:.5rem;padding:.55rem 1rem;font-size:.78rem;font-weight:700;display:flex;position:absolute;box-shadow:0 8px 24px #0003}.badge-left{top:10%;left:-20%}.badge-right{bottom:10%;right:-20%}.dot{border-radius:50%;width:8px;height:8px;display:inline-block}.dot.online{background-color:var(--primary);box-shadow:0 0 10px var(--primary)}.hero-image-info{text-align:center;width:100%}.hero-image-role{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:1rem;font-weight:600}section{flex-direction:column;flex:1;justify-content:center;padding:2rem 0;display:flex;overflow:hidden}.section-header{align-items:center;gap:1.5rem;margin-bottom:4rem;display:flex}.section-title{letter-spacing:-.02em;white-space:nowrap;font-size:1.8rem;font-weight:800}.section-line{background:linear-gradient(to right, var(--primary-half), transparent);opacity:.3;flex-grow:1;height:1px}.about-content{grid-template-columns:1.1fr .9fr;gap:4rem;display:grid}.about-text p{color:var(--text-muted);margin-bottom:.75rem;font-size:.9rem;line-height:1.6}.stats-container{border-top:1px solid var(--border);gap:3rem;margin-top:1rem;padding-top:1rem;display:flex}.stat-item{flex-direction:column;display:flex}.stat-number{color:var(--text-main);margin-bottom:.25rem;font-size:2.4rem;font-weight:800;line-height:1}.stat-label{color:var(--primary);text-transform:uppercase;letter-spacing:.05em;opacity:.9;font-size:.85rem;font-weight:700}.skills-container h3{margin-bottom:1rem;font-size:1.1rem;font-weight:700}.skills-grid{flex-wrap:wrap;gap:.5rem;display:flex}.skill-tag{background:var(--bg-card);border:1px solid var(--border);color:var(--text-main);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border-radius:100px;align-items:center;gap:.5rem;padding:.45rem .9rem;font-size:.8rem;font-weight:600;transition:all .3s;display:flex}.skill-icon{object-fit:contain;width:16px;height:16px}.skill-tag:hover{border-color:var(--primary);color:var(--primary);box-shadow:0 5px 15px var(--primary-faint);transform:translateY(-3px)}body:not(.light-mode) img[src*=nextjs-original],body:not(.light-mode) img[src*=github-original],body:not(.light-mode) img[src*=expo]{filter:invert()}.projects-section{flex:1;grid-template-columns:300px 1fr;gap:0;display:grid;overflow:hidden}.projects-sidebar{border-right:1px solid var(--border);flex-direction:column;padding-right:0;display:flex;overflow:hidden}.sidebar-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:baseline;padding:2rem 1.5rem 1.5rem;display:flex}.sidebar-title{letter-spacing:-.02em;font-size:1.6rem;font-weight:800}.sidebar-count{color:var(--text-muted);background:var(--bg-card);border:1px solid var(--border);border-radius:100px;padding:.25rem .75rem;font-size:.8rem;font-weight:600}.projects-list{flex-direction:column;flex:1;gap:.25rem;padding:.75rem 0;display:flex;overflow-y:auto}.projects-list::-webkit-scrollbar{width:4px}.projects-list::-webkit-scrollbar-track{background:0 0}.projects-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.project-item{text-align:left;cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-left:3px solid #0000;flex-direction:column;gap:.35rem;padding:.85rem 1.5rem;transition:all .25s;display:flex}.project-item:hover{background:var(--primary-faint);color:var(--text-main)}.project-item.active{background:var(--primary-faint);border-left-color:var(--primary);color:var(--text-main)}.project-item-top{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.project-item-title{font-size:.9rem;font-weight:700;line-height:1.3}.status-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.status-done{background:#4ade80;box-shadow:0 0 6px #4ade80}.status-progress{background:var(--primary);box-shadow:0 0 6px var(--primary)}.status-concept{background:#f59e0b;box-shadow:0 0 6px #f59e0b}.project-item-meta{color:var(--text-muted);gap:.75rem;font-size:.75rem;display:flex}.project-item-cat{font-weight:600}.project-detail{flex-direction:column;gap:1.5rem;height:100%;min-height:0;max-height:100%;padding:2.5rem 3rem;display:flex;overflow-y:auto}.detail-top{justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.detail-category{text-transform:uppercase;letter-spacing:.1em;color:var(--primary);margin-bottom:.5rem;font-size:.75rem;font-weight:700;display:block}.detail-title{letter-spacing:-.02em;font-size:2rem;font-weight:800}.detail-status{white-space:nowrap;border-radius:100px;flex-shrink:0;padding:.4rem 1rem;font-size:.75rem;font-weight:700}.status-done-badge{color:#4ade80;background:#4ade801a;border:1px solid #4ade804d}.status-progress-badge{background:var(--primary-faint);color:var(--primary);border:1px solid var(--primary-half)}.status-concept-badge{color:#f59e0b;background:#f59e0b1a;border:1px solid #f59e0b4d}.detail-desc{color:var(--text-muted);max-width:640px;font-size:1rem;line-height:1.75}.detail-highlight{background:var(--primary-faint);border-left:3px solid var(--primary);border-radius:0 8px 8px 0;align-items:flex-start;gap:1rem;padding:1rem 1.5rem;display:flex}.highlight-icon{color:var(--primary);flex-shrink:0;margin-top:2px;font-size:.9rem}.detail-highlight p{color:var(--text-main);font-size:.9rem;font-weight:600;line-height:1.5}.detail-tech{flex-direction:column;gap:.75rem;display:flex}.detail-tech-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);font-size:.75rem;font-weight:700}.detail-tech-list{flex-wrap:wrap;gap:.5rem;display:flex}.tech-chip{background:var(--bg-card);border:1px solid var(--border);color:var(--text-main);border-radius:6px;padding:.35rem .9rem;font-size:.82rem;font-weight:600}.detail-actions{border-top:1px solid var(--border);gap:1rem;margin-top:auto;padding-top:1rem;display:flex}@media (width<=1024px){body{height:auto;min-height:100vh;overflow:hidden auto}.app,main,.main-container{overflow:visible}.main-container{padding-bottom:2rem}header nav,.header-actions .desktop-btn{display:none}.mobile-menu-btn{background:var(--bg-card);border:1px solid var(--border);cursor:pointer;z-index:103;border-radius:12px;justify-content:center;align-items:center;width:45px;height:45px;display:flex}.sticky-header{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background-color:#0f172acc}.mobile-dropdown{background:var(--bg-card);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);z-index:999;border-bottom:1px solid var(--border);width:100%;position:fixed;top:70px;left:0;box-shadow:0 20px 40px #0000004d}.mobile-nav{flex-direction:column;align-items:center;gap:1.5rem;padding:2.5rem 1.5rem;display:flex}.mobile-nav a{color:var(--text-main);text-align:center;width:100%;font-size:1.25rem;font-weight:700;text-decoration:none;transition:all .3s}.mobile-nav a.active{color:var(--primary)}.hero{text-align:center;grid-template-columns:1fr;gap:3rem;padding:3rem 0}.hero-title{font-size:3.2rem}.hero-desc{margin:0 auto 2.5rem}.hero-actions{justify-content:center}.about-content{grid-template-columns:1fr;gap:3rem}.projects-section{grid-template-columns:1fr;overflow-y:visible}.projects-sidebar{border-right:none;border-bottom:1px solid var(--border);max-height:400px}}@media (width<=768px){.container{padding:0 1.25rem}.header-inner{padding:1rem 1.25rem}.hero-title{font-size:2.4rem}.hero-subtitle{font-size:1.1rem}.avatar-container{width:200px;height:200px}.avatar{width:160px;height:160px}.hero-actions{flex-direction:column;width:100%;max-width:320px;margin:0 auto}.hero-actions button{width:100%}.project-detail{padding:1.5rem 1.25rem}.detail-title{font-size:1.5rem}#contact{padding:3rem 1.25rem!important}}@media (width<=480px){.hero-title{font-size:2.1rem}.logo{font-size:1.1rem}.stats-container{justify-content:center;gap:1.5rem}}@media print{@page{size:A4 portrait;margin:0}body *{visibility:hidden}.cv-container,.cv-container *{visibility:visible}.cv-container{width:210mm;height:297mm;position:fixed;top:0;left:0;box-shadow:none!important}body{-webkit-print-color-adjust:exact;print-color-adjust:exact}}.cv-container{background:#fff;flex-direction:row;width:210mm;height:297mm;margin:0 auto;font-family:Plus Jakarta Sans,Segoe UI,sans-serif;font-size:10pt;line-height:1.45;display:flex;overflow:hidden;box-shadow:0 4px 40px #0000002e}.cv-sidebar{color:#e2e8f0;background:#0d1526;flex-direction:column;flex-shrink:0;gap:18px;width:34%;padding:28px 20px;display:flex}.cv-photo-wrapper{flex-direction:column;align-items:center;gap:10px;display:flex}.cv-photo-ring{background:linear-gradient(135deg,#38bdf8,#0ea5e9);border-radius:50%;flex-shrink:0;width:115px;height:115px;padding:3px}.cv-photo{object-fit:cover;object-position:center 20%;border-radius:50%;width:100%;height:100%;display:block}.cv-sidebar-section{flex-direction:column;gap:8px;display:flex}.cv-sidebar-title{color:#38bdf8;text-transform:uppercase;letter-spacing:.12em;border-bottom:1px solid #38bdf840;padding-bottom:5px;font-size:8.5pt;font-weight:700}.cv-contact-list{flex-direction:column;gap:6px;list-style:none;display:flex}.cv-contact-item{color:#cbd5e1;align-items:center;gap:7px;font-size:9pt;display:flex}.cv-contact-icon{text-align:center;flex-shrink:0;width:16px;font-size:10pt}.cv-skills-grid{flex-wrap:wrap;gap:5px;display:flex}.cv-skill-tag{color:#93c5fd;background:#38bdf81f;border:1px solid #38bdf833;border-radius:3px;padding:2px 7px;font-size:8pt;font-weight:600}.cv-lang-item{justify-content:space-between;align-items:center;font-size:9pt;display:flex}.cv-lang-level{color:#38bdf8;background:#38bdf81a;border-radius:3px;padding:1px 7px;font-size:8pt}.cv-main{flex-direction:column;gap:16px;width:66%;padding:28px 26px;display:flex}.cv-header{border-bottom:2px solid #e2e8f0;flex-direction:column;gap:5px;padding-bottom:14px;display:flex}.cv-name{color:#0d1526;letter-spacing:-.02em;margin:0;font-size:23pt;font-weight:800;line-height:1.05}.cv-name-accent{color:#0284c7}.cv-role{color:#0284c7;text-transform:uppercase;letter-spacing:.15em;margin:0;font-size:10.5pt;font-weight:700}.cv-tagline{color:#64748b;margin-top:4px;font-size:9pt;line-height:1.5}.cv-main-section{flex-direction:column;gap:8px;display:flex}.cv-main-title{color:#0d1526;text-transform:uppercase;letter-spacing:.1em;align-items:center;gap:8px;margin-bottom:2px;font-size:9.5pt;font-weight:800;display:flex}.cv-main-title:after{content:"";background:#e2e8f0;flex:1;height:1px}.cv-projects-grid{grid-template-columns:1fr 1fr;gap:9px;display:grid}.cv-project-card{background:#f8fafc;border:1px solid #e2e8f0;border-left:3px solid #0284c7;border-radius:6px;flex-direction:column;gap:5px;padding:10px 12px;display:flex}.cv-project-top{justify-content:space-between;align-items:center;display:flex}.cv-project-title{color:#0d1526;font-size:9.5pt;font-weight:700}.cv-project-year{color:#64748b;background:#e2e8f0;border-radius:3px;padding:1px 6px;font-size:8pt;font-weight:600}.cv-project-desc{color:#475569;font-size:8.5pt;line-height:1.45}.cv-project-tech{flex-wrap:wrap;gap:4px;margin-top:2px;display:flex}.cv-tech-chip{color:#0284c7;background:#0284c714;border-radius:3px;padding:1px 6px;font-size:7.5pt;font-weight:700}.cv-profile-text{color:#475569;font-size:9pt;line-height:1.55}.cv-footer{text-align:center;color:#94a3b8;border-top:1px solid #e2e8f0;margin-top:auto;padding-top:10px;font-size:8pt}
