*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary:#0a0a0f;--bg-secondary:#111118;--bg-tertiary:#1a1a24;--accent-primary:#6c63ff;--accent-secondary:#00d4ff;--accent-gradient:linear-gradient(135deg, #6c63ff, #00d4ff);--accent-gradient-r:linear-gradient(135deg, #00d4ff, #6c63ff);--text-primary:#f0f0ff;--text-secondary:#88a;--border:#6c63ff26;--border-hover:#6c63ff66;--nav-bg:#0a0a0fcc;--shadow-card:0 4px 24px #0006;--shadow-glow:0 0 24px #6c63ff1f;--transition:.2s ease}[data-theme=light]{--bg-primary:#f8f8ff;--bg-secondary:#fff;--bg-tertiary:#f0f0fa;--text-primary:#1a1a2e;--text-secondary:#66a;--border:#6c63ff1f;--border-hover:#6c63ff59;--nav-bg:#f8f8ffd9;--shadow-card:0 4px 24px #6c63ff14;--shadow-glow:0 0 24px #6c63ff0f}html{scroll-behavior:smooth}body{background:var(--bg-primary);color:var(--text-primary);min-height:100vh;transition:background var(--transition), color var(--transition);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:SF Pro Display,-apple-system,Segoe UI,sans-serif;font-size:.95rem;line-height:1.7}a{color:var(--accent-primary);transition:color var(--transition);text-decoration:none}a:hover{color:var(--accent-secondary)}.portfolio{max-width:860px;min-height:100vh;margin:0 auto;padding:5.5rem 2rem 5rem}.section-label{text-transform:uppercase;letter-spacing:.15em;color:var(--accent-primary);align-items:center;gap:.75rem;margin-bottom:1.5rem;font-size:.72rem;font-weight:700;display:flex}.section-label:after{content:"";background:var(--border);flex:1;height:1px}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.96)translateY(8px)}to{opacity:1;transform:scale(1)translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes tabFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.tab-panel{animation:.25s tabFadeIn}.navbar{z-index:1000;background:var(--nav-bg);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);position:fixed;top:0;left:0;right:0}.navbar-inner{justify-content:space-between;align-items:center;gap:1rem;max-width:860px;height:3.5rem;margin:0 auto;padding:0 2rem;display:flex}.navbar-logo{cursor:pointer;background:0 0;border:none;flex-shrink:0;align-items:center;gap:.6rem;padding:0;font-family:inherit;display:flex}.navbar-logo-badge{background:var(--accent-gradient);color:#fff;letter-spacing:-.03em;width:32px;height:32px;transition:opacity var(--transition);border-radius:8px;justify-content:center;align-items:center;font-size:.75rem;font-weight:800;display:flex}.navbar-logo:hover .navbar-logo-badge{opacity:.85}.navbar-tabs{background:var(--bg-secondary);border:1px solid var(--border);border-radius:10px;align-items:center;gap:.25rem;padding:.25rem;display:flex}.navbar-tab{color:var(--text-secondary);cursor:pointer;transition:color var(--transition), background var(--transition);white-space:nowrap;background:0 0;border:none;border-radius:7px;padding:.4rem .85rem;font-family:inherit;font-size:.82rem;font-weight:500;position:relative}.navbar-tab:hover{color:var(--text-primary);background:var(--bg-tertiary)}.navbar-tab--active{color:#fff;background:var(--accent-gradient);font-weight:600}.navbar-tab--active:hover{background:var(--accent-gradient);color:#fff}.theme-toggle{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;width:36px;height:36px;transition:background var(--transition), border-color var(--transition), color var(--transition);background:0 0;border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.theme-toggle:hover{background:var(--bg-tertiary);border-color:var(--border-hover);color:var(--text-primary)}.theme-toggle svg{width:16px;height:16px;display:block}.hero-content{animation:.4s fadeInUp}.hero-grid{grid-template-columns:3fr 2fr;align-items:start;gap:2rem;margin-bottom:2rem;display:grid}.hero-left{flex-direction:column;gap:.5rem;display:flex}.hero-name{letter-spacing:-.03em;background:var(--accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:.25rem;font-size:3.5rem;font-weight:800;line-height:1.1}.hero-title{color:var(--text-secondary);font-size:1rem;font-weight:400;line-height:1.5}.hero-location{color:var(--text-secondary);align-items:center;gap:.4rem;margin-top:.15rem;font-size:.87rem;display:flex}.hero-location svg{width:14px;height:14px;color:var(--accent-primary);flex-shrink:0}.hero-bio{color:var(--text-primary);opacity:.85;margin-top:.75rem;font-size:.95rem;line-height:1.7}.hero-right{flex-direction:column;align-items:flex-end;gap:1rem;display:flex}.availability-card{background:var(--bg-secondary);border:1px solid var(--border);width:100%;box-shadow:var(--shadow-card);border-radius:16px;padding:1.25rem;position:relative;overflow:hidden}.availability-card:before{content:"";background:var(--accent-gradient);height:2px;position:absolute;top:0;left:0;right:0}.availability-badge{color:var(--text-primary);align-items:center;gap:.5rem;margin-bottom:.85rem;font-size:.82rem;font-weight:600;display:flex}.availability-dot{background:#22c55e;border-radius:50%;flex-shrink:0;width:8px;height:8px;box-shadow:0 0 8px #22c55e80}.availability-role{color:var(--text-secondary);font-size:.8rem;line-height:1.6}.availability-role strong{color:var(--text-primary);font-weight:600}.deco-ring{background:conic-gradient(#6c63ff,#00d4ff,#6c63ff);border-radius:50%;flex-shrink:0;width:64px;height:64px;margin:.75rem auto 0;animation:6s linear infinite spin;position:relative}.deco-ring:after{content:"";background:var(--bg-secondary);border-radius:50%;position:absolute;inset:6px}.hero-links{border-top:1px solid var(--border);flex-wrap:wrap;gap:.6rem;padding-top:1.5rem;display:flex}.hero-link-btn{border:1px solid var(--border);color:var(--text-primary);cursor:pointer;transition:background var(--transition), border-color var(--transition), color var(--transition);white-space:nowrap;background:0 0;border-radius:999px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-family:inherit;font-size:.83rem;font-weight:500;text-decoration:none;display:flex}.hero-link-btn:hover{background:var(--bg-tertiary);border-color:var(--border-hover);color:var(--text-primary);text-decoration:none}.hero-link-btn svg{opacity:.75;flex-shrink:0;width:15px;height:15px}.resume-modal{max-width:380px}.resume-modal-sub{color:var(--text-secondary);margin-bottom:1.25rem;font-size:.87rem}.resume-options{flex-direction:column;gap:.6rem;display:flex}.resume-option{background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-primary);transition:background var(--transition), border-color var(--transition);border-radius:12px;align-items:center;gap:.85rem;padding:.9rem 1rem;text-decoration:none;display:flex}.resume-option:hover{background:var(--bg-tertiary);border-color:var(--border-hover);color:var(--text-primary);text-decoration:none}.resume-option-flag{flex-shrink:0;font-size:1.5rem}.resume-option-info{flex-direction:column;flex:1;display:flex}.resume-option-lang{color:var(--text-primary);font-size:.9rem;font-weight:600}.resume-option-hint{color:var(--text-secondary);font-size:.75rem}.resume-option-arrow{color:var(--accent-primary);opacity:0;transition:opacity var(--transition);font-size:1rem}.resume-option:hover .resume-option-arrow{opacity:1}.skills-content{animation:.4s fadeInUp}.skills-grid{grid-template-columns:repeat(2,1fr);gap:1rem;display:grid}.skill-card{background:var(--bg-secondary);border:1px solid var(--border);transition:border-color var(--transition), box-shadow var(--transition), transform var(--transition);border-radius:14px;padding:1.25rem;animation:.4s both fadeInUp;position:relative;overflow:hidden}.skill-card:before{content:"";background:var(--accent-gradient);opacity:0;height:2px;transition:opacity var(--transition);position:absolute;top:0;left:0;right:0}.skill-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-glow);transform:translateY(-2px)}.skill-card:hover:before{opacity:1}.skill-card-header{align-items:flex-start;gap:.75rem;margin-bottom:.85rem;display:flex}.skill-card-icon{flex-shrink:0;margin-top:.1rem;font-size:1.4rem;line-height:1}.skill-card-meta{flex:1}.skill-card-title{color:var(--text-primary);align-items:center;gap:.5rem;margin-bottom:.2rem;font-size:.9rem;font-weight:700;display:flex}.skill-card-level{text-transform:uppercase;letter-spacing:.06em;color:var(--accent-primary);background:#6c63ff1a;border:1px solid #6c63ff40;border-radius:4px;padding:.1rem .45rem;font-size:.6rem;font-weight:700}.skill-card-desc{color:var(--text-secondary);font-size:.78rem;line-height:1.5}.skill-card-pills{flex-wrap:wrap;gap:.35rem;display:flex}.pill{color:var(--text-secondary);transition:background var(--transition), border-color var(--transition), color var(--transition);white-space:nowrap;background:#6c63ff14;border:1px solid #6c63ff33;border-radius:999px;padding:.25rem .65rem;font-size:.75rem;font-weight:500}.pill:hover{color:var(--text-primary);background:#6c63ff2e;border-color:#6c63ff66}.pill--sm{padding:.18rem .5rem;font-size:.7rem}.pill--more{opacity:.5}.projects-content{animation:.4s fadeInUp}.projects-grid{flex-direction:column;gap:.75rem;display:flex}.project-card{background:var(--bg-secondary);border:1px solid var(--border);cursor:pointer;text-align:left;transition:border-color var(--transition), box-shadow var(--transition), transform var(--transition);border-radius:14px;flex-direction:column;gap:.6rem;padding:1.5rem 1.5rem 1.5rem 1.75rem;font-family:inherit;animation:.4s both fadeInUp;display:flex;position:relative;overflow:hidden}.project-card:before{content:"";background:var(--accent-gradient);opacity:.4;width:3px;transition:opacity var(--transition);position:absolute;top:0;bottom:0;left:0}.project-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-glow);transform:translateY(-2px)}.project-card:hover:before{opacity:1}.project-card-top{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.project-card-title{color:var(--text-primary);font-size:1rem;font-weight:700;line-height:1.3}.project-card-company{color:var(--text-secondary);text-transform:none;letter-spacing:0;background:#6c63ff14;border:1px solid #6c63ff2e;border-radius:999px;padding:.15rem .55rem;font-size:.73rem;font-weight:600}.project-card-desc{color:var(--text-secondary);font-size:.88rem;line-height:1.65}.project-card-tech{flex-wrap:wrap;gap:.3rem;margin-top:.25rem;display:flex}.project-card-hint{color:var(--accent-primary);opacity:0;transition:opacity var(--transition);align-items:center;gap:.35rem;margin-top:.1rem;font-size:.78rem;font-weight:500;display:flex}.project-card:hover .project-card-hint{opacity:1}.modal-backdrop{z-index:2000;-webkit-backdrop-filter:blur(8px);background:#000000b3;justify-content:center;align-items:center;padding:1.5rem;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal-card{background:var(--bg-secondary);border:1px solid var(--border-hover);border-radius:16px;width:100%;max-width:600px;max-height:85vh;padding:2rem;animation:.2s scaleIn;position:relative;overflow-y:auto;box-shadow:0 24px 64px #0009}.modal-card:before{content:"";background:var(--accent-gradient);-webkit-mask-composite:xor;pointer-events:none;border-radius:16px;padding:1px;position:absolute;inset:0;-webkit-mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);-webkit-mask-position:0 0,0 0;mask-position:0 0,0 0;-webkit-mask-size:auto,auto;mask-size:auto,auto;-webkit-mask-repeat:repeat,repeat;mask-repeat:repeat,repeat;-webkit-mask-clip:content-box,border-box;mask-clip:content-box,border-box;-webkit-mask-origin:content-box,border-box;mask-origin:content-box,border-box;-webkit-mask-composite:xor;mask-composite:exclude;-webkit-mask-source-type:auto,auto;mask-mode:match-source,match-source}.modal-close{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;width:32px;height:32px;transition:background var(--transition), border-color var(--transition), color var(--transition);z-index:1;background:0 0;border-radius:8px;justify-content:center;align-items:center;font-size:.85rem;display:flex;position:absolute;top:1rem;right:1rem}.modal-close:hover{background:var(--bg-tertiary);border-color:var(--border-hover);color:var(--text-primary)}.modal-header{margin-bottom:1rem;padding-right:2.5rem}.modal-title{color:var(--text-primary);letter-spacing:-.02em;margin-bottom:.5rem;font-size:1.35rem;font-weight:800}.modal-title-line{background:var(--accent-gradient);border-radius:2px;width:3rem;height:2px;margin-bottom:.75rem}.modal-meta{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.modal-company{color:var(--accent-primary);font-size:.8rem;font-weight:600}.modal-period{color:var(--text-secondary);font-size:.78rem}.modal-period:before{content:"·";color:var(--border-hover);margin-right:.75rem}.modal-description{color:var(--text-primary);border-bottom:1px solid var(--border);opacity:.9;margin-bottom:1rem;padding-bottom:1rem;font-size:.93rem;line-height:1.7}.modal-details{flex-direction:column;gap:.5rem;margin-bottom:1.25rem;padding:0;list-style:none;display:flex}.modal-details li{color:var(--text-secondary);padding-left:1.25rem;font-size:.88rem;line-height:1.65;position:relative}.modal-details li:before{content:"›";color:var(--accent-primary);font-size:1rem;font-weight:700;line-height:1.4;position:absolute;left:0}.modal-tech{flex-wrap:wrap;gap:.35rem;display:flex}.cw-vars{--cw-bg:var(--bg-secondary);--cw-surface:var(--bg-tertiary);--cw-border:var(--border);--cw-accent:var(--accent-primary);--cw-text:var(--text-primary);--cw-muted:var(--text-secondary)}@media (width<=768px){.portfolio{padding:5rem 1.25rem 4rem}.hero-grid{grid-template-columns:1fr;gap:1.5rem}.hero-right{align-items:stretch}.hero-name{font-size:2.5rem}.skills-grid{grid-template-columns:1fr}.navbar-inner{padding:0 1.25rem}.navbar-tab{padding:.38rem .7rem;font-size:.78rem}}@media (width<=480px){.portfolio{padding:4.75rem 1rem 3.5rem}.hero-name{font-size:2rem}.hero-links{gap:.5rem}.hero-link-btn{padding:.45rem .85rem;font-size:.78rem}.modal-card{padding:1.5rem}.navbar-tab{padding:.35rem .6rem;font-size:.75rem}.project-card{padding:1.25rem 1.25rem 1.25rem 1.5rem}}
