@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap');
  *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
  :root { --bg: #0a0a0a; --fg: #f0ede8; --muted: rgba(240,237,232,0.45); --card-bg: #141414; --border: rgba(240,237,232,0.1); }
  html { scroll-behavior: smooth; }
  body { background: var(--bg); color: var(--fg); font-family: 'Inter', sans-serif; overflow-x: hidden; -webkit-font-smoothing: antialiased; padding-bottom: 100px; }
  #greeting-overlay { position: fixed; inset: 0; background: var(--bg); z-index: 999; display: flex; flex-direction: column; align-items: center; justify-content: center; }
  .greet-word { font-size: clamp(40px, 8vw, 96px); font-weight: 600; letter-spacing: -0.04em; line-height: 1; position: absolute; text-align: center; display: flex; gap: 0.04em; }
  .greet-char { display: inline-block; opacity: 0; filter: blur(8px); transform: translateY(12px) scale(0.92); transition: opacity 0.4s ease, filter 0.4s ease, transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1); }
  .greet-char.in { opacity: 1; filter: blur(0); transform: translateY(0) scale(1); }
  .greet-char.out { opacity: 0; filter: blur(6px); transform: translateY(-10px) scale(1.04); transition: opacity 0.3s ease, filter 0.3s ease, transform 0.3s ease; }
  .greet-sub { position: absolute; bottom: 80px; font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--muted); display: flex; flex-direction: column; align-items: center; gap: 16px; }
  .greet-dots { display: flex; gap: 6px; }
  .greet-dot { width: 5px; height: 5px; border-radius: 50%; background: var(--border); transition: background 0.3s; }
  .greet-dot.active { background: var(--fg); }
  #greeting-overlay.fade-out { opacity: 0; transition: opacity 0.6s ease; pointer-events: none; }
  nav { position: fixed; top: 20px; left: 50%; transform: translateX(-50%); z-index: 200; display: flex; align-items: center; height: 52px; padding: 0 8px; border-radius: 16px; background: rgba(10,10,10,0.75); backdrop-filter: blur(32px) saturate(180%); border: 1px solid rgba(255,255,255,0.1); box-shadow: 0 4px 24px rgba(0,0,0,0.5), 0 1px 0 rgba(255,255,255,0.06) inset; white-space: nowrap; gap: 0; transition: opacity 0.45s cubic-bezier(0.65,0,0.35,1), transform 0.45s cubic-bezier(0.65,0,0.35,1); }
  nav.is-split { opacity: 0; pointer-events: none; transform: translateX(-50%) scale(0.88); }
  .nav-pill { position: fixed; top: 20px; z-index: 200; display: flex; align-items: center; height: 52px; padding: 0 8px; border-radius: 16px; background: rgba(10,10,10,0.75); backdrop-filter: blur(32px) saturate(180%); border: 1px solid rgba(255,255,255,0.1); box-shadow: 0 4px 24px rgba(0,0,0,0.5), 0 1px 0 rgba(255,255,255,0.06) inset; opacity: 0; pointer-events: none; transition: opacity 0.5s cubic-bezier(0.65,0,0.35,1), transform 0.6s cubic-bezier(0.34,1.56,0.64,1); }
  .nav-pill.nav-pill-left { left: 20px; transform: translateY(-10px) translateX(-16px); }
  .nav-pill.nav-pill-right { right: 20px; transform: translateY(-10px) translateX(16px); }
  .nav-pill.is-visible { opacity: 1; pointer-events: auto; transform: translateY(0) translateX(0); }
  .nav-divider { width: 1px; height: 22px; background: rgba(255,255,255,0.1); margin: 0 6px; flex-shrink: 0; }
  .nav-icons { display: flex; align-items: center; gap: 6px; }
  .nav-icon { position: relative; width: 34px; height: 34px; display: flex; align-items: center; justify-content: center; cursor: pointer; flex-shrink: 0; text-decoration: none; transition: transform 0.25s cubic-bezier(0.34, 1.56, 0.64, 1), box-shadow 0.25s ease; clip-path: url(#squircleClip); }
  .nav-icon:hover { transform: scale(1.15) translateY(-3px); box-shadow: 0 8px 20px rgba(0,0,0,0.5); }
  .nav-icon svg { width: 16px; height: 16px; flex-shrink: 0; }
  .nav-icon-home { overflow: hidden; }
  .nav-icon-gh { background: linear-gradient(135deg, #374151, #111827); }
  .nav-icon-li { background: linear-gradient(135deg, #2563eb, #1e40af); }
  .nav-icon-yt { background: linear-gradient(135deg, #dc2626, #991b1b); }
  .nav-icon-dc { background: linear-gradient(135deg, #4f46e5, #3730a3); }
  .hero { height: 100vh; display: flex; flex-direction: column; justify-content: center; padding: 0 40px 0 160px; position: relative; }
  .hero-line { font-size: clamp(28px, 3.8vw, 52px); font-weight: 700; letter-spacing: -0.03em; line-height: 1.35; display: block; color: #ffffff; }
  .flag-swap { display: inline-block; position: relative; cursor: default; width: 1.1em; height: 1em; vertical-align: middle; }
  .flag-swap .f-peace, .flag-swap .f-nepal { position: absolute; left: 0; top: 0; display: inline-block; transform-origin: center center; transition: transform 0.5s cubic-bezier(0.34, 1.56, 0.64, 1), opacity 0.35s ease; }
  .flag-swap .f-peace { opacity: 1; transform: rotate(0deg) scale(1); }
  .flag-swap .f-nepal { opacity: 0; transform: rotate(45deg) scale(0.3); }
  .flag-swap:hover .f-peace { opacity: 0; transform: rotate(-45deg) scale(0.3); }
  .flag-swap:hover .f-nepal { opacity: 1; transform: rotate(0deg) scale(1); }
  .stack-section { padding: 0 40px 80px; overflow: visible; display: flex; flex-direction: column; align-items: center; }
  .stack-title { font-size: clamp(22px, 2.8vw, 38px); font-weight: 700; letter-spacing: -0.02em; color: var(--fg); margin-bottom: 36px; position: relative; display: inline-block; cursor: default; }
  .stack-title::after { content: ''; position: absolute; left: 0; bottom: -6px; width: 100%; height: 2px; background: var(--fg); transform-origin: left center; transition: transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1), opacity 0.3s ease; }
  .stack-title:hover::after { transform: scaleX(1.06) translateY(-2px); opacity: 0.6; }
  .stack-row { display: flex; align-items: center; justify-content: center; gap: 32px; flex-wrap: wrap; }
  .stack-item { position: relative; display: flex; align-items: center; justify-content: center; cursor: default; }
  .stack-item img { width: 38px; height: 38px; object-fit: contain; opacity: 0.75; transition: opacity 0.3s ease, transform 0.35s cubic-bezier(0.34, 1.56, 0.64, 1), filter 0.3s ease; display: block; }
  .stack-item:hover img { opacity: 1; filter: drop-shadow(0 0 8px rgba(240,237,232,0.25)); transform: translateY(-6px) scale(1.2); }
  .stack-item .aws-logo { width: 46px; height: 46px; filter: brightness(10); opacity: 0.75; }
  .stack-item:hover .aws-logo { filter: brightness(10) drop-shadow(0 0 8px rgba(240,237,232,0.25)); opacity: 1; }
  .stack-item .bash-logo { filter: invert(1); opacity: 0.75; }
  .stack-item:hover .bash-logo { filter: invert(1) drop-shadow(0 0 8px rgba(240,237,232,0.25)); opacity: 1; }
  .stack-bubble { position: absolute; bottom: calc(100% + 14px); left: 50%; transform: translateX(-50%) scale(0.7) translateY(6px); opacity: 0; pointer-events: none; transition: opacity 0.2s ease, transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1); white-space: nowrap; z-index: 100; }
  .stack-item:hover .stack-bubble { opacity: 1; transform: translateX(-50%) scale(1) translateY(0); }
  .stack-bubble-inner { background: var(--fg); color: #0a0a0a; font-size: 11px; font-weight: 600; letter-spacing: 0.04em; padding: 5px 10px; border-radius: 20px; border: 2px solid #0a0a0a; position: relative; }
  .stack-bubble-inner::after { content: ''; position: absolute; bottom: -8px; left: 50%; transform: translateX(-50%); width: 5px; height: 5px; border-radius: 50%; background: var(--fg); border: 2px solid #0a0a0a; box-shadow: 0 7px 0 -1px var(--fg), 0 7px 0 1px #0a0a0a, 0 13px 0 -2px var(--fg), 0 13px 0 0px #0a0a0a; }
  .experience-section { padding: 100px 40px 80px; border-top: 1px solid var(--border); display: flex; flex-direction: column; align-items: center; }
  .experience-title { font-size: clamp(22px, 2.8vw, 38px); font-weight: 700; letter-spacing: -0.02em; color: var(--fg); margin-bottom: 56px; position: relative; display: inline-block; cursor: default; }
  .experience-title::after { content: ''; position: absolute; left: 0; bottom: -6px; width: 100%; height: 2px; background: var(--fg); transform-origin: left center; transition: transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1), opacity 0.3s ease; }
  .experience-title:hover::after { transform: scaleX(1.06) translateY(-2px); opacity: 0.6; }
  .exp-stage { position: relative; display: flex; align-items: center; justify-content: center; gap: 0; width: 100%; max-width: 860px; }
  .exp-side-img { position: absolute; top: 50%; width: 100px; opacity: 0.18; pointer-events: none; transition: opacity 0.4s ease; }
  .exp-side-img-left { left: 0; transform: translateY(-50%) rotate(180deg); }
  .exp-side-img-right { right: 0; transform: translateY(-50%); }
  .exp-stage:hover .exp-side-img { opacity: 0.28; }
  .phone-wrap { position: relative; z-index: 2; transition: transform 0.65s cubic-bezier(0.34, 1.56, 0.64, 1); }
  .exp-stage.expanded .phone-wrap { transform: translateX(-90px); }
  .phone { position: relative; width: 240px; height: 460px; border: 3.5px solid rgba(240,237,232,0.75); border-radius: 32px; background: #0d0d0d; overflow: hidden; flex-shrink: 0; box-shadow: 0 32px 80px rgba(0,0,0,0.6), inset 0 1px 0 rgba(255,255,255,0.08); transition: box-shadow 0.4s ease; }
  .exp-stage.expanded .phone { box-shadow: 0 48px 100px rgba(0,0,0,0.8), inset 0 1px 0 rgba(255,255,255,0.08); }
  .phone-power { position: absolute; border: 3.5px solid rgba(240,237,232,0.75); right: -7px; top: 80px; height: 36px; border-radius: 0 4px 4px 0; width: 0; }
  .phone-notch { position: absolute; top: 0; left: 50%; transform: translateX(-50%); width: 80px; height: 10px; background: rgba(240,237,232,0.75); border-bottom-left-radius: 14px; border-bottom-right-radius: 14px; z-index: 10; }
  .exp-detail-card { position: absolute; left: 50%; top: 50%; transform: translateY(-50%) translateX(-20px) scale(0.92); width: 210px; background: #111; border: 1px solid rgba(240,237,232,0.1); border-radius: 20px; padding: 20px 18px; opacity: 0; pointer-events: none; transition: opacity 0.5s cubic-bezier(0.4,0,0.2,1), transform 0.65s cubic-bezier(0.34,1.56,0.64,1); z-index: 1; }
  .exp-stage.expanded .exp-detail-card { opacity: 1; transform: translateY(-50%) translateX(16px) scale(1); pointer-events: auto; }
  .detail-img { width: 40px; height: 40px; border-radius: 12px; background: rgba(255,255,255,0.05); border: 1px solid rgba(240,237,232,0.08); display: flex; align-items: center; justify-content: center; overflow: hidden; margin-bottom: 14px; }
  .detail-img img { width: 24px; height: 24px; object-fit: contain; }
  .detail-role { font-size: 15px; font-weight: 700; letter-spacing: -0.02em; color: rgba(240,237,232,0.95); line-height: 1.2; margin-bottom: 4px; }
  .detail-year { font-size: 10px; color: rgba(240,237,232,0.28); letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: 14px; }
  .detail-divider { height: 1px; background: rgba(240,237,232,0.07); margin-bottom: 12px; }
  .detail-desc { font-size: 11.5px; color: rgba(240,237,232,0.5); line-height: 1.6; letter-spacing: 0.01em; }
  .detail-progress { height: 2px; background: rgba(240,237,232,0.06); border-radius: 2px; margin-top: 18px; overflow: hidden; }
  .detail-progress-bar { height: 100%; background: rgba(240,237,232,0.25); border-radius: 2px; width: 100%; transform: scaleX(0); transform-origin: left; transition: transform 3s linear; }
  .exp-stage.expanded .detail-progress-bar { transform: scaleX(1); }
  .lock-screen { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; background: #0d0d0d; z-index: 2; transition: opacity 0.5s ease, transform 0.5s cubic-bezier(0.4,0,0.2,1); }
  .lock-screen.hidden { opacity: 0; transform: translateY(-24px); pointer-events: none; }
  .lock-time { font-size: 3rem; font-weight: 200; letter-spacing: -0.05em; color: rgba(240,237,232,0.95); line-height: 1; margin-top: 8px; }
  .lock-date { font-size: 10px; color: rgba(240,237,232,0.38); letter-spacing: 0.1em; text-transform: uppercase; margin-top: 6px; }
  .fp-wrap { position: absolute; bottom: 48px; display: flex; flex-direction: column; align-items: center; gap: 8px; }
  .fp-ring { width: 42px; height: 42px; border-radius: 50%; border: 1.5px solid rgba(240,237,232,0.15); display: flex; align-items: center; justify-content: center; position: relative; }
  .fp-ring::before { content: ''; position: absolute; inset: -4px; border-radius: 50%; border: 1.5px solid rgba(240,237,232,0); transition: border-color 0.3s, transform 0.3s; }
  .fp-ring.scanning::before { border-color: rgba(240,237,232,0.4); animation: fp-pulse 0.7s ease-in-out 3; }
  @keyframes fp-pulse { 0%,100% { transform: scale(1); border-color: rgba(240,237,232,0.15); } 50% { transform: scale(1.18); border-color: rgba(240,237,232,0.7); } }
  .fp-ring svg path { transition: stroke 0.3s; }
  .fp-ring.scanning svg path { stroke: rgba(240,237,232,0.9) !important; }
  .fp-hint { font-size: 8.5px; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(240,237,232,0.2); animation: breathe 2.8s ease-in-out infinite; }
  @keyframes breathe { 0%,100%{opacity:0.4} 50%{opacity:1} }
  .home-screen { position: absolute; inset: 0; background: #0d0d0d; overflow-y: auto; overflow-x: hidden; scrollbar-width: none; z-index: 1; opacity: 0; transform: translateY(24px); transition: opacity 0.5s ease, transform 0.5s cubic-bezier(0.34,1.56,0.64,1); }
  .home-screen::-webkit-scrollbar { display: none; }
  .home-screen.visible { opacity: 1; transform: translateY(0); z-index: 3; }
  .home-header { padding: 22px 16px 10px; font-size: 10px; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(240,237,232,0.35); }
  .exp-tiles { padding: 0 12px 24px; display: flex; flex-direction: column; gap: 8px; }
  .exp-tile { display: flex; align-items: center; gap: 12px; padding: 11px 12px; border: 1px solid rgba(240,237,232,0.08); border-radius: 14px; background: rgba(255,255,255,0.03); opacity: 0; transform: translateY(8px); transition: opacity 0.38s ease, transform 0.38s cubic-bezier(0.34,1.56,0.64,1), border-color 0.25s, background 0.25s; cursor: pointer; }
  .exp-tile:hover { border-color: rgba(240,237,232,0.22); background: rgba(255,255,255,0.06); }
  .exp-tile.active { border-color: rgba(240,237,232,0.3); background: rgba(255,255,255,0.07); }
  .exp-tile.show { opacity: 1; transform: translateY(0); }
  .tile-logo { width: 40px; height: 40px; border-radius: 11px; background: rgba(255,255,255,0.05); border: 1px solid rgba(240,237,232,0.08); display: flex; align-items: center; justify-content: center; flex-shrink: 0; overflow: hidden; }
  .tile-logo img { width: 24px; height: 24px; object-fit: contain; }
  .tile-info { flex: 1; min-width: 0; }
  .tile-name { font-size: 13px; font-weight: 600; color: rgba(240,237,232,0.92); letter-spacing: -0.01em; line-height: 1.3; white-space: normal; word-break: break-word; }
  .tile-meta { font-size: 10px; color: rgba(240,237,232,0.32); letter-spacing: 0.02em; margin-top: 3px; }
  .tile-year { font-size: 11px; color: rgba(240,237,232,0.25); letter-spacing: 0.04em; flex-shrink: 0; padding-left: 6px; }

  .projects-section { padding: 100px 40px 80px; border-top: 1px solid var(--border); display: flex; flex-direction: column; align-items: center; }
  .projects-title { font-size: clamp(22px, 2.8vw, 38px); font-weight: 700; letter-spacing: -0.02em; color: var(--fg); margin-bottom: 64px; position: relative; display: inline-block; cursor: default; }
  .projects-title::after { content: ''; position: absolute; left: 0; bottom: -6px; width: 100%; height: 2px; background: var(--fg); transform-origin: left center; transition: transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1), opacity 0.3s ease; }
  .projects-title:hover::after { transform: scaleX(1.06) translateY(-2px); opacity: 0.6; }
  .proj-stage { position: relative; width: 100%; max-width: 680px; height: 380px; display: flex; align-items: center; justify-content: center; }
  .folder-zone { position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); transition: left 0.7s cubic-bezier(0.65,0,0.35,1), transform 0.7s cubic-bezier(0.65,0,0.35,1); z-index: 10; }
  .folder-zone.moved { left: 22%; transform: translate(-50%, -50%); }
  .folder-wrap-p { width: 170px; height: 130px; perspective: 1200px; display: flex; align-items: center; justify-content: center; position: relative; cursor: pointer; user-select: none; }
  .folder-container-p { position: relative; width: 100%; height: 100%; transform-style: preserve-3d; transition: transform 0.6s cubic-bezier(0.23,1,0.32,1); backface-visibility: hidden; }
  .folder-zone.fopen .folder-container-p { transform: rotateX(10deg) rotateY(-5deg); }
  .folder-back-p { position: absolute; bottom: 0; width: 100%; }
  .folder-front-wrapper-p { position: absolute; bottom: -7px; width: 100%; z-index: 90; transform-origin: bottom; transition: transform 0.5s cubic-bezier(0.175,0.885,0.32,1.275); border-radius: 12px; }
  .folder-zone.fopen .folder-front-wrapper-p { transform: rotateX(-50deg); }
  .folder-label-p { position: absolute; top: 10px; left: 10px; width: 30px; height: 4px; background: rgba(255,255,255,0.5); border-radius: 10px; }
  .p-hint { position: absolute; top: -44px; right: -54px; display: flex; flex-direction: column; align-items: center; gap: 2px; pointer-events: none; z-index: 100; animation: pfh 2.5s ease-in-out infinite; transition: opacity 0.3s ease; }
  .folder-zone.fopen .p-hint { opacity: 0; pointer-events: none; }
  .p-hint-text { font-family: 'Inter', sans-serif; color: #60a5fa; font-size: 10px; font-weight: 900; text-decoration: underline; letter-spacing: 0.5px; white-space: nowrap; position: relative; right: -25px; top: 10px; transform: rotate(45deg); }
  .p-hint-arrow { height: 35px; width: 35px; }
  @keyframes pfh { 0%,100%{transform:translateY(0);} 50%{transform:translateY(6px);} }
  .p-file { position: absolute; bottom: 5px; left: 10%; width: 80%; height: 85px; border-radius: 8px; overflow: hidden; transition: all 0.58s cubic-bezier(0.68,-0.55,0.265,1.55); z-index: 0; cursor: pointer; }
  .p-file-1 { background: linear-gradient(135deg,#7c3aed,#4f46e5); z-index:25; transition-delay:0.15s; }
  .p-file-2 { background: linear-gradient(135deg,#0ea5e9,#0284c7); z-index:26; transition-delay:0.10s; }
  .p-file-3 { background: linear-gradient(135deg,#10b981,#059669); z-index:27; transition-delay:0.05s; }
  .p-file-4 { background: linear-gradient(135deg,#f59e0b,#d97706); z-index:28; transition-delay:0.02s; }
  .p-file-shine { position: absolute; top: 0; left: -100%; width: 50%; height: 100%; background: linear-gradient(90deg,transparent,rgba(255,255,255,0.3),transparent); transform: skewX(-20deg); transition: none; }
  .folder-zone.fopen .p-file-shine { left: 150%; transition: left 0.8s ease-in-out; transition-delay: 0.3s; }
  .p-file-inner { padding: 10px 12px; height: 100%; display: flex; flex-direction: column; justify-content: space-between; }
  .p-file-name { font-size: 12px; font-weight: 800; color: rgba(255,255,255,0.95); letter-spacing: -0.01em; opacity: 0; transform: translateY(4px); transition: opacity 0.3s ease 0.35s, transform 0.3s ease 0.35s; }
  .folder-zone.fopen .p-file-name { opacity: 1; transform: translateY(0); }
  .p-file-tag { font-size: 8px; font-weight: 700; color: rgba(255,255,255,0.55); letter-spacing: 0.08em; text-transform: uppercase; opacity: 0; transition: opacity 0.3s ease 0.42s; }
  .folder-zone.fopen .p-file-tag { opacity: 1; }
  .folder-zone.fopen .p-file-1 { transform: translateY(-160px) rotate(-18deg) translateX(-44px); }
  .folder-zone.fopen .p-file-2 { transform: translateY(-130px) rotate(14deg) translateX(42px); }
  .folder-zone.fopen .p-file-3 { transform: translateY(-100px) rotate(-22deg) translateX(-28px); }
  .folder-zone.fopen .p-file-4 { transform: translateY(-70px) rotate(17deg) translateX(30px); }
  .folder-zone.fopen .p-file:hover { filter: brightness(1.12); }
  .folder-zone.fopen .p-file-1:hover { transform: translateY(-175px) rotate(-18deg) translateX(-44px); }
  .folder-zone.fopen .p-file-2:hover { transform: translateY(-145px) rotate(14deg) translateX(42px); }
  .folder-zone.fopen .p-file-3:hover { transform: translateY(-115px) rotate(-22deg) translateX(-28px); }
  .folder-zone.fopen .p-file-4:hover { transform: translateY(-85px) rotate(17deg) translateX(30px); }
  .p-counter { position: absolute; top: -92px; right: -78px; background: #a18cd1; padding: 4px 8px; border-radius: 50px; display: flex; align-items: center; gap: 8px; box-shadow: 0 10px 20px rgba(0,0,0,0.3), inset 0 1px 1px rgba(255,255,255,0.2); transform: scale(0) translateY(20px); opacity: 0; transition: all 0.5s cubic-bezier(0.34,1.56,0.64,1); z-index: 100; pointer-events: none; }
  .folder-zone.fopen .p-counter { transform: scale(1) translateY(0); opacity: 1; transition-delay: 0.25s; }
  .p-sdot { width: 6px; height: 6px; background: #34d399; border-radius: 50%; position: relative; box-shadow: 0 0 10px #34d399; }
  .p-sdot::after { content:''; position:absolute; top:0; left:0; width:100%; height:100%; background:#34d399; border-radius:50%; animation: ppulse 2s infinite; }
  @keyframes ppulse { 0%{transform:scale(1);opacity:1;} 100%{transform:scale(3);opacity:0;} }
  .p-clabel { font-family:'Inter',sans-serif; font-size:8px; font-weight:800; color:#000; text-transform:uppercase; }
  .p-cnum { font-family:'Inter',sans-serif; font-size:12px; font-weight:900; color:#fff; }
  .p-timer-ring { position: absolute; top: -10px; left: -10px; right: -10px; bottom: -10px; pointer-events: none; opacity: 0; transition: opacity 0.4s ease; }
  .folder-zone.fopen .p-timer-ring { opacity: 1; }
  .p-timer-ring circle { fill: none; stroke: rgba(240,237,232,0.15); stroke-width: 2; stroke-dasharray: 440; stroke-dashoffset: 0; stroke-linecap: round; transform: rotate(-90deg); transform-origin: 50% 50%; transition: stroke-dashoffset 5s linear, stroke 0.3s; }
  .p-timer-ring circle.active { stroke-dashoffset: 440; }

  .proj-detail-zone { position: absolute; right: 0; top: 50%; transform: translateY(-50%) translateX(50px); opacity: 0; pointer-events: none; width: 270px; transition: opacity 0.5s cubic-bezier(0.4,0,0.2,1), transform 0.65s cubic-bezier(0.34,1.56,0.64,1); z-index: 5; }
  .proj-detail-zone.visible { opacity: 1; transform: translateY(-50%) translateX(0); pointer-events: auto; }
  .proj-detail-card { background: #111; border: 1px solid rgba(240,237,232,0.12); border-radius: 20px; overflow: hidden; position: relative; }

  .pd-banner {
    width: 100%;
    height: 110px;
    position: relative;
    overflow: hidden;
    flex-shrink: 0;
  }
  .pd-banner-img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    transition: transform 0.4s ease;
  }
  .proj-detail-card:hover .pd-banner-img {
    transform: scale(1.05);
  }
  .pd-banner-pill {
    position: absolute;
    top: 12px;
    left: 14px;
    background: rgba(0,0,0,0.45);
    backdrop-filter: blur(8px);
    border: 1px solid rgba(255,255,255,0.15);
    border-radius: 20px;
    padding: 3px 9px;
    font-size: 8px;
    font-weight: 700;
    color: rgba(255,255,255,0.9);
    letter-spacing: 0.08em;
    text-transform: uppercase;
    z-index: 2;
  }

  .pd-body { padding: 14px 16px 16px; }
  .pd-close { position: absolute; top: 10px; right: 10px; width: 22px; height: 22px; border-radius: 50%; background: rgba(0,0,0,0.35); backdrop-filter: blur(6px); border: 1px solid rgba(255,255,255,0.15); color: rgba(255,255,255,0.7); font-size: 11px; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: background 0.2s, color 0.2s; font-family: 'Inter', sans-serif; z-index: 10; }
  .pd-close:hover { background: rgba(255,255,255,0.2); color: #fff; }
  .pd-name { font-size: 16px; font-weight: 700; color: rgba(240,237,232,0.95); letter-spacing: -0.02em; margin-bottom: 3px; }
  .pd-tag { font-size: 9px; color: rgba(240,237,232,0.3); letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 10px; }
  .pd-divider { height: 1px; background: rgba(240,237,232,0.07); margin-bottom: 10px; }
  .pd-desc { font-size: 11px; color: rgba(240,237,232,0.5); line-height: 1.6; letter-spacing: 0.01em; margin-bottom: 14px; }
  .pd-btn { display: block; width: 100%; padding: 9px; background: rgba(240,237,232,0.06); border: 1px solid rgba(240,237,232,0.18); border-radius: 10px; color: rgba(240,237,232,0.88); font-family: 'Inter', sans-serif; font-size: 11px; font-weight: 600; letter-spacing: 0.04em; text-align: center; cursor: pointer; text-decoration: none; transition: background 0.25s, border-color 0.25s, transform 0.3s cubic-bezier(0.34,1.56,0.64,1); }
  .pd-btn:hover { background: rgba(240,237,232,0.13); border-color: rgba(240,237,232,0.38); transform: translateY(-2px); }
  .pd-btn:active { transform: scale(0.97); }
  .pd-bar { height: 2px; background: rgba(240,237,232,0.06); border-radius: 2px; margin-top: 14px; overflow: hidden; }
  .pd-bar-fill { height: 100%; background: rgba(240,237,232,0.25); border-radius: 2px; width: 100%; transform: scaleX(0); transform-origin: left; }

  .contact-section { padding: 100px 40px 100px; border-top: 1px solid var(--border); display: flex; flex-direction: column; align-items: center; }
  .contact-title { font-size: clamp(22px, 2.8vw, 38px); font-weight: 700; letter-spacing: -0.02em; color: var(--fg); margin-bottom: 64px; position: relative; display: inline-block; cursor: default; }
  .contact-title::after { content: ''; position: absolute; left: 0; bottom: -6px; width: 100%; height: 2px; background: var(--fg); transform-origin: left center; transition: transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1), opacity 0.3s ease; }
  .contact-title:hover::after { transform: scaleX(1.06) translateY(-2px); opacity: 0.6; }
  .contact-body { display: flex; align-items: center; gap: 80px; width: 100%; max-width: 760px; }
  .contact-photo { width: 280px; height: 320px; border-radius: 28px; object-fit: cover; flex-shrink: 0; opacity: 0.92; filter: grayscale(12%); }
  .contact-links { display: flex; flex-direction: column; gap: 0; flex: 1; }
  .contact-link { display: flex; align-items: center; gap: 16px; padding: 16px 0; border-bottom: 1px solid var(--border); text-decoration: none; color: var(--fg); transition: gap 0.3s cubic-bezier(0.34, 1.56, 0.64, 1), opacity 0.2s ease; cursor: pointer; }
  .contact-link:first-child { border-top: 1px solid var(--border); }
  .contact-link:hover { gap: 22px; opacity: 1; }
  .contact-link:not(:hover) { opacity: 0.6; }
  .contact-link-icon { width: 32px; height: 32px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
  .contact-link-icon svg { width: 18px; height: 18px; }
  .contact-link-label { font-size: 13px; font-weight: 500; letter-spacing: -0.01em; flex: 1; }
  .contact-link-value { font-size: 11px; color: rgba(240,237,232,0.35); letter-spacing: 0.02em; font-weight: 400; }
  .contact-link-arrow { font-size: 14px; color: rgba(240,237,232,0.2); transition: color 0.2s, transform 0.3s cubic-bezier(0.34,1.56,0.64,1); }
  .contact-link:hover .contact-link-arrow { color: rgba(240,237,232,0.7); transform: translateX(4px); }

  @media (max-width: 768px) {
    nav { top: 14px; }
    .hero { padding: 0 24px; }
    .stack-section { padding: 0 24px 60px; }
    .contact-section { padding: 60px 24px; }
    .experience-section, .projects-section { padding: 60px 24px; }
    .exp-side-img { display: none; }
    .proj-stage { height: 440px; flex-direction: column; }
    .folder-zone { position: relative; left: auto !important; top: auto !important; transform: none !important; margin: 0 auto; }
    .folder-zone.moved { margin-bottom: 24px; }
    .proj-detail-zone { position: relative; right: auto; top: auto; transform: none !important; opacity: 0; width: 100%; max-width: 340px; margin: 0 auto; }
    .proj-detail-zone.visible { opacity: 1; transform: none !important; }
    .proj-stage { height: auto; flex-direction: column; align-items: center; gap: 32px; }
    .contact-body { flex-direction: column; gap: 36px; }
    .contact-photo { width: 180px; height: 220px; }
  }