:root{--green-50:#f0fdf4;--green-100:#dcfce7;--green-200:#bbf7d0;--green-400:#4ade80;--green-500:#22c55e;--green-600:#16a34a;--green-700:#15803d;--green-900:#14532d;--dark:#080e08;--dark-2:#0d160d;--dark-3:#111d11;--bg:#fff;--bg-alt:#fafafa;--bg-card:#fff;--text:#0f172a;--text-muted:#6b7280;--text-subtle:#9ca3af;--border:#e5e7eb;--border-card:#e5e7eb;--white:#fff}[data-theme=dark]{--bg:#0a0f0a;--bg-alt:#0d160d;--bg-card:#111d11;--text:#e2e8f0;--text-muted:#94a3b8;--text-subtle:#64748b;--border:#ffffff14;--border-card:#ffffff12;--white:#0a0f0a}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{color:var(--text);background:var(--white);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow-x:hidden}main{padding-top:0}img{max-width:100%;height:auto;display:block}button,a{font-family:inherit}.app-content{opacity:0;pointer-events:none;transition:opacity .6s}.app-content--visible{opacity:1;pointer-events:all}.reveal{opacity:0;transition:opacity .65s cubic-bezier(.22,1,.36,1),transform .65s cubic-bezier(.22,1,.36,1);transform:translateY(32px)}.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}.reveal-delay-4{transition-delay:.4s}@keyframes vt-slide-in{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes vt-slide-out{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-14px)}}@media (prefers-reduced-motion:no-preference){::view-transition-old(root){animation:.22s both vt-slide-out}::view-transition-new(root){animation:.3s both vt-slide-in}}html.vt-theme::view-transition-old(root){mix-blend-mode:normal;animation:none}html.vt-theme::view-transition-new(root){mix-blend-mode:normal;animation:none}html.vt-theme::view-transition-image-pair(root){isolation:auto}html.vt-modal::view-transition-old(root){animation:none}html.vt-modal::view-transition-new(root){animation:none}::view-transition-group(project-hero){animation-duration:.38s;animation-timing-function:cubic-bezier(.22,1,.36,1)}@keyframes logo-glitch{0%,90%,to{text-shadow:none;filter:none;transform:none}91%{text-shadow:-2px 0 #ff0080,2px 0 #00e5ff;filter:brightness(1.4);transform:translate(-2px,1px)}92%{text-shadow:2px 0 #ff0080,-2px 0 #00e5ff;filter:brightness(1.2);transform:translate(2px,-1px)}93%{text-shadow:-1px 0 #ff0080,1px 0 #00e5ff;filter:brightness(1.4);transform:translate(-1px,2px)}94%{text-shadow:none;filter:none;transform:none}}.logo-glitch{animation:9s infinite logo-glitch;display:inline-block}@media (prefers-reduced-motion:reduce){.logo-glitch,.hero__glow--1,.hero__glow--2,.hero__code-float,.hero__cursor,.hero__scroll-line,.projects__eyebrow-dot{animation:none!important}.reveal{opacity:1!important;transition:none!important;transform:none!important}}.skip-to-content{z-index:9999;background:var(--green-600);color:#fff;pointer-events:none;border-radius:10px;padding:10px 18px;font-size:14px;font-weight:700;text-decoration:none;transition:transform .2s;position:fixed;top:12px;left:12px;transform:translateY(-80px)}.skip-to-content:focus{pointer-events:auto;outline-offset:2px;outline:3px solid #fff;transform:translateY(0)}:focus-visible{outline:2px solid var(--green-500);outline-offset:3px;border-radius:4px}:focus:not(:focus-visible){outline:none}.rd-toast{color:#fff;z-index:99999;opacity:0;pointer-events:none;white-space:nowrap;background:#0f172a;border-radius:12px;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:600;transition:opacity .25s,transform .25s cubic-bezier(.22,1,.36,1);display:flex;position:fixed;bottom:28px;left:50%;transform:translate(-50%)translateY(16px);box-shadow:0 8px 24px #00000040}.rd-toast:before{content:"✓";background:var(--green-500);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:11px;font-weight:900;display:flex}.rd-toast--visible{opacity:1;transform:translate(-50%)translateY(0)}.rd-toast--hiding{opacity:0;transform:translate(-50%)translateY(8px)}*{scrollbar-width:thin;scrollbar-color:var(--green-700) #ffffff0a}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:#080e0899}::-webkit-scrollbar-thumb{background:var(--green-700);border-radius:999px}::-webkit-scrollbar-thumb:hover{background:var(--green-600)}.pp-loading{background:var(--bg);justify-content:center;align-items:center;gap:8px;min-height:100vh;display:flex}.pp-loading__dot{background:var(--green-500);border-radius:50%;width:8px;height:8px;animation:1.2s ease-in-out infinite ppDotPulse}.pp-loading__dot:nth-child(2){animation-delay:.2s}.pp-loading__dot:nth-child(3){animation-delay:.4s}@keyframes ppDotPulse{0%,80%,to{opacity:.4;transform:scale(.6)}40%{opacity:1;transform:scale(1)}}.loader{z-index:9999;background:#080e08;flex-direction:column;justify-content:center;align-items:center;gap:28px;transition:opacity .7s,transform .7s;display:flex;position:fixed;inset:0}.loader--exit{opacity:0;pointer-events:none;transform:scale(1.06)}.loader__ring-wrap{width:160px;height:160px;position:relative}.loader__ring-wrap:before,.loader__ring-wrap:after{content:"";pointer-events:none;border:1px dashed #22c55e12;border-radius:50%;position:absolute}.loader__ring-wrap:before{animation:14s linear infinite orbitSpin;inset:-14px}.loader__ring-wrap:after{border-color:#22c55e0a;animation:22s linear infinite reverse orbitSpin;inset:-28px}@keyframes orbitSpin{to{transform:rotate(360deg)}}.loader__svg{width:100%;height:100%;position:absolute;inset:0}.loader__track{stroke:#22c55e14}.loader__arc{stroke:#22c55e;filter:drop-shadow(0 0 6px #22c55ea6);transition:stroke-dashoffset 80ms linear}.loader__center{flex-direction:column;justify-content:center;align-items:center;gap:6px;display:flex;position:absolute;inset:0}.loader__icon{color:#22c55e;font-family:Fira Code,monospace;font-size:24px;font-weight:700;animation:2.2s ease-in-out infinite iconPulse}@keyframes iconPulse{0%,to{opacity:.65}50%{opacity:1;filter:drop-shadow(0 0 8px #22c55ee6)}}.loader__pct{color:#ffffff59;letter-spacing:.5px;text-align:center;min-width:34px;font-family:Fira Code,monospace;font-size:12px}.loader__name{color:#fff;letter-spacing:-.4px;margin:0;font-size:20px;font-weight:800;animation:.6s cubic-bezier(.22,1,.36,1) .2s both fadeUp}.loader__status{color:#22c55e73;letter-spacing:.4px;min-height:18px;margin:0;font-family:Fira Code,monospace;font-size:12px;transition:opacity .3s;animation:.6s cubic-bezier(.22,1,.36,1) .35s both fadeUp}@keyframes fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (pointer:fine){*,:before,:after{cursor:none!important}}.cursor-dot{pointer-events:none;z-index:99999;will-change:transform;mix-blend-mode:normal;background:#22c55e;border-radius:50%;width:12px;height:12px;transition:width .2s,height .2s,top .2s,left .2s,background .2s,opacity .2s;position:fixed;top:-6px;left:-6px}.cursor-dot--hover{background:#4ade80;width:8px;height:8px;top:-4px;left:-4px}.cursor-dot--click{background:#86efac;width:6px;height:6px;top:-3px;left:-3px}.cursor-dot--hidden{opacity:0}.cursor-ring{pointer-events:none;z-index:99998;will-change:transform;border:1.5px solid #22c55e99;border-radius:50%;width:40px;height:40px;transition:width .25s cubic-bezier(.22,1,.36,1),height .25s cubic-bezier(.22,1,.36,1),top .25s cubic-bezier(.22,1,.36,1),left .25s cubic-bezier(.22,1,.36,1),border-color .25s,background .25s,opacity .2s;position:fixed;top:-20px;left:-20px}.cursor-ring--hover{background:#22c55e0f;border-color:#22c55e66;width:56px;height:56px;top:-28px;left:-28px}.cursor-ring--click{background:#22c55e14;border-color:#86efaccc;width:32px;height:32px;top:-16px;left:-16px}.cursor-ring--hidden{opacity:0}.scroll-progress{z-index:10000;pointer-events:none;background:0 0;height:3px;position:fixed;top:0;left:0;right:0}.scroll-progress__fill{background:linear-gradient(90deg,#16a34a,#4ade80,#86efac);border-radius:0 2px 2px 0;height:100%;transition:width .1s linear;position:relative;box-shadow:0 0 10px #22c55eb3}.scroll-progress__fill:after{content:"";background:#4ade80;border-radius:50%;width:6px;height:6px;position:absolute;top:50%;right:0;transform:translateY(-50%);box-shadow:0 0 8px #4ade80}.back-to-top{z-index:500;background:var(--green-600);color:#fff;cursor:pointer;opacity:0;pointer-events:none;border:none;border-radius:12px;justify-content:center;align-items:center;width:44px;height:44px;transition:opacity .25s,transform .25s,background .2s;display:flex;position:fixed;bottom:32px;right:32px;transform:translateY(12px)scale(.9);box-shadow:0 4px 20px #16a34a59}.back-to-top--visible{opacity:1;pointer-events:all;transform:translateY(0)scale(1)}.back-to-top:hover{background:var(--green-700);transform:translateY(-3px)scale(1.05);box-shadow:0 8px 28px #16a34a73}.back-to-top:active{transform:translateY(0)scale(.97)}@media (width<=640px){.back-to-top{width:40px;height:40px;bottom:20px;right:20px}}.hero{background:var(--dark);flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:80px 24px 60px;display:flex;position:relative;overflow:hidden}.hero__canvas{pointer-events:none;opacity:.55;width:100%;height:100%;position:absolute;inset:0}.hero:after{content:"";pointer-events:none;z-index:1;background:radial-gradient(#080e088c 0%,#080e08d1 100%);position:absolute;inset:0}.hero__glow{filter:blur(120px);pointer-events:none;z-index:2;border-radius:50%;position:absolute}.hero__glow--1{background:radial-gradient(circle,#16a34a2e,#0000 70%);width:600px;height:600px;animation:8s ease-in-out infinite alternate glowDrift;top:-150px;left:-100px}.hero__glow--2{background:radial-gradient(circle,#22c55e1f,#0000 70%);width:500px;height:500px;animation:10s ease-in-out infinite alternate-reverse glowDrift;bottom:-100px;right:-80px}@keyframes glowDrift{0%{transform:translate(0)scale(1)}to{transform:translate(40px,30px)scale(1.1)}}.hero__code-float{color:#4ade8033;white-space:nowrap;pointer-events:none;-webkit-user-select:none;user-select:none;z-index:2;font-family:Fira Code,Courier New,monospace;font-size:12px;animation:6s ease-in-out infinite floatCode;position:absolute}@keyframes floatCode{0%,to{opacity:.15;transform:translateY(0)}50%{opacity:.35;transform:translateY(-12px)}}.hero__container{z-index:3;text-align:center;flex-direction:column;align-items:center;gap:0;width:100%;max-width:820px;display:flex;position:relative}.hero__container:before{content:"";pointer-events:none;z-index:-1;background:radial-gradient(32% 100%,#080e08eb 0%,#080e08b8 28%,#080e0852 52%,#0000 70%);width:130vw;position:absolute;top:-60px;bottom:-60px;left:50%;transform:translate(-50%)}.hero__terminal-badge{cursor:pointer;background:#ffffff0a;border:1px solid #ffffff14;border-radius:10px;align-items:center;gap:6px;margin-bottom:16px;padding:7px 16px 7px 10px;font-family:inherit;transition:border-color .25s,background .25s,transform .25s;animation:.7s cubic-bezier(.22,1,.36,1) both fadeSlideDown;display:inline-flex}.hero__terminal-badge:hover{background:#22c55e12;border-color:#22c55e66;transform:translateY(-1px)}.hero__terminal-dot{border-radius:50%;width:10px;height:10px}.hero__terminal-dot--r{background:#ff5f57}.hero__terminal-dot--y{background:#ffbd2e}.hero__terminal-dot--g{background:#28c840}.hero__terminal-label{color:#ffffff59;letter-spacing:.3px;margin-left:6px;font-family:Fira Code,monospace;font-size:12px}.hero__tag{color:#ffffff73;margin-bottom:12px;font-family:Fira Code,monospace;font-size:14px;animation:.75s cubic-bezier(.22,1,.36,1) .1s both fadeSlideDown}.hero__tag-blink{color:var(--green-400);animation:1s step-end infinite blink}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.hero__tag-highlight{color:var(--green-400);font-weight:600}.hero__title{letter-spacing:-4px;color:#fff;margin-bottom:16px;font-size:clamp(64px,11vw,110px);font-weight:900;line-height:.95;animation:.8s cubic-bezier(.22,1,.36,1) .15s both fadeSlideDown}.hero__title-accent{background:linear-gradient(135deg, var(--green-400) 0%, var(--green-500) 50%, #86efac 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;display:inline-block}.hero__typing{color:var(--green-400);justify-content:center;align-items:center;gap:2px;min-height:36px;margin-bottom:12px;font-family:Fira Code,monospace;font-size:clamp(16px,2.5vw,22px);animation:.85s cubic-bezier(.22,1,.36,1) .2s both fadeSlideDown;display:flex}.hero__typing-prefix{color:#ffffff4d}.hero__cursor{background:var(--green-400);vertical-align:text-bottom;border-radius:1px;width:2px;height:1.1em;animation:1s step-end infinite cursorBlink;display:inline-block}@keyframes cursorBlink{0%,to{opacity:1}50%{opacity:0}}.hero__desc{color:#ffffff73;max-width:580px;margin-bottom:24px;font-size:16px;line-height:1.75;animation:.9s cubic-bezier(.22,1,.36,1) .25s both fadeSlideDown}.hero__actions{flex-wrap:wrap;justify-content:center;align-items:center;gap:14px;margin-bottom:36px;animation:.95s cubic-bezier(.22,1,.36,1) .3s both fadeSlideDown;display:flex}.hero__btn{cursor:pointer;white-space:nowrap;border:none;border-radius:12px;align-items:center;gap:8px;padding:14px 28px;font-size:15px;font-weight:600;text-decoration:none;transition:all .25s;display:inline-flex}.hero__btn--primary{background:var(--green-600);color:#fff;box-shadow:0 0 0 1px var(--green-700), 0 4px 24px #16a34a66;position:relative;overflow:hidden}.hero__btn--primary:before{content:"";background:linear-gradient(135deg, var(--green-500), var(--green-600));opacity:0;transition:opacity .25s;position:absolute;inset:0}.hero__btn--primary:hover:before{opacity:1}.hero__btn--primary:hover{box-shadow:0 0 0 1px var(--green-500), 0 8px 32px #16a34a8c;transform:translateY(-2px)}.hero__btn--primary span{z-index:1;position:relative}.hero__btn--primary svg{z-index:1;transition:transform .2s;position:relative}.hero__btn--primary:hover svg{transform:translate(3px)}.hero__btn--ghost{color:#fff9;background:#ffffff0d;border:1px solid #ffffff1a}.hero__btn--ghost:hover{color:#fff;background:#ffffff17;border-color:#fff3;transform:translateY(-2px)}.hero__stats{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff08;border:1px solid #ffffff12;border-radius:16px;justify-content:center;align-items:center;gap:0;animation:1s cubic-bezier(.22,1,.36,1) .35s both fadeSlideDown;display:flex;overflow:hidden}.hero__stat{border-right:1px solid #ffffff12;flex-direction:column;flex:1;align-items:center;gap:4px;padding:20px 36px;transition:background .25s;display:flex;position:relative}.hero__stat:last-child{border-right:none}.hero__stat:hover{background:#22c55e0d}.hero__stat-num{color:var(--green-400);font-size:26px;font-weight:800;line-height:1}.hero__stat-lbl{color:#ffffff59;text-transform:uppercase;letter-spacing:.6px;font-size:12px;font-weight:500}.hero__scroll{z-index:3;flex-direction:column;align-items:center;gap:6px;animation:1s .6s both fadeSlideDown;display:flex;position:absolute;bottom:32px;left:50%;transform:translate(-50%)}.hero__scroll-text{color:#fff3;letter-spacing:2px;text-transform:uppercase;font-family:monospace;font-size:10px}.hero__scroll-line{background:linear-gradient(#22c55e80,#0000);width:1px;height:40px;animation:2s ease-in-out infinite scrollPulse}@keyframes scrollPulse{0%,to{opacity:.4;transform:scaleY(1)}50%{opacity:1;transform:scaleY(1.3)}}.hero__marquee{z-index:2;pointer-events:none;height:230px;animation:2.4s cubic-bezier(.22,1,.36,1) .3s both paused fadeSlideUp;position:absolute;top:47%;left:0;right:0;overflow:hidden;transform:translateY(-50%)}.app-content--visible .hero__marquee{animation-play-state:running}.hero__marquee:before{content:"";pointer-events:none;z-index:5;background:linear-gradient(90deg,#0000,#22c55e0d 50%,#0000);width:50%;animation:7s ease-in-out infinite marqueeScan;position:absolute;top:0;bottom:0;left:-50%}@keyframes marqueeScan{0%{opacity:0;transform:translate(0)}8%{opacity:1}92%{opacity:1}to{opacity:0;transform:translate(300%)}}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(-50%)translate(22vw)}to{opacity:1;transform:translateY(-50%)translate(0)}}.hero__marquee-scroll{scrollbar-width:none;pointer-events:auto;width:100%;height:100%;overflow:auto hidden}.hero__marquee-scroll::-webkit-scrollbar{display:none}.hero__marquee-track{align-items:center;gap:16px;width:max-content;height:100%;padding:24px 0;display:flex}.hero__marquee-btn{z-index:10;pointer-events:auto;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#ffffffa6;cursor:pointer;opacity:0;background:#080e08b8;border:1px solid #22c55e38;border-radius:50%;justify-content:center;align-items:center;width:38px;height:38px;transition:opacity .2s,background .2s,border-color .2s,color .2s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.hero__marquee:hover .hero__marquee-btn{opacity:1}.hero__marquee-btn:hover{color:#fff;background:#22c55e26;border-color:#22c55e80}.hero__marquee-btn--left{left:12px}.hero__marquee-btn--right{right:12px}.hero__marquee-item{flex-shrink:0;animation:5s ease-in-out infinite cardFloat}.hero__marquee-item:nth-child(2n){animation-duration:6.5s;animation-delay:-2s}.hero__marquee-item:nth-child(3n){animation-duration:4.5s;animation-delay:-1.2s}.hero__marquee-item:nth-child(4n){animation-duration:5.8s;animation-delay:-3.4s}.hero__marquee-item:nth-child(5n){animation-duration:4s;animation-delay:-.7s}.hero__marquee-item:nth-child(7n){animation-duration:6s;animation-delay:-4s}@keyframes cardFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-7px)}}.hero__marquee-card{cursor:pointer;will-change:transform;background:#080e08b3;border:1px solid #22c55e1f;border-radius:12px;width:290px;height:172px;transition:border-color .3s,box-shadow .3s,transform .5s cubic-bezier(.23,1,.32,1);position:relative;overflow:hidden}.hero__marquee-card:before{content:"";z-index:3;pointer-events:none;border-top:1.5px solid #22c55e59;border-left:1.5px solid #22c55e59;width:10px;height:10px;transition:width .3s,height .3s,border-color .3s;position:absolute;top:6px;left:6px}.hero__marquee-card:after{content:"";z-index:3;pointer-events:none;border-bottom:1.5px solid #22c55e59;border-right:1.5px solid #22c55e59;width:10px;height:10px;transition:width .3s,height .3s,border-color .3s;position:absolute;bottom:6px;right:6px}.hero__marquee:hover .hero__marquee-card:hover{border-color:#22c55e73;transform:translateY(-5px)scale(1.03);box-shadow:0 0 20px #22c55e26,0 8px 28px #00000080}.hero__marquee:hover .hero__marquee-card:hover:before,.hero__marquee:hover .hero__marquee-card:hover:after{border-color:#22c55ebf;width:14px;height:14px}.hero__marquee-card img{object-fit:cover;object-position:top center;filter:brightness(.78)saturate(.72);width:100%;height:100%;transition:transform .4s,filter .3s;display:block}.hero__marquee:hover .hero__marquee-card:hover img{filter:brightness(.88)saturate(.85);transform:scale(1.06)}.hero__marquee-placeholder{color:#fff6;letter-spacing:.05em;filter:brightness(.78);flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;font-size:2rem;font-weight:700;display:flex}.hero__marquee-glare{border-radius:inherit;pointer-events:none;z-index:3;opacity:0;transition:opacity .3s;position:absolute;inset:0}.hero__marquee-card:hover .hero__marquee-glare{opacity:1}.hero__marquee-shimmer{z-index:2;pointer-events:none;border-radius:inherit;background:linear-gradient(108deg,#0000 38%,#ffffff12 50%,#0000 62%);animation:8s ease-in-out infinite cardShimmer;position:absolute;inset:0;transform:translate(-100%)}.hero__marquee-item:nth-child(2n) .hero__marquee-shimmer{animation-delay:-2.5s}.hero__marquee-item:nth-child(3n) .hero__marquee-shimmer{animation-delay:-5s}.hero__marquee-item:nth-child(4n) .hero__marquee-shimmer{animation-delay:-1s}.hero__marquee-item:nth-child(5n) .hero__marquee-shimmer{animation-delay:-6.5s}.hero__marquee-item:nth-child(7n) .hero__marquee-shimmer{animation-delay:-3.5s}@keyframes cardShimmer{0%{opacity:0;transform:translate(-100%)}3%{opacity:1}25%{opacity:0;transform:translate(200%)}26%,to{opacity:0;transform:translate(-100%)}}.hero__marquee-info{pointer-events:none;z-index:2;background:linear-gradient(#0000 0%,#080e0866 40%,#080e08f2 100%);flex-direction:column;gap:3px;padding:36px 14px 11px;display:flex;position:absolute;bottom:0;left:0;right:0}.hero__marquee-pname{color:#ffffffd9;white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;line-height:1.2;overflow:hidden}.hero__marquee-sname{color:#86efaca6;white-space:nowrap;text-overflow:ellipsis;letter-spacing:.2px;font-family:Fira Code,monospace;font-size:11px;overflow:hidden}@keyframes fadeSlideDown{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@media (width<=768px){.hero{padding:110px 20px 90px}.hero__title{letter-spacing:-2px}.hero__code-float{display:none}.hero__stat{padding:16px 20px}.hero__stat-num{font-size:22px}.hero__scroll,.hero__marquee{display:none}}@media (width<=480px){.hero__stats{flex-direction:column;gap:0}.hero__stat{border-bottom:1px solid #ffffff12;border-right:none;width:100%;padding:14px 24px}.hero__stat:last-child{border-bottom:none}}.marquee{background:#0d160d;border-top:1px solid #22c55e1f;border-bottom:1px solid #22c55e1f;flex-direction:column;gap:0;padding:0;display:flex;position:relative;overflow:hidden}.marquee:before,.marquee:after{content:"";z-index:2;pointer-events:none;width:120px;position:absolute;top:0;bottom:0}.marquee:before{background:linear-gradient(90deg,#0d160d,#0000);left:0}.marquee:after{background:linear-gradient(270deg,#0d160d,#0000);right:0}.marquee__track{border-bottom:1px solid #ffffff0a;gap:0;width:max-content;padding:14px 0;animation:32s linear infinite marqueeScroll;display:flex}.marquee__track:last-child{border-bottom:none}.marquee__track--reverse{animation-duration:38s;animation-direction:reverse}@keyframes marqueeScroll{0%{transform:translate(0)}to{transform:translate(-50%)}}.marquee__track:hover{animation-play-state:paused}.marquee__item{color:#4ade8073;white-space:nowrap;align-items:center;gap:10px;padding:0 28px;font-family:Fira Code,monospace;font-size:12.5px;font-weight:500;transition:color .2s;display:inline-flex}.marquee__item:hover{color:#4ade80e6}.marquee__dot{background:#22c55e59;border-radius:50%;flex-shrink:0;width:4px;height:4px}.modal-backdrop{z-index:2000;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#000000a6;justify-content:center;align-items:center;padding:24px;animation:.2s backdropIn;display:flex;position:fixed;inset:0}@keyframes backdropIn{0%{opacity:0}to{opacity:1}}.modal{scrollbar-width:thin;scrollbar-color:var(--green-200) transparent;background:#fff;border-radius:20px;width:100%;max-width:680px;max-height:90vh;animation:.3s cubic-bezier(.22,1,.36,1) modalIn;position:relative;overflow-y:auto;box-shadow:0 32px 80px #00000059}@keyframes modalIn{0%{opacity:0;transform:translateY(24px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.modal__close{z-index:10;color:#fff;cursor:pointer;background:#00000059;border:none;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;transition:background .2s;display:flex;position:absolute;top:14px;right:14px}.modal__close:hover{background:#0000008c}.modal__image-wrap{aspect-ratio:16/9;view-transition-name:project-hero;background:#f3f4f6;border-radius:20px 20px 0 0;overflow:hidden}.modal__image{object-fit:cover;object-position:top;width:100%;height:100%;display:block}.modal__placeholder{flex-direction:column;justify-content:center;align-items:center;gap:12px;width:100%;height:100%;display:flex}.modal__placeholder-initials{background:linear-gradient(135deg, var(--green-700), var(--green-500));color:#fff;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;font-size:22px;font-weight:800;display:flex;box-shadow:0 0 28px #22c55e59}.modal__placeholder-name{color:#fff6;font-size:14px;font-weight:500}.modal__content{padding:24px 28px 28px}.modal__meta{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:12px;display:flex}.modal__grade-badge{background:var(--green-50);color:var(--green-700);text-transform:uppercase;letter-spacing:.6px;border:1px solid var(--green-200);border-radius:100px;padding:4px 12px;font-size:11px;font-weight:700;display:inline-block}.modal__views{color:#6b7280;align-items:center;gap:4px;margin-left:auto;font-size:11px;font-weight:600;display:inline-flex}[data-theme=dark] .modal__views{color:var(--text-muted)}.modal__badge{letter-spacing:.6px;text-transform:uppercase;border-radius:100px;align-items:center;gap:4px;padding:4px 10px;font-size:10px;font-weight:800;display:inline-flex}.modal__badge--featured{color:#78350f;background:linear-gradient(135deg,#f59e0b,#fbbf24)}.modal__badge--new{background:linear-gradient(135deg, var(--green-600), var(--green-500));color:#fff}.modal__title{color:#0f172a;letter-spacing:-.5px;margin:0 0 8px;font-size:24px;font-weight:900;line-height:1.2}.modal__student{color:#6b7280;align-items:center;gap:6px;margin-bottom:16px;font-size:14px;font-weight:500;display:flex}.modal__student--clickable{cursor:pointer;background:0 0;border:none;padding:0;font-family:inherit;transition:color .15s}.modal__student--clickable:hover{color:var(--green-600)}.modal__tags{flex-wrap:wrap;gap:6px;margin-bottom:20px;display:flex}.modal__tag{color:#6b7280;letter-spacing:.3px;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:100px;padding:3px 10px;font-family:Fira Code,monospace;font-size:11px;font-weight:700}.modal__desc{color:#374151;margin-bottom:24px;font-size:15px;line-height:1.75}.modal__actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.modal__visit-btn{background:var(--green-600);color:#fff;border-radius:10px;align-items:center;gap:8px;padding:12px 22px;font-size:14px;font-weight:700;text-decoration:none;transition:all .25s;display:inline-flex;box-shadow:0 4px 16px #16a34a4d}.modal__visit-btn:hover{background:var(--green-700);transform:translateY(-2px);box-shadow:0 8px 24px #16a34a66}.modal__soon{color:#9ca3af;border:1px solid #e5e7eb;border-radius:8px;padding:8px 16px;font-size:13px;font-weight:600;display:inline-block}.modal__share-btn{color:#374151;cursor:pointer;background:0 0;border:1.5px solid #e5e7eb;border-radius:10px;align-items:center;gap:7px;padding:11px 18px;font-family:inherit;font-size:14px;font-weight:600;transition:all .2s;display:inline-flex}.modal__share-btn:hover{border-color:var(--green-400);color:var(--green-700);background:var(--green-50)}[data-theme=dark] .modal__share-btn{border-color:var(--border);color:var(--text-muted)}[data-theme=dark] .modal__share-btn:hover{border-color:var(--green-700);color:var(--green-400);background:#22c55e14}.modal__related{border-top:1px solid #f0f0f0;padding:20px 28px 28px}.modal__comments{padding:0 28px 32px}.modal__related-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.modal__related-title{color:#0f172a;letter-spacing:.4px;text-transform:uppercase;margin:0;font-size:13px;font-weight:800}.modal__related-tabs{flex-wrap:wrap;gap:6px;display:flex}.modal__related-tab{color:#6b7280;cursor:pointer;background:#f3f4f6;border:1.5px solid #0000;border-radius:100px;align-items:center;gap:5px;padding:5px 12px;font-family:inherit;font-size:12px;font-weight:600;transition:all .15s;display:inline-flex}.modal__related-tab:hover:not(.disabled){background:var(--green-50);color:var(--green-700);border-color:var(--green-300)}.modal__related-tab.active{background:var(--green-600);color:#fff;border-color:var(--green-600)}.modal__related-tab.disabled{opacity:.4;cursor:default}.modal__related-tab-count{text-align:center;background:#ffffff40;border-radius:100px;min-width:16px;padding:1px 6px;font-size:10px;font-weight:700}.modal__related-tab:not(.active) .modal__related-tab-count{color:#374151;background:#e5e7eb}.modal__related-scroll{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.modal__rel-card{cursor:pointer;text-align:left;background:#f9fafb;border:1.5px solid #f0f0f0;border-radius:12px;padding:0;font-family:inherit;transition:all .2s;overflow:hidden}.modal__rel-card:hover{border-color:var(--green-400);transform:translateY(-2px);box-shadow:0 6px 20px #16a34a26}.modal__rel-thumb{aspect-ratio:16/10;background:#e5e7eb;width:100%;overflow:hidden}.modal__rel-thumb img{object-fit:cover;width:100%;height:100%;display:block}.modal__rel-placeholder{color:#ffffffb3;justify-content:center;align-items:center;width:100%;height:100%;font-family:Fira Code,monospace;font-size:16px;font-weight:800;display:flex}.modal__rel-info{flex-direction:column;gap:2px;padding:8px 10px;display:flex}.modal__rel-name{color:#0f172a;white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:700;display:block;overflow:hidden}.modal__rel-meta{color:#9ca3af;font-size:11px;font-weight:500}.modal__related-empty{color:#9ca3af;text-align:center;margin:0;padding:16px 0;font-size:13px}[data-theme=dark] .modal__related{border-top-color:var(--border)}[data-theme=dark] .modal__related-title{color:var(--text)}[data-theme=dark] .modal__related-tab{color:var(--text-muted);background:#ffffff0f}[data-theme=dark] .modal__related-tab:hover:not(.disabled){color:var(--green-400);border-color:var(--green-700);background:#22c55e1a}[data-theme=dark] .modal__rel-card{border-color:var(--border);background:#ffffff0a}[data-theme=dark] .modal__rel-card:hover{border-color:var(--green-600)}[data-theme=dark] .modal__rel-thumb{background:#ffffff0f}[data-theme=dark] .modal__rel-name{color:var(--text)}[data-theme=dark] .modal__related-tab:not(.active) .modal__related-tab-count{color:var(--text-muted);background:#ffffff1a}@media (width<=640px){.modal-backdrop{align-items:center;padding:16px}.modal{border-radius:20px;max-width:100%;max-height:88vh}.modal__image-wrap{border-radius:20px 20px 0 0}.modal__content{padding:18px 18px 24px}.modal__title{font-size:19px}.modal__related{padding:16px 18px 24px}.modal__related-scroll{grid-template-columns:repeat(2,1fr);gap:10px}.modal__related-header{flex-direction:column;align-items:flex-start}}[data-theme=dark] .modal{background:var(--bg-card)}[data-theme=dark] .modal__image-wrap{background:#0d160d}[data-theme=dark] .modal__title{color:var(--text)}[data-theme=dark] .modal__student,[data-theme=dark] .modal__desc{color:var(--text-muted)}[data-theme=dark] .modal__grade-badge{background:#16a34a1f;border-color:#16a34a40}[data-theme=dark] .modal__soon{color:var(--text-subtle);border-color:var(--border)}[data-theme=dark] .modal__tag{color:var(--text-muted);background:#ffffff0d;border-color:#ffffff1a}[data-theme=dark] .modal__student--clickable:hover{color:var(--green-400)}.gallery{columns:3;column-gap:10px}.gallery__item{break-inside:avoid;cursor:zoom-in;background:var(--bg-card);vertical-align:top;border:none;border-radius:10px;width:100%;margin-bottom:10px;padding:0;display:block;position:relative;overflow:hidden}.gallery__item--sm{aspect-ratio:4/3}.gallery__item--md{aspect-ratio:16/10}.gallery__item--lg{aspect-ratio:2/3}.gallery__img{object-fit:cover;object-position:top center;opacity:0;width:100%;height:100%;transition:opacity .35s,transform .5s cubic-bezier(.22,1,.36,1);display:block}.gallery__img--loaded{opacity:1}.gallery__item:hover .gallery__img{transform:scale(1.06)}.gallery__shimmer{background:linear-gradient(90deg,#ffffff0a 25%,#ffffff17 50%,#ffffff0a 75%) 0 0/200% 100%;animation:1.5s linear infinite galleryShimmer;position:absolute;inset:0}@keyframes galleryShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.gallery__placeholder{flex-direction:column;justify-content:center;align-items:center;gap:8px;display:flex;position:absolute;inset:0}.gallery__placeholder-initials{color:#ffffff4d;font-size:36px;font-weight:900}.gallery__placeholder-name{color:#fff6;text-align:center;word-break:break-word;padding:0 12px;font-size:12px;font-weight:600}.gallery__overlay{opacity:0;pointer-events:none;background:linear-gradient(#0000 35%,#00000026 55%,#000000e0 100%);align-items:flex-end;transition:opacity .28s;display:flex;position:absolute;inset:0}.gallery__item:hover .gallery__overlay{opacity:1}.gallery__overlay-content{text-align:left;flex-direction:column;gap:3px;width:100%;padding:14px 13px;display:flex}.gallery__overlay-title{color:#fff;white-space:nowrap;text-overflow:ellipsis;max-width:100%;font-size:13px;font-weight:700;line-height:1.3;overflow:hidden}.gallery__overlay-student{color:#fff9;font-size:11px;font-weight:400}.gallery__badges{gap:4px;display:flex;position:absolute;top:8px;left:8px}.gallery__badge{letter-spacing:.4px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-radius:6px;padding:3px 7px;font-size:10px;font-weight:800}.gallery__badge--featured{color:#713f12;background:#facc15e0}.gallery__badge--new{color:#fff;background:#22c55ee0}@media (width<=860px){.gallery{columns:2}}@media (width<=480px){.gallery{columns:1}}.tl{padding-left:26px;position:relative}.tl__line{background:linear-gradient(to bottom, var(--green-500), var(--green-200), transparent);border-radius:2px;width:2px;position:absolute;top:8px;bottom:8px;left:7px}[data-theme=dark] .tl__line{background:linear-gradient(to bottom, var(--green-500), #22c55e2e, transparent)}.tl__group{opacity:0;margin-bottom:36px;transition:opacity .6s cubic-bezier(.22,1,.36,1),transform .6s cubic-bezier(.22,1,.36,1);transform:translateY(24px)}.tl__group--visible{opacity:1;transform:translateY(0)}.tl__marker{align-items:center;gap:10px;margin-bottom:14px;display:flex}.tl__dot{background:var(--bg);border:3.5px solid var(--green-500);border-radius:50%;width:16px;height:16px;position:absolute;left:0;box-shadow:0 0 0 4px #22c55e26}.tl__month{color:var(--text);text-transform:capitalize;font-size:15px;font-weight:800}.tl__count{color:var(--green-600);background:#22c55e1a;border-radius:100px;padding:2px 9px;font-size:11px;font-weight:800}[data-theme=dark] .tl__count{color:var(--green-400)}.tl__cards{grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:12px;display:grid}.tl__card{border:1.5px solid var(--border);background:var(--bg-card);animation:tlCardIn .5s calc(var(--i) * 40ms) cubic-bezier(.22,1,.36,1) both;border-radius:14px;align-items:center;gap:11px;padding:8px;text-decoration:none;transition:border-color .25s,transform .25s,box-shadow .25s;display:flex}@keyframes tlCardIn{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}.tl__card:hover{border-color:#22c55e80;transform:translateY(-3px);box-shadow:0 10px 28px #0000001f}.tl__thumb{background:var(--bg-alt);border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:76px;height:48px;display:flex;overflow:hidden}.tl__thumb img{object-fit:cover;width:100%;height:100%}.tl__thumb-ph{color:var(--green-500);font-family:Fira Code,monospace;font-size:11px;font-weight:700}.tl__card-body{flex-direction:column;gap:3px;min-width:0;display:flex}.tl__card-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:700;overflow:hidden}.tl__card-meta{color:var(--text-subtle);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}@media (width<=480px){.tl{padding-left:22px}.tl__cards{grid-template-columns:1fr}}.lightbox{z-index:1000;background:#040704f7;flex-direction:column;animation:.22s lightboxFadeIn;display:flex;position:fixed;inset:0}@keyframes lightboxFadeIn{0%{opacity:0}to{opacity:1}}.lightbox__backdrop{z-index:-1;cursor:zoom-out;position:absolute;inset:0}.lightbox__topbar{flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.lightbox__counter{color:#ffffff59;letter-spacing:.5px;font-family:Fira Code,monospace;font-size:12px;font-weight:600}.lightbox__close{color:#ffffffb3;cursor:pointer;background:#ffffff14;border:1px solid #ffffff1a;border-radius:50%;justify-content:center;align-items:center;width:38px;height:38px;transition:background .18s,color .18s,transform .18s;display:flex}.lightbox__close:hover{color:#fff;background:#ffffff29;transform:scale(1.08)}.lightbox__body{flex:1;align-items:center;gap:6px;min-height:0;padding:0 10px;display:flex;overflow:hidden}.lightbox__nav{color:#ffffffa6;cursor:pointer;background:#ffffff12;border:1px solid #ffffff1a;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:46px;height:46px;transition:background .18s,color .18s,transform .18s;display:flex}.lightbox__nav:hover{color:#fff;background:#ffffff24;transform:scale(1.1)}.lightbox__stage{flex:1;justify-content:center;align-items:center;min-width:0;height:100%;animation:.25s lightboxStageFade;display:flex}.lightbox__stage--from-right{animation:.3s cubic-bezier(.22,1,.36,1) lightboxSlideFromRight}.lightbox__stage--from-left{animation:.3s cubic-bezier(.22,1,.36,1) lightboxSlideFromLeft}@keyframes lightboxStageFade{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}@keyframes lightboxSlideFromRight{0%{opacity:0;transform:translate(52px)scale(.97)}to{opacity:1;transform:translate(0)scale(1)}}@keyframes lightboxSlideFromLeft{0%{opacity:0;transform:translate(-52px)scale(.97)}to{opacity:1;transform:translate(0)scale(1)}}.lightbox__image{object-fit:contain;border-radius:6px;max-width:100%;max-height:100%;display:block;box-shadow:0 20px 80px #000000d9}.lightbox__placeholder{aspect-ratio:16/10;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:14px;width:100%;max-width:560px;display:flex;box-shadow:0 20px 80px #0009}.lightbox__placeholder-initials{color:#ffffff40;font-size:60px;font-weight:900}.lightbox__placeholder-name{color:#ffffff73;text-align:center;padding:0 24px;font-size:17px;font-weight:600}.lightbox__info{border-top:1px solid #ffffff12;flex-shrink:0;justify-content:space-between;align-items:center;gap:16px;padding:12px 20px;display:flex}.lightbox__info-text{flex-direction:column;gap:5px;min-width:0;display:flex}.lightbox__title{color:#fff;white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:16px;font-weight:700;overflow:hidden}.lightbox__meta{flex-wrap:wrap;align-items:center;gap:7px;display:flex}.lightbox__student-btn{color:#ffffff80;cursor:pointer;background:0 0;border:none;align-items:center;gap:5px;padding:0;font-family:inherit;font-size:13px;font-weight:500;transition:color .18s;display:inline-flex}.lightbox__student-btn:hover{color:#fff}.lightbox__dot{color:#fff3;font-size:13px}.lightbox__grade{color:var(--green-400);letter-spacing:.3px;background:#22c55e1f;border-radius:100px;padding:2px 9px;font-size:11px;font-weight:700}.lightbox__tag{color:#ffffff59;background:#ffffff0f;border-radius:100px;padding:2px 8px;font-size:11px;font-weight:600}.lightbox__visit-btn{background:var(--green-600);color:#fff;white-space:nowrap;border-radius:10px;flex-shrink:0;align-items:center;gap:7px;padding:10px 18px;font-size:13px;font-weight:700;text-decoration:none;transition:background .18s,transform .18s;display:inline-flex}.lightbox__visit-btn:hover{background:var(--green-500);transform:translateY(-1px)}.lightbox__filmstrip{scrollbar-width:none;flex-shrink:0;align-items:center;gap:5px;padding:8px 14px 14px;display:flex;overflow-x:auto}.lightbox__filmstrip::-webkit-scrollbar{display:none}.lightbox__film-item{cursor:pointer;opacity:.55;background:#ffffff0d;border:2px solid #0000;border-radius:5px;flex-shrink:0;width:70px;height:46px;padding:0;transition:border-color .18s,transform .18s,opacity .18s;overflow:hidden}.lightbox__film-item img{object-fit:cover;object-position:top center;width:100%;height:100%;display:block}.lightbox__film-item:hover{opacity:1;border-color:#ffffff4d;transform:scale(1.06)}.lightbox__film-item--active{border-color:var(--green-500);opacity:1;box-shadow:0 0 0 1px var(--green-500)}@media (width<=640px){.lightbox__filmstrip{display:none}.lightbox__nav{width:38px;height:38px}.lightbox__body{gap:4px;padding:0 6px}.lightbox__info{flex-wrap:wrap;gap:10px;padding:10px 14px}.lightbox__title{font-size:14px}.lightbox__meta{gap:5px}.lightbox__tag{display:none}.lightbox__topbar{padding:10px 14px}.lightbox__visit-btn{justify-content:center;width:100%}}.projects{background:var(--bg-alt);padding:96px 24px 80px;transition:background .3s;position:relative}.projects:before{content:"";background:linear-gradient(90deg, transparent, var(--green-200), transparent);height:1px;position:absolute;top:0;left:0;right:0}.projects__container{max-width:1200px;margin:0 auto}.projects__header{text-align:center;margin-bottom:40px}.projects__eyebrow{text-transform:uppercase;letter-spacing:1.5px;color:var(--green-600);align-items:center;gap:8px;margin-bottom:14px;font-size:12px;font-weight:700;display:inline-flex}.projects__eyebrow-dot{background:var(--green-500);border-radius:50%;width:6px;height:6px;animation:2s infinite pulse}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(1.4)}}.projects__title{color:#0f172a;letter-spacing:-1.5px;font-size:clamp(28px,5vw,42px);font-weight:900;line-height:1.1}.projects__controls{flex-direction:column;gap:14px;margin-bottom:20px;display:flex}.projects__controls-row{align-items:center;gap:10px;display:flex}.projects__search-wrap{align-items:center;width:100%;max-width:600px;display:flex;position:relative}.projects__search-wrap>svg{color:#9ca3af;pointer-events:none;position:absolute;left:16px}.projects__search{color:#0f172a;background:#fff;border:2px solid #e5e7eb;border-radius:14px;outline:none;width:100%;padding:13px 44px 13px 46px;font-family:inherit;font-size:15px;transition:border-color .2s,box-shadow .2s}.projects__search::placeholder{color:#9ca3af}.projects__search:focus{border-color:var(--green-500);box-shadow:0 0 0 4px #22c55e1a}.projects__search-clear{cursor:pointer;color:#6b7280;background:#f3f4f6;border:none;border-radius:6px;align-items:center;padding:5px;transition:all .15s;display:flex;position:absolute;right:14px}.projects__search-clear:hover{color:#dc2626;background:#fee2e2}.projects__sort{flex-shrink:0;position:relative}.projects__sort-btn{color:#374151;cursor:pointer;white-space:nowrap;background:#fff;border:2px solid #e5e7eb;border-radius:14px;align-items:center;gap:6px;padding:13px 14px;font-family:inherit;font-size:14px;font-weight:600;transition:all .2s;display:inline-flex}.projects__sort-btn:hover{border-color:var(--green-400);color:var(--green-700)}.projects__sort-btn:disabled{opacity:.4;cursor:not-allowed}.projects__sort-btn:disabled:hover{color:#374151;border-color:#e5e7eb}.projects__sort-dropdown{z-index:50;background:#fff;border:1px solid #e5e7eb;border-radius:12px;min-width:170px;animation:.18s cubic-bezier(.22,1,.36,1) dropIn;position:absolute;top:calc(100% + 6px);right:0;overflow:hidden;box-shadow:0 12px 40px #00000021}@keyframes dropIn{0%{opacity:0;transform:translateY(-8px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.projects__sort-option{color:#374151;text-align:left;cursor:pointer;background:0 0;border:none;width:100%;padding:10px 16px;font-family:inherit;font-size:14px;font-weight:500;transition:background .15s;display:block}.projects__sort-option:hover{background:var(--green-50);color:var(--green-700)}.projects__sort-option.active{background:var(--green-50);color:var(--green-700);font-weight:700}.projects__grade-pills{flex-wrap:wrap;gap:8px;display:flex}.projects__grade-pill{color:#6b7280;cursor:pointer;white-space:nowrap;background:#fff;border:1.5px solid #e5e7eb;border-radius:100px;padding:7px 16px;font-family:inherit;font-size:13px;font-weight:600;transition:all .18s}.projects__grade-pill:hover{border-color:var(--green-400);color:var(--green-700);background:var(--green-50)}.projects__grade-pill.active{background:var(--green-600);border-color:var(--green-600);color:#fff;box-shadow:0 2px 10px #16a34a4d}.projects__grade-pill-count{color:inherit;background:#00000014;border-radius:100px;justify-content:center;align-items:center;min-width:20px;height:18px;margin-left:2px;padding:0 5px;font-size:11px;font-weight:700;display:inline-flex}.projects__grade-pill.active .projects__grade-pill-count{background:#ffffff40}.projects__view-toggle{background:#fff;border:2px solid #e5e7eb;border-radius:12px;flex-shrink:0;align-items:center;gap:2px;padding:3px;display:flex}.projects__view-btn{color:#9ca3af;cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;width:34px;height:34px;transition:background .18s,color .18s;display:flex;position:relative;overflow:hidden}.projects__view-btn:hover{background:var(--green-50);color:var(--green-700)}.projects__view-btn.active{background:var(--green-600);color:#fff}.projects__view-btn--attention{color:var(--green-600);background:#22c55e14}.projects__view-btn--attention:after{content:"";pointer-events:none;background:linear-gradient(105deg,#0000 20%,#ffffff8c 50%,#0000 80%);width:40%;height:100%;animation:3.6s ease-in-out 1.8s infinite viewBtnShine;position:absolute;top:0;left:0;transform:translate(-160%)skew(-12deg)}@keyframes viewBtnShine{0%{transform:translate(-160%)skew(-12deg)}18%{transform:translate(300%)skew(-12deg)}to{transform:translate(300%)skew(-12deg)}}.projects__view-btn-dot{background:var(--green-500);width:6px;height:6px;box-shadow:0 0 0 1.5px var(--bg-card,white);pointer-events:none;border-radius:50%;animation:1.8s ease-in-out infinite viewBtnDot;position:absolute;top:5px;right:5px}@keyframes viewBtnDot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.4)}}[data-theme=dark] .projects__view-toggle{background:var(--bg-card);border-color:var(--border)}[data-theme=dark] .projects__view-btn:hover,[data-theme=dark] .projects__view-btn--attention{color:var(--green-400);background:#22c55e1a}[data-theme=dark] .projects__view-btn--attention:after{background:linear-gradient(105deg,#0000 20%,#ffffff2e 50%,#0000 80%)}.projects__tag-pills{flex-wrap:wrap;gap:6px;display:flex}.projects__tag-pill{color:#6b7280;cursor:pointer;white-space:nowrap;background:#fff;border:1.5px solid #e5e7eb;border-radius:100px;padding:5px 13px;font-family:Fira Code,monospace;font-size:12px;font-weight:600;transition:all .18s}.projects__tag-pill:hover{color:#2563eb;background:#eff6ff;border-color:#93c5fd}.projects__tag-pill.active{color:#fff;background:#2563eb;border-color:#2563eb;box-shadow:0 2px 10px #2563eb4d}.projects__submit-cta{margin-top:60px}.projects__submit-cta-inner{background:linear-gradient(135deg,#16a34a14,#22c55e0a);border:1.5px solid #16a34a33;border-radius:20px;flex-wrap:wrap;align-items:center;gap:20px;padding:28px 32px;display:flex}.projects__submit-cta-icon{color:var(--green-600);flex-shrink:0;font-family:Fira Code,monospace;font-size:28px;font-weight:800}.projects__submit-cta-title{color:#0f172a;margin:0 0 4px;font-size:18px;font-weight:800}.projects__submit-cta-desc{color:#6b7280;margin:0;font-size:14px}.projects__submit-cta-btn{background:var(--green-600);color:#fff;white-space:nowrap;border-radius:12px;flex-shrink:0;align-items:center;gap:8px;margin-left:auto;padding:11px 22px;font-size:14px;font-weight:700;text-decoration:none;transition:all .2s;display:inline-flex}.projects__submit-cta-btn:hover{background:var(--green-700);transform:translateY(-2px);box-shadow:0 8px 24px #16a34a4d}.projects__meta{align-items:center;gap:8px;margin-bottom:28px;display:flex}.projects__count{color:var(--green-600);font-size:22px;font-weight:900}.projects__count-label{color:#9ca3af;font-size:14px;font-weight:500}.projects__reset{color:#dc2626;cursor:pointer;background:0 0;border:1px solid #fca5a5;border-radius:8px;align-items:center;gap:5px;margin-left:auto;padding:5px 12px;font-family:inherit;font-size:13px;font-weight:600;transition:all .2s;display:flex}.projects__reset:hover{background:#fee2e2}.projects__grid{grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:22px;display:grid}@media (width>=1024px){.projects__grid{grid-template-columns:repeat(3,1fr)}}.projects__card-wrap{opacity:0;transition:opacity .45s cubic-bezier(.22,1,.36,1),transform .45s cubic-bezier(.22,1,.36,1);transform:translateY(18px)scale(.97)}.projects__grid.visible .projects__card-wrap{opacity:1;transform:none}@keyframes cardIn{0%{opacity:0;transform:translateY(20px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.projects__type-pills{flex-wrap:wrap;gap:8px;padding-bottom:4px;display:flex}.projects__type-pill{cursor:pointer;border:1px solid var(--border);background:var(--bg-card);color:var(--text-muted);border-radius:999px;padding:7px 18px;font-size:13px;font-weight:600;transition:all .2s}.projects__type-pill:hover{border-color:var(--green-500);color:var(--green-600)}.projects__type-pill.active{background:var(--green-600);border-color:var(--green-600);color:#fff}.projects__type-pill--recent{align-items:center;gap:7px;display:flex}.projects__recent-dot{background:var(--green-500);border-radius:50%;flex-shrink:0;width:7px;height:7px;animation:2s ease-in-out infinite recentPulse}.projects__type-pill--recent.active .projects__recent-dot{background:#fff}@keyframes recentPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.65)}}.projects__type-pill--favs{align-items:center;gap:7px;display:flex}.projects__type-pill--favs svg{color:#ef4444;flex-shrink:0}.projects__type-pill--favs.active svg{color:#fff}.projects__type-divider{grid-column:1/-1;align-items:center;gap:16px;margin-top:8px;padding:8px 0 4px;display:flex}.projects__type-divider:before,.projects__type-divider:after{content:"";background:var(--border);flex:1;height:1px}.projects__type-divider-label{text-transform:uppercase;letter-spacing:1.2px;color:var(--text-subtle);white-space:nowrap;font-size:12px;font-weight:700}@keyframes projectHighlight{0%{box-shadow:0 0 0 2px var(--green-500), 0 0 32px #22c55e8c}60%{box-shadow:0 0 0 2px var(--green-500), 0 0 18px #22c55e4d}to{box-shadow:none}}.projects__card-wrap--highlight .project-card{animation:2s forwards projectHighlight}.projects__skeleton-card{background:var(--bg-card,#111d11);border:1px solid var(--border-card,#ffffff0f);border-radius:18px;animation:.4s cubic-bezier(.22,1,.36,1) both cardIn;overflow:hidden}.projects__skeleton-img{aspect-ratio:16/10;background:linear-gradient(90deg,#ffffff0a 25%,#ffffff12 50%,#ffffff0a 75%) 0 0/200% 100%;animation:1.5s linear infinite shimmer}.projects__skeleton-body{flex-direction:column;gap:10px;padding:14px 16px 16px;display:flex}.projects__skeleton-line{background:linear-gradient(90deg,#ffffff0a 25%,#ffffff12 50%,#ffffff0a 75%) 0 0/200% 100%;border-radius:6px;animation:1.5s linear infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.projects__pagination{flex-wrap:wrap;justify-content:center;align-items:center;gap:6px;margin-top:52px;display:flex}.projects__page-btn{color:#374151;cursor:pointer;background:#fff;border:1.5px solid #e5e7eb;border-radius:10px;justify-content:center;align-items:center;min-width:40px;height:40px;padding:0 10px;font-family:inherit;font-size:14px;font-weight:600;transition:all .2s;display:flex}.projects__page-btn:hover:not(:disabled){border-color:var(--green-500);color:var(--green-700);background:var(--green-50)}.projects__page-btn.active{background:var(--green-600);border-color:var(--green-600);color:#fff;box-shadow:0 2px 10px #16a34a4d}.projects__page-btn--arrow{color:#9ca3af}.projects__page-btn:disabled{opacity:.35;cursor:not-allowed}.projects__page-ellipsis{color:#9ca3af;padding:0 4px;font-weight:600}.projects__empty{text-align:center;padding:80px 24px}.projects__empty-icon{color:var(--green-400);opacity:.4;margin-bottom:16px;font-family:Fira Code,monospace;font-size:40px;font-weight:800}.projects__empty-title{color:#0f172a;margin:0 0 8px;font-size:20px;font-weight:700}.projects__empty-desc{color:#9ca3af;margin:0 0 24px}.projects__empty-btn{background:var(--green-600);color:#fff;cursor:pointer;border:none;border-radius:10px;padding:12px 24px;font-family:inherit;font-size:15px;font-weight:600;transition:background .2s,transform .2s}.projects__empty-btn:hover{background:var(--green-700);transform:translateY(-2px)}@media (width<=640px){.projects{padding:64px 16px 60px}.projects__grid{grid-template-columns:1fr;gap:16px}.projects__controls-row{flex-wrap:wrap}.projects__search-wrap{flex:1;min-width:0}.projects__search{font-size:14px}.projects__sort-btn{padding:11px 12px;font-size:13px}.projects__grade-pills{gap:6px}.projects__grade-pill{padding:6px 12px;font-size:12px}.projects__submit-cta-inner{gap:14px;padding:20px}.projects__submit-cta-btn{justify-content:center;width:100%;margin-left:0}}[data-theme=dark] .projects__title{color:var(--text)}[data-theme=dark] .projects__search{background:var(--bg-card);color:var(--text);border-color:var(--border)}[data-theme=dark] .projects__search-clear{color:var(--text-muted);background:#ffffff0f}[data-theme=dark] .projects__grade-pill{background:var(--bg-card);border-color:var(--border);color:var(--text-muted)}[data-theme=dark] .projects__grade-pill:hover{color:var(--green-400);border-color:var(--green-600);background:#22c55e14}[data-theme=dark] .projects__sort-btn{background:var(--bg-card);border-color:var(--border);color:var(--text-muted)}[data-theme=dark] .projects__sort-btn:hover{border-color:var(--green-700);color:var(--green-400)}[data-theme=dark] .projects__sort-dropdown{background:var(--bg-card);border-color:var(--border);box-shadow:0 12px 40px #00000080}[data-theme=dark] .projects__sort-option{color:var(--text-muted)}[data-theme=dark] .projects__sort-option:hover,[data-theme=dark] .projects__sort-option.active{color:var(--green-400);background:#22c55e14}[data-theme=dark] .projects__page-btn{background:var(--bg-card);border-color:var(--border);color:var(--text-muted)}[data-theme=dark] .projects__empty-title{color:var(--text)}[data-theme=dark] .projects__tag-pill{background:var(--bg-card);border-color:var(--border);color:var(--text-muted)}[data-theme=dark] .projects__tag-pill:hover{color:#93c5fd;background:#2563eb1f;border-color:#2563eb66}[data-theme=dark] .projects__submit-cta-inner{background:#16a34a0f;border-color:#16a34a33}[data-theme=dark] .projects__submit-cta-title{color:var(--text)}[data-theme=dark] .projects__submit-cta-desc{color:var(--text-muted)}.stats{background:var(--bg-alt);padding:80px 24px;position:relative}.stats:before{content:"";background:linear-gradient(90deg, transparent, var(--green-200), transparent);height:1px;position:absolute;top:0;left:0;right:0}.stats__container{max-width:1200px;margin:0 auto}.stats__header{text-align:center;margin-bottom:48px}.stats__eyebrow{text-transform:uppercase;letter-spacing:1.5px;color:var(--green-600);align-items:center;gap:8px;margin-bottom:12px;font-size:12px;font-weight:700;display:inline-flex}.stats__eyebrow-dot{background:var(--green-500);border-radius:50%;width:6px;height:6px}.stats__title{color:#0f172a;letter-spacing:-1px;font-size:clamp(24px,4vw,36px);font-weight:900;line-height:1.1}.stats__summary{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:48px;display:grid}.stats__summary-card{text-align:center;animation:statIn .6s calc(var(--i) * .1s) cubic-bezier(.22,1,.36,1) both;background:#fff;border:1.5px solid #e5e7eb;border-radius:20px;padding:28px 20px;transition:all .35s cubic-bezier(.22,1,.36,1);position:relative;overflow:hidden}@keyframes statIn{0%{opacity:0;transform:translateY(20px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.stats__summary-card:before{content:"";background:linear-gradient(90deg, var(--green-500), var(--green-400));transform-origin:0;height:3px;transition:transform .4s;position:absolute;top:0;left:0;right:0;transform:scaleX(0)}.stats__summary-card:hover{border-color:var(--green-200);transform:translateY(-4px);box-shadow:0 12px 36px #16a34a1a}.stats__summary-card:hover:before{transform:scaleX(1)}.stats__summary-num{color:var(--green-600);letter-spacing:-2px;margin-bottom:6px;font-size:40px;font-weight:900;line-height:1}.stats__summary-lbl{color:#9ca3af;text-transform:uppercase;letter-spacing:.5px;font-size:13px;font-weight:600}.stats__chart{background:#fff;border:1.5px solid #e5e7eb;border-radius:20px;padding:32px}.stats__chart-title{color:#0f172a;margin:0 0 28px;font-size:16px;font-weight:700}.stats__bars{align-items:flex-end;gap:12px;height:180px;display:flex}.stats__bar-group{height:100%;animation:barGroupIn .5s calc(var(--delay)) cubic-bezier(.22,1,.36,1) both;flex-direction:column;flex:1;align-items:center;gap:6px;display:flex}@keyframes barGroupIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.stats__bar-count{color:var(--green-600);font-size:13px;font-weight:800;line-height:1}.stats__bar-track{background:var(--green-50);border-radius:8px;flex:1;align-items:flex-end;width:100%;display:flex;overflow:hidden}.stats__bar-fill{background:linear-gradient(to top, var(--green-700), var(--green-500));border-radius:8px;width:100%;height:0%}.stats__bar-label{color:#6b7280;text-align:center;white-space:nowrap;font-size:11px;font-weight:700}@media (width<=768px){.stats__summary{grid-template-columns:repeat(2,1fr)}}@media (width<=480px){.stats{padding:60px 16px}.stats__summary{grid-template-columns:repeat(2,1fr);gap:10px}.stats__summary-card{padding:20px 14px}.stats__summary-num{font-size:30px}.stats__chart{padding:20px 16px}.stats__bars{gap:8px;height:140px}.stats__bar-label{font-size:10px}}[data-theme=dark] .stats__title{color:var(--text)}[data-theme=dark] .stats__summary-card{background:var(--bg-card);border-color:var(--border-card)}[data-theme=dark] .stats__summary-card:hover{border-color:var(--green-700)}[data-theme=dark] .stats__summary-lbl{color:var(--text-subtle)}[data-theme=dark] .stats__chart{background:var(--bg-card);border-color:var(--border-card)}[data-theme=dark] .stats__chart-title{color:var(--text)}[data-theme=dark] .stats__bar-track{background:#22c55e14}[data-theme=dark] .stats__bar-label{color:var(--text-subtle)}.about{background:#fff;padding:96px 24px 80px;position:relative}.about__divider{background:linear-gradient(90deg, transparent, var(--green-200), transparent);height:1px;position:absolute;top:0;left:0;right:0}.about__container{max-width:1200px;margin:0 auto}.about__grid{grid-template-columns:1fr 1fr;align-items:center;gap:72px;display:grid}.about__eyebrow{text-transform:uppercase;letter-spacing:1.5px;color:var(--green-600);align-items:center;gap:8px;margin-bottom:16px;font-size:12px;font-weight:700;display:inline-flex}.about__eyebrow-dot{background:var(--green-500);border-radius:50%;width:6px;height:6px}.about__title{color:#0f172a;letter-spacing:-1px;margin-bottom:20px;font-size:clamp(26px,4vw,38px);font-weight:900;line-height:1.15}.about__desc{color:#6b7280;margin-bottom:28px;font-size:16px;line-height:1.75}.about__code-block{background:#0f172a;border:1px solid #ffffff0f;border-radius:12px;margin-bottom:28px;padding:18px 20px;font-family:Fira Code,monospace;font-size:13px;line-height:1.6;box-shadow:0 4px 20px #0000001a}.about__code-comment{color:#4b5563}.about__code-key{color:#93c5fd}.about__code-var{color:#86efac}.about__code-str{color:#fde68a}.about__cta{background:var(--green-600);color:#fff;border-radius:10px;align-items:center;gap:8px;padding:12px 22px;font-size:14px;font-weight:700;text-decoration:none;transition:all .25s;display:inline-flex;box-shadow:0 4px 16px #16a34a4d}.about__cta:hover{background:var(--green-700);transform:translateY(-2px);box-shadow:0 8px 24px #16a34a66}.about__cta svg{transition:transform .2s}.about__cta:hover svg{transform:translate(2px,-2px)}.about__stats{grid-template-columns:1fr 1fr;gap:16px;display:grid}.about__stat{text-align:center;animation:statIn .6s calc(var(--i) * .1s) cubic-bezier(.22,1,.36,1) both;background:#fff;border:1.5px solid #e5e7eb;border-radius:20px;flex-direction:column;align-items:center;gap:6px;padding:28px 22px;transition:all .35s cubic-bezier(.22,1,.36,1);display:flex;position:relative;overflow:hidden}.about__stat:hover{border-color:var(--green-300);transform:translateY(-6px);box-shadow:0 16px 48px #16a34a26}.about__stat-glow{opacity:0;background:radial-gradient(circle at 50% 0,#22c55e0f,#0000 70%);transition:opacity .35s;position:absolute;inset:0}.about__stat:hover .about__stat-glow{opacity:1}.about__stat-icon{font-size:28px;line-height:1}.about__stat-num{color:var(--green-600);letter-spacing:-1px;font-size:32px;font-weight:900;line-height:1}.about__stat-lbl{color:#9ca3af;text-transform:uppercase;letter-spacing:.6px;font-size:12px;font-weight:600}@media (width<=900px){.about__grid{grid-template-columns:1fr;gap:48px}}@media (width<=480px){.about{padding:64px 16px 60px}.about__stats{gap:12px}.about__stat{padding:22px 16px}.about__stat-num{font-size:28px}}[data-theme=dark] .about{background:var(--bg)}[data-theme=dark] .about__title{color:var(--text)}[data-theme=dark] .about__desc{color:var(--text-muted)}[data-theme=dark] .about__stat{background:var(--bg-card);border-color:var(--border-card)}[data-theme=dark] .about__stat-lbl{color:var(--text-subtle)}.cursor-spotlight{pointer-events:none;z-index:0;background:radial-gradient(700px circle at var(--cx,-200px) var(--cy,-200px), #22c55e0e, transparent 40%);will-change:background;position:fixed;inset:0}.install{z-index:9999;background:#0f1f0f;border:1px solid #22c55e4d;border-radius:16px;align-items:center;gap:12px;min-width:300px;max-width:calc(100vw - 32px);padding:12px 16px;animation:.35s cubic-bezier(.22,1,.36,1) installSlide;display:flex;position:fixed;bottom:24px;left:50%;transform:translate(-50%);box-shadow:0 8px 32px #00000080,0 0 0 1px #22c55e14}@keyframes installSlide{0%{opacity:0;transform:translate(-50%)translateY(16px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.install__icon{color:#22c55e;background:#22c55e1f;border:1px solid #22c55e33;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.install__text{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.install__text strong{color:#e2e8f0;font-size:.875rem;font-weight:700}.install__text span{color:#fff6;font-size:.75rem}.install__btn{color:#061206;cursor:pointer;white-space:nowrap;background:#22c55e;border:none;border-radius:8px;padding:7px 16px;font-family:inherit;font-size:.825rem;font-weight:700;transition:background .15s}.install__btn:hover{background:#16a34a}.install__close{color:#ffffff4d;cursor:pointer;background:0 0;border:none;flex-shrink:0;align-items:center;padding:4px;transition:color .15s;display:flex}.install__close:hover{color:#ffffffb3}.palette-backdrop{-webkit-backdrop-filter:blur(6px);z-index:10000;background:#050a0599;justify-content:center;align-items:flex-start;padding:12vh 16px 16px;animation:.18s both paletteBackdropIn;display:flex;position:fixed;inset:0}@keyframes paletteBackdropIn{0%{opacity:0}to{opacity:1}}.palette{background:var(--bg-card);border:1.5px solid var(--border);border-radius:18px;flex-direction:column;width:100%;max-width:580px;max-height:65vh;animation:.22s cubic-bezier(.22,1,.36,1) both paletteIn;display:flex;overflow:hidden;box-shadow:0 24px 80px #00000073}@keyframes paletteIn{0%{opacity:0;transform:translateY(-14px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.palette__input-row{border-bottom:1.5px solid var(--border);color:var(--text-subtle);flex-shrink:0;align-items:center;gap:11px;padding:15px 18px;display:flex}.palette__input{color:var(--text);background:0 0;border:none;outline:none;flex:1;font-family:inherit;font-size:16px;font-weight:500}.palette__input::placeholder{color:var(--text-subtle)}.palette__esc{border:1px solid var(--border);color:var(--text-subtle);text-transform:uppercase;border-radius:5px;padding:3px 6px;font-family:Fira Code,monospace;font-size:10px;font-weight:700}.palette__list{flex:1;padding:8px;overflow-y:auto}.palette__group{margin-bottom:6px}.palette__group-title{text-transform:uppercase;letter-spacing:1.2px;color:var(--text-subtle);padding:8px 10px 5px;font-size:10px;font-weight:800}.palette__item{cursor:pointer;text-align:left;width:100%;color:var(--text);background:0 0;border:none;border-radius:10px;align-items:center;gap:11px;padding:9px 10px;font-family:inherit;transition:background .12s;display:flex}.palette__item--active{background:#22c55e1a}.palette__item--active .palette__item-label{color:var(--green-600)}[data-theme=dark] .palette__item--active .palette__item-label{color:var(--green-400)}.palette__item-icon{flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:16px;display:flex}.palette__item-avatar{background:linear-gradient(135deg, var(--green-700), var(--green-500));color:#fff;border-radius:8px;font-size:11px;font-weight:800}.palette__item-thumb{background:var(--bg-alt);border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:30px;display:flex;overflow:hidden}.palette__item-thumb img{object-fit:cover;width:100%;height:100%}.palette__item-thumb-ph{color:var(--green-500);font-family:Fira Code,monospace;font-size:10px;font-weight:700}.palette__item-label{white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.palette__item-meta{color:var(--text-subtle);white-space:nowrap;flex-shrink:0;margin-left:auto;font-size:12px}.palette__empty{text-align:center;color:var(--text-subtle);padding:28px;font-size:14px}.palette__footer{border-top:1.5px solid var(--border);color:var(--text-subtle);flex-shrink:0;gap:18px;padding:10px 18px;font-size:11px;display:flex}.palette__footer kbd{border:1px solid var(--border);border-radius:4px;margin-right:2px;padding:1px 5px;font-family:Fira Code,monospace;font-size:10px}@media (width<=480px){.palette-backdrop{padding-top:8vh}.palette{max-height:75vh}.palette__item-meta,.palette__footer{display:none}}.term-backdrop{-webkit-backdrop-filter:blur(5px);z-index:10001;background:#050a05a6;justify-content:center;align-items:center;padding:20px;animation:.18s both termBackdropIn;display:flex;position:fixed;inset:0}@keyframes termBackdropIn{0%{opacity:0}to{opacity:1}}.term{background:#0a120a;border:1.5px solid #22c55e59;border-radius:14px;width:100%;max-width:620px;animation:.28s cubic-bezier(.22,1,.36,1) both termIn;overflow:hidden;box-shadow:0 24px 80px #0009,0 0 40px #22c55e1f}@keyframes termIn{0%{opacity:0;transform:translateY(24px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.term__bar{background:#ffffff0a;border-bottom:1px solid #22c55e2e;align-items:center;gap:7px;padding:11px 14px;display:flex}.term__dot{border-radius:50%;width:11px;height:11px}.term__dot--r{cursor:pointer;background:#ff5f57}.term__dot--y{background:#febc2e}.term__dot--g{background:#28c840}.term__bar-title{color:#86efac99;margin-left:8px;font-family:Fira Code,monospace;font-size:11px}.term__body{color:#86efac;cursor:text;height:360px;padding:14px 16px;font-family:Fira Code,monospace;font-size:13px;line-height:1.7;overflow-y:auto}.term__line{white-space:pre-wrap;word-break:break-word}.term__line--cmd{color:#e2e8f0}.term__prompt{align-items:center;gap:8px;display:flex}.term__prompt-sign{color:var(--green-500);font-weight:700}.term__input{color:#e2e8f0;caret-color:var(--green-400);background:0 0;border:none;outline:none;flex:1;font-family:Fira Code,monospace;font-size:13px}@media (width<=480px){.term__body{height:300px;font-size:12px}}.recent{background:var(--bg);padding:28px 24px 0}.recent__container{max-width:1200px;margin:0 auto}.recent__head{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.recent__title{text-transform:uppercase;letter-spacing:1.2px;color:var(--green-600);align-items:center;gap:7px;font-size:12px;font-weight:800;display:inline-flex}[data-theme=dark] .recent__title{color:var(--green-400)}.recent__clear{color:var(--text-subtle);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 8px;font-family:inherit;font-size:12px;font-weight:600;transition:color .2s,background .2s}.recent__clear:hover{color:var(--text);background:var(--bg-alt)}.recent__strip{scrollbar-width:none;gap:12px;padding-bottom:8px;display:flex;overflow-x:auto}.recent__strip::-webkit-scrollbar{display:none}.recent__card{border:1.5px solid var(--border);background:var(--bg-card);animation:recentIn .5s calc(var(--i) * 60ms) cubic-bezier(.22,1,.36,1) both;border-radius:14px;flex-shrink:0;align-items:center;gap:10px;padding:7px 14px 7px 7px;text-decoration:none;transition:border-color .25s,transform .25s,box-shadow .25s;display:flex}@keyframes recentIn{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}.recent__card:hover{border-color:#22c55e80;transform:translateY(-2px);box-shadow:0 8px 24px #0000001f}.recent__thumb{background:var(--bg-alt);border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:64px;height:40px;display:flex;overflow:hidden}.recent__thumb img{object-fit:cover;width:100%;height:100%}.recent__thumb-ph{color:var(--green-500);font-family:Fira Code,monospace;font-size:11px;font-weight:700}.recent__info{flex-direction:column;gap:2px;min-width:0;display:flex}.recent__name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;max-width:150px;font-size:13px;font-weight:700;overflow:hidden}.recent__student{color:var(--text-subtle);white-space:nowrap;font-size:11px}@media (width<=480px){.recent{padding:20px 16px 0}}.sh-toast{z-index:10005;background:#0a120a;border:1.5px solid #22c55e73;border-radius:16px;align-items:center;gap:12px;padding:13px 18px;animation:.45s cubic-bezier(.22,1,.36,1) both shToastIn;display:flex;position:fixed;bottom:26px;right:26px;box-shadow:0 16px 48px #00000073,0 0 24px #22c55e26}@keyframes shToastIn{0%{opacity:0;transform:translateY(24px)scale(.92)}to{opacity:1;transform:translateY(0)scale(1)}}.sh-toast__egg{font-size:26px;animation:.8s .3s shEggWiggle}.sh-toast--pill-red{border-color:#f8717180}.sh-toast--pill-blue{border-color:#60a5fa80}@keyframes shEggWiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-18deg)scale(1.15)}60%{transform:rotate(14deg)scale(1.1)}}.sh-toast__text{flex-direction:column;gap:5px;display:flex}.sh-toast__title{color:#86efac;letter-spacing:.2px;font-size:13px;font-weight:800}.sh-toast__dots{align-items:center;gap:5px;display:flex}.sh-toast__dot{background:#86efac2e;border:1px solid #86efac4d;border-radius:50%;width:8px;height:8px}.sh-toast__dot--on{background:var(--green-500);border-color:var(--green-400);box-shadow:0 0 8px #22c55e99}.sh-toast__count{color:#86efacb3;margin-left:4px;font-family:Fira Code,monospace;font-size:11px;font-weight:700}.sh-matrix{z-index:10010;cursor:pointer;background:#000800;transition:opacity 1s,transform 1s;animation:1.4s cubic-bezier(.22,1,.36,1) both shMatrixEnter;position:fixed;inset:0}.sh-matrix--closing{opacity:0;transform:scale(1.02)}@keyframes shMatrixEnter{0%{opacity:0;transform:scale(1.04)}to{opacity:1;transform:scale(1)}}@keyframes shMatrixIn{0%{opacity:0}to{opacity:1}}.sh-matrix__canvas{width:100%;height:100%;display:block}.sh-matrix__msg{pointer-events:none;text-shadow:0 0 18px #22c55ecc;flex-direction:column;justify-content:center;align-items:center;gap:10px;font-family:Fira Code,monospace;display:flex;position:absolute;inset:0}.sh-matrix__line1{color:#d9ffe1;font-size:clamp(22px,5vw,42px);font-weight:700;animation:1.2s .8s both shMsgIn}.sh-matrix__line2{color:#4ade80;font-size:clamp(13px,2.5vw,18px);animation:1.2s 2s both shMsgIn}.sh-matrix__wake{color:#86efac8c;margin-top:18px;font-size:12px;animation:2.4s ease-in-out 3s infinite both shWakePulse}@keyframes shWakePulse{0%,to{opacity:.35}50%{opacity:.9}}@keyframes shMsgIn{0%{opacity:0;letter-spacing:6px;transform:translateY(10px)}to{opacity:1;letter-spacing:2px;transform:translateY(0)}}.sh-confetti{pointer-events:none;z-index:10006;position:fixed;inset:0;overflow:hidden}.sh-confetti__piece{animation:linear both shFall;position:absolute;top:-16px}.sh-confetti__piece--loop{animation-iteration-count:infinite}@keyframes shFall{0%{opacity:1;transform:translateY(-20px)rotate(0)}90%{opacity:1}to{opacity:.6;transform:translateY(105vh)rotate(540deg)}}.sh-party-unlock{z-index:10008;-webkit-backdrop-filter:blur(6px);cursor:pointer;background:#050a05b3;justify-content:center;align-items:center;animation:.3s both shMatrixIn;display:flex;position:fixed;inset:0}.sh-party-unlock__card{cursor:default;background:#0a120a;border:1.5px solid #22c55e80;border-radius:24px;flex-direction:column;align-items:center;gap:10px;padding:44px 56px;animation:.6s cubic-bezier(.22,1,.36,1) both shUnlockPop;display:flex;box-shadow:0 30px 90px #0009,0 0 60px #22c55e33}@keyframes shUnlockPop{0%{opacity:0;transform:scale(.7)rotate(-3deg)}to{opacity:1;transform:scale(1)rotate(0)}}.sh-party-unlock__emoji{font-size:56px;animation:1s .4s infinite shEggWiggle}.sh-party-unlock__title{color:#86efac;letter-spacing:1px;text-align:center;font-size:clamp(20px,4vw,30px);font-weight:900}.sh-party-unlock__desc{color:#86efacb3;font-family:Fira Code,monospace;font-size:13px}.sh-party-unlock__btn{background:var(--green-600);color:#fff;cursor:pointer;border:none;border-radius:100px;margin-top:14px;padding:12px 30px;font-family:inherit;font-size:15px;font-weight:800;transition:transform .2s cubic-bezier(.22,1,.36,1),box-shadow .2s;box-shadow:0 10px 30px #16a34a66}.sh-party-unlock__btn:hover{transform:scale(1.06);box-shadow:0 14px 40px #16a34a8c}@keyframes shPartyHue{0%{filter:hue-rotate()}to{filter:hue-rotate(360deg)}}html.party-mode body{animation:8s linear infinite shPartyHue}@media (prefers-reduced-motion:reduce){html.party-mode body{animation:none}}.sh-party-stop{z-index:10007;color:#86efac;cursor:pointer;background:#0a120a;border:1.5px solid #22c55e80;border-radius:100px;padding:10px 22px;font-family:inherit;font-size:13px;font-weight:800;animation:.4s cubic-bezier(.22,1,.36,1) both shToastIn;position:fixed;bottom:24px;left:50%;transform:translate(-50%);box-shadow:0 12px 36px #0006}.sh-party-stop:hover{background:#11200f}@media (width<=480px){.sh-toast{bottom:16px;left:16px;right:16px}.sh-party-unlock__card{margin:0 16px;padding:32px 28px}}
