@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600&family=Cal+Sans:wght@400&display=swap";@import "https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800;900&family=JetBrains+Mono:wght@400;500&display=swap";:root{--bg:#fafaf9;--bg2:#f3f2f0;--surface:#eeecea;--border:#00000014;--border2:#00000024;--text:#0d0d0d;--text2:#525252;--text3:#a3a3a3;--accent:#4285f4;--accent2:#3b82f6;--adim:#2b6cb01a;--fh:"Plus Jakarta Sans", system-ui, sans-serif;--fm:"JetBrains Mono", monospace;--max:1140px;--pad:clamp(1.5rem,5vw,3rem);--nav:60px;--ease:cubic-bezier(.16,1,.3,1);--ease2:cubic-bezier(.4,0,.2,1)}[data-theme=dark]{--bg:#080808;--bg2:#111;--surface:#1a1a1a;--border:#ffffff12;--border2:#ffffff21;--text:#f5f5f0;--text2:#a8a8a0;--text3:#555550;--accent:#60a5fa;--accent2:#93c5fd;--adim:#60a5fa1a}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{font-family:var(--fh);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;cursor:auto;line-height:1.6;overflow-x:hidden}a{color:inherit;text-decoration:none}button{cursor:pointer;font:inherit;background:0 0;border:none;padding:0}.container{max-width:var(--max);padding:0 var(--pad);margin:0 auto}img{max-width:100%;display:block}.nav{height:var(--nav);z-index:500;border-bottom:1px solid #0000;transition:background .4s,border-color .4s;position:fixed;top:0;left:0;right:0}.nav.solid{-webkit-backdrop-filter:blur(24px)saturate(180%);backdrop-filter:blur(24px)saturate(180%);border-color:var(--border);background:#080808e0}[data-theme=light] .nav.solid{background:#fafaf9e0}.nav-wrap{justify-content:space-between;align-items:center;height:100%;display:flex}.nav-logo{font-family:var(--fh);letter-spacing:-.04em;color:var(--text);font-size:1.05rem;font-weight:800;transition:opacity .2s}.nav-logo:hover{opacity:.6}.nav-logo span{color:var(--accent)}.nav-center{align-items:center;gap:.15rem;display:flex}.nav-link{color:var(--text2);border-radius:8px;padding:.35rem .75rem;font-size:.8rem;font-weight:500;transition:color .18s,background .18s}.nav-link:hover,.nav-link.on{color:var(--text);background:var(--surface)}.nav-right{align-items:center;gap:.5rem;display:flex}.nav-cta{color:var(--bg);background:var(--text);transition:opacity .18s,transform .18s var(--ease);border-radius:8px;padding:.38rem 1rem;font-size:.8rem;font-weight:600}.nav-cta:hover{opacity:.8;transform:translateY(-1px)}.theme-btn{width:34px;height:34px;color:var(--text2);background:var(--surface);border-radius:50%;justify-content:center;align-items:center;transition:background .18s,color .18s;display:flex}.theme-btn:hover{background:var(--border2);color:var(--text)}.theme-btn svg{width:15px;height:15px}.nav-burger{background:var(--surface);border-radius:8px;flex-direction:column;gap:5px;padding:8px;display:none}.nav-burger span{background:var(--text);width:18px;height:1.5px;transition:all .28s var(--ease);border-radius:2px;display:block}.nav-burger.x span:first-child{transform:translateY(6.5px)rotate(45deg)}.nav-burger.x span:nth-child(2){opacity:0;transform:scaleX(0)}.nav-burger.x span:nth-child(3){transform:translateY(-6.5px)rotate(-45deg)}.nav-mob{inset:var(--nav) 0 0 0;background:var(--bg);z-index:499;flex-direction:column;justify-content:center;align-items:center;gap:2rem;display:flex;position:fixed}.nav-mob a{font-family:var(--fh);letter-spacing:-.04em;color:var(--text);font-size:2rem;font-weight:800;transition:color .18s}.nav-mob a:hover{color:var(--accent)}.hero{min-height:100svh;padding-top:var(--nav);background:var(--bg);align-items:center;display:flex;position:relative;overflow:hidden}.hero-noise{opacity:.04;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:200px;position:absolute;inset:0}.hero-tag{font-family:var(--fm);color:var(--accent);letter-spacing:.12em;text-transform:uppercase;background:var(--adim);border:1px solid color-mix(in srgb,var(--accent) 25%,transparent);border-radius:100px;align-items:center;gap:.5rem;margin-bottom:2.5rem;padding:.3rem .75rem;font-size:.68rem;display:inline-flex;overflow:hidden}.hero-tag-dot{background:var(--accent);border-radius:50%;width:5px;height:5px;animation:2s ease-in-out infinite dotpulse}@keyframes dotpulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}.hero-h{letter-spacing:-.06em;color:var(--text);margin-bottom:2rem;padding-bottom:.15em;font-size:clamp(3.8rem,9vw,8rem);font-weight:900;line-height:.92}.hero-h .line{display:block;overflow:visible}.hero-h .word{display:inline-block;transform:translateY(110%)}.hero-h .accent-w{color:var(--accent)}.hero-sub{color:var(--text2);opacity:0;max-width:520px;margin-bottom:3rem;font-size:clamp(1rem,1.8vw,1.25rem);font-weight:400;line-height:1.65;transform:translateY(20px)}.hero-actions{opacity:0;flex-wrap:wrap;gap:.75rem;display:flex;transform:translateY(20px)}.btn-primary{color:var(--bg);background:var(--text);transition:opacity .2s,transform .25s var(--ease);border-radius:10px;align-items:center;gap:.5rem;padding:.75rem 1.75rem;font-size:.875rem;font-weight:700;display:inline-flex}.btn-primary:hover{opacity:.85;transform:translateY(-3px)}.btn-ghost{color:var(--text);background:var(--surface);border:1px solid var(--border2);transition:border-color .2s,transform .25s var(--ease);border-radius:10px;align-items:center;gap:.5rem;padding:.75rem 1.75rem;font-size:.875rem;font-weight:600;display:inline-flex}.btn-ghost:hover{border-color:var(--text2);transform:translateY(-3px)}.hero-scroll{opacity:0;flex-direction:column;align-items:center;gap:.5rem;display:flex;position:absolute;bottom:2.5rem;left:50%;transform:translate(-50%)}.hero-scroll-track{background:var(--border2);width:1px;height:48px;position:relative;overflow:hidden}.hero-scroll-thumb{background:var(--accent);width:100%;height:100%;animation:1.6s ease-in-out infinite scrolldrip;position:absolute;top:-100%;left:0}@keyframes scrolldrip{0%{top:-100%}to{top:100%}}.hero-scroll-lbl{font-family:var(--fm);color:var(--text3);letter-spacing:.14em;text-transform:uppercase;font-size:.55rem}.hero-stats{opacity:0;justify-content:center;gap:3rem;padding-top:2rem;display:flex;transform:translateY(20px)}.hstat-n{letter-spacing:-.05em;color:var(--text);font-size:2rem;font-weight:900;line-height:1;display:block}.hstat-l{font-family:var(--fm);color:var(--text3);letter-spacing:.08em;text-transform:uppercase;font-size:.58rem}.sec{padding:9rem 0}.sec-alt{background:var(--bg2)}.stag{font-family:var(--fm);color:var(--accent);letter-spacing:.18em;text-transform:uppercase;align-items:center;gap:.55rem;margin-bottom:1rem;font-size:.63rem;display:flex}.stag:before{content:"";background:var(--accent);width:20px;height:1.5px}.sec-h{letter-spacing:-.05em;color:var(--text);padding-bottom:.1em;font-size:clamp(2.2rem,4.5vw,3.2rem);font-weight:900;line-height:1.05}.about-grid{grid-template-columns:1.1fr .9fr;align-items:start;gap:6rem;display:grid}.about-copy p{color:var(--text2);margin-bottom:1.2rem;font-size:1.05rem;line-height:1.82}.about-copy p:last-child{margin:0}.hl{color:var(--text);font-weight:600}.stack-wrap{flex-wrap:wrap;gap:.45rem;margin-top:1.5rem;display:flex}.stack-pill{font-family:var(--fm);color:var(--text2);background:var(--surface);border:1px solid var(--border);transition:border-color .18s,color .18s,transform .2s var(--ease);border-radius:6px;padding:.38rem .82rem;font-size:.72rem}.stack-pill:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}.tl{padding-left:2rem;position:relative}.tl:before{content:"";background:var(--border);width:1px;position:absolute;top:.4rem;bottom:0;left:0}.tl-item{padding-bottom:3rem;position:relative}.tl-item:last-child{padding-bottom:0}.tl-dot{background:var(--bg);border:2px solid var(--border2);z-index:1;border-radius:50%;width:10px;height:10px;transition:border-color .4s,background .4s,box-shadow .4s;position:absolute;top:.38rem;left:-2rem;transform:translate(-4px)}.tl-item.vis .tl-dot{border-color:var(--accent);background:var(--accent);box-shadow:0 0 0 4px var(--adim)}.tl-period{font-family:var(--fm);color:var(--text3);letter-spacing:.06em;margin-bottom:.35rem;font-size:.65rem}.tl-role{letter-spacing:-.025em;color:var(--text);margin-bottom:.12rem;font-size:1.05rem;font-weight:700}.tl-org{color:var(--accent)}.tl-desc{color:var(--text2);margin:.5rem 0 .75rem;font-size:.9375rem;line-height:1.72}.tl-desc a{color:var(--accent);text-underline-offset:3px;text-decoration:underline}.tl-skills{flex-wrap:wrap;gap:.35rem;display:flex}.tl-skill{font-family:var(--fm);color:var(--accent);background:var(--adim);border:1px solid color-mix(in srgb,var(--accent) 25%,transparent);border-radius:4px;padding:.16rem .48rem;font-size:.6rem}.pj-wrap{position:relative}.pj-scene{background:var(--bg);height:100svh;position:sticky;top:0;overflow:hidden}.pj-hdr{z-index:20;padding:1.4rem var(--pad) 0;pointer-events:none;justify-content:space-between;align-items:center;display:flex;position:absolute;top:0;left:0;right:0}.pj-hdr-label{font-family:var(--fm);color:var(--accent);letter-spacing:.18em;text-transform:uppercase;align-items:center;gap:.45rem;font-size:.62rem;display:flex}.pj-hdr-label:before{content:"";background:var(--accent);width:14px;height:1.5px}.pj-hdr-count{font-family:var(--fm);color:var(--text3);font-size:.7rem}.pj-hdr-count strong{color:var(--text);font-size:.85rem}.pj-cards{position:absolute;inset:0}.pj-card{will-change:transform,opacity;transform-origin:50%;backface-visibility:hidden;transform-style:preserve-3d;pointer-events:auto;grid-template-columns:1fr 1fr;display:grid;position:absolute;inset:0}.pj-card-l{border-right:1px solid var(--border);background:var(--bg);flex-direction:column;justify-content:center;padding:4.5rem 3rem 4rem clamp(2.5rem,5vw,5rem);display:flex;position:relative;overflow:hidden}.pj-ghost{letter-spacing:-.06em;opacity:.05;pointer-events:none;-webkit-user-select:none;user-select:none;z-index:0;color:var(--text);font-size:clamp(12rem,28vw,24rem);font-weight:900;line-height:1;position:absolute;bottom:-.12em;left:-.04em}.pj-dots{z-index:10;flex-direction:column;gap:.5rem;display:flex;position:absolute;top:50%;left:.9rem;transform:translateY(-50%)}.pj-dot{background:var(--border2);border-radius:50%;width:7px;height:7px;transition:background .25s,transform .25s,box-shadow .25s}.pj-dot.on{transform:scale(1.6)}.pj-content{z-index:1;position:relative}.pj-num{font-family:var(--fm);color:var(--text3);letter-spacing:.14em;text-transform:uppercase;align-items:center;gap:.4rem;margin-bottom:.5rem;font-size:.6rem;display:flex}.pj-num-dot{border-radius:50%;width:5px;height:5px}.pj-name{letter-spacing:-.055em;color:var(--text);flex-wrap:wrap;align-items:center;gap:.55rem;margin-bottom:.5rem;font-size:clamp(2.5rem,4.5vw,4rem);font-weight:900;line-height:.88;display:flex}.pj-indev{font-family:var(--fm);letter-spacing:.1em;text-transform:uppercase;color:#a16207;background:#eab3081a;border:1px solid #eab3084d;border-radius:4px;padding:3px 8px;font-size:.45rem}[data-theme=dark] .pj-indev{color:#fcd34d;background:#fcd34d14;border-color:#fcd34d40}.pj-tagline{margin-bottom:.9rem;font-size:.9rem;font-weight:600}.pj-desc{color:var(--text2);max-width:400px;margin-bottom:1.2rem;font-size:.875rem;line-height:1.72}.pj-tags{flex-wrap:wrap;gap:.75rem;margin-bottom:2rem;display:flex}.pj-tag{font-family:var(--fm);color:var(--text2);background:var(--surface);border:1px solid var(--border);border-radius:4px;padding:.15rem .8rem;font-size:.58rem}.pj-btns{flex-wrap:wrap;align-items:center;gap:1rem;display:flex}.pj-btn{transition:transform .2s var(--ease),box-shadow .2s;z-index:20;cursor:pointer;background:0 0;border:1.5px solid;border-radius:8px;justify-content:center;align-items:center;gap:.35rem;padding:.5rem 1.1rem;font-size:.78rem;font-weight:700;display:inline-flex;position:relative;transform:translateZ(0)}.pj-btn:hover{transform:translateY(-2px)}.pj-btn svg{pointer-events:none}.pj-ic{border:1.5px solid var(--border2);width:34px;height:34px;color:var(--text2);transition:border-color .18s,color .18s,transform .2s var(--ease);border-radius:8px;justify-content:center;align-items:center;display:inline-flex}.pj-ic:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}.pj-ic svg{width:15px;height:15px}.pj-prog{background:var(--border);height:2px;position:absolute;bottom:0;left:0;right:0}.pj-prog-fill{border-radius:1px;height:100%}.pj-card-r{background:var(--bg2);flex-direction:column;justify-content:center;padding:4.5rem clamp(2rem,5vw,4rem) 4rem 3rem;display:flex;overflow:hidden}.pj-feat-lbl{font-family:var(--fm);color:var(--text3);letter-spacing:.14em;text-transform:uppercase;margin-bottom:.3rem;font-size:.6rem}.pj-feat-title{letter-spacing:-.02em;color:var(--text);margin-bottom:1.3rem;font-size:1.05rem;font-weight:700}.pj-feats{flex-direction:column;gap:.48rem;display:flex}.pj-feat{background:var(--bg);border:1px solid var(--border);border-radius:10px;align-items:center;gap:.8rem;padding:.78rem .9rem;transition:border-color .2s;display:flex}.pj-feat:hover{border-color:var(--border2)}.feat-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.feat-txt{color:var(--text2);font-size:.835rem;font-weight:500;line-height:1.4}.pj-cue{font-family:var(--fm);color:var(--text3);letter-spacing:.12em;text-transform:uppercase;opacity:.5;align-items:center;gap:.45rem;margin-top:1.3rem;font-size:.57rem;display:flex}@keyframes bob{0%,to{transform:translateY(0)}50%{transform:translateY(5px)}}.pj-cue-arr{animation:1.5s ease-in-out infinite bob}.det-ov{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);z-index:999;overscroll-behavior:contain;background:#0009;justify-content:center;align-items:center;padding:1.5rem;animation:.18s fadein;display:flex;position:fixed;inset:0;overflow-y:auto}@keyframes fadein{0%{opacity:0}to{opacity:1}}@keyframes popin{0%{opacity:0;transform:scale(.93)translateY(20px)}to{opacity:1;transform:none}}.det{background:var(--bg);width:100%;max-width:700px;max-height:88vh;animation:popin .3s var(--ease);overscroll-behavior:contain;border-radius:20px;position:relative;overflow-y:auto;box-shadow:0 40px 100px #0003}.det::-webkit-scrollbar{width:4px}.det::-webkit-scrollbar-track{background:var(--bg2)}.det::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}.det-close{float:right;background:var(--surface);width:30px;height:30px;color:var(--text2);z-index:1;border-radius:8px;justify-content:center;align-items:center;margin:.75rem .75rem 0 0;transition:background .15s,color .15s;display:flex;position:sticky;top:.75rem}.det-close:hover{background:var(--border2);color:var(--text)}.det-head{border-bottom:1px solid var(--border);clear:both;padding:1.75rem 1.75rem 1.35rem}.det-n{font-family:var(--fm);letter-spacing:.12em;text-transform:uppercase;margin-bottom:.4rem;font-size:.65rem;display:block}.det-title{letter-spacing:-.04em;color:var(--text);margin-bottom:.2rem;font-size:1.7rem;font-weight:900}.det-sub{color:var(--text2);margin-bottom:1rem;font-size:.875rem}.det-acts{flex-wrap:wrap;gap:.5rem;display:flex}.det-btn{border:1.5px solid var(--border2);color:var(--text2);border-radius:7px;align-items:center;gap:.35rem;padding:.42rem .88rem;font-size:.78rem;font-weight:600;transition:all .18s;display:inline-flex}.det-btn:hover{border-color:var(--text3);color:var(--text)}.det-btn svg{width:13px;height:13px}.det-body{padding:1.35rem 1.75rem 1.75rem}.det-sec{margin-bottom:1.5rem}.det-sec h3{font-family:var(--fm);color:var(--text3);letter-spacing:.1em;text-transform:uppercase;margin-bottom:.6rem;font-size:.68rem;font-weight:600}.det-sec p{color:var(--text2);margin-bottom:.65rem;font-size:.9175rem;line-height:1.72}.det-sec p:last-child{margin:0}.det-feats{flex-direction:column;gap:.4rem;list-style:none;display:flex}.det-feats li{color:var(--text2);align-items:flex-start;gap:.5rem;font-size:.875rem;display:flex}.det-chk{flex-shrink:0;margin-top:.1em}.tag-row{flex-wrap:wrap;gap:.38rem;display:flex}.tag{font-family:var(--fm);color:var(--accent);background:var(--adim);border-radius:4px;padding:.16rem .48rem;font-size:.6rem}.certs-sec{background:var(--bg2);padding:9rem 0}.cert-intro{grid-template-columns:1fr 1fr;align-items:end;gap:5rem;margin-bottom:4.5rem;display:grid}.cert-h{letter-spacing:-.05em;color:var(--text);margin-bottom:0;font-size:clamp(2.2rem,4.5vw,3.2rem);font-weight:900;line-height:1.05}.cert-h span{color:var(--accent)}.cert-right-txt{color:var(--text2);max-width:420px;font-size:1rem;line-height:1.7}.cert-grid{grid-template-columns:repeat(4,1fr);gap:1.25rem;display:grid}.cert-card{background:var(--bg);border:1px solid var(--border);cursor:none;text-align:left;width:100%;transition:box-shadow .25s,border-color .25s,transform .35s var(--ease);opacity:0;border-radius:18px;flex-direction:column;display:flex;overflow:hidden;transform:translateY(36px)scale(.96)}.cert-card.vis{opacity:1;transform:none}.cert-card:hover{border-color:var(--accent);transform:translateY(-5px)scale(1.01);box-shadow:0 12px 48px #0000001a}[data-theme=dark] .cert-card:hover{box-shadow:0 12px 48px #0006}.cert-bar{height:3px}.cert-icon-zone{justify-content:center;align-items:center;padding:1.75rem 1.5rem .75rem;display:flex}.cert-icon{border-radius:14px;justify-content:center;align-items:center;width:58px;height:58px;display:flex}.cert-icon svg{width:28px;height:28px}.cert-body{flex:1;padding:.6rem 1.35rem 1rem}.cert-from{font-family:var(--fm);color:var(--text3);letter-spacing:.08em;text-transform:uppercase;margin-bottom:.35rem;font-size:.58rem;display:block}.cert-name{letter-spacing:-.03em;color:var(--text);margin-bottom:.45rem;font-size:1.12rem;font-weight:800}.cert-desc{color:var(--text2);font-size:.78rem;line-height:1.6}.cert-foot{border-top:1px solid var(--border);justify-content:space-between;align-items:center;padding:.8rem 1.35rem 1.1rem;display:flex}.cert-yr{font-family:var(--fm);color:var(--text3);font-size:.6rem}.cert-view{font-family:var(--fm);color:var(--accent);font-size:.63rem;transition:transform .18s}.cert-card:hover .cert-view{transform:translate(4px)}.lb-ov{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);z-index:800;background:#0009;justify-content:center;align-items:center;padding:1.5rem;animation:.18s fadein;display:flex;position:fixed;inset:0}.lb{background:var(--bg);width:100%;max-width:660px;animation:popin .3s var(--ease);border-radius:20px;padding:2rem;position:relative;box-shadow:0 40px 100px #0003}.lb-close{width:32px;height:32px;color:var(--text2);background:var(--surface);border-radius:8px;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex;position:absolute;top:.9rem;right:.9rem}.lb-close:hover{background:var(--border2);color:var(--text)}.lb-img{border:1px solid var(--border);border-radius:12px;width:100%;margin-bottom:1.25rem;display:block}.lb-ph{background:var(--bg2);border:1px dashed var(--border2);height:220px;color:var(--text3);border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:.5rem;margin-bottom:1.25rem;display:flex}.lb-ph p{font-family:var(--fm);font-size:.68rem}.lb-info h3{color:var(--text);font-size:1.05rem;font-weight:700}.lb-info p{color:var(--text2);margin-top:.12rem;font-size:.82rem}.contact-sec{background:var(--bg);padding:9rem 0}.contact-grid{grid-template-columns:1fr 1fr;align-items:start;gap:5rem;display:grid}.contact-big{letter-spacing:-.06em;color:var(--text);margin-bottom:1.25rem;font-size:clamp(2.6rem,6vw,4.5rem);font-weight:900;line-height:.96}.contact-big span{color:var(--accent)}.contact-sub{color:var(--text2);max-width:380px;margin-bottom:2.5rem;font-size:1rem;line-height:1.7}.c-links{flex-direction:column;gap:.55rem;display:flex}.c-link{border:1px solid var(--border);background:var(--bg2);transition:border-color .22s,box-shadow .22s,transform .25s var(--ease);border-radius:14px;align-items:center;gap:.85rem;padding:.95rem 1.15rem;display:flex}.c-link:hover{border-color:var(--accent);transform:translate(6px);box-shadow:0 4px 24px #00000012}[data-theme=dark] .c-link:hover{box-shadow:0 4px 24px #0000004d}.c-ico{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.c-ico svg{width:18px;height:18px}.c-body{flex:1}.c-lbl{color:var(--text);margin-bottom:.08rem;font-size:.9rem;font-weight:700;display:block}.c-sub{font-family:var(--fm);color:var(--text3);font-size:.68rem}.c-arr{color:var(--text3);font-size:.8rem;transition:transform .2s,color .2s}.c-link:hover .c-arr{color:var(--accent);transform:translate(4px)}.contact-info{flex-direction:column;gap:1rem;padding-top:2rem;display:flex}.info-card{background:var(--bg2);border:1px solid var(--border);border-radius:14px;padding:1.5rem}.info-card-lbl{font-family:var(--fm);color:var(--text3);letter-spacing:.12em;text-transform:uppercase;margin-bottom:.4rem;font-size:.58rem}.info-card-val{letter-spacing:-.02em;color:var(--text);font-size:1rem;font-weight:700}.info-card-sub{color:var(--text2);margin-top:.15rem;font-size:.82rem;line-height:1.5}.avail-badge{font-family:var(--fm);color:#16a34a;background:#16a34a1a;border:1px solid #16a34a38;border-radius:100px;align-items:center;gap:.4rem;margin-top:.6rem;padding:.22rem .7rem;font-size:.62rem;display:inline-flex}[data-theme=dark] .avail-badge{color:#4ade80;background:#4ade8014;border-color:#4ade8033}.avail-dot{background:currentColor;border-radius:50%;width:5px;height:5px;animation:2s infinite dotpulse}.contact-quote{background:var(--bg2);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:14px;padding:1.5rem}.contact-quote p{color:var(--text2);font-size:.9rem;font-style:italic;line-height:1.65}.contact-quote cite{font-family:var(--fm);color:var(--text3);letter-spacing:.08em;margin-top:.6rem;font-size:.58rem;font-style:normal;display:block}.footer{background:var(--bg2);border-top:1px solid var(--border);padding:2rem 0}.footer-in{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;display:flex}.footer-logo{letter-spacing:-.03em;color:var(--text);font-size:1rem;font-weight:800}.footer-logo span{color:var(--accent)}.footer-copy{font-family:var(--fm);color:var(--text3);letter-spacing:.05em;font-size:.6rem}.footer-links a{color:var(--text3);font-size:.82rem;transition:color .18s}.footer-links a:hover{color:var(--text)}.fade-up{opacity:0;transition:opacity .7s var(--ease),transform .7s var(--ease);transform:translateY(32px)}.fade-up.vis{opacity:1;transform:none}.fade-up.d1{transition-delay:80ms}.fade-up.d2{transition-delay:.16s}.fade-up.d3{transition-delay:.24s}.fade-up.d4{transition-delay:.32s}@media (width<=900px){body{cursor:auto}.cursor,.nav-center,.nav-cta{display:none}.nav-burger{display:flex}.about-grid{grid-template-columns:1fr;gap:3rem}.pj-card{grid-template-rows:56% 44%;grid-template-columns:1fr}.pj-card-l{padding:4.5rem var(--pad) 1.5rem;border-right:none;border-bottom:1px solid var(--border)}.pj-card-r{padding:1.5rem var(--pad) 3rem}.pj-dots{left:.5rem}.cert-intro{grid-template-columns:1fr;gap:1.5rem;margin-bottom:3rem}.cert-grid{grid-template-columns:1fr 1fr;gap:1rem}.contact-grid{grid-template-columns:1fr;gap:3.5rem}.footer-in{text-align:center;flex-direction:column}.footer-links{gap:2rem}}@media (width<=520px){.cert-grid{grid-template-columns:1fr}.contact-big{font-size:2.4rem}.hero-stats{gap:1.25rem}.hero-h{font-size:3.2rem}}.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:.3;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}
