.profile-hover-card{align-items:center;display:inline-flex;position:relative}.profile-trigger{border:1px solid var(--border);color:inherit;cursor:pointer;text-align:left;background:0 0;border-radius:999px;flex-direction:column;padding:.55rem .85rem;transition:border-color .2s,background .2s,transform .2s,box-shadow .2s;display:inline-flex}.profile-trigger:hover,.profile-trigger:focus-visible{border-color:var(--accent);background:color-mix(in srgb, var(--accent) 8%, transparent);outline:none;transform:translateY(-1px);box-shadow:0 .75rem 2rem #0000001f}.profile-name-row{align-items:center;gap:.45rem;display:flex}.profile-name{color:var(--text);letter-spacing:-.03em;font-size:1.1rem;font-weight:900}.profile-availability-icon{border:1px solid var(--border);width:1.55rem;height:1.55rem;color:var(--accent);background:color-mix(in srgb, var(--accent) 12%, transparent);border-radius:999px;justify-content:center;align-items:center;transition:transform .2s,background .2s,border-color .2s;display:inline-flex}.profile-trigger:hover .profile-availability-icon,.profile-trigger:focus-visible .profile-availability-icon{border-color:var(--accent);background:color-mix(in srgb, var(--accent) 20%, transparent);transform:translateY(-1px)}.profile-trigger-role{color:var(--muted);margin-top:.2rem;font-size:.85rem;font-weight:700;display:block}.profile-popover{z-index:1000;border:1px solid var(--border);background:var(--surface-solid);width:760px;min-height:280px;color:var(--text);opacity:0;pointer-events:none;transform-origin:0 0;border-radius:1.75rem;grid-template-columns:220px 1fr;align-items:center;gap:2rem;padding:2rem;transition:opacity .2s,transform .2s,border-color .2s,box-shadow .2s;display:grid;position:absolute;top:calc(100% + 1.2rem);left:0;transform:translateY(.75rem)scale(.96);box-shadow:0 2rem 6rem #0000004d}.profile-hover-card:hover .profile-popover,.profile-hover-card:focus-within .profile-popover{opacity:1;pointer-events:auto;border-color:var(--accent);transform:translateY(0)scale(1);box-shadow:0 2.5rem 7rem #0000005c}.profile-popover:before{content:"";border-left:1px solid var(--border);border-top:1px solid var(--border);background:var(--surface-solid);width:1.1rem;height:1.1rem;position:absolute;top:-.6rem;left:1.5rem;transform:rotate(45deg)}.profile-popover-image{border:1px solid var(--border);object-fit:cover;border-radius:1.5rem;width:220px;height:220px}.profile-popover-content{min-width:0}.profile-popover-content strong{color:var(--text);letter-spacing:-.04em;font-size:1.8rem;line-height:1.1;display:block}.profile-role{color:var(--accent);margin-top:.5rem;font-size:1.1rem;font-weight:800;display:block}.profile-meta{gap:.8rem;margin-top:1.4rem;display:grid}.profile-meta p{color:var(--muted);margin:0;font-size:1rem;line-height:1.5}.profile-meta span{color:var(--text);letter-spacing:.08em;text-transform:uppercase;margin-bottom:.15rem;font-size:.85rem;font-weight:800;display:block}.profile-socials{flex-wrap:wrap;gap:.75rem;margin-top:1.5rem;display:flex}.profile-socials a{border:1px solid var(--border);color:var(--muted);border-radius:999px;align-items:center;gap:.5rem;padding:.75rem 1rem;font-size:.95rem;font-weight:800;text-decoration:none;transition:color .2s,border-color .2s,background .2s,transform .2s;display:inline-flex}.profile-socials a:hover{color:var(--accent-text);border-color:var(--accent);background:var(--accent);transform:translateY(-2px)}.profile-link-icon{flex-shrink:0;width:1.15rem;height:1.15rem}@media (width<=850px){.profile-popover{display:none}}.header-menu{position:relative}.header-menu-toggle{width:2.7rem;height:2.7rem;color:var(--text);cursor:pointer;background:0 0;border:none;border-radius:999px;flex-direction:column;justify-content:center;align-items:center;gap:.32rem;transition:transform .2s,background .2s;display:inline-flex}.header-menu-toggle span{background:currentColor;border-radius:999px;width:1.35rem;height:2px}.header-menu-toggle:hover{background:color-mix(in srgb, var(--accent) 10%, transparent);transform:scale(1.1)}.header-menu-backdrop{z-index:80;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);opacity:0;pointer-events:none;background:#0003;transition:opacity .2s;position:fixed;inset:0}.header-menu-backdrop.open{opacity:1;pointer-events:auto}.header-menu-drawer{z-index:90;background:var(--surface-solid);width:min(370px,100vw);height:100vh;color:var(--text);border-left:1px solid var(--border);padding:1.5rem 1.75rem;transition:transform .25s;position:fixed;top:0;right:0;transform:translate(100%);box-shadow:-2rem 0 5rem #00000038}.header-menu-drawer.open{transform:translate(0)}.header-menu-top{justify-content:space-between;align-items:center;display:flex}.header-menu-title{color:var(--subtle);letter-spacing:.12em;text-transform:uppercase;font-size:.85rem;font-weight:800}.header-menu-close{color:var(--text);cursor:pointer;background:0 0;border:none;font-size:2.2rem;line-height:1;transition:transform .2s,color .2s}.header-menu-close:hover{color:var(--accent);transform:rotate(90deg)}.header-menu-list{gap:1.6rem;margin-top:3.5rem;display:grid}.header-menu-entry{width:100%;color:var(--text);cursor:pointer;text-align:left;background:0 0;border:none;justify-content:space-between;align-items:center;padding:0;font-size:1.45rem;font-weight:650;transition:color .2s,transform .2s;display:flex}.header-menu-entry:hover{color:var(--accent);transform:translate(.35rem)}.header-menu-arrow{color:var(--text);font-size:2rem;line-height:1;transition:color .2s,transform .2s}.header-menu-entry:hover .header-menu-arrow{color:var(--accent);transform:translate(.25rem)}.footer{border-top:1px solid var(--border);background:color-mix(in srgb, var(--surface) 80%, transparent);padding:1.1rem 1.5rem}.footer-container{justify-content:space-between;align-items:center;gap:2rem;max-width:1100px;margin:0 auto;display:flex}.footer-left{align-items:center;gap:1rem;min-width:0;display:flex}.footer-logo{color:var(--text);letter-spacing:-.03em;white-space:nowrap;font-size:1rem;font-weight:800;text-decoration:none}.footer-copy{color:var(--subtle);white-space:nowrap;font-size:.9rem}.footer-links{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:.75rem;display:flex}.footer-links a{min-height:2.25rem;color:var(--muted);border:1px solid #0000;border-radius:999px;align-items:center;gap:.45rem;padding:.45rem .7rem;font-size:.9rem;font-weight:700;text-decoration:none;transition:color .2s,border-color .2s,background .2s,transform .2s;display:inline-flex}.footer-links a:hover{color:var(--accent);border-color:var(--border);background:var(--surface-solid);transform:translateY(-2px)}.footer-icon{flex-shrink:0;width:1.15rem;height:1.15rem}@media (width<=768px){.footer-container{flex-direction:column;align-items:flex-start;gap:1rem}.footer-left{flex-direction:column;align-items:flex-start;gap:.35rem}.footer-copy{white-space:normal}.footer-links{justify-content:flex-start}}.skills-grid{grid-template-columns:repeat(auto-fit,minmax(135px,1fr));gap:1rem;margin-top:2rem;display:grid}.skill-card{border:1px solid var(--border);background:var(--surface);min-height:120px;color:var(--text);cursor:pointer;border-radius:1rem;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;padding:1.25rem 1rem;transition:transform .2s,border-color .2s,background .2s,box-shadow .2s;display:flex}.skill-card i{font-size:2.5rem}.skill-card span{color:var(--muted);text-align:center;font-size:.9rem;font-weight:700}.skill-card:hover{border-color:var(--accent);transform:translateY(-4px)}.skill-card.active{border-color:var(--accent);background:var(--surface-solid);box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 20%, transparent)}.skill-card.active span{color:var(--text)}.selected-skill-card{border:1px solid var(--border);background:var(--surface);border-radius:1.25rem;margin-top:1.5rem;padding:1.5rem}.selected-skill-header{align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.selected-skill-icon{border:1px solid var(--border);background:var(--surface-solid);border-radius:1rem;place-items:center;width:3.25rem;height:3.25rem;display:grid}.selected-skill-icon i{font-size:2rem}.selected-skill-header span{color:var(--accent);letter-spacing:.12em;text-transform:uppercase;margin-bottom:.25rem;font-size:.75rem;font-weight:800;display:block}.selected-skill-header h3{color:var(--text);margin:0;font-size:1.35rem}.selected-skill-card p{max-width:760px;color:var(--muted);margin:0;font-size:1rem;line-height:1.8}@media (width<=768px){.skills-grid{grid-template-columns:repeat(2,1fr)}.skill-card{min-height:105px}.skill-card i{font-size:2.2rem}}.contact-layout{grid-template-columns:1.1fr .9fr;align-items:center;gap:2rem;margin-top:2rem;display:grid}.contact-text h2{color:var(--text);letter-spacing:-.04em;margin:0;font-size:clamp(2rem,5vw,3.5rem);line-height:1.05}.contact-text p{max-width:620px;color:var(--muted);margin:1.25rem 0 0;font-size:1.05rem;line-height:1.8}.contact-links{gap:1rem;display:grid}.contact-card{border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:1.25rem;align-items:center;gap:1rem;padding:1.25rem;text-decoration:none;transition:transform .2s,border-color .2s,background .2s;display:flex}.contact-card:hover{border-color:var(--accent);background:var(--surface-solid);transform:translateY(-4px)}.contact-icon{width:2rem;height:2rem;color:var(--accent);flex-shrink:0}.contact-card strong{color:var(--text);margin-bottom:.25rem;font-size:1rem;display:block}.contact-card span{color:var(--subtle);font-size:.9rem}@media (width<=850px){.contact-layout{grid-template-columns:1fr}}.projects-intro{max-width:680px;color:var(--muted);margin:1rem 0 0;font-size:1.05rem;line-height:1.8}.projects-grid{grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-top:2rem;display:grid}.project-card{border:1px solid var(--border);background:var(--surface);border-radius:1.25rem;flex-direction:column;min-height:100%;padding:1.4rem;transition:transform .2s,border-color .2s,background .2s,box-shadow .2s;display:flex}.project-card:hover{border-color:var(--accent);background:var(--surface-solid);transform:translateY(-5px);box-shadow:0 1.25rem 2.5rem #0000001f}.project-card-header span{color:var(--accent);letter-spacing:.12em;text-transform:uppercase;margin-bottom:.6rem;font-size:.75rem;font-weight:800;display:inline-block}.project-card-header h3{color:var(--text);letter-spacing:-.03em;margin:0;font-size:1.35rem;line-height:1.2}.project-description{color:var(--muted);margin:1rem 0 0;line-height:1.7}.project-tags{flex-wrap:wrap;gap:.5rem;margin-top:1.2rem;display:flex}.project-tags span{border:1px solid var(--border);background:color-mix(in srgb, var(--surface-solid) 75%, transparent);color:var(--subtle);border-radius:999px;padding:.35rem .65rem;font-size:.78rem;font-weight:700}.project-highlights{color:var(--muted);margin:1.2rem 0 0;padding-left:1.1rem;line-height:1.7}.project-highlights li::marker{color:var(--accent)}.project-links{flex-wrap:wrap;gap:.75rem;margin-top:auto;padding-top:1.3rem;display:flex}.project-links a{border:1px solid var(--border);color:var(--text);border-radius:999px;padding:.65rem .9rem;font-size:.9rem;font-weight:800;text-decoration:none;transition:color .2s,border-color .2s,background .2s,transform .2s}.project-links a:hover{color:var(--accent-text);border-color:var(--accent);background:var(--accent);transform:translateY(-2px)}@media (width<=950px){.projects-grid{grid-template-columns:1fr 1fr}}@media (width<=650px){.projects-grid{grid-template-columns:1fr}.project-card{padding:1.2rem}}.themes-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.25rem;margin-top:2.5rem;display:grid}.theme-card{border:1px solid var(--border);background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 10%, transparent), transparent 65%), var(--surface);min-height:190px;color:var(--text);border-radius:1.35rem;flex-direction:column;justify-content:space-between;gap:1.25rem;padding:1.25rem;transition:transform .22s,border-color .22s,background .22s,box-shadow .22s;display:flex;position:relative;overflow:hidden}.theme-card:hover{border-color:var(--accent);background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 16%, transparent), transparent 65%), var(--surface-solid);transform:translateY(-5px);box-shadow:0 1.5rem 3.5rem #0000002e}.theme-card.active{border-color:var(--accent);background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 18%, transparent), transparent 70%), var(--surface-solid)}.theme-card.active:after{content:"Selected";background:var(--accent);color:var(--accent-text);letter-spacing:.05em;text-transform:uppercase;border-radius:999px;padding:.3rem .6rem;font-size:.7rem;font-weight:900;position:absolute;top:1rem;right:1rem}.theme-card h3{color:var(--text);letter-spacing:-.03em;margin:0 0 .4rem;font-size:1.2rem;line-height:1.1}.theme-card p{max-width:90%;color:var(--subtle);margin:0;font-size:.9rem;line-height:1.5}.theme-card-actions{flex-wrap:wrap;gap:.65rem;display:flex}.theme-card-actions button{border:1px solid var(--border);background:color-mix(in srgb, var(--surface-solid) 70%, transparent);color:var(--muted);cursor:pointer;border-radius:999px;padding:.5rem .85rem;font-size:.85rem;font-weight:800;transition:color .2s,background .2s,border-color .2s,transform .2s}.theme-card-actions button:hover{color:var(--text);border-color:var(--accent);transform:translateY(-2px)}.theme-card-actions button.active{color:var(--accent-text);background:var(--accent);border-color:var(--accent)}.theme-card-actions button:focus-visible{outline:2px solid var(--accent);outline-offset:3px}@media (width<=768px){.themes-grid{grid-template-columns:1fr}.theme-card{min-height:165px}.theme-card.active:after{width:fit-content;margin-bottom:.75rem;position:static}}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:system-ui,sans-serif}button,a{font:inherit}.app{background:radial-gradient(circle at top left, var(--bg-glow), transparent 35%), var(--bg);min-height:100vh;color:var(--text);transition:background .25s,color .25s}.app.dark.theme-standard{--bg:#020617;--bg-glow:#38bdf81f;--header-bg:#020617d9;--surface:#0f172ab3;--surface-solid:#020617;--border:#1e293b;--text:#f8fafc;--muted:#cbd5e1;--subtle:#94a3b8;--accent:#38bdf8;--accent-text:#020617}.app.light.theme-standard{--bg:#f8fafc;--bg-glow:#2563eb1f;--header-bg:#f8fafcd9;--surface:#fffc;--surface-solid:#fff;--border:#e2e8f0;--text:#0f172a;--muted:#475569;--subtle:#64748b;--accent:#2563eb;--accent-text:#fff}.app.dark.theme-ocean{--bg:#031926;--bg-glow:#14b8a629;--header-bg:#031926db;--surface:#072536bf;--surface-solid:#041c2b;--border:#164e63;--text:#ecfeff;--muted:#a5f3fc;--subtle:#67e8f9;--accent:#14b8a6;--accent-text:#042f2e}.app.light.theme-ocean{--bg:#ecfeff;--bg-glow:#14b8a62e;--header-bg:#ecfeffdb;--surface:#ffffffd1;--surface-solid:#fff;--border:#a5f3fc;--text:#083344;--muted:#155e75;--subtle:#0e7490;--accent:#0d9488;--accent-text:#fff}.app.dark.theme-forest{--bg:#07130d;--bg-glow:#22c55e24;--header-bg:#07130ddb;--surface:#14532d38;--surface-solid:#0b1f14;--border:#14532d;--text:#f0fdf4;--muted:#bbf7d0;--subtle:#86efac;--accent:#22c55e;--accent-text:#052e16}.app.light.theme-forest{--bg:#f0fdf4;--bg-glow:#22c55e29;--header-bg:#f0fdf4db;--surface:#ffffffd1;--surface-solid:#fff;--border:#bbf7d0;--text:#052e16;--muted:#166534;--subtle:#15803d;--accent:#16a34a;--accent-text:#fff}.app.dark.theme-rose{--bg:#190711;--bg-glow:#f472b629;--header-bg:#190711db;--surface:#50072459;--surface-solid:#220817;--border:#831843;--text:#fff1f2;--muted:#fecdd3;--subtle:#fda4af;--accent:#f472b6;--accent-text:#500724}.app.light.theme-rose{--bg:#fff1f2;--bg-glow:#f472b62e;--header-bg:#fff1f2db;--surface:#ffffffd1;--surface-solid:#fff;--border:#fecdd3;--text:#500724;--muted:#9f1239;--subtle:#be123c;--accent:#e11d48;--accent-text:#fff}header{z-index:20;border-bottom:1px solid var(--border);background:var(--header-bg);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);position:sticky;top:0}nav{justify-content:space-between;align-items:center;gap:1.5rem;max-width:1200px;margin:0 auto;padding:1rem 1.5rem;display:flex}.logo{color:var(--text);letter-spacing:-.03em;font-size:1.2rem;font-weight:800;text-decoration:none}nav ul{gap:4.5rem;margin:0;padding:0;list-style:none;display:flex}nav>ul a{color:var(--muted);transform-origin:50%;font-size:.95rem;font-weight:700;text-decoration:none;transition:color .2s,transform .2s,text-shadow .2s;display:inline-block;position:relative}nav>ul a:hover,nav>ul a:focus-visible{color:var(--text);text-shadow:0 0 1.2rem color-mix(in srgb, var(--accent) 55%, transparent);outline:none;transform:scale(1.5)}nav>ul a:after{content:"";background:var(--accent);border-radius:999px;width:0;height:2px;transition:width .22s;position:absolute;bottom:-.35rem;left:50%;transform:translate(-50%)}nav>ul a:hover:after,nav>ul a:focus-visible:after{width:100%}.header-actions{align-items:center;gap:.75rem;display:flex}.language-switch{border:1px solid var(--border);background:var(--surface);border-radius:999px;gap:.35rem;padding:.25rem;display:flex}.language-switch button{color:var(--subtle);cursor:pointer;background:0 0;border:none;border-radius:999px;padding:.35rem .65rem;font-size:.8rem;font-weight:700;transition:background .2s,color .2s}.language-switch button:hover{color:var(--text)}.language-switch button.active{background:var(--accent);color:var(--accent-text)}.theme-switch{border:1px solid var(--border);background:var(--surface);cursor:pointer;border-radius:999px;width:3rem;height:1.65rem;padding:.15rem}.theme-switch-thumb{background:var(--accent);width:1.25rem;height:1.25rem;color:var(--accent-text);border-radius:50%;place-items:center;font-size:.75rem;transition:transform .2s;display:grid;transform:translate(0)}.app.light .theme-switch-thumb{transform:translate(1.25rem)}.about-section{align-items:center;min-height:100vh;padding:6rem 1.5rem;display:flex}.about-container{width:100%;max-width:1100px;margin:0 auto}.about-layout{grid-template-columns:1.05fr .95fr;align-items:center;gap:3rem;display:grid}.about-content{max-width:720px}.about-content h2{color:var(--text);letter-spacing:-.04em;margin:0 0 1.5rem;font-size:clamp(2.2rem,5vw,4.4rem);line-height:1.05}.about-content p{max-width:680px;color:var(--muted);margin:0 0 1rem;font-size:1.05rem;line-height:1.8}.about-code-card{border:1px solid var(--border);background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 10%, transparent), transparent), var(--surface);border-radius:1.25rem;transition:transform .25s,border-color .25s,box-shadow .25s,background .25s;overflow:hidden;transform:perspective(900px)rotateY(-4deg)rotateX(2deg);box-shadow:0 1.5rem 4rem #0000002e}.about-code-card:hover{border-color:var(--accent);transform:perspective(900px)rotateY(0)rotateX(0)translateY(-6px);box-shadow:0 2rem 5rem #0000003d}.code-window-header{border-bottom:1px solid var(--border);background:color-mix(in srgb, var(--surface-solid) 80%, transparent);justify-content:space-between;align-items:center;height:2.8rem;padding:0 1rem;display:flex}.code-dots{gap:.45rem;display:flex}.code-dots span{background:var(--border);border-radius:50%;width:.7rem;height:.7rem}.code-dots span:first-child{background:#ef4444}.code-dots span:nth-child(2){background:#f59e0b}.code-dots span:nth-child(3){background:#22c55e}.code-file-name{color:var(--subtle);font-size:.8rem;font-weight:700}.about-code-card pre{margin:0;padding:1.25rem;overflow-x:auto}.about-code-card code{font-family:JetBrains Mono,Fira Code,Consolas,monospace;font-size:.9rem;line-height:1.9}.code-line{white-space:nowrap;display:block}.line-number{width:2rem;color:var(--subtle);-webkit-user-select:none;user-select:none;margin-right:1rem;display:inline-block}.code-keyword{color:#c084fc}.code-variable{color:var(--accent)}.code-property{color:#60a5fa}.code-string{color:#22c55e}.code-operator{color:var(--muted)}.code-bracket{color:var(--text)}.about-highlights{grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:3rem;display:grid}.about-highlights div{border:1px solid var(--border);background:var(--surface);border-radius:1rem;padding:1.25rem;transition:transform .2s,border-color .2s,background .2s}.about-highlights div:hover{border-color:var(--accent);background:var(--surface-solid);transform:translateY(-4px)}.about-highlights strong{color:var(--text);margin-bottom:.35rem;font-size:.95rem;display:block}.about-highlights span{color:var(--subtle);font-size:.9rem}@media (width<=950px){.about-layout{grid-template-columns:1fr;gap:2rem}.about-code-card{transform:none}.about-code-card:hover{transform:translateY(-4px)}}@media (width<=768px){.about-section{padding:5rem 1.25rem}.about-highlights{grid-template-columns:1fr}.about-content h2{font-size:clamp(2rem,10vw,3rem)}.about-code-card code{font-size:.78rem}.about-code-card pre{padding:1rem}}.page-section{min-height:70vh;padding:6rem 1.5rem}.section-container{max-width:1100px;margin:0 auto}.section-container h2{color:var(--text);letter-spacing:-.04em;margin:0;font-size:clamp(2rem,5vw,3.5rem)}@media (width<=768px){nav{flex-wrap:wrap}nav ul{order:3;justify-content:center;gap:1rem;width:100%}.header-actions{margin-left:auto}.about-section{padding:5rem 1.25rem}.about-highlights{grid-template-columns:1fr}.about-content h2{font-size:clamp(2rem,10vw,3rem)}}main,.footer,nav ul,.header-actions{transition:filter .25s,opacity .25s,transform .25s}.app:has(.profile-hover-card:hover) main{filter:blur(4px);opacity:.45;transform:scale(.995)}.app:has(.profile-hover-card:focus-within) main{filter:blur(4px);opacity:.45;transform:scale(.995)}.app:has(.profile-hover-card:hover) .footer{filter:blur(4px);opacity:.45;transform:scale(.995)}.app:has(.profile-hover-card:focus-within) .footer{filter:blur(4px);opacity:.45;transform:scale(.995)}.app:has(.profile-hover-card:hover) nav ul{filter:blur(4px);opacity:.45;transform:scale(.995)}.app:has(.profile-hover-card:focus-within) nav ul{filter:blur(4px);opacity:.45;transform:scale(.995)}.app:has(.profile-hover-card:hover) .header-actions{filter:blur(4px);opacity:.45;transform:scale(.995)}.app:has(.profile-hover-card:focus-within) .header-actions{filter:blur(4px);opacity:.45;transform:scale(.995)}
