@import url(https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/variable/pretendardvariable.css);@import url(https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@500;600;700&display=swap);*{box-sizing:border-box}html{scroll-behavior:smooth}#root,body,html{margin:0;min-height:100%}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Pretendard Variable,Pretendard,-apple-system,BlinkMacSystemFont,Segoe UI,Apple SD Gothic Neo,Noto Sans KR,sans-serif;text-rendering:optimizeLegibility}h1,h2,h3,h4{font-family:Space Grotesk,Pretendard Variable,Pretendard,sans-serif;letter-spacing:-.01em}a{color:inherit}img{max-width:100%}::selection{background:#2563eb2e}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}}:root{--ink:#0b1f3f;--ink-soft:#243b61;--body:#4a5e7e;--muted:#7589a8;--brand:#2563eb;--brand-strong:#1d4ed8;--brand-deep:#1e3a8a;--brand-soft:#eaf1ff;--brand-line:#2563eb29;--line:#0b1f3f14;--line-strong:#0b1f3f21;--card:#fff;--card-2:#f5f9ff;--shadow-sm:0 1px 2px #0b1f3f0a,0 2px 6px #0b1f3f0d;--shadow-md:0 10px 30px #0b1f3f14;--shadow-lg:0 24px 60px #0f285f29;--r-xl:26px;--r-lg:20px;--r-md:14px;--r-sm:10px;--pill:999px;--container:1120px;--nav-h:70px}.portfolio{background:radial-gradient(1100px 520px at 12% -8%,#59a5ff24,#0000 60%),radial-gradient(900px 480px at 96% 4%,#2563eb1a,#0000 58%),linear-gradient(180deg,#f7faff,#eef4ff 36%,#f8fbff);color:#0b1f3f;color:var(--ink);min-height:100vh;overflow-x:clip;padding:18px 20px 0;position:relative}.bg-orb{border-radius:50%;filter:blur(60px);pointer-events:none;position:absolute;z-index:0}.bg-orb-a{animation:floatSlow 16s ease-in-out infinite;background:radial-gradient(circle,#59a5ff47,#0000 70%);height:420px;left:-140px;top:120px;width:420px}.bg-orb-b{animation:floatSlow 19s ease-in-out infinite reverse;background:radial-gradient(circle,#2563eb33,#0000 70%);height:360px;right:-120px;top:40px;width:360px}.floating-lines-layer{inset:0;opacity:.16;pointer-events:none;position:fixed;z-index:0}.floating-lines-layer .floating-lines-container{inset:0;position:absolute}.topbar{grid-gap:16px;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffffd1;border:1px solid #0b1f3f14;border:1px solid var(--line);border-radius:999px;border-radius:var(--pill);box-shadow:0 10px 30px #0b1f3f14;box-shadow:var(--shadow-md);display:grid;gap:16px;grid-template-columns:auto 1fr auto;margin:0 auto 28px;padding:10px 12px 10px 18px;position:sticky;top:14px;width:min(1120px,100%);width:min(var(--container),100%);z-index:40}.brand,.topbar{align-items:center}.brand{color:#0b1f3f;color:var(--ink);display:inline-flex;font-size:.82rem;font-weight:700;gap:9px;letter-spacing:.14em;text-decoration:none;white-space:nowrap}.brand-mark{background:linear-gradient(140deg,#59a5ff,#1e3a8a);background:linear-gradient(140deg,#59a5ff,var(--brand-deep));border-radius:50%;box-shadow:0 0 0 4px #2563eb24;height:11px;width:11px}.topbar-nav{display:flex;flex-wrap:wrap;gap:6px;justify-content:center}.topbar-nav a{border-radius:999px;border-radius:var(--pill);color:#7589a8;color:var(--muted);font-size:.86rem;font-weight:600;padding:7px 12px;position:relative;text-decoration:none;transition:color .18s ease,background .18s ease}.topbar-nav a:hover{background:#2563eb12;color:#1d4ed8;color:var(--brand-strong)}.topbar-nav a.is-active{background:#eaf1ff;background:var(--brand-soft);color:#1d4ed8;color:var(--brand-strong)}.topbar-cta{background:linear-gradient(120deg,#2563eb,#1e3a8a);background:linear-gradient(120deg,var(--brand),var(--brand-deep));border-radius:999px;border-radius:var(--pill);box-shadow:0 8px 20px #2563eb4d;color:#fff;font-size:.84rem;font-weight:700;padding:9px 18px;text-decoration:none;transition:transform .18s ease,box-shadow .18s ease;white-space:nowrap}.topbar-cta:hover{box-shadow:0 12px 26px #2563eb61;transform:translateY(-1px)}main{grid-gap:28px;display:grid;gap:28px;margin:0 auto;width:min(1120px,100%);width:min(var(--container),100%);z-index:1}.section,main{position:relative}.section{background:#fff;background:var(--card);border:1px solid #0b1f3f14;border:1px solid var(--line);border-radius:26px;border-radius:var(--r-xl);box-shadow:0 1px 2px #0b1f3f0a,0 2px 6px #0b1f3f0d;box-shadow:var(--shadow-sm);padding:clamp(24px,3.4vw,40px);scroll-margin-top:94px;scroll-margin-top:calc(var(--nav-h) + 24px)}.section[data-index]:before{color:#2563eb52;content:attr(data-index);font-family:Space Grotesk,sans-serif;font-size:.78rem;font-weight:700;letter-spacing:.16em;position:absolute;right:26px;top:22px}.section-head{margin-bottom:24px}.section-head h2{color:#0b1f3f;color:var(--ink);font-size:clamp(1.5rem,3vw,2.1rem);margin:0}.section-head p{color:#7589a8;color:var(--muted);font-size:.96rem;line-height:1.65;margin:8px 0 0;max-width:640px}.hero{grid-gap:clamp(24px,3vw,44px);align-items:center;background:radial-gradient(700px 380px at 92% 8%,#59a5ff29,#0000 60%),linear-gradient(150deg,#fff,#f1f7ff);border:1px solid #0b1f3f14;border:1px solid var(--line);border-radius:26px;border-radius:var(--r-xl);box-shadow:0 10px 30px #0b1f3f14;box-shadow:var(--shadow-md);display:grid;gap:clamp(24px,3vw,44px);grid-template-columns:1.45fr .95fr;overflow:hidden;padding:clamp(30px,4vw,56px);position:relative;scroll-margin-top:94px;scroll-margin-top:calc(var(--nav-h) + 24px)}.hero-text{align-content:center;display:grid}.hero-tag{background:#eaf1ff;background:var(--brand-soft);border-radius:999px;border-radius:var(--pill);color:#1e3a8a;color:var(--brand-deep);font-size:.72rem;font-weight:700;letter-spacing:.14em;margin:0;padding:6px 13px;text-transform:uppercase;width:fit-content}.hero-name{color:#0b1f3f;color:var(--ink);font-size:clamp(2.6rem,6vw,4.2rem);letter-spacing:-.03em;line-height:1.02;margin:18px 0 0}.hero-role{color:#1d4ed8;color:var(--brand-strong);font-family:Space Grotesk,sans-serif;font-size:clamp(1.05rem,2vw,1.35rem);font-weight:600;margin:12px 0 0}.hero-desc{color:#4a5e7e;color:var(--body);font-size:1rem;line-height:1.8;margin:20px 0 0;max-width:540px}.hero-keywords{display:flex;flex-wrap:wrap;gap:8px;margin-top:22px}.keyword{background:#ffffffb3;border:1px solid #2563eb29;border:1px solid var(--brand-line);border-radius:999px;border-radius:var(--pill);color:#243b61;color:var(--ink-soft);font-size:.8rem;font-weight:600;padding:7px 13px}.hero-actions{display:flex;flex-wrap:wrap;gap:11px;margin-top:26px}.btn{align-items:center;border-radius:999px;border-radius:var(--pill);display:inline-flex;font-size:.92rem;font-weight:700;justify-content:center;padding:12px 22px;text-decoration:none;transition:transform .18s ease,box-shadow .18s ease,background .18s ease}.btn:hover{transform:translateY(-2px)}.btn-primary{background:linear-gradient(120deg,#2563eb,#1e3a8a);background:linear-gradient(120deg,var(--brand),var(--brand-deep));box-shadow:0 12px 26px #2563eb52;color:#fff}.btn-ghost{background:#ffffffd9;border:1px solid #2563eb29;border:1px solid var(--brand-line);color:#1e3a8a;color:var(--brand-deep)}.btn-ghost:hover{background:#eaf1ff;background:var(--brand-soft)}.hero-panel{grid-gap:16px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffc7;border:1px solid #0b1f3f14;border:1px solid var(--line);border-radius:20px;border-radius:var(--r-lg);box-shadow:0 10px 30px #0b1f3f14;box-shadow:var(--shadow-md);display:grid;gap:16px;padding:22px}.hero-panel-quote{color:#0b1f3f;color:var(--ink);font-family:Space Grotesk,Pretendard Variable,sans-serif;font-size:1.08rem;font-weight:600;line-height:1.5;margin:0}.hero-facts{grid-gap:10px;display:grid;gap:10px;list-style:none;margin:0;padding:0}.hero-facts li{align-items:baseline;border-bottom:1px dashed #0b1f3f21;border-bottom:1px dashed var(--line-strong);display:flex;gap:10px;justify-content:space-between;padding-bottom:10px}.hero-facts li:last-child{border-bottom:none;padding-bottom:0}.hero-facts span{color:#7589a8;color:var(--muted);font-size:.74rem;letter-spacing:.06em;text-transform:uppercase}.hero-facts strong{color:#0b1f3f;color:var(--ink);font-size:.9rem;text-align:right}.hero-stats{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(3,1fr);margin-top:2px}.hero-stat{background:#eaf1ff;background:var(--brand-soft);border-radius:14px;border-radius:var(--r-md);padding:12px 6px;text-align:center}.hero-stat strong{color:#1e3a8a;color:var(--brand-deep);display:block;font-family:Space Grotesk,sans-serif;font-size:1.4rem;line-height:1}.hero-stat span{color:#4f6da3;display:block;font-size:.7rem;letter-spacing:.04em;margin-top:5px}.about-grid{grid-gap:18px;display:grid;gap:18px;grid-template-columns:.85fr 1.15fr}.about-photo-card{grid-gap:4px;align-content:center;background:#f5f9ff;background:var(--card-2);border:1px solid #0b1f3f14;border:1px solid var(--line);border-radius:20px;border-radius:var(--r-lg);display:grid;gap:4px;justify-items:center;padding:26px 20px;text-align:center}.about-photo-frame{aspect-ratio:2/3;background:#fff;border:1px solid #2563eb29;border:1px solid var(--brand-line);border-radius:14px;border-radius:var(--r-md);box-shadow:0 1px 2px #0b1f3f0a,0 2px 6px #0b1f3f0d;box-shadow:var(--shadow-sm);margin-bottom:16px;overflow:hidden;padding:6px;width:min(188px,66%)}.about-photo{background:#fff;border-radius:10px;border-radius:calc(var(--r-md) - 4px);display:block;height:100%;object-fit:cover;object-position:center;width:100%}.about-photo-card h3{color:#0b1f3f;color:var(--ink);font-size:1.3rem;margin:0}.about-photo-en{color:#7589a8;color:var(--muted);font-family:Space Grotesk,sans-serif;font-size:.85rem;letter-spacing:.1em;margin:2px 0 0}.about-info-card{align-content:center;background:#fff;background:var(--card);border:1px solid #0b1f3f14;border:1px solid var(--line);border-radius:20px;border-radius:var(--r-lg);display:grid;padding:12px}.info-list{grid-gap:8px;display:grid;gap:8px;list-style:none;margin:0;padding:0}.info-list li{grid-gap:12px;align-items:center;background:#f5f9ff;background:var(--card-2);border:1px solid #0b1f3f14;border:1px solid var(--line);border-radius:14px;border-radius:var(--r-md);display:grid;gap:12px;grid-template-columns:96px 1fr;padding:13px 16px}.info-list span{color:#7589a8;color:var(--muted);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase}.info-list a,.info-list strong{color:#0b1f3f;color:var(--ink);font-size:.96rem;text-decoration:none;word-break:break-all}.info-list a:hover{color:#1d4ed8;color:var(--brand-strong);text-decoration:underline}.edu-grid{grid-gap:18px;display:grid;gap:18px;grid-template-columns:1.1fr .9fr}.activity-card,.edu-degree{background:#fff;background:var(--card);border:1px solid #0b1f3f14;border:1px solid var(--line);border-radius:20px;border-radius:var(--r-lg);padding:24px}.edu-degree{background:linear-gradient(155deg,#fff,#f1f7ff)}.edu-period{color:#1d4ed8;color:var(--brand-strong);font-size:.82rem;font-weight:600;margin:0}.edu-degree h3{color:#0b1f3f;color:var(--ink);font-size:1.35rem;margin:8px 0 4px}.edu-major{color:#7589a8;color:var(--muted);font-size:.92rem;margin:0}.edu-capstone{grid-gap:4px;background:#eaf1ff;background:var(--brand-soft);border-left:3px solid #2563eb;border-left:3px solid var(--brand);border-radius:14px;border-radius:var(--r-md);display:grid;gap:4px;margin-top:18px;padding:14px 16px}.edu-capstone strong{color:#1e3a8a;color:var(--brand-deep);font-size:.96rem}.edu-capstone span{color:#243b61;color:var(--ink-soft);font-size:.86rem;line-height:1.55}.activity-title{color:#0b1f3f;color:var(--ink);font-size:1.1rem;margin:0 0 18px}.timeline{list-style:none;margin:0;padding:0 0 0 18px;position:relative}.timeline:before{background:linear-gradient(180deg,#2563eb29,#0000);background:linear-gradient(180deg,var(--brand-line),#0000);bottom:6px;content:"";left:4px;position:absolute;top:6px;width:2px}.timeline li{padding:0 0 18px;position:relative}.timeline li:last-child{padding-bottom:0}.timeline-dot{background:#2563eb;background:var(--brand);border-radius:50%;box-shadow:0 0 0 4px #2563eb24;height:9px;left:-18px;position:absolute;top:5px;width:9px}.timeline-period{color:#7589a8;color:var(--muted);font-size:.78rem;margin:0}.timeline-name{color:#0b1f3f;color:var(--ink);font-size:.96rem;font-weight:600;line-height:1.5;margin:3px 0 0}.project-grid{grid-gap:22px;display:grid;gap:22px;grid-template-columns:repeat(2,minmax(0,1fr))}.project-card{background:#fff;background:var(--card);border:1px solid #0b1f3f14;border:1px solid var(--line);border-radius:20px;border-radius:var(--r-lg);box-shadow:0 1px 2px #0b1f3f0a,0 2px 6px #0b1f3f0d;box-shadow:var(--shadow-sm);cursor:pointer;display:flex;flex-direction:column;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.project-card:focus-visible,.project-card:hover{border-color:#2563eb29;border-color:var(--brand-line);box-shadow:0 24px 60px #0f285f29;box-shadow:var(--shadow-lg);outline:none;transform:translateY(-5px)}.project-card.is-open{border-color:#2563eb;border-color:var(--brand)}.project-thumb{aspect-ratio:16/9;background:#f5f9ff;background:var(--card-2);overflow:hidden;position:relative;width:100%}.project-thumb img{display:block;height:100%;object-fit:cover;object-position:center top;transition:transform .4s ease;width:100%}.project-card:hover .project-thumb img{transform:scale(1.04)}.project-badge{background:linear-gradient(120deg,#2563eb,#1e3a8a);background:linear-gradient(120deg,var(--brand),var(--brand-deep));border-radius:999px;border-radius:var(--pill);box-shadow:0 6px 16px #2563eb57;color:#fff;font-size:.72rem;font-weight:700;left:12px;padding:5px 11px;position:absolute;top:12px}.project-badge.inline{box-shadow:none;position:static}.project-body{display:flex;flex:1 1;flex-direction:column;gap:4px;padding:20px}.project-card-head{align-items:baseline;display:flex;gap:10px;justify-content:space-between}.project-card-head h3{color:#0b1f3f;color:var(--ink);font-size:1.25rem;margin:0}.project-team{color:#7589a8;color:var(--muted);font-size:.76rem;white-space:nowrap}.project-type{color:#1d4ed8;color:var(--brand-strong);font-size:.9rem;font-weight:600;margin:2px 0 0}.project-period{color:#7589a8;color:var(--muted);font-size:.78rem;margin:2px 0 0}.project-summary{color:#4a5e7e;color:var(--body);font-size:.9rem;line-height:1.65;margin:10px 0 0}.project-stack{display:flex;flex-wrap:wrap;gap:6px;margin-top:14px}.tag{background:#eaf1ff;background:var(--brand-soft);border:1px solid #2563eb29;border:1px solid var(--brand-line);border-radius:999px;border-radius:var(--pill);color:#1e3a8a;color:var(--brand-deep);font-size:.74rem;font-weight:600;padding:5px 10px}.project-more{color:#1d4ed8;color:var(--brand-strong);font-size:.82rem;font-weight:700;margin-top:auto;padding-top:16px}.skills-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(2,minmax(0,1fr))}.skill-group{background:#f5f9ff;background:var(--card-2);border:1px solid #0b1f3f14;border:1px solid var(--line);border-radius:14px;border-radius:var(--r-md);padding:18px 20px}.skill-group h3{color:#0b1f3f;color:var(--ink);font-size:1rem;margin:0 0 12px}.tag-row{display:flex;flex-wrap:wrap;gap:7px}.credentials-grid{grid-gap:18px;display:grid;gap:18px;grid-template-columns:repeat(2,minmax(0,1fr))}.credential-col{background:#fff;background:var(--card);border:1px solid #0b1f3f14;border:1px solid var(--line);border-radius:20px;border-radius:var(--r-lg);padding:22px 24px}.credential-label{color:#1d4ed8;color:var(--brand-strong);font-family:Space Grotesk,sans-serif;font-size:.86rem;letter-spacing:.08em;margin:0 0 14px;text-transform:uppercase}.credential-list{grid-gap:10px;display:grid;gap:10px;list-style:none;margin:0;padding:0}.credential-list li{align-items:center;background:#f5f9ff;background:var(--card-2);border:1px solid #0b1f3f14;border:1px solid var(--line);border-radius:14px;border-radius:var(--r-md);display:flex;gap:12px;justify-content:space-between;padding:14px 16px}.credential-name{color:#0b1f3f;color:var(--ink);font-size:.94rem;font-weight:600}.credential-date{color:#7589a8;color:var(--muted);font-size:.8rem;white-space:nowrap}.credential-tag{background:linear-gradient(120deg,#2563eb,#1e3a8a);background:linear-gradient(120deg,var(--brand),var(--brand-deep));border-radius:999px;border-radius:var(--pill);color:#fff;font-size:.74rem;font-weight:700;padding:4px 10px;white-space:nowrap}.contact{background:radial-gradient(620px 320px at 88% 10%,#59a5ff2e,#0000 60%),linear-gradient(150deg,#fff,#eff5ff);overflow:hidden}.contact-inner{max-width:640px}.contact h2{color:#0b1f3f;color:var(--ink);font-size:clamp(1.7rem,3.4vw,2.4rem);margin:0}.contact-lead{color:#4a5e7e;color:var(--body);font-size:1rem;line-height:1.7;margin:14px 0 0}.contact-links{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}.contact-link{background:#ffffffd9;border:1px solid #2563eb29;border:1px solid var(--brand-line);border-radius:999px;border-radius:var(--pill);color:#1e3a8a;color:var(--brand-deep);font-size:.9rem;font-weight:700;padding:11px 18px;text-decoration:none;transition:transform .18s ease,background .18s ease,box-shadow .18s ease}.contact-link:hover{background:#eaf1ff;background:var(--brand-soft);transform:translateY(-2px)}.contact-link.primary{background:linear-gradient(120deg,#2563eb,#1e3a8a);background:linear-gradient(120deg,var(--brand),var(--brand-deep));border-color:#0000;box-shadow:0 10px 24px #2563eb4d;color:#fff}.footer{border-top:1px solid #0b1f3f14;border-top:1px solid var(--line);color:#7589a8;color:var(--muted);display:flex;flex-wrap:wrap;font-size:.82rem;gap:8px;justify-content:space-between;margin:28px auto 0;padding:28px 6px 36px;position:relative;width:min(1120px,100%);width:min(var(--container),100%);z-index:1}.footer-meta{font-family:Space Grotesk,sans-serif;letter-spacing:.04em}.modal-backdrop{animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#08142c80;display:grid;inset:0;padding:18px;place-items:center;position:fixed;z-index:80}.modal{animation:modalIn .24s ease;background:#fff;border:1px solid #0b1f3f14;border:1px solid var(--line);border-radius:20px;border-radius:var(--r-lg);box-shadow:0 24px 60px #0f285f29;box-shadow:var(--shadow-lg);max-height:90vh;overflow-y:auto;position:relative;width:min(760px,100%)}.modal-close{background:#ffffffeb;border:none;border-radius:50%;box-shadow:0 1px 2px #0b1f3f0a,0 2px 6px #0b1f3f0d;box-shadow:var(--shadow-sm);color:#0b1f3f;color:var(--ink);cursor:pointer;font-size:.9rem;font-weight:700;height:36px;position:absolute;right:14px;top:14px;transition:background .18s ease,transform .18s ease;width:36px;z-index:2}.modal-close:hover{background:#fff;transform:rotate(90deg)}.modal-image{display:block;height:300px;object-fit:cover;object-position:center top;width:100%}.modal-body{padding:26px clamp(22px,3.4vw,34px) 32px}.modal-head{align-items:center;display:flex;gap:12px}.modal-head h3{color:#0b1f3f;color:var(--ink);font-size:1.55rem;margin:0}.modal-type{color:#1d4ed8;color:var(--brand-strong);font-size:.98rem;font-weight:600;margin:6px 0 0}.modal-meta{color:#7589a8;color:var(--muted);font-size:.86rem;margin:4px 0 16px}.modal-summary{color:#4a5e7e;color:var(--body);font-size:.98rem;line-height:1.75;margin:18px 0 0}.modal-subhead{color:#0b1f3f;color:var(--ink);font-size:.92rem;letter-spacing:.02em;margin:22px 0 10px}.modal-list{grid-gap:8px;color:#4a5e7e;color:var(--body);display:grid;gap:8px;line-height:1.6;margin:0;padding:0 0 0 20px}.modal-list li{font-size:.94rem}.modal-trouble{background:#eaf1ff;background:var(--brand-soft);border-left:3px solid #2563eb;border-left:3px solid var(--brand);border-radius:0 14px 14px 0;border-radius:0 var(--r-md) var(--r-md) 0;color:#243b61;color:var(--ink-soft);font-size:.92rem;line-height:1.7;margin:22px 0 0;padding:16px 18px}.modal-trouble strong{color:#1e3a8a;color:var(--brand-deep);display:block;margin-bottom:4px}.modal-links{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}.modal-link{background:#f5f9ff;background:var(--card-2);border:1px solid #2563eb29;border:1px solid var(--brand-line);border-radius:999px;border-radius:var(--pill);color:#1e3a8a;color:var(--brand-deep);font-size:.86rem;font-weight:700;padding:10px 16px;text-decoration:none;transition:background .18s ease,transform .18s ease}.modal-link:hover{background:#eaf1ff;background:var(--brand-soft);transform:translateY(-1px)}.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}.reveal.is-visible{opacity:1;transform:none}.project-card:focus-visible,a:focus-visible,button:focus-visible{outline:2px solid #2563eb;outline:2px solid var(--brand);outline-offset:3px}.split-parent{display:block}.split-char,.split-line,.split-word{will-change:transform,opacity}@keyframes floatSlow{0%,to{transform:translateY(0)}50%{transform:translateY(-16px)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalIn{0%{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:none}}@media (max-width:960px){.hero{grid-template-columns:1fr}.hero-panel{order:2}.about-grid,.edu-grid{grid-template-columns:1fr}.about-photo-frame{width:min(176px,58%)}}@media (max-width:820px){.topbar{border-radius:20px;border-radius:var(--r-lg);gap:10px 12px;grid-template-areas:"brand cta" "nav nav";grid-template-columns:auto auto;padding:12px 14px}.brand{grid-area:brand}.topbar-cta{grid-area:cta;justify-self:end}.topbar-nav{-ms-overflow-style:none;flex-wrap:nowrap;grid-area:nav;justify-content:flex-start;overflow-x:auto;padding-bottom:2px;scrollbar-width:none;width:100%}.topbar-nav::-webkit-scrollbar{display:none}.topbar-nav a{white-space:nowrap}}@media (max-width:680px){.portfolio{padding:14px 14px 0}.credentials-grid,.project-grid,.skills-grid{grid-template-columns:1fr}.section[data-index]:before{display:none}.hero-stats{grid-template-columns:repeat(3,1fr)}.info-list li{grid-template-columns:80px 1fr}.modal-image{height:210px}}.floating-lines-container{height:100%;inset:0;overflow:hidden;position:absolute;width:100%}.floating-lines-container canvas{display:block;height:100%;width:100%}
/*# sourceMappingURL=main.0a210a96.css.map*/