:root,[data-theme=dark]{--bg-primary:#000;--bg-secondary:#0a0a0a;--bg-card:#111;--bg-card-hover:#1a1a1a;--border-subtle:#ffffff0f;--border-medium:#ffffff1a;--border-hover:#ffffff26;--text-primary:#e8e8ed;--text-secondary:#8a8a9a;--text-tertiary:#5a5a6e;--text-accent:#c4b5fd;--accent:#a78bfa;--accent-dim:#a78bfa1f;--accent-glow:#a78bfa33;--tag-bg:#ffffff0d;--tag-text:#9a9ab0;--navbar-blur-bg:#000000d9;--mobile-nav-bg:#000000f2;--toggle-track:#1e1e2e;--toggle-thumb:#2a2a3d;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}[data-theme=light]{--bg-primary:#f8f8fc;--bg-secondary:#efeff5;--bg-card:#fff;--bg-card-hover:#f0f0f8;--border-subtle:#0000000f;--border-medium:#0000001a;--border-hover:#00000026;--text-primary:#1a1a2e;--text-secondary:#5a5a72;--text-tertiary:#8a8a9e;--text-accent:#7c3aed;--accent:#7c3aed;--accent-dim:#7c3aed14;--accent-glow:#7c3aed1f;--tag-bg:#0000000a;--tag-text:#6a6a82;--navbar-blur-bg:#f8f8fcd9;--mobile-nav-bg:#f8f8fcf2;--toggle-track:#e2e2ec;--toggle-thumb:#fff;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}:root{--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--space-xs:.25rem;--space-sm:.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--space-3xl:4rem;--space-4xl:6rem;--space-5xl:8rem;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-smooth:cubic-bezier(.4, 0, .2, 1);--duration-fast:.15s;--duration-normal:.3s;--duration-slow:.5s}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);background-color:var(--bg-primary);color:var(--text-primary);transition:background-color .4s var(--ease-smooth), color .4s var(--ease-smooth);line-height:1.6;overflow-x:hidden}a{color:inherit;text-decoration:none}ul,ol{list-style:none}img{max-width:100%;display:block}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}::selection{background:var(--accent-dim);color:var(--text-accent)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}.container{max-width:1100px;padding:0 var(--space-xl);margin:0 auto}@media (width<=768px){.container{padding:0 var(--space-lg)}}.mono{font-family:var(--font-mono)}.text-secondary{color:var(--text-secondary)}.text-accent{color:var(--text-accent)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes grain{0%,to{transform:translate(0)}10%{transform:translate(-5%,-10%)}20%{transform:translate(-15%,5%)}30%{transform:translate(7%,-25%)}40%{transform:translate(-5%,25%)}50%{transform:translate(-15%,10%)}60%{transform:translate(15%)}70%{transform:translateY(15%)}80%{transform:translate(3%,35%)}90%{transform:translate(-10%,10%)}}@keyframes slideUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-40px)}to{opacity:1;transform:translateY(0)}}@keyframes overlayIn{0%{opacity:0;-webkit-backdrop-filter:blur();backdrop-filter:blur()}to{opacity:1;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px)}}@keyframes detailSlideIn{0%{opacity:0;transform:translateY(60px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.animate-in{animation:fadeInUp .7s var(--ease-out) forwards;opacity:0}.animate-in-delay-1{animation-delay:.1s}.animate-in-delay-2{animation-delay:.2s}.animate-in-delay-3{animation-delay:.3s}.animate-in-delay-4{animation-delay:.4s}.animate-in-delay-5{animation-delay:.5s}.app{min-height:100vh;position:relative}.grain-overlay{pointer-events:none;z-index:9999;opacity:.025;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");width:200%;height:200%;position:fixed;top:-50%;left:-50%}[data-theme=light] .grain-overlay{opacity:.012}.theme-toggle{cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:0;display:flex}.theme-toggle-track{background:var(--toggle-track);border:1px solid var(--border-medium);width:44px;height:24px;transition:all var(--duration-normal) var(--ease-smooth);border-radius:12px;position:relative}.theme-toggle-thumb{background:var(--toggle-thumb);width:18px;height:18px;transition:all var(--duration-normal) var(--ease-out);border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:2px;box-shadow:0 1px 3px #0003}.theme-toggle-thumb.dark{left:2px}.theme-toggle-thumb.light{left:22px}.theme-toggle-thumb svg{width:12px;height:12px;color:var(--text-accent)}.theme-toggle:hover .theme-toggle-track{border-color:var(--accent)}.navbar{z-index:100;padding:var(--space-lg) 0;transition:all var(--duration-normal) var(--ease-smooth);position:fixed;top:0;left:0;right:0}.navbar.scrolled{background:var(--navbar-blur-bg);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border-subtle);padding:var(--space-md) 0}.navbar-inner{justify-content:space-between;align-items:center;display:flex}.navbar-logo{font-family:var(--font-mono);color:var(--text-primary);letter-spacing:-.02em;transition:color var(--duration-fast) var(--ease-smooth);font-size:1.1rem;font-weight:500}.navbar-logo:hover{color:var(--text-accent)}.navbar-links{align-items:center;gap:var(--space-xl);display:flex}.navbar-links a{color:var(--text-secondary);transition:color var(--duration-fast) var(--ease-smooth);font-size:.875rem;position:relative}.navbar-links a:after{content:"";background:var(--accent);width:0;height:1px;transition:width var(--duration-normal) var(--ease-out);position:absolute;bottom:-4px;left:0}.navbar-links a:hover{color:var(--text-primary)}.navbar-links a:hover:after{width:100%}.navbar-links .theme-toggle:after{display:none}.navbar-resume-btn{font-size:.8rem;font-family:var(--font-mono);border-radius:var(--radius-sm);transition:all var(--duration-normal) var(--ease-smooth);padding:.45rem 1rem;border:1px solid var(--border-medium)!important;color:var(--text-accent)!important}.navbar-resume-btn:after{display:none!important}.navbar-resume-btn:hover{background:var(--accent-dim);border-color:var(--accent)!important}.navbar-toggle{flex-direction:column;gap:5px;padding:4px;display:none}.navbar-toggle span{background:var(--text-secondary);width:22px;height:1.5px;transition:all var(--duration-normal) var(--ease-smooth);display:block}@media (width<=768px){.navbar-toggle{display:flex}.navbar-links{background:var(--mobile-nav-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:var(--space-xl);gap:var(--space-lg);border-bottom:1px solid var(--border-subtle);flex-direction:column;display:none;position:absolute;top:100%;left:0;right:0}.navbar-links.open{display:flex}}.hero{align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.hero-content{z-index:2;padding:var(--space-5xl) 0;position:relative}.hero-greeting{font-family:var(--font-mono);color:var(--text-accent);margin-bottom:var(--space-lg);align-items:center;gap:var(--space-sm);font-size:.875rem;display:flex}.hero-greeting .line{background:var(--accent);width:32px;height:1px;display:inline-block}.hero-name{letter-spacing:-.03em;color:var(--text-primary);margin-bottom:var(--space-md);font-size:clamp(2.5rem,7vw,4.5rem);font-weight:700;line-height:1.1}.hero-tagline{color:var(--text-secondary);letter-spacing:-.02em;margin-bottom:var(--space-2xl);max-width:600px;font-size:clamp(1.2rem,3vw,1.8rem);font-weight:300;line-height:1.3}.hero-tagline .highlight{color:var(--text-accent);font-weight:400}.hero-description{color:var(--text-tertiary);max-width:520px;margin-bottom:var(--space-2xl);font-size:1rem;line-height:1.7}.hero-cta{align-items:center;gap:var(--space-lg);flex-wrap:wrap;display:flex}.hero-cta-primary{align-items:center;gap:var(--space-sm);font-family:var(--font-mono);border:1px solid var(--accent);border-radius:var(--radius-sm);color:var(--text-accent);transition:all var(--duration-normal) var(--ease-smooth);padding:.75rem 1.5rem;font-size:.875rem;display:inline-flex}.hero-cta-primary:hover{background:var(--accent-dim);transform:translateY(-2px)}.hero-cta-secondary{color:var(--text-secondary);transition:color var(--duration-fast) var(--ease-smooth);align-items:center;gap:var(--space-sm);font-size:.875rem;display:inline-flex}.hero-cta-secondary:hover{color:var(--text-primary)}.hero-cta-secondary .arrow{transition:transform var(--duration-normal) var(--ease-out)}.hero-cta-secondary:hover .arrow{transform:translate(4px)}.hero-glow{background:radial-gradient(circle, var(--accent-glow) 0%, transparent 70%);filter:blur(100px);pointer-events:none;z-index:1;opacity:.4;width:500px;height:500px;position:absolute;top:20%;right:-10%}[data-theme=light] .hero-glow{opacity:.25}.hero-status{align-items:center;gap:var(--space-sm);font-family:var(--font-mono);color:var(--text-tertiary);margin-bottom:var(--space-2xl);background:var(--tag-bg);border-radius:var(--radius-xl);border:1px solid var(--border-subtle);padding:.35rem .75rem;font-size:.75rem;display:inline-flex}.hero-status .dot{background:#4ade80;border-radius:50%;width:6px;height:6px;animation:2s ease-in-out infinite pulse}.section{padding:var(--space-5xl) 0;position:relative}.section-label{font-family:var(--font-mono);color:var(--text-accent);margin-bottom:var(--space-md);align-items:center;gap:var(--space-sm);font-size:.8rem;display:flex}.section-label .num{color:var(--accent)}.section-title{letter-spacing:-.02em;margin-bottom:var(--space-3xl);color:var(--text-primary);font-size:clamp(1.5rem,4vw,2rem);font-weight:600}.section-divider{background:var(--border-subtle);border:none;width:100%;height:1px}.about-content{gap:var(--space-4xl);grid-template-columns:1fr 1fr;align-items:start;display:grid}.about-text p{color:var(--text-secondary);margin-bottom:var(--space-lg);font-size:1rem;line-height:1.8}.about-text p strong,.about-text p .hl{color:var(--text-primary);font-weight:500}.about-tech{padding-top:var(--space-sm)}.about-tech h3{font-family:var(--font-mono);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.1em;margin-bottom:var(--space-lg);font-size:.8rem}.tech-grid{gap:var(--space-sm) var(--space-lg);grid-template-columns:repeat(2,1fr);display:grid}.tech-item{align-items:center;gap:var(--space-sm);font-family:var(--font-mono);color:var(--text-secondary);padding:var(--space-sm) 0;transition:color var(--duration-fast) var(--ease-smooth);font-size:.85rem;display:flex}.tech-item:before{content:"▹";color:var(--accent);font-size:.7rem}.tech-item:hover{color:var(--text-primary)}@media (width<=768px){.about-content{gap:var(--space-2xl);grid-template-columns:1fr}}.experience-timeline{padding-left:var(--space-2xl);position:relative}.experience-timeline:before{content:"";background:var(--border-subtle);width:1px;height:100%;position:absolute;top:0;left:11px}.experience-item{padding-bottom:var(--space-2xl);gap:var(--space-xl);grid-template-columns:140px 1fr;display:grid;position:relative}.experience-item:last-child{padding-bottom:0}.experience-dot{left:calc(-1 * var(--space-2xl) + 7px);background:var(--bg-primary);border:2px solid var(--accent);z-index:1;width:9px;height:9px;transition:background var(--duration-normal) var(--ease-smooth);border-radius:50%;position:absolute;top:6px}.experience-item:hover .experience-dot{background:var(--accent)}.experience-period{color:var(--text-tertiary);padding-top:2px;font-size:.8rem}.experience-content{position:relative}.experience-role{color:var(--text-primary);margin-bottom:var(--space-sm);font-size:1.05rem;font-weight:600}.experience-org{color:var(--text-accent);font-weight:500}.experience-description{color:var(--text-secondary);margin-bottom:var(--space-md);font-size:.9rem;line-height:1.7}.experience-skills{gap:var(--space-sm);flex-wrap:wrap;display:flex}@media (width<=768px){.experience-item{gap:var(--space-xs);grid-template-columns:1fr}.experience-period{order:-1}}.pj{align-items:center;height:100vh;display:flex;position:relative;overflow:hidden}.pj-glow{pointer-events:none;z-index:0;filter:blur(120px);opacity:.35;transition:background .8s var(--ease-out);position:absolute;inset:0}[data-theme=light] .pj-glow{opacity:.2}.pj-bg-num{opacity:.15;pointer-events:none;font-size:clamp(14rem,30vw,24rem);font-weight:900;font-family:var(--font-sans);transition:all .6s var(--ease-out);-webkit-user-select:none;user-select:none;z-index:1;line-height:1;position:absolute;top:50%;right:-2%;transform:translateY(-50%)}[data-theme=light] .pj-bg-num{opacity:.25}.pj-sidebar{align-items:center;gap:var(--space-xl);z-index:10;flex-direction:column;display:flex;position:absolute;top:50%;left:clamp(1rem,3vw,2.5rem);transform:translateY(-50%)}.pj-counter{flex-direction:column;align-items:center;gap:6px;display:flex}.pj-counter-now{transition:color .5s var(--ease-out);font-size:1.6rem;font-weight:700}.pj-counter-line{background:var(--border-medium);width:1px;height:24px;display:block}.pj-counter-total{color:var(--text-tertiary);font-size:.85rem}.pj-dots{flex-direction:column;gap:10px;display:flex}.pj-dot{background:var(--border-medium);cursor:pointer;width:10px;height:10px;transition:all var(--duration-normal) var(--ease-out);border:none;border-radius:50%;padding:0}.pj-dot:hover{background:var(--text-secondary);transform:scale(1.3)}.pj-dot.active{transform:scale(1.5)}.pj-hint{writing-mode:vertical-rl;color:var(--text-tertiary);letter-spacing:.2em;text-transform:uppercase;opacity:.4;font-size:.6rem}.pj-center{z-index:5;max-width:650px;padding:0 var(--space-xl);margin-left:clamp(70px,8vw,120px);position:relative}.pj-center .section-label{margin-bottom:var(--space-xl)}.pj-slide,.pj-slide--transitioning{animation:pjSlideIn .6s var(--ease-out) forwards}@keyframes pjSlideIn{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}.pj-name{letter-spacing:-.04em;margin-bottom:var(--space-sm);color:var(--text-primary);font-size:clamp(2.5rem,6vw,4rem);font-weight:800;line-height:1.05}.pj-tagline{font-family:var(--font-mono);margin-bottom:var(--space-2xl);transition:color .5s var(--ease-out);font-size:.9rem}.pj-desc{color:var(--text-secondary);margin-bottom:var(--space-xl);max-width:520px;font-size:1.05rem;line-height:1.8}.pj-tags{gap:var(--space-sm);margin-bottom:var(--space-2xl);flex-wrap:wrap;display:flex}.pj-actions{align-items:center;gap:var(--space-xl);margin-bottom:var(--space-2xl);display:flex}.pj-more-btn{align-items:center;gap:var(--space-sm);font-family:var(--font-mono);border:1px solid var(--btn-color,var(--accent));border-radius:var(--radius-sm);color:var(--btn-color,var(--accent));cursor:pointer;transition:all var(--duration-normal) var(--ease-smooth);background:0 0;padding:.75rem 1.5rem;font-size:.9rem;font-weight:500;display:inline-flex}.pj-more-btn svg{transition:transform var(--duration-normal) var(--ease-out)}.pj-more-btn:hover{background:var(--accent-dim);transform:translateY(-3px);box-shadow:0 8px 30px #00000026}.pj-more-btn:hover svg{transform:translate(5px)}.pj-links{align-items:center;gap:var(--space-md);display:flex}.pj-progress{background:var(--border-subtle);width:160px;height:2px;margin-bottom:var(--space-xl);border-radius:1px;overflow:hidden}.pj-progress-fill{height:100%;transition:width .6s var(--ease-out), background .6s var(--ease-out);border-radius:1px}.pj-scroll-down{align-items:center;gap:var(--space-sm);color:var(--text-tertiary);opacity:.5;font-size:.7rem;display:flex}.pj-scroll-arrow{font-size:1rem;animation:2s ease-in-out infinite pjBounce}@keyframes pjBounce{0%,to{transform:translateY(0)}50%{transform:translateY(5px)}}.project-link{color:var(--text-tertiary);transition:all var(--duration-fast) var(--ease-smooth);align-items:center;display:flex}.project-link:hover{color:var(--text-accent);transform:translateY(-2px)}.project-link svg{width:20px;height:20px}.project-tags{gap:var(--space-sm);flex-wrap:wrap;display:flex}.project-tag{font-family:var(--font-mono);color:var(--tag-text);background:var(--tag-bg);border-radius:var(--radius-sm);border:1px solid var(--border-subtle);transition:all var(--duration-fast) var(--ease-smooth);padding:.3rem .7rem;font-size:.75rem}.project-tag:hover{border-color:var(--border-medium);color:var(--text-secondary)}@media (width<=768px){.pj{height:auto;min-height:100vh;padding:var(--space-4xl) 0}.pj-sidebar{left:var(--space-md);gap:var(--space-md);flex-direction:column;position:absolute}.pj-center{padding:0 var(--space-md);margin-left:50px}.pj-name{font-size:clamp(1.8rem,8vw,2.5rem)}.pj-bg-num{font-size:10rem;right:-15%}}.project-detail-overlay{z-index:1000;padding:var(--space-xl);animation:overlayIn .3s var(--ease-smooth) forwards;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}[data-theme=light] .project-detail-overlay{background:#fff9}.project-detail{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);width:100%;max-width:700px;max-height:85vh;padding:var(--space-2xl);animation:detailSlideIn .4s var(--ease-out) forwards;position:relative;overflow-y:auto}.project-detail::-webkit-scrollbar{width:4px}.project-detail::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:2px}.project-detail-close{top:var(--space-lg);right:var(--space-lg);background:var(--tag-bg);border:1px solid var(--border-subtle);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;transition:all var(--duration-normal) var(--ease-smooth);z-index:10;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute}.project-detail-close:hover{color:var(--text-primary);border-color:var(--border-medium);background:var(--bg-card-hover)}.project-detail-close svg{width:16px;height:16px}.project-detail-header{margin-bottom:var(--space-2xl);padding-right:var(--space-2xl)}.project-detail-num{margin-bottom:var(--space-sm);font-size:.8rem;display:block}.project-detail-name{letter-spacing:-.03em;margin-bottom:var(--space-sm);font-size:clamp(1.5rem,4vw,2rem);font-weight:700}.project-detail-tagline{font-family:var(--font-mono);color:var(--text-secondary);margin-bottom:var(--space-xl);font-size:.85rem}.project-detail-actions{gap:var(--space-md);flex-wrap:wrap;display:flex}.project-detail-btn{align-items:center;gap:var(--space-sm);font-family:var(--font-mono);border:1px solid var(--border-medium);border-radius:var(--radius-sm);color:var(--text-secondary);transition:all var(--duration-normal) var(--ease-smooth);padding:.55rem 1rem;font-size:.8rem;display:inline-flex}.project-detail-btn:hover{color:var(--text-primary);border-color:var(--border-hover);background:var(--tag-bg)}.project-detail-btn.primary:hover{background:var(--accent-dim)}.project-detail-btn svg{width:14px;height:14px}.project-detail-body{gap:var(--space-2xl);flex-direction:column;display:flex}.project-detail-section h3{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;color:var(--text-tertiary);margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid var(--border-subtle);font-size:.8rem}.project-detail-section p{color:var(--text-secondary);margin-bottom:var(--space-md);font-size:.95rem;line-height:1.8}.project-detail-section p:last-child{margin-bottom:0}.project-detail-features{gap:var(--space-sm) var(--space-xl);grid-template-columns:1fr 1fr;display:grid}.project-detail-features li{align-items:center;gap:var(--space-sm);color:var(--text-secondary);padding:var(--space-xs) 0;font-size:.9rem;display:flex}.feature-check{flex-shrink:0;align-items:center;display:flex}@media (width<=768px){.project-detail{max-height:90vh;padding:var(--space-xl)}.project-detail-features{grid-template-columns:1fr}}.contact-inner{text-align:center;max-width:550px;margin:0 auto}.contact-inner .section-label{justify-content:center}.contact-heading{letter-spacing:-.03em;margin-bottom:var(--space-lg);font-size:clamp(1.8rem,5vw,2.5rem);font-weight:600}.contact-text{color:var(--text-secondary);margin-bottom:var(--space-2xl);font-size:1rem;line-height:1.7}.contact-links{justify-content:center;align-items:center;gap:var(--space-xl);flex-wrap:wrap;display:flex}.contact-link{align-items:center;gap:var(--space-sm);font-family:var(--font-mono);color:var(--text-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);transition:all var(--duration-normal) var(--ease-smooth);padding:.6rem 1.2rem;font-size:.85rem;display:flex}.contact-link:hover{color:var(--text-accent);border-color:var(--accent);background:var(--accent-dim);transform:translateY(-2px)}.contact-link svg{width:16px;height:16px}.footer{padding:var(--space-2xl) 0;border-top:1px solid var(--border-subtle)}.footer-inner{justify-content:space-between;align-items:center;display:flex}.footer-credit{font-family:var(--font-mono);color:var(--text-tertiary);font-size:.75rem}.footer-links{gap:var(--space-lg);display:flex}.footer-link{color:var(--text-tertiary);transition:color var(--duration-fast) var(--ease-smooth)}.footer-link:hover{color:var(--text-accent)}.footer-link svg{width:18px;height:18px}@media (width<=768px){.footer-inner{gap:var(--space-lg);flex-direction:column}}.reveal{opacity:0;transition:all .8s var(--ease-out);transform:translateY(30px)}.reveal.visible{opacity:1;transform:translateY(0)}.cert-grid{gap:var(--space-xl);margin-top:var(--space-3xl);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.cert-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-xl);text-align:left;transition:all var(--duration-normal) var(--ease-smooth);cursor:pointer;flex-direction:column;display:flex;position:relative;overflow:hidden}.cert-card:before{content:"";background:var(--accent);transform-origin:0;width:100%;height:2px;transition:transform var(--duration-normal) var(--ease-out);position:absolute;top:0;left:0;transform:scaleX(0)}.cert-card:hover{border-color:var(--border-hover);background:var(--bg-card-hover);transform:translateY(-4px);box-shadow:0 10px 30px #0000001a}.cert-card:hover:before{transform:scaleX(1)}.cert-card-icon{color:var(--text-accent);margin-bottom:var(--space-lg)}.cert-card-info{flex-grow:1}.cert-card-title{color:var(--text-primary);margin-bottom:var(--space-xs);font-size:1.1rem;font-weight:600;line-height:1.4}.cert-card-issuer{color:var(--text-secondary);margin-bottom:var(--space-md);font-size:.9rem}.cert-card-date{color:var(--text-tertiary);background:var(--tag-bg);border-radius:var(--radius-sm);padding:4px 8px;font-size:.75rem;display:inline-block}.cert-card-view{color:var(--accent);margin-top:var(--space-lg);opacity:0;transition:all var(--duration-normal) var(--ease-smooth);font-size:.85rem;font-weight:500;transform:translate(-10px)}.cert-card:hover .cert-card-view{opacity:1;transform:translate(0)}.cert-lightbox-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;padding:var(--space-xl);animation:fadeIn .3s var(--ease-out);background:#000c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.cert-lightbox{background:var(--bg-card);border:1px solid var(--border-medium);border-radius:var(--radius-lg);width:100%;max-width:800px;max-height:90vh;animation:detailSlideIn .4s var(--ease-out);flex-direction:column;display:flex;position:relative;overflow-y:auto}.cert-lightbox-close{top:var(--space-md);right:var(--space-md);background:var(--bg-secondary);border:1px solid var(--border-subtle);width:32px;height:32px;color:var(--text-secondary);transition:all var(--duration-fast) var(--ease-smooth);z-index:10;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute}.cert-lightbox-close:hover{background:var(--border-hover);color:var(--text-primary);transform:rotate(90deg)}.cert-lightbox-close svg{width:16px;height:16px}.cert-lightbox-img-wrap{background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle);width:100%;min-height:300px;padding:var(--space-2xl);justify-content:center;align-items:center;display:flex}.cert-lightbox-img{object-fit:contain;border:1px solid var(--border-subtle);max-width:100%;max-height:500px;box-shadow:0 10px 40px #0003}.cert-lightbox-placeholder{text-align:center;color:var(--text-secondary)}.cert-lightbox-info{padding:var(--space-2xl);text-align:center}.cert-lightbox-info h3{color:var(--text-primary);margin-bottom:var(--space-xs);font-size:1.5rem}.cert-lightbox-info p{color:var(--text-secondary);font-size:.95rem}
