:root{--primary: #1e3a5f;--primary-light: #2d5a8a;--accent: #3b9eff;--accent-green: #34c796;--accent-orange: #ff8f4d;--accent-purple: #a78bfa;--bg: #f5f7fa;--bg-warm: #fafbfd;--card: #ffffff;--card-alt: #f0f4f8;--text: #2c3e50;--text-secondary: #5a6b80;--text-muted: #94a3b8;--text-on-primary: #ffffff;--border: #e2e8f0;--border-light: #edf2f7;--shadow-sm: 0 1px 3px rgba(30,58,95,.06), 0 1px 2px rgba(30,58,95,.04);--shadow-md: 0 4px 16px rgba(30,58,95,.08);--shadow-lg: 0 12px 40px rgba(30,58,95,.1);--shadow-xl: 0 20px 60px rgba(30,58,95,.12);--radius-sm: 8px;--radius: 14px;--radius-lg: 20px;--radius-full: 9999px;--font-sans: "Inter", -apple-system, "PingFang SC", "Noto Sans CJK SC", "Microsoft YaHei", "Helvetica Neue", sans-serif;--font-mono: "SF Mono", "Fira Code", "Consolas", monospace;--nav-height: 64px;--container-max: 1100px;--section-py: 72px;--ease-out: cubic-bezier(.25, .46, .45, .94);--transition-fast: .2s var(--ease-out);--transition-normal: .35s var(--ease-out)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:var(--font-sans);font-size:15px;line-height:1.7;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}a{color:var(--accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-light)}img{max-width:100%;height:auto;display:block}ul,ol{list-style:none}.text-xs{font-size:12px}.text-sm{font-size:13px}.text-base{font-size:15px}.text-lg{font-size:17px}.text-xl{font-size:20px}.text-2xl{font-size:24px}.text-3xl{font-size:30px}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.font-extrabold{font-weight:800}.navbar{position:fixed;top:0;left:0;right:0;height:var(--nav-height);background:#ffffffeb;backdrop-filter:blur(16px) saturate(180%);-webkit-backdrop-filter:blur(16px) saturate(180%);border-bottom:1px solid var(--border-light);z-index:1000;transition:box-shadow var(--transition-normal)}.navbar.scrolled{box-shadow:0 2px 20px #1e3a5f14}.nav-inner{max-width:var(--container-max);margin:0 auto;height:100%;display:flex;align-items:center;justify-content:space-between;padding:0 28px}.nav-logo{display:flex;align-items:center;gap:10px;cursor:pointer;user-select:none}.nav-logo .logo-avatar{width:34px;height:34px;border-radius:50%;object-fit:cover;background:linear-gradient(135deg,var(--accent),var(--accent-green));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:14px;border:2px solid rgba(59,158,255,.2)}.nav-logo .logo-name{font-size:17px;font-weight:700;color:var(--primary);letter-spacing:.5px}.nav-links{display:flex;gap:4px}.nav-link{padding:8px 16px;border-radius:var(--radius-full);font-size:14px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);border:none;background:none;white-space:nowrap}.nav-link:hover{color:var(--accent);background:#3b9eff0f}.nav-link.active{color:var(--accent);background:#3b9eff1a;font-weight:600}.hamburger{display:none;width:36px;height:36px;flex-direction:column;align-items:center;justify-content:center;gap:5px;cursor:pointer;background:none;border:none;padding:6px;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.hamburger:hover{background:var(--card-alt)}.hamburger span{display:block;width:22px;height:2px;background:var(--text);border-radius:2px;transition:all var(--transition-normal)}.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.hamburger.active span:nth-child(2){opacity:0}.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}.mobile-overlay{display:none;position:fixed;inset:0;background:#0f172a66;z-index:999;backdrop-filter:blur(4px);opacity:0;transition:opacity var(--transition-normal)}.mobile-overlay.show{display:block;opacity:1}.main-content{margin-top:var(--nav-height);min-height:calc(100vh - var(--nav-height))}.page-section{display:none;padding:var(--section-py) 24px;animation:pageFadeIn .4s var(--ease-out)}.page-section.active{display:block}@keyframes pageFadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.container{max-width:var(--container-max);margin:0 auto}.home-hero{display:flex;flex-direction:column;align-items:center;text-align:center;max-width:720px;margin:0 auto;padding:40px 0 20px}.hero-info{width:100%}.hero-greeting{font-size:14px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--accent);margin-bottom:8px}.hero-name{font-size:42px;font-weight:800;color:var(--primary);line-height:1.2;margin-bottom:8px;letter-spacing:-.5px}.hero-intention{font-size:18px;color:var(--text-secondary);margin-bottom:20px;font-weight:500}.hero-tagline{font-size:15px;color:var(--text-secondary);line-height:1.75;max-width:580px;margin:0 auto 28px;padding-left:0;border-left:none;font-style:normal}.tag-group{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:32px;justify-content:center}.tag-pill{padding:6px 16px;border-radius:var(--radius-full);font-size:13px;font-weight:600;border:1px solid var(--border);color:var(--text-secondary);background:var(--card);transition:all var(--transition-fast)}.tag-pill:hover{border-color:var(--accent);color:var(--accent);box-shadow:0 2px 8px #3b9eff26;transform:translateY(-1px)}.tag-pill.accent-blue{background:#3b9eff14;border-color:#3b9eff40;color:var(--accent)}.tag-pill.accent-green{background:#34c79614;border-color:#34c79640;color:var(--accent-green)}.tag-pill.accent-orange{background:#ff8f4d14;border-color:#ff8f4d40;color:var(--accent-orange)}.contact-row{display:flex;gap:20px;flex-wrap:wrap;padding-top:20px;border-top:1px solid var(--border)}.contact-item{display:flex;align-items:center;gap:6px;font-size:14px;color:var(--text-secondary)}.contact-item svg{width:16px;height:16px;stroke:var(--accent);flex-shrink:0}.contact-item a{color:var(--text-secondary)}.contact-item a:hover{color:var(--accent)}.quick-nav-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-top:44px}.qn-card{background:var(--card);border-radius:var(--radius);padding:22px 16px;border:1px solid var(--border-light);cursor:pointer;transition:all var(--transition-normal);text-align:center}.qn-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:transparent}.qn-card:nth-child(1):hover{border-color:#3b9eff4d}.qn-card:nth-child(2):hover{border-color:#34c7964d}.qn-card:nth-child(3):hover{border-color:#a78bfa4d}.qn-card:nth-child(4):hover{border-color:#ff8f4d4d}.qn-card:nth-child(5):hover{border-color:#f59e0b4d}.qn-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin:0 auto 10px;font-size:20px;transition:transform var(--transition-fast)}.qn-card:hover .qn-icon{transform:scale(1.1)}.qn-card:nth-child(1) .qn-icon{background:#3b9eff1a}.qn-card:nth-child(2) .qn-icon{background:#34c7961a}.qn-card:nth-child(3) .qn-icon{background:#a78bfa1a}.qn-card:nth-child(4) .qn-icon{background:#ff8f4d1a}.qn-card:nth-child(5) .qn-icon{background:#f59e0b1a}.qn-title{font-size:14px;font-weight:700;color:var(--primary);margin-bottom:3px}.qn-desc{font-size:12px;color:var(--text-muted);line-height:1.45}.section-header{margin-bottom:36px}.section-label{font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--accent);margin-bottom:8px;display:inline-block}.section-title{font-size:26px;font-weight:800;color:var(--primary);line-height:1.3;letter-spacing:-.3px}.timeline{position:relative;padding-left:32px}.timeline:before{content:"";position:absolute;left:11px;top:4px;bottom:4px;width:2px;background:linear-gradient(to bottom,var(--accent) 0%,var(--accent-green) 50%,var(--accent-orange) 100%);border-radius:1px;opacity:.35}.tl-item{position:relative;margin-bottom:32px}.tl-item:last-child{margin-bottom:0}.tl-dot{position:absolute;left:-32px;top:6px;width:24px;height:24px;border-radius:50%;background:var(--card);border:2px solid var(--accent);display:flex;align-items:center;justify-content:center;z-index:1;box-shadow:0 0 0 4px var(--bg)}.tl-dot-inner{width:8px;height:8px;border-radius:50%;background:var(--accent)}.tl-item:nth-child(odd) .tl-dot{border-color:var(--accent)}.tl-item:nth-child(odd) .tl-dot-inner{background:var(--accent)}.tl-item:nth-child(2n+2) .tl-dot{border-color:var(--accent-green)}.tl-item:nth-child(2n+2) .tl-dot-inner{background:var(--accent-green)}.tl-item:nth-child(3n) .tl-dot{border-color:var(--accent-purple)}.tl-item:nth-child(3n) .tl-dot-inner{background:var(--accent-purple)}.tl-item:nth-child(4n) .tl-dot{border-color:var(--accent-orange)}.tl-item:nth-child(4n) .tl-dot-inner{background:var(--accent-orange)}.tl-card{background:var(--card);border-radius:var(--radius);border:1px solid var(--border-light);overflow:hidden;transition:all var(--transition-normal)}.tl-card:hover{box-shadow:var(--shadow-md);border-color:transparent;transform:translateY(-2px)}.tl-head{padding:20px 24px 0;display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap}.tl-company-info{flex:1;min-width:200px}.tl-company{font-size:17px;font-weight:700;color:var(--primary);margin-bottom:2px}.tl-role{font-size:14px;font-weight:600;color:var(--accent)}.tl-date-badge{padding:4px 12px;border-radius:var(--radius-full);font-size:12px;font-weight:600;background:var(--card-alt);color:var(--text-muted);white-space:nowrap;flex-shrink:0}.tl-body{padding:16px 24px 20px}.tl-bullets li{position:relative;padding-left:18px;margin-bottom:8px;font-size:14px;color:var(--text-secondary);line-height:1.65}.tl-bullets li:before{content:"";position:absolute;left:0;top:9px;width:6px;height:6px;border-radius:50%;background:var(--accent);opacity:.5}.tl-bullets li:last-child{margin-bottom:0}.data-chip{display:inline-block;padding:1px 8px;margin-left:4px;border-radius:4px;font-size:12px;font-weight:700;color:var(--accent);background:#3b9eff14}.data-chip.green{color:var(--accent-green);background:#34c79614}.data-chip.orange{color:var(--accent-orange);background:#ff8f4d14}.edu-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}.edu-card{background:var(--card);border-radius:var(--radius);border:1px solid var(--border-light);overflow:hidden;transition:all var(--transition-normal)}.edu-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}.edu-header{padding:24px 24px 16px;background:linear-gradient(135deg,var(--card) 0%,var(--bg-warm) 100%);border-bottom:1px solid var(--border-light)}.edu-school{font-size:19px;font-weight:800;color:var(--primary);margin-bottom:4px;display:flex;align-items:center;gap:8px}.edu-school-type{font-size:11px;font-weight:700;padding:2px 8px;border-radius:var(--radius-full);background:var(--accent);color:#fff}.edu-school-type.master{background:var(--accent-green)}.edu-major{font-size:14px;color:var(--text-secondary);font-weight:500}.edu-time{font-size:13px;color:var(--text-muted);margin-top:4px}.edu-body{padding:16px 24px 20px}.edu-honors-title{font-size:13px;font-weight:700;color:var(--text-secondary);margin-bottom:10px;display:flex;align-items:center;gap:6px}.edu-honors-title:before{content:"";display:inline-block;width:4px;height:14px;border-radius:2px;background:linear-gradient(to bottom,var(--accent),var(--accent-green))}.edu-honor-item{padding:6px 0 6px 16px;font-size:13px;color:var(--text-secondary);position:relative;line-height:1.55}.edu-honor-item:before{content:"🏆";position:absolute;left:0;top:6px;font-size:11px}.skills-layout{display:grid;grid-template-columns:1fr 1fr;gap:24px}.skill-category-card{background:var(--card);border-radius:var(--radius);border:1px solid var(--border-light);overflow:hidden}.skill-cat-header{padding:18px 22px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border-light);background:var(--bg-warm)}.skill-cat-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:17px}.skill-cat-title{font-size:16px;font-weight:700;color:var(--primary)}.skill-cat-subtitle{font-size:12px;color:var(--text-muted)}.skill-cat-body{padding:18px 22px}.skill-row{margin-bottom:16px}.skill-row:last-child{margin-bottom:0}.skill-meta{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}.skill-name{font-size:14px;font-weight:600;color:var(--text)}.skill-percent{font-size:13px;font-weight:700;color:var(--accent)}.skill-track{height:6px;background:var(--card-alt);border-radius:3px;overflow:hidden}.skill-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--accent),var(--accent-green));width:0;transition:width 1s var(--ease-out)}.skill-fill.animated{width:var(--target-width)}.skill-cat-card:nth-child(1) .skill-cat-icon{background:#3b9eff1a}.skill-cat-card:nth-child(2) .skill-cat-icon{background:#34c7961a}.skill-cat-card:nth-child(3) .skill-cat-icon{background:#a78bfa1a}.skill-cat-card:nth-child(4) .skill-cat-icon{background:#ff8f4d1a}.soft-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.soft-tag{padding:6px 14px;border-radius:var(--radius-full);font-size:13px;font-weight:500;color:var(--text-secondary);border:1px solid var(--border);background:var(--card);transition:all var(--transition-fast)}.soft-tag:hover{border-color:var(--accent);color:var(--accent);background:#3b9eff0d}.awards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.award-card{background:var(--card);border-radius:var(--radius);border:1px solid var(--border-light);padding:20px 22px;transition:all var(--transition-normal);display:flex;gap:14px;align-items:flex-start}.award-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:transparent}.award-icon{width:42px;height:42px;flex-shrink:0;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:19px}.award-card:nth-child(n+1) .award-icon{background:#ffd7001a}.award-card:nth-child(4n+2) .award-icon{background:#c0c0c01a}.award-card:nth-child(4n+3) .award-icon{background:#cd7f321a}.award-card:nth-child(4n) .award-icon{background:#3b9eff1a}.award-info{flex:1}.award-name{font-size:15px;font-weight:700;color:var(--primary);margin-bottom:2px;line-height:1.4}.award-source{font-size:13px;color:var(--text-muted)}.lang-highlight{grid-column:1 / -1;background:linear-gradient(135deg,#3b9eff0f,#34c7960f);border-color:#3b9eff26}.lang-score-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:12px}.lang-score-item{text-align:center;padding:12px 8px;background:var(--card);border-radius:var(--radius-sm)}.lang-score-num{font-size:24px;font-weight:800;color:var(--accent)}.lang-score-label{font-size:12px;color:var(--text-muted);margin-top:2px}.portfolio-filter{display:flex;gap:8px;margin-bottom:28px;flex-wrap:wrap}.pf-btn{padding:7px 20px;border-radius:var(--radius-full);font-size:13px;font-weight:600;color:var(--text-secondary);background:var(--card);border:1px solid var(--border);cursor:pointer;transition:all var(--transition-fast)}.pf-btn:hover{border-color:var(--accent);color:var(--accent)}.pf-btn.active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 4px 12px #3b9eff40}.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.portfolio-card{background:var(--card);border-radius:var(--radius-lg);border:1px solid var(--border-light);overflow:hidden;cursor:pointer;transition:all var(--transition-normal)}.portfolio-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px);border-color:transparent}.pc-cover{position:relative;width:100%;aspect-ratio:1/1;overflow:hidden;background:linear-gradient(135deg,#f0f4f8,#e8f0fe)}.pc-cover img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease-out)}.portfolio-card:hover .pc-cover img{transform:scale(1.04)}.pc-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(15,23,42,.6) 100%);display:flex;align-items:flex-end;justify-content:flex-end;padding:16px;opacity:0;transition:opacity var(--transition-normal)}.portfolio-card:hover .pc-overlay{opacity:1}.pc-expand-icon{width:36px;height:36px;border-radius:50%;background:#fff3;backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.pc-expand-icon svg{width:16px;height:16px}.pc-expand-icon:hover{background:var(--accent)}.pc-info{padding:18px 20px 20px}.pc-tags{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:8px}.pc-tag{padding:2px 9px;border-radius:var(--radius-full);font-size:11px;font-weight:600;background:var(--card-alt);color:var(--text-muted)}.pc-title{font-size:16px;font-weight:800;color:var(--primary);line-height:1.4;margin-bottom:6px}.pc-desc{font-size:13px;color:var(--text-secondary);line-height:1.65}.pc-detail{border-top:1px solid var(--border-light);background:var(--bg-warm)}.pc-detail-inner{padding:24px}.project-overview-inline{background:var(--card);border-radius:var(--radius);padding:20px 24px;margin-bottom:20px;border:1px solid var(--border-light)}.ov-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;text-align:center}.ov-item{padding:8px}.ov-emoji{font-size:22px;display:block;margin-bottom:6px}.ov-label{display:block;font-size:11px;color:var(--text-muted);letter-spacing:1px;margin-bottom:2px}.ov-val{display:block;font-size:13px;font-weight:800;color:var(--primary)}.report-quote{margin-bottom:20px}.report-quote blockquote{font-size:15px;color:var(--primary);line-height:1.8;font-weight:600;font-style:italic;border-left:4px solid var(--accent);padding-left:18px;margin:0}.portfolio-card.expanded .pc-detail{display:block!important;animation:detailSlideIn .35s var(--ease-out)}@keyframes detailSlideIn{0%{opacity:0;max-height:0}to{opacity:1;max-height:2000px}}.portfolio-card.filtered-out{display:none}.video-grid-inline{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:12px}.vi-card{text-align:center}.vi-player{border-radius:var(--radius-sm);overflow:hidden;background:#000;box-shadow:var(--shadow-md)}.vi-player video{width:100%;display:block}.vi-caption{margin-top:8px;font-size:13px;font-weight:600;color:var(--text-muted)}.pipeline-inline{display:flex;align-items:stretch;gap:0;margin-top:20px;background:var(--card-alt);border-radius:var(--radius);padding:20px 16px;overflow-x:auto}.ps-step{flex:1;min-width:140px;text-align:center;padding:8px 6px}.ps-num{font-size:24px;font-weight:900;color:var(--accent);opacity:.2;line-height:1;margin-bottom:4px}.ps-step h4{font-size:13px;font-weight:700;color:var(--primary);margin-bottom:4px}.ps-step p{font-size:11px;color:var(--text-muted);line-height:1.5}.ps-arrow{display:flex;align-items:center;font-size:18px;color:var(--accent);opacity:.3;font-weight:700;padding:0 2px;flex-shrink:0}.gallery-grid-inline{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:16px}.gi-item{border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;border:1px solid var(--border-light);transition:transform var(--transition-fast),box-shadow var(--transition-fast);background:#fff}.gi-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}.gi-item img{width:100%;display:block}.gi-cap{font-size:11px;text-align:center;padding:5px;color:var(--text-muted);background:#fff}.gallery-scroll-inline{display:flex;gap:12px;overflow-x:auto;padding:8px 0 12px;scroll-snap-type:x mandatory}.gsi-item{min-width:220px;max-width:260px;flex-shrink:0;scroll-snap-align:start;border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;border:1px solid var(--border-light);background:#fff;transition:transform var(--transition-fast)}.gsi-item:hover{transform:translateY(-3px);box-shadow:var(--shadow-sm)}.gsi-item img{width:100%;display:block}.gsi-cap{font-size:11px;text-align:center;padding:5px;color:var(--text-muted);background:#fff}.lb-overlay{display:none;position:fixed;inset:0;background:#0f172ad9;z-index:9999;align-items:center;justify-content:center;cursor:zoom-out;backdrop-filter:blur(8px)}.lb-overlay.active{display:flex}.lb-overlay img{max-width:92vw;max-height:90vh;border-radius:var(--radius);box-shadow:var(--shadow-xl)}.lb-close{position:absolute;top:18px;right:24px;font-size:32px;color:#fff;cursor:pointer;opacity:.6;transition:opacity .2s;line-height:1;user-select:none}.lb-close:hover{opacity:1}.pf-modal-overlay{display:none;position:fixed;inset:0;z-index:5000;background:#0f172ab8;backdrop-filter:blur(14px) saturate(160%);-webkit-backdrop-filter:blur(14px) saturate(160%);opacity:0;transition:opacity .3s var(--ease-out)}.pf-modal-overlay.active{display:flex;align-items:center;justify-content:center}.pf-modal-overlay.visible{opacity:1}.pf-modal-content{position:relative;width:94vw;max-width:960px;height:90vh;background:var(--card);border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 25px 80px #0f172a40;display:flex;flex-direction:column;transform:translateY(40px) scale(.97);transition:transform .4s cubic-bezier(.34,1.56,.64,1)}.pf-modal-overlay.visible .pf-modal-content{transform:translateY(0) scale(1)}.pf-modal-header{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:18px 28px;background:var(--card);border-bottom:1px solid var(--border-light);flex-shrink:0}.pf-modal-title-wrap{display:flex;align-items:center;gap:12px;min-width:0}.pf-modal-cover-thumb{width:40px;height:40px;border-radius:8px;object-fit:cover;flex-shrink:0}.pf-modal-title{font-size:17px;font-weight:800;color:var(--primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pf-modal-close{width:38px;height:38px;border-radius:50%;border:none;background:var(--card-alt);color:var(--text-secondary);font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);flex-shrink:0}.pf-modal-close:hover{background:#e74c3c1a;color:#e74c3c;transform:rotate(90deg)}.pf-modal-body{flex:1;overflow-y:auto;padding:28px;-webkit-overflow-scrolling:touch}.pf-modal-body::-webkit-scrollbar{width:6px}.pf-modal-body::-webkit-scrollbar-track{background:transparent}.pf-modal-body::-webkit-scrollbar-thumb{background:#1e3a5f1f;border-radius:3px}.pf-modal-body .gallery-grid-inline{grid-template-columns:repeat(4,1fr)}.pf-modal-body .gallery-scroll-inline .gsi-item{min-width:200px;max-width:240px}.pf-modal-body .ov-grid{grid-template-columns:repeat(4,1fr)}@media (max-width: 900px){.pf-modal-body .gallery-grid-inline,.pf-modal-body .ov-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.pf-modal-content{width:100vw;height:100vh;border-radius:0;max-width:none}.pf-modal-header{padding:14px 20px}.pf-modal-body{padding:20px}.pf-modal-body .gallery-grid-inline,.pf-modal-body .ov-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.pf-modal-body{padding:16px}.pf-modal-body .gallery-grid-inline{grid-template-columns:1fr 1fr}.pf-modal-body .gallery-scroll-inline .gsi-item{min-width:160px}}.footer{text-align:center;padding:36px 24px;color:var(--text-muted);font-size:13px;border-top:1px solid var(--border-light);margin-top:24px}.footer a{color:var(--text-secondary);font-weight:500}.footer a:hover{color:var(--accent)}@media (max-width: 900px){.home-hero{grid-template-columns:1fr}.photo-card{position:static;max-width:300px;margin:0 auto}.edu-grid,.skills-layout{grid-template-columns:1fr}.quick-nav-grid{grid-template-columns:repeat(3,1fr)}.video-grid-inline{grid-template-columns:1fr}.gallery-grid-inline,.lang-score-grid,.portfolio-grid,.ov-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){:root{--nav-height: 56px;--section-py: 44px}.hamburger{display:flex}.nav-links{display:none;position:fixed;top:var(--nav-height);left:0;right:0;background:var(--card);flex-direction:column;padding:16px 20px 20px;box-shadow:var(--shadow-lg);z-index:999;transform:translateY(-100%);opacity:0;pointer-events:none;transition:all var(--transition-normal)}.nav-links.open{display:flex;transform:translateY(0);opacity:1;pointer-events:auto}.nav-link{padding:12px 16px;font-size:15px;text-align:center}.hero-name{font-size:30px}.hero-tagline{max-width:100%}.tag-group,.contact-row{justify-content:center}}@media (max-width: 480px){.nav-inner{padding:0 16px}.page-section{padding:var(--section-py) 16px}.hero-name{font-size:26px}.contact-row{flex-direction:column;gap:10px}.gallery-scroll-inline .gsi-item{min-width:180px}.quick-nav-grid{grid-template-columns:1fr}}
