:root{--bg: #FBFBFD;--white: #FFFFFF;--s2: #F5F5F7;--ink: #1D1D1F;--soft: #6E6E73;--xsoft: #AEAEB2;--accent: #0071E3;--line: rgba(0,0,0,.08);--font: "Plus Jakarta Sans", -apple-system, sans-serif;--ease: cubic-bezier(.4,0,.2,1);--spring: cubic-bezier(.34,1.36,.64,1)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:var(--font);background:var(--bg);color:var(--ink);overflow-x:hidden;-webkit-font-smoothing:antialiased}.page-header{max-width:1100px;margin:0 auto;padding:80px 48px 56px;display:flex;align-items:flex-end;justify-content:space-between;gap:40px;flex-wrap:wrap}.header-label{font-size:11px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--accent);margin-bottom:14px}.header-title{font-size:72px;font-weight:700;letter-spacing:-3px;line-height:1.05;color:var(--ink)}.header-sub{font-size:17px;font-weight:300;color:var(--soft);line-height:1.6;margin-top:16px;max-width:400px}.filter-wrap{padding-bottom:8px}.filter-bar{display:flex;gap:6px;background:var(--s2);border:1px solid var(--line);border-radius:100px;padding:5px}.f-btn{display:flex;align-items:center;gap:7px;padding:9px 20px;border:none;border-radius:100px;background:transparent;font-family:var(--font);font-size:13px;font-weight:500;color:var(--soft);cursor:pointer;white-space:nowrap;transition:color .18s,background .22s,box-shadow .22s}.f-btn:hover{color:var(--ink)}.f-btn.active{background:var(--white);color:var(--ink);box-shadow:0 2px 10px #00000014}.f-badge{min-width:20px;height:20px;padding:0 5px;border-radius:100px;background:#0000000f;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s}.f-btn.active .f-badge{background:var(--accent);color:#fff}.project-list{max-width:1100px;margin:0 auto;padding:0 48px}.p-row{display:grid;grid-template-columns:3rem 1fr auto auto 2rem;align-items:center;gap:0 2rem;height:76px;border-top:1px solid var(--line);cursor:pointer;position:relative;transition:background .18s var(--ease)}.p-row:last-child{border-bottom:1px solid var(--line)}.p-row:hover{background:#0071e306}.p-row:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent);transform:scaleY(0);transform-origin:center;transition:transform .28s var(--spring)}.p-row:hover:before{transform:scaleY(1)}.p-num{font-size:11px;font-weight:700;letter-spacing:1px;color:var(--xsoft);font-variant-numeric:tabular-nums;transition:color .2s;position:relative;z-index:1;margin-left:12px}.p-row:hover .p-num{color:var(--accent)}.p-title{font-size:18px;font-weight:600;letter-spacing:-.3px;color:var(--ink);transition:color .2s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.p-row:hover .p-title{color:var(--accent)}.p-cat{font-size:11px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--xsoft);white-space:nowrap}.p-year{font-size:13px;font-weight:400;color:var(--xsoft);white-space:nowrap}.p-arrow{font-size:18px;color:var(--xsoft);transform:translate(-4px);opacity:0;transition:transform .25s var(--spring),opacity .2s}.p-row:hover .p-arrow{transform:translate(0);opacity:1;color:var(--accent)}#no-results{display:none;text-align:center;color:var(--soft);font-size:16px;font-weight:300;max-width:1100px;margin:0 auto;padding:80px 0 80px 48px}#cursor-preview{position:fixed;width:220px;height:160px;border-radius:18px;overflow:hidden;box-shadow:0 16px 48px #0000002e;background:linear-gradient(135deg,#e8e8ee,#d8d8e0);display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:80;opacity:0;transform:translate(-50%,-115%) rotate(-2deg);transition:opacity .2s,transform .15s}#cursor-preview.show{opacity:1;transform:translate(-50%,-115%) rotate(-1deg)}#backdrop{position:fixed;inset:0;z-index:100;background:#0a0a0a73;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);opacity:0;pointer-events:none;transition:opacity .35s var(--ease)}#backdrop.show{opacity:1;pointer-events:all}#panel{position:fixed;top:0;right:0;bottom:0;width:min(520px,100vw);background:var(--white);z-index:101;display:flex;flex-direction:column;box-shadow:-24px 0 80px #00000024;transform:translate(100%);transition:transform .4s var(--ease);overflow-y:auto}#panel.show{transform:translate(0)}#panel-img{width:100%;height:280px;flex-shrink:0;background:linear-gradient(135deg,#f0f0f5,#e4e4ec);display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}#panel-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.panel-body{padding:40px 44px 60px;flex:1}.panel-cat{font-size:10px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--accent);display:block;margin-bottom:12px}.panel-title{font-size:30px;font-weight:700;letter-spacing:-1px;line-height:1.1;color:var(--ink);margin-bottom:28px}.panel-meta{display:flex;gap:32px;margin-bottom:28px;padding-bottom:28px;border-bottom:1px solid var(--line)}.meta-label{font-size:10px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--xsoft);display:block;margin-bottom:5px}.meta-val{font-size:14px;font-weight:500;color:var(--ink)}.panel-desc{font-size:15px;font-weight:300;line-height:1.85;color:var(--soft);margin-bottom:28px}.panel-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:36px}.p-tag{padding:5px 14px;border-radius:100px;background:var(--s2);border:1px solid var(--line);font-size:12px;font-weight:500;color:var(--soft)}.panel-link{display:inline-flex;align-items:center;gap:8px;padding:13px 30px;background:var(--accent);border-radius:100px;text-decoration:none;color:#fff;font-size:14px;font-weight:500;box-shadow:0 4px 16px #0071e34d;transition:background .2s,transform .25s var(--spring);margin-bottom:32px}.panel-link:hover{background:#0077ed;transform:translateY(-2px) scale(1.02)}.panel-nav{display:flex;align-items:center;gap:12px;padding-top:28px;border-top:1px solid var(--line)}.nav-btn{width:40px;height:40px;border-radius:50%;border:1px solid var(--line);background:var(--s2);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--ink);transition:background .2s,color .2s,transform .25s var(--spring),border-color .2s}.nav-btn:hover{background:var(--ink);color:#fff;border-color:var(--ink);transform:scale(1.08)}.nav-ctr{font-size:13px;font-weight:500;color:var(--soft);margin:0 4px}#btn-close{position:absolute;top:20px;right:20px;width:40px;height:40px;border-radius:50%;background:#ffffffe0;backdrop-filter:blur(8px);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--ink);transition:background .2s,color .2s,transform .25s var(--spring)}#btn-close:hover{background:var(--ink);color:#fff;transform:scale(1.1) rotate(90deg)}.main-footer{display:flex;flex-direction:column;align-items:center;padding:64px 40px 32px;margin-top:80px;border-top:1px solid var(--line);background:var(--bg)}.footer-logo{font-size:28px;font-weight:700;letter-spacing:-1px;color:var(--ink);margin-bottom:32px}.footer-nav{display:flex;flex-wrap:wrap;justify-content:center;gap:28px;margin-bottom:40px}.footer-nav a{text-decoration:none;color:var(--soft);font-size:12px;letter-spacing:.3px;transition:color .2s}.footer-nav a:hover{color:var(--ink)}.footer-copy{font-size:11px;color:var(--xsoft);padding-top:22px;border-top:1px solid var(--line);width:100%;text-align:center}@keyframes fadeUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes rowEnter{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.navbar{animation:fadeIn .5s var(--ease) both}.p-row--anim{opacity:0;animation:rowEnter .5s var(--row-delay, .4s) var(--ease) forwards}.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease),transform .7s var(--ease)}.reveal.visible{opacity:1;transform:translateY(0)}.reveal.delay-1{transition-delay:.1s}.reveal.delay-2{transition-delay:.2s}.reveal.delay-3{transition-delay:.3s}#panel.show .panel-cat{animation:fadeUp .35s .05s var(--ease) both}#panel.show .panel-title{animation:fadeUp .4s .1s var(--ease) both}#panel.show .panel-meta{animation:fadeUp .4s .15s var(--ease) both}#panel.show .panel-desc{animation:fadeUp .4s .2s var(--ease) both}#panel.show .panel-tags{animation:fadeUp .4s .25s var(--ease) both}#panel.show .panel-link{animation:fadeUp .4s .3s var(--ease) both}#panel.show .panel-nav{animation:fadeUp .4s .35s var(--ease) both}#panel.show #panel-img{animation:fadeIn .35s 0s var(--ease) both}.f-btn{position:relative}.f-btn:after{content:"";position:absolute;inset:0;border-radius:100px;background:var(--white);opacity:0;transform:scale(.9);transition:opacity .2s,transform .25s var(--spring);z-index:-1}.f-btn.active:after{opacity:1;transform:scale(1)}.p-row:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}#no-results{animation:fadeUp .4s var(--ease) both}@media(max-width:767px){.page-header{padding:56px 20px 36px;flex-direction:column;align-items:flex-start;gap:24px}.header-title{font-size:clamp(40px,12vw,56px);letter-spacing:-2px}.header-sub{font-size:15px}.filter-bar{flex-wrap:wrap;border-radius:var(--r-md)}.f-btn{padding:8px 14px;font-size:12px}.project-list{padding:0 20px}.p-row{grid-template-columns:2rem 1fr 2rem;height:auto;min-height:64px;padding:12px 0;gap:0 12px}.p-cat,.p-year{display:none}.p-title{font-size:15px}.p-num{margin-left:4px}#cursor-preview{display:none}#panel{width:100vw}.panel-body{padding:28px 24px 48px}.panel-title{font-size:24px}}@media(min-width:768px)and (max-width:1023px){.page-header{padding:64px 32px 40px}.header-title{font-size:clamp(48px,8vw,64px)}.project-list{padding:0 32px}.p-row{gap:0 20px}#cursor-preview{display:none}#panel{width:min(480px,92vw)}}@media(min-width:1024px)and (max-width:1439px){.page-header{padding:72px 40px 48px}.header-title{font-size:60px}.project-list{padding:0 40px}}
