@import "https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";@import "https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@media (max-width:1200px){.hero{padding-top:120px}}@media (max-width:1024px){.projects-grid{grid-template-columns:1fr}}@media (max-width:768px){.header{padding:16px 20px}.header-nav,.logo-tagline{display:none}.hero{padding:100px 20px 60px}.title-line{font-size:36px}.title-sub{font-size:20px}.hero-details{flex-direction:column;align-items:flex-start;gap:16px}.detail-divider{width:100%;height:1px}.projects{padding:60px 20px 80px}.card-inner{min-height:280px;padding:24px}.card-index span{font-size:36px}.card-title{font-size:24px}.footer-content{flex-direction:column;gap:40px}.footer-links{gap:48px}.footer-title{font-size:28px}.footer-bottom{flex-direction:column;gap:12px}}@media (max-width:480px){.status,.card-description{display:none}}.app-3d{background:#0a0a0a;position:fixed;inset:0;overflow:hidden}.canvas-container{z-index:1;position:fixed;inset:0}.canvas-container canvas{width:100%!important;height:100%!important}.scroll-container{z-index:10;scroll-behavior:smooth;height:100vh;position:relative;overflow:hidden auto}.header-3d{z-index:100;pointer-events:none;background:linear-gradient(#0a0a0ae6 0%,#0000 100%);justify-content:space-between;align-items:center;padding:24px clamp(40px,8vw,80px);display:flex;position:fixed;top:0;left:0;right:0}.header-3d>*{pointer-events:auto}.hero-section{justify-content:center;align-items:center;min-height:100vh;padding:120px clamp(40px,8vw,80px) 80px;display:flex}.hero-section .hero-content{text-align:center;flex-direction:column;align-items:center;max-width:900px;display:flex}.hero-section .hero-intro{align-items:center;gap:16px;margin-bottom:32px;display:flex}.hero-section .intro-line{background:var(--accent-primary);width:40px;height:1px}.hero-section .intro-text{font-family:var(--font-mono);color:var(--accent-primary);letter-spacing:3px;text-transform:uppercase;font-size:12px;font-weight:500}.hero-section .hero-title{flex-direction:column;gap:8px;margin-bottom:48px;display:flex}.hero-section .title-line{color:#fff;letter-spacing:-.03em;font-size:clamp(48px,8vw,96px);font-weight:600;line-height:1.1}.hero-section .title-sub{color:var(--text-secondary);font-size:clamp(28px,4vw,48px);font-weight:400}.hero-section .title-highlight{color:var(--accent-primary);font-weight:600}.hero-section .hero-details{flex-wrap:wrap;justify-content:center;align-items:center;gap:32px;margin-bottom:64px;display:flex}.hero-section .detail-item{text-align:center;flex-direction:column;gap:6px;display:flex}.hero-section .detail-label{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:2px;text-transform:uppercase;font-size:10px}.hero-section .detail-value{color:var(--text-secondary);font-size:14px;font-weight:500}.hero-section .detail-divider{background:#ffffff1a;width:1px;height:32px}.hero-section .hero-scroll-hint{flex-direction:column;align-items:center;gap:12px;animation:2s ease-in-out infinite heroFloat;display:flex}.hero-section .scroll-text{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:2px;text-transform:uppercase;font-size:11px}.hero-section .scroll-arrow{color:var(--accent-primary);font-size:20px}@keyframes heroFloat{0%,to{transform:translateY(0)}50%{transform:translateY(8px)}}.project-section{align-items:center;min-height:100vh;padding:80px clamp(40px,8vw,80px);display:flex}.project-content{grid-template-columns:1fr 1fr;align-items:center;gap:60px;width:100%;max-width:1400px;margin:0 auto;display:grid}.project-media{aspect-ratio:16/10;max-height:70vh;position:relative}.media-container{border-radius:16px;width:100%;height:100%;position:relative;overflow:hidden}.media-container img{object-fit:cover;width:100%;height:100%}.media-overlay{background:linear-gradient(135deg,transparent 0%,#0000004d 50%,var(--overlay-color,#ff6b00)150%);opacity:.4;mix-blend-mode:multiply;position:absolute;inset:0}.media-frame{pointer-events:none;position:absolute;inset:-1px}.frame-corner{border:0 solid #ffffff4d;width:24px;height:24px;position:absolute}.frame-tl{border-top-width:2px;border-left-width:2px;top:0;left:0}.frame-tr{border-top-width:2px;border-right-width:2px;top:0;right:0}.frame-bl{border-bottom-width:2px;border-left-width:2px;bottom:0;left:0}.frame-br{border-bottom-width:2px;border-right-width:2px;bottom:0;right:0}.project-info{flex-direction:column;gap:24px;max-width:500px;display:flex}.info-header{align-items:center;gap:16px;display:flex}.project-type{font-family:var(--font-mono);letter-spacing:2px;text-transform:uppercase;font-size:12px;font-weight:500}.project-title{color:#fff;letter-spacing:-.03em;font-size:clamp(36px,5vw,56px);font-weight:600;line-height:1.1}.project-description{color:var(--text-secondary);font-size:16px;line-height:1.7}.project-tags{flex-wrap:wrap;gap:10px;display:flex}.project-tag{font-family:var(--font-mono);color:var(--text-secondary);letter-spacing:.5px;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:100px;padding:8px 16px;font-size:11px;transition:all .3s}.project-tag:hover{border-color:var(--tag-color,#ff6b00);color:var(--tag-color,#ff6b00);background:#ff6b001a}.project-cta{border:1px solid var(--cta-color,#ff6b00);color:var(--cta-color,#ff6b00);font-family:var(--font-mono);letter-spacing:1px;cursor:pointer;background:0 0;border-radius:100px;align-items:center;gap:12px;width:fit-content;margin-top:8px;padding:16px 28px;font-size:12px;transition:all .3s;display:inline-flex}.project-cta:hover{background:var(--cta-color,#ff6b00);color:#0a0a0a}.cta-arrow{font-size:16px;transition:transform .3s}.project-cta:hover .cta-arrow{transform:translate(4px)}.scroll-progress{z-index:100;flex-direction:column;align-items:center;gap:16px;display:flex;position:fixed;top:50%;left:clamp(40px,8vw,80px);transform:translateY(-50%)}.progress-track{background:#ffffff1a;border-radius:2px;width:2px;height:100px;overflow:hidden}.progress-thumb{background:var(--accent-primary);transform-origin:top;border-radius:2px;width:100%;height:100%;transition:transform .1s ease-out}.progress-hint{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:2px;writing-mode:vertical-rl;text-orientation:mixed;font-size:9px}.footer-section{text-align:center;font-family:var(--font-mono);color:var(--text-muted);letter-spacing:1px;padding:60px clamp(40px,8vw,80px);font-size:10px}@media (max-width:1200px){.project-content{gap:40px}.project-title{font-size:clamp(32px,4vw,48px)}}@media (max-width:900px){.hero-section{padding:100px 24px 80px}.hero-section .hero-details{gap:24px}.hero-section .detail-divider{display:none}.project-section{padding:60px 24px}.project-content{grid-template-columns:1fr;gap:32px}.project-media{max-height:50vh}.project-info{max-width:none}.scroll-progress{display:none}}@media (max-width:600px){.header-3d{padding:16px 20px}.hero-section{padding:80px 20px 60px}.hero-section .hero-intro{margin-bottom:24px}.hero-section .intro-line{width:24px}.hero-section .hero-title{margin-bottom:32px}.hero-section .title-line{font-size:36px}.hero-section .title-sub{font-size:20px}.hero-section .hero-details{flex-direction:column;gap:20px;margin-bottom:48px}.project-section{padding:40px 20px}.project-title{font-size:28px}.project-description{font-size:14px}.project-tags{gap:8px}.project-tag{padding:6px 12px;font-size:10px}}.app-hybrid{background:#050505;position:fixed;inset:0;overflow:hidden}.scene-container-hybrid{position:absolute;inset:0}.project-card-3d{-webkit-backdrop-filter:blur(20px);background:#0a0a0ae6;border:1px solid #ffffff1a;border-radius:20px;width:700px;overflow:hidden;box-shadow:0 30px 100px #0009}.card-3d-image{width:100%;height:400px;position:relative;overflow:hidden}.card-3d-image img{object-fit:cover;width:100%;height:100%;transition:transform .6s}.project-card-3d:hover .card-3d-image img{transform:scale(1.03)}.card-3d-image-overlay{pointer-events:none;background:linear-gradient(#0000 0% 40%,#0a0a0a99 70%,#0a0a0af2 100%);position:absolute;inset:0}.card-3d-content{padding:20px 28px 28px}.header-spatial{z-index:100;pointer-events:none;justify-content:space-between;align-items:center;padding:24px clamp(32px,6vw,64px);display:flex;position:fixed;top:0;left:0;right:0}.header-spatial>*{pointer-events:auto}.header-spatial .logo{font-family:var(--font-mono);align-items:center;gap:2px;display:flex}.header-spatial .logo .bracket{color:var(--accent-primary);font-size:18px;font-weight:400}.header-spatial .logo .text{color:var(--text-primary);letter-spacing:1px;font-size:14px;font-weight:600}.header-spatial .status{font-family:var(--font-mono);color:var(--text-secondary);background:#ff6b001a;border:1px solid #ff6b0033;border-radius:100px;align-items:center;gap:8px;padding:8px 14px;font-size:11px;display:flex}.header-spatial .status .dot{background:var(--accent-primary);border-radius:50%;width:6px;height:6px;animation:2s infinite pulse}.footer-spatial{z-index:100;pointer-events:none;font-family:var(--font-mono);color:var(--text-muted);letter-spacing:1px;padding:24px clamp(32px,6vw,64px);font-size:10px;position:fixed;bottom:0;left:0;right:0}.hero-3d-content{text-align:center;color:#fff;width:600px;max-width:90vw;font-family:var(--font-primary);flex-direction:column;align-items:center;display:flex}.hero-3d-intro{font-family:var(--font-mono);color:var(--accent-primary);letter-spacing:3px;text-transform:uppercase;align-items:center;gap:16px;margin-bottom:24px;font-size:12px;display:flex}.hero-3d-intro .intro-line{background:var(--accent-primary);width:40px;height:1px}.hero-3d-title{flex-direction:column;gap:8px;margin-bottom:32px;display:flex}.hero-3d-title>span:first-child{letter-spacing:-.03em;font-size:clamp(52px,10vw,96px);font-weight:600;line-height:1.05}.hero-3d-subtitle{color:var(--text-secondary);font-size:clamp(24px,4vw,40px);font-weight:400}.hero-3d-subtitle .highlight{color:var(--accent-primary);font-weight:600}.hero-3d-details{border-top:1px solid #ffffff1a;flex-wrap:wrap;justify-content:center;align-items:center;gap:24px;margin-bottom:48px;padding-top:24px;display:flex}.hero-3d-details .detail{text-align:center;flex-direction:column;gap:4px;display:flex}.hero-3d-details .label{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:2px;text-transform:uppercase;font-size:11px}.hero-3d-details .value{color:var(--text-secondary);font-size:15px;font-weight:500}.hero-3d-details .divider{background:#ffffff1a;width:1px;height:28px}.hero-3d-scroll{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:2px;flex-direction:column;align-items:center;gap:8px;font-size:10px;animation:2s ease-in-out infinite heroFloat;display:flex}.hero-3d-scroll .arrow{color:var(--accent-primary);font-size:18px}.card-3d,.project-card-3d{color:#fff;font-family:var(--font-primary)}.card-3d-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.card-3d-category{font-family:var(--font-mono);letter-spacing:2px;text-transform:uppercase;font-size:11px;font-weight:500}.card-3d-year{font-family:var(--font-mono);color:var(--text-muted);font-size:11px}.card-3d-title{letter-spacing:-.01em;margin-bottom:8px;font-size:24px;font-weight:600;line-height:1.2}.card-3d-desc{color:var(--text-secondary);margin-bottom:16px;font-size:13px;line-height:1.6}.card-3d-tags{flex-wrap:wrap;gap:8px;display:flex}.card-3d-tag{font-family:var(--font-mono);color:var(--text-secondary);letter-spacing:.5px;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:100px;padding:6px 12px;font-size:10px;transition:all .2s}.card-3d-tag:hover{border-color:var(--accent-primary);color:var(--accent-primary);background:#ff6b001a}.card-3d-btn{border:1px solid var(--card-color,var(--accent-primary));color:var(--card-color,var(--accent-primary));font-family:var(--font-mono);letter-spacing:1px;text-transform:uppercase;cursor:pointer;background:0 0;border-radius:100px;align-items:center;gap:10px;margin-top:20px;padding:12px 24px;font-size:12px;transition:all .3s;display:inline-flex;position:relative;overflow:hidden}.card-3d-btn:before{content:"";background:var(--card-color,var(--accent-primary));transform-origin:0;z-index:-1;transition:transform .3s;position:absolute;inset:0;transform:scaleX(0)}.card-3d-btn:hover{color:#0a0a0a;border-color:var(--card-color,var(--accent-primary))}.card-3d-btn:hover:before{transform:scaleX(1)}.card-3d-btn .btn-arrow{transition:transform .3s}.card-3d-btn:hover .btn-arrow{transform:translate(4px)}.card-3d-btn:active{transform:scale(.97)}.scroll-progress-3d{z-index:100;pointer-events:none;align-items:center;gap:12px;display:flex;position:fixed;top:50%;right:clamp(24px,4vw,48px);transform:translateY(-50%)}.scroll-progress-3d .progress-bar{background:#ffffff1a;border-radius:2px;width:2px;height:120px;overflow:hidden}.scroll-progress-3d .progress-fill{background:var(--accent-primary);transform-origin:top;border-radius:2px;width:100%;height:100%;transition:transform .1s ease-out}.scroll-progress-3d .progress-dots{flex-direction:column;gap:16px;display:flex}.scroll-progress-3d .progress-dot{background:#fff3;border-radius:50%;width:8px;height:8px;transition:all .3s}.scroll-progress-3d .progress-dot.active{background:var(--accent-primary);box-shadow:0 0 12px var(--accent-primary)}@media (max-width:768px){.header-spatial{padding:16px 20px}.header-spatial .status span:last-child{display:none}.footer-spatial{padding:16px 20px}.hero-3d-content{width:90vw}.hero-3d-title>span:first-child{font-size:36px}.hero-3d-subtitle{font-size:18px}.hero-3d-details{flex-direction:column;gap:16px}.hero-3d-details .divider{display:none}.card-3d{padding:20px}.card-3d-title{font-size:22px}.card-3d-desc{font-size:12px}.scroll-progress-3d{right:16px}.scroll-progress-3d .progress-bar{height:80px}.scroll-progress-3d .progress-dots{gap:12px}.scroll-progress-3d .progress-dot{width:6px;height:6px}}:root{--font-primary:"Space Grotesk",-apple-system,BlinkMacSystemFont,sans-serif;--font-mono:"JetBrains Mono",monospace;--bg-primary:#0a0a0a;--bg-secondary:#111;--bg-card:#111111e6;--text-primary:#fff;--text-secondary:#fff9;--text-muted:#ffffff59;--border-color:#ffffff14;--border-strong:#ffffff1f;--accent-primary:#ff6b00;--accent-secondary:#ff8533;--accent-tertiary:#ff9f5a;--accent-green:#22c55e;--gradient-primary:linear-gradient(135deg,#ff6b00 0%,#ff8533 50%,#ffab5c 100%)}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background-color:var(--bg-primary);font-family:var(--font-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--text-primary);line-height:1.6;overflow-x:hidden}::selection{background:var(--accent-primary);color:#fff}.app{flex-direction:column;min-height:100vh;display:flex}.main{flex:1}.header{z-index:100;background:0 0;justify-content:space-between;align-items:center;padding:20px clamp(24px,6vw,80px);transition:all .4s;display:flex;position:fixed;top:0;left:0;right:0}.header.scrolled{-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border-color);background:#0a0a0ae6}.header-left{align-items:center;gap:16px;display:flex}.logo{font-family:var(--font-mono);align-items:center;gap:2px;display:flex}.logo-bracket{color:var(--accent-primary);font-size:18px;font-weight:400}.logo-text{color:var(--text-primary);letter-spacing:1px;font-size:14px;font-weight:600}.logo-tagline{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:1px;align-items:center;gap:8px;font-size:10px;display:flex}.tagline-dot{background:var(--accent-primary);border-radius:50%;width:6px;height:6px}.header-nav{gap:32px;display:flex}.nav-link{color:var(--text-secondary);align-items:center;gap:8px;font-size:13px;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.nav-link:hover{color:var(--text-primary)}.nav-index{font-family:var(--font-mono);color:var(--accent-primary);font-size:10px}.header-right{align-items:center;display:flex}.status{background:#ff6b001a;border:1px solid #ff6b0033;border-radius:100px;align-items:center;gap:8px;padding:8px 14px;display:flex}.status-dot{background:var(--accent-primary);border-radius:50%;width:6px;height:6px;animation:2s infinite pulse}.status-text{font-family:var(--font-mono);color:var(--text-secondary);letter-spacing:.5px;font-size:11px}.hero{align-items:center;padding:160px clamp(24px,6vw,80px) 80px;display:flex;position:relative;overflow:hidden}.hero-grid{background-image:linear-gradient(var(--border-color)1px,transparent 1px),linear-gradient(90deg,var(--border-color)1px,transparent 1px);pointer-events:none;background-size:60px 60px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(#000 20%,#0000 70%);mask-image:radial-gradient(#000 20%,#0000 70%)}.hero-content{flex:1;max-width:800px}.hero-intro{align-items:center;gap:16px;margin-bottom:32px;display:flex}.intro-line{background:var(--gradient-primary);width:48px;height:1px}.intro-text{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:3px;font-size:12px}.hero-title{margin-bottom:40px}.title-line{letter-spacing:-.03em;color:var(--text-primary);font-size:clamp(48px,7vw,80px);font-weight:600;line-height:1.05;display:block}.title-sub{color:var(--text-secondary);margin-top:8px;font-size:clamp(28px,4vw,42px);font-weight:400}.title-highlight{color:var(--accent-primary);font-weight:500}.hero-details{border-top:1px solid var(--border-color);align-items:center;gap:32px;padding:24px 0;display:flex}.detail-item{flex-direction:column;gap:4px;display:flex}.detail-label{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:1px;text-transform:uppercase;font-size:10px}.detail-value{color:var(--text-primary);font-size:14px;font-weight:500}.detail-divider{background:var(--border-color);width:1px;height:32px}.projects{background:var(--bg-secondary);padding:100px clamp(24px,6vw,80px) 120px}.section-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;margin-bottom:60px;padding-bottom:24px;display:flex}.section-label{align-items:center;gap:16px;display:flex}.label-line{background:var(--border-strong);width:32px;height:1px}.label-number{font-family:var(--font-mono);color:var(--accent-primary);font-size:12px}.label-text{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:2px;font-size:12px}.section-count{font-family:var(--font-mono);color:var(--text-muted);font-size:12px}.projects-grid{perspective:1000px;grid-template-columns:repeat(2,1fr);gap:24px;display:grid}.project-card{cursor:pointer;transform-style:preserve-3d;will-change:transform;border-radius:20px;position:relative}.card-glow{background:linear-gradient(135deg,var(--glow-color),transparent 60%);opacity:0;z-index:0;border-radius:21px;transition:opacity .3s;position:absolute;inset:-1px}.card-inner{background:var(--bg-secondary);border:1px solid var(--border-color);z-index:1;border-radius:20px;flex-direction:column;min-height:320px;padding:32px;transition:border-color .3s,box-shadow .3s;display:flex;position:relative;overflow:hidden}.project-card:hover .card-inner{border-color:#ff6b0033;box-shadow:0 20px 60px #0006}.card-grid{background-image:linear-gradient(var(--border-color)1px,transparent 1px),linear-gradient(90deg,var(--border-color)1px,transparent 1px);opacity:.5;pointer-events:none;background-size:24px 24px;position:absolute;inset:0}.card-header{justify-content:space-between;align-items:flex-start;margin-bottom:24px;display:flex}.card-index span{font-family:var(--font-mono);color:var(--border-strong);font-size:48px;font-weight:600;line-height:1}.card-meta{align-items:center;gap:16px;display:flex}.card-type{font-family:var(--font-mono);color:var(--type-color,var(--accent-primary));letter-spacing:1px;text-transform:uppercase;align-items:center;gap:6px;font-size:11px;display:flex}.type-dot{background:var(--type-color,var(--accent-primary));border-radius:50%;width:6px;height:6px}.card-year{font-family:var(--font-mono);color:var(--text-muted);font-size:11px}.card-body{flex-direction:column;flex:1;gap:12px;display:flex}.card-title{color:var(--text-primary);letter-spacing:-.02em;font-size:28px;font-weight:600}.card-description{color:var(--text-secondary);max-width:320px;font-size:14px;line-height:1.6}.card-tags{flex-wrap:wrap;gap:8px;margin-top:auto;display:flex}.tag{border:1px solid var(--border-color);font-family:var(--font-mono);color:var(--text-secondary);letter-spacing:.5px;background:#ffffff0d;border-radius:100px;padding:6px 12px;font-size:10px}.corner{border-color:var(--border-color);border-style:solid;border-width:0;width:16px;height:16px;transition:border-color .3s;position:absolute}.corner-tl{border-top-width:1px;border-left-width:1px;top:16px;left:16px}.corner-tr{border-top-width:1px;border-right-width:1px;top:16px;right:16px}.corner-bl{border-bottom-width:1px;border-left-width:1px;bottom:16px;left:16px}.corner-br{border-bottom-width:1px;border-right-width:1px;bottom:16px;right:16px}.project-card:hover .corner{border-color:var(--border-strong)}.card-accent{transform-origin:0;z-index:2;border-radius:0 0 20px 20px;width:100%;height:3px;position:absolute;bottom:0;left:0;transform:scaleX(0)}.footer{color:#fff;background:#050505;padding:80px clamp(24px,6vw,80px);position:relative;overflow:hidden}.footer-grid{pointer-events:none;background-image:linear-gradient(#ffffff08 1px,#0000 1px),linear-gradient(90deg,#ffffff08 1px,#0000 1px);background-size:48px 48px;position:absolute;inset:0}.footer-content{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:60px;margin-bottom:60px;display:flex;position:relative}.footer-main{flex-direction:column;gap:24px;display:flex}.footer-label{font-family:var(--font-mono);color:#fff6;letter-spacing:2px;align-items:center;gap:8px;font-size:11px;display:flex}.label-dot{background:var(--accent-primary);border-radius:50%;width:6px;height:6px}.footer-title{letter-spacing:-.02em;font-size:36px;font-weight:600;line-height:1.2}.title-gradient{background:var(--gradient-primary);color:#0000;-webkit-background-clip:text;background-clip:text}.footer-email{color:#fff9;align-items:center;gap:12px;font-size:18px;text-decoration:none;transition:color .2s;display:inline-flex}.footer-email:hover{color:#fff}.email-arrow{border:1px solid #fff3;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;transition:all .2s;display:inline-flex}.footer-email:hover .email-arrow{background:var(--accent-primary);border-color:var(--accent-primary)}.footer-links{gap:80px;display:flex}.link-group{flex-direction:column;gap:12px;display:flex}.group-label{font-family:var(--font-mono);color:#ffffff4d;letter-spacing:1px;text-transform:uppercase;margin-bottom:4px;font-size:11px}.link-group a{color:#fff9;font-size:14px;text-decoration:none;transition:color .2s}.link-group a:hover{color:#fff}.footer-bottom{font-family:var(--font-mono);color:#ffffff4d;letter-spacing:1px;border-top:1px solid #ffffff1a;justify-content:space-between;padding-top:24px;font-size:11px;display:flex;position:relative}.footer-copyright{align-items:center;gap:12px;display:flex}.separator{opacity:.3}.footer-tech{align-items:center;gap:12px;display:flex}@media (max-width:1200px){.hero{padding-top:120px}}@media (max-width:1024px){.projects-grid{grid-template-columns:1fr}}@media (max-width:768px){.header{padding:16px 20px}.header-nav,.logo-tagline{display:none}.hero{padding:100px 20px 60px}.title-line{font-size:36px}.title-sub{font-size:20px}.hero-details{flex-direction:column;align-items:flex-start;gap:16px}.detail-divider{width:100%;height:1px}.projects{padding:60px 20px 80px}.card-inner{min-height:280px;padding:24px}.card-index span{font-size:36px}.card-title{font-size:24px}.footer-content{flex-direction:column;gap:40px}.footer-links{gap:48px}.footer-title{font-size:28px}.footer-bottom{flex-direction:column;gap:12px}}@media (max-width:480px){.status,.card-description{display:none}}.app-fullscreen{background:var(--bg-primary);position:fixed;inset:0;overflow:hidden}.sections-container{position:absolute;inset:0;overflow:hidden}.sections-wrapper{will-change:transform;height:100vh}.app-fullscreen-scroll{background:var(--bg-primary);scroll-behavior:smooth;position:fixed;inset:0;overflow:hidden auto}.fullscreen-section{justify-content:flex-start;align-items:center;width:100vw;height:100vh;display:flex;position:relative;overflow:hidden}.header-fullscreen{z-index:100;-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border-color);background:#0a0a0acc;justify-content:space-between;align-items:center;padding:20px clamp(24px,4vw,60px);display:flex;position:fixed;top:0;left:0;right:0}.header-fullscreen .nav-link.active,.header-fullscreen .nav-link.active .nav-index{color:var(--accent-primary)}.header-fullscreen .header-nav{position:relative}.nav-underline{background:var(--accent-primary);border-radius:1px;height:2px;position:absolute;bottom:-4px}.hero-section{background:var(--bg-primary);padding:0 clamp(40px,8vw,120px)}.hero-bg-grid{background-image:linear-gradient(var(--border-color)1px,transparent 1px),linear-gradient(90deg,var(--border-color)1px,transparent 1px);pointer-events:none;background-size:80px 80px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(#000 10%,#0000 70%);mask-image:radial-gradient(#000 10%,#0000 70%)}.hero-content-full{z-index:1;max-width:900px;position:relative}.hero-title-full{margin-bottom:48px}.hero-title-full .title-line{letter-spacing:-.03em;font-size:clamp(56px,9vw,100px);font-weight:600;line-height:1.05;display:block}.hero-title-full .title-sub{color:var(--text-secondary);margin-top:8px;font-size:clamp(28px,4vw,48px);font-weight:400}.scroll-hint{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:1px;flex-direction:column;align-items:flex-start;gap:8px;margin-top:60px;font-size:11px;display:flex}.scroll-arrow{color:var(--accent-primary);font-size:20px}.project-section{padding:0}.project-bg-image{filter:brightness(.35)saturate(1.1);background-position:50%;background-size:cover;transition:transform 10s ease-out,filter 1s;position:absolute;inset:0;transform:scale(1.05)}.project-section.active .project-bg-image{filter:brightness(.4)saturate(1.1);transform:scale(1)}.project-bg-overlay{pointer-events:none;background:linear-gradient(90deg,#0a0a0af2 0%,#0a0a0acc 40%,#0a0a0a66 70%,#0a0a0a33 100%);position:absolute;inset:0}.project-layout{z-index:1;justify-content:space-between;align-items:center;width:100%;height:100%;padding:0 clamp(48px,8vw,140px);display:flex;position:relative}.project-info{max-width:580px}.project-meta{align-items:center;gap:20px;margin-bottom:20px;display:flex}.project-type{font-family:var(--font-mono);letter-spacing:2px;text-transform:uppercase;align-items:center;gap:8px;font-size:12px;display:flex}.project-type .type-dot{border-radius:50%;width:8px;height:8px}.project-year{font-family:var(--font-mono);color:var(--text-muted);font-size:12px}.project-title-full{letter-spacing:-.03em;color:var(--text-primary);margin-bottom:20px;font-size:clamp(42px,6vw,72px);font-weight:600;line-height:1.1}.project-desc-full{color:var(--text-secondary);margin-bottom:28px;font-size:16px;line-height:1.7}.project-tags-full{flex-wrap:wrap;gap:10px;margin-bottom:36px;display:flex}.tag-full{font-family:var(--font-mono);color:var(--text-secondary);letter-spacing:.5px;background:#ffffff14;border:1px solid #ffffff1f;border-radius:100px;padding:8px 16px;font-size:11px;transition:all .2s}.tag-full:hover{border-color:var(--accent-primary);color:var(--accent-primary);background:#ff6b0026}.project-btn{border:1px solid var(--btn-color,var(--accent-primary));color:var(--btn-color,var(--accent-primary));font-family:var(--font-mono);letter-spacing:1px;text-transform:uppercase;cursor:pointer;background:0 0;border-radius:100px;align-items:center;gap:12px;padding:14px 28px;font-size:12px;transition:all .3s;display:inline-flex;position:relative;overflow:hidden}.project-btn:before{content:"";background:var(--btn-color,var(--accent-primary));transform-origin:0;z-index:-1;transition:transform .3s;position:absolute;inset:0;transform:scaleX(0)}.project-btn:hover{color:var(--bg-primary)}.project-btn:hover:before{transform:scaleX(1)}.project-btn .btn-arrow{transition:transform .3s}.project-btn:hover .btn-arrow{transform:translate(4px)}.project-index-side{flex-direction:column;align-items:flex-end;gap:8px;display:flex}.project-index-side .index-number{font-family:var(--font-mono);opacity:.9;font-size:clamp(80px,12vw,160px);font-weight:700;line-height:1}.project-index-side .index-total{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:2px;font-size:14px}.scroll-indicator{z-index:100;flex-direction:column;align-items:flex-start;gap:12px;display:flex;position:fixed;top:50%;left:clamp(20px,3vw,40px);transform:translateY(-50%)}.scroll-indicator-main{align-items:stretch;gap:16px;display:flex}.indicator-track{background:#ffffff1a;border-radius:2px;width:2px;overflow:hidden}.indicator-fill{background:var(--accent-primary);transform-origin:top;border-radius:2px;width:100%;height:100%}.indicator-items{flex-direction:column;justify-content:space-between;display:flex}.indicator-item{cursor:pointer;background:0 0;border:none;align-items:center;gap:12px;padding:4px 0;transition:all .3s;display:flex}.indicator-item .indicator-dot{background:#fff3;border-radius:50%;flex-shrink:0;width:8px;height:8px;transition:all .3s}.indicator-item .indicator-label{font-family:var(--font-mono);color:var(--text-muted);white-space:nowrap;font-size:12px}.indicator-item:hover .indicator-dot{background:#ffffff80;transform:scale(1.2)}.indicator-item:hover .indicator-label{opacity:1}.indicator-item.active .indicator-dot{background:var(--accent-primary);box-shadow:0 0 12px var(--accent-primary)}.indicator-item.active .indicator-label{color:var(--accent-primary)}.indicator-text{font-family:var(--font-mono);color:var(--text-muted);flex-direction:row;align-self:flex-start;align-items:baseline;gap:2px;font-size:11px;display:flex}.indicator-text .current{color:var(--accent-primary);font-size:14px;font-weight:600}.indicator-text .divider{opacity:.3;font-size:10px}.indicator-text .total{font-size:11px}.project-section-portfolio{background:var(--bg-primary);padding:0}.portfolio-layout{grid-template-columns:clamp(320px,28vw,420px) 1fr;align-items:center;gap:clamp(40px,5vw,80px);width:100%;max-width:1600px;height:100%;margin:0 auto;padding:100px clamp(32px,5vw,80px) 60px;display:grid}.portfolio-info{border-right:1px solid var(--border-color);flex-direction:column;gap:20px;padding-right:20px;display:flex}.portfolio-index{align-items:center;gap:12px;margin-bottom:8px;display:flex}.portfolio-index .index-num{font-family:var(--font-mono);font-size:32px;font-weight:600;line-height:1}.portfolio-index .index-line{background:var(--border-color);flex:1;max-width:40px;height:1px}.portfolio-index .index-total{font-family:var(--font-mono);color:var(--text-muted);font-size:14px}.portfolio-meta{align-items:center;gap:16px;display:flex}.portfolio-meta .meta-type{font-family:var(--font-mono);letter-spacing:2px;text-transform:uppercase;font-size:11px;font-weight:500}.portfolio-meta .meta-year{font-family:var(--font-mono);color:var(--text-muted);font-size:11px}.portfolio-title{letter-spacing:-.02em;color:var(--text-primary);font-size:28px;font-weight:600;line-height:1.2}.portfolio-desc{color:var(--text-secondary);font-size:14px;line-height:1.7}.portfolio-tags{flex-wrap:wrap;gap:8px;display:flex}.portfolio-tag{border:1px solid var(--border-color);font-family:var(--font-mono);color:var(--text-secondary);letter-spacing:.5px;background:#ffffff0a;border-radius:4px;padding:6px 12px;font-size:10px}.portfolio-link{border:1px solid var(--link-color,var(--accent-primary));font-family:var(--font-mono);color:var(--text-primary);letter-spacing:.5px;background:#ffffff1a;border-radius:30px;align-items:center;gap:8px;margin-top:24px;padding:12px 24px;font-size:13px;font-weight:500;text-decoration:none;transition:all .3s cubic-bezier(.16,1,.3,1);display:inline-flex;position:relative;overflow:hidden}.portfolio-link:hover{background:var(--link-color,var(--accent-primary));color:#000;transform:translateY(-2px);box-shadow:0 4px 12px #0003}.portfolio-link .link-arrow{transition:transform .3s cubic-bezier(.16,1,.3,1)}.portfolio-link:hover .link-arrow{transform:translate(4px)}.showcase-link-wrapper{cursor:pointer;width:100%;height:100%;text-decoration:none;display:block}.portfolio-showcase{justify-content:center;align-items:center;display:flex;position:relative}.showcase-browser-frame{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;width:100%;max-width:min(900px,100%);position:relative;overflow:hidden;box-shadow:0 4px 6px #0000001a,0 25px 80px #0006}.browser-toolbar{border-bottom:1px solid var(--border-color);background:#ffffff08;align-items:center;gap:12px;padding:12px 16px;display:flex}.browser-dots{gap:6px;display:flex}.browser-dots span{border-radius:50%;width:10px;height:10px}.browser-dots span:first-child{background:#ff5f57}.browser-dots span:nth-child(2){background:#febc2e}.browser-dots span:nth-child(3){background:#28c840}.browser-url{text-align:center;font-family:var(--font-mono);color:var(--text-muted);background:#ffffff0d;border-radius:6px;flex:1;margin-right:60px;padding:6px 16px;font-size:11px}.browser-content{aspect-ratio:16/10;background:var(--bg-secondary);justify-content:center;align-items:center;width:100%;display:flex;position:relative;overflow:hidden}.browser-content img{object-fit:contain;width:auto;max-width:100%;height:100%}@media (min-width:1800px){.portfolio-layout{grid-template-columns:450px 1fr;gap:100px;max-width:1700px}.showcase-browser-frame{max-width:1000px}.portfolio-title{font-size:32px}.portfolio-desc{font-size:15px}}@media (max-width:1800px) and (min-width:1440px){.portfolio-layout{max-width:1500px}}@media (max-width:1440px) and (min-width:1200px){.portfolio-layout{gap:60px;max-width:1300px}}@media (max-width:1200px) and (min-width:1024px){.portfolio-layout{grid-template-columns:clamp(280px,30vw,340px) 1fr;gap:40px}.portfolio-title{font-size:26px}}@media (max-width:1024px){.project-index-side .index-number{font-size:100px}.portfolio-layout{grid-template-columns:1fr;gap:32px;max-width:700px;padding:100px 24px 40px}.portfolio-info{border-right:none;border-bottom:1px solid var(--border-color);padding-bottom:24px;padding-right:0}.portfolio-title{font-size:24px}.showcase-browser-frame{max-width:100%}}@media (max-width:768px){.header-fullscreen{padding:16px 20px}.header-fullscreen .header-nav{display:none}.hero-section{padding:0 24px}.hero-title-full .title-line{font-size:40px}.hero-title-full .title-sub{font-size:20px}.project-layout{text-align:center;flex-direction:column;justify-content:center;padding:80px 24px 40px}.project-info{max-width:100%}.project-meta{justify-content:center}.project-title-full{font-size:32px}.project-desc-full{font-size:14px}.project-tags-full{justify-content:center}.project-index-side{align-items:flex-end;position:absolute;bottom:40px;right:24px}.project-index-side .index-number{opacity:.3;font-size:60px}.scroll-indicator{gap:10px;left:16px}.indicator-item{gap:8px;padding:3px 0}.indicator-item .indicator-dot{width:6px;height:6px}.indicator-item .indicator-label{font-size:10px}.indicator-text{margin-left:4px}.indicator-text .current{font-size:12px}.indicator-text .total{font-size:10px}}.project-detail-page{background:var(--bg-primary);min-height:100vh;color:var(--text-primary)}.detail-header{z-index:100;background:linear-gradient(#0a0a0ae6 0%,#0000 100%);justify-content:space-between;align-items:center;padding:24px clamp(32px,6vw,80px);display:flex;position:fixed;top:0;left:0;right:0}.back-button{font-family:var(--font-mono);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:100px;align-items:center;gap:8px;padding:8px 16px;font-size:13px;text-decoration:none;transition:all .2s;display:flex}.back-button:hover{color:var(--text-primary);border-color:var(--accent-primary)}.back-arrow{transition:transform .2s}.back-button:hover .back-arrow{transform:translate(-4px)}.header-logo{font-family:var(--font-mono);align-items:center;gap:2px;display:flex}.header-logo .logo-bracket{color:var(--accent-primary);font-size:18px}.header-logo .logo-text{color:var(--text-primary);letter-spacing:1px;font-size:14px;font-weight:600}.detail-hero{align-items:flex-end;width:100%;height:70vh;min-height:500px;display:flex;position:relative;overflow:hidden}.detail-hero-image{position:absolute;inset:0}.detail-hero-image img{object-fit:cover;width:100%;height:100%}.hero-overlay{background:linear-gradient(#0a0a0a4d 0%,#0a0a0a80 50%,#0a0a0af2 100%);position:absolute;inset:0}.detail-hero-content{z-index:2;width:100%;max-width:1200px;margin:0 auto;padding:0 clamp(32px,6vw,80px) 60px;position:relative}.hero-meta{font-family:var(--font-mono);align-items:center;gap:12px;margin-bottom:16px;font-size:12px;display:flex}.hero-meta .meta-type{text-transform:uppercase;letter-spacing:2px;font-weight:500}.hero-meta .meta-divider{color:var(--text-muted)}.hero-meta .meta-year,.hero-meta .meta-status{color:var(--text-secondary)}.detail-title{letter-spacing:-.03em;margin-bottom:12px;font-size:clamp(42px,8vw,72px);font-weight:600;line-height:1.1}.detail-subtitle{color:var(--text-secondary);font-size:clamp(18px,3vw,24px);font-weight:400}.detail-content{max-width:900px;margin:0 auto;padding:80px clamp(24px,6vw,80px)}.content-section{margin-bottom:64px}.section-title{font-size:14px;font-family:var(--font-mono);color:var(--accent-primary);text-transform:uppercase;letter-spacing:2px;border-bottom:1px solid var(--border-color);margin-bottom:24px;padding-bottom:12px}.overview-text{color:var(--text-primary);margin-bottom:24px;font-size:18px;line-height:1.8}.description-text{color:#ffffffbf;margin-bottom:40px;font-size:16px;line-height:1.8}.project-meta-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:24px;margin-bottom:32px;display:grid}.meta-item{flex-direction:column;gap:6px;display:flex}.meta-label{font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;font-size:11px}.meta-value{color:var(--text-primary);font-size:15px}.tags-section{margin-top:32px}.tags-section .meta-label{margin-bottom:12px;display:block}.detail-tags{flex-wrap:wrap;gap:10px;display:flex}.detail-tag{border:1px solid var(--border-color);font-family:var(--font-mono);color:var(--text-secondary);background:#ffffff08;border-radius:100px;padding:8px 16px;font-size:12px;transition:all .2s}.detail-tag:hover{color:var(--accent-primary);background:#ff6b001a}.challenges-list,.outcomes-list{margin:0;padding:0;list-style:none}.challenges-list li,.outcomes-list li{border-bottom:1px solid var(--border-color);color:var(--text-secondary);align-items:flex-start;gap:16px;padding:16px 0;font-size:16px;line-height:1.6;display:flex}.challenges-list li:last-child,.outcomes-list li:last-child{border-bottom:none}.bullet{border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:8px}.check-icon{flex-shrink:0;font-size:18px}.gallery-grid{grid-template-columns:1fr;gap:40px;display:grid}.gallery-item{border:1px solid var(--border-color);border-radius:12px;overflow:hidden}.gallery-item img{object-fit:cover;width:100%;height:100%;transition:transform .4s}.gallery-item:hover img{transform:scale(1.03)}.links-grid{flex-wrap:wrap;gap:16px;display:flex}.project-link-card{border:1px solid var(--border-color);color:var(--text-secondary);background:#ffffff08;border-radius:12px;align-items:center;gap:12px;padding:16px 24px;text-decoration:none;transition:all .2s;display:flex}.project-link-card:hover{border-color:var(--link-color,var(--accent-primary));color:var(--text-primary);background:#ff6b001a}.link-icon{font-size:20px}.link-label{font-family:var(--font-mono);font-size:13px}.link-arrow{margin-left:auto;transition:transform .2s}.project-link-card:hover .link-arrow{transform:translate(4px)}.project-navigation{border-top:1px solid var(--border-color);text-align:center;padding-top:40px}.nav-back-home{border:1px solid var(--accent-primary);color:var(--accent-primary);font-family:var(--font-mono);background:0 0;border-radius:100px;align-items:center;gap:10px;padding:14px 28px;font-size:13px;text-decoration:none;transition:all .3s;display:inline-flex}.nav-back-home:hover{background:var(--accent-primary);color:var(--bg-primary)}.nav-arrow{transition:transform .2s}.nav-back-home:hover .nav-arrow{transform:translate(-4px)}.detail-footer{text-align:center;font-family:var(--font-mono);color:var(--text-muted);letter-spacing:1px;border-top:1px solid var(--border-color);padding:40px clamp(32px,6vw,80px);font-size:11px}.project-not-found{flex-direction:column;justify-content:center;align-items:center;gap:24px;min-height:100vh;display:flex}.project-not-found h1{color:var(--text-primary);font-size:32px}.project-not-found .back-link{color:var(--accent-primary);font-family:var(--font-mono);font-size:14px;text-decoration:none}.detail-title-section{max-width:1200px;margin:0 auto;padding:120px clamp(24px,6vw,80px) 40px}.title-content{text-align:center}.title-meta{font-family:var(--font-mono);justify-content:center;align-items:center;gap:12px;margin-bottom:20px;font-size:12px;display:flex}.title-meta .meta-type{text-transform:uppercase;letter-spacing:2px;font-weight:500}.title-meta .meta-divider{color:var(--text-muted)}.title-meta .meta-year,.title-meta .meta-status{color:var(--text-secondary)}.project-main-title{letter-spacing:-.03em;color:var(--text-primary);margin-bottom:16px;font-size:clamp(48px,10vw,80px);font-weight:600;line-height:1.1}.project-main-subtitle{color:var(--text-secondary);max-width:600px;margin:0 auto;font-size:clamp(18px,3vw,24px);font-weight:400}.detail-video-section{max-width:1200px;margin:0 auto;padding:0 clamp(24px,6vw,80px) 60px}.video-container{border:1px solid var(--border-color);background:#000;border-radius:16px;width:100%;position:relative;overflow:hidden}.video-poster{aspect-ratio:16/9;cursor:pointer;width:100%;position:relative;overflow:hidden}.video-poster img{object-fit:cover;width:100%;height:100%;transition:transform .6s,filter .3s}.video-poster:hover img{filter:brightness(.7);transform:scale(1.02)}.video-play-overlay{background:#0000004d;flex-direction:column;justify-content:center;align-items:center;gap:16px;transition:background .3s;display:flex;position:absolute;inset:0}.video-poster:hover .video-play-overlay{background:#00000080}.play-button{background:var(--accent,var(--accent-primary));cursor:pointer;color:#fff;border:none;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;transition:transform .3s,box-shadow .3s;display:flex;box-shadow:0 8px 32px #ff6b004d}.play-button svg{width:32px;height:32px;margin-left:4px}.video-poster:hover .play-button{transform:scale(1.1);box-shadow:0 12px 48px #ff6b0066}.play-text{font-family:var(--font-mono);color:#ffffffe6;text-transform:uppercase;letter-spacing:2px;font-size:13px}.video-iframe-wrapper{aspect-ratio:16/9;width:100%;position:relative}.video-iframe-wrapper iframe{border:none;width:100%;height:100%;position:absolute;top:0;left:0}.local-video{aspect-ratio:16/9;background:#000;width:100%}.videos-section{margin-bottom:64px}.videos-grid{flex-direction:column;gap:24px;display:flex}.video-card{border:1px solid var(--border-color);background:#ffffff05;border-radius:12px;transition:all .3s;overflow:hidden}.video-card:hover{border-color:#ff6b004d;box-shadow:0 8px 32px #0000004d}.video-card-player{position:relative}.video-card-player .video-container{border:none;border-bottom:1px solid var(--border-color);border-radius:0}.video-card-info{padding:16px 20px}.video-card-label{letter-spacing:-.01em;margin-bottom:6px;font-size:15px;font-weight:600}.video-card-desc{color:var(--text-muted);margin:0;font-size:13px;line-height:1.5}@media (max-width:700px){.videos-grid{grid-template-columns:1fr}}@media (max-width:768px){.detail-header{padding:16px 24px}.back-button span:last-child{display:none}.detail-title-section{padding:100px 24px 30px}.title-meta{flex-wrap:wrap}.detail-video-section{padding:0 16px 40px}.video-container{border-radius:12px}.play-button{width:64px;height:64px}.play-button svg{width:24px;height:24px}.play-text{font-size:11px}.detail-hero{height:60vh;min-height:400px}.detail-hero-content{padding:0 24px 40px}.detail-content{padding:60px 24px}.overview-text{font-size:16px}.project-meta-grid{grid-template-columns:1fr 1fr}.gallery-grid{grid-template-columns:1fr}}.gallery-item-wrapper{flex-direction:column;gap:12px;display:flex}.gallery-caption{font-family:var(--font-primary);color:var(--text-secondary);border-left:2px solid var(--accent-primary);max-width:600px;padding-left:16px;font-size:14px;line-height:1.6}
