: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}}@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}.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)}.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:40px;transition:opacity .6s,transform .6s;display:flex;position:fixed;inset:0}.loader--exit{opacity:0;pointer-events:none;transform:scale(1.04)}.loader__logo{color:#ffffff26;letter-spacing:-.3px;align-items:center;gap:10px;font-size:15px;font-weight:800;animation:1.4s ease-in-out infinite logoPulse;display:flex}@keyframes logoPulse{0%,to{opacity:.15}50%{opacity:.35}}.loader__logo-icon{color:#22c55e;opacity:.4;font-family:Fira Code,monospace}.loader__terminal{background:#0d160d;border:1px solid #22c55e2e;border-radius:14px;width:min(560px,92vw);overflow:hidden;box-shadow:0 0 0 1px #22c55e0f,0 32px 80px #0009,0 0 60px #22c55e0f}.loader__bar{background:#ffffff08;border-bottom:1px solid #ffffff0d;align-items:center;gap:6px;padding:12px 16px;display:flex}.loader__bar-dot{border-radius:50%;width:11px;height:11px}.loader__bar-dot--r{background:#ff5f57}.loader__bar-dot--y{background:#ffbd2e}.loader__bar-dot--g{background:#28c840}.loader__bar-title{color:#ffffff40;margin-left:6px;font-family:Fira Code,monospace;font-size:12px}.loader__body{flex-direction:column;gap:10px;min-height:180px;padding:22px 24px;display:flex}.loader__line{opacity:0;align-items:center;gap:6px;font-family:Fira Code,monospace;font-size:13.5px;line-height:1.5;transition:opacity .3s,transform .3s;display:flex;transform:translate(-8px)}.loader__line.visible{opacity:1;transform:translate(0)}.loader__line--white{color:#ffffffa6}.loader__line--green{color:#4ade80}.loader__line--accent{color:#86efac;font-weight:600}.loader__caret{vertical-align:middle;background:#22c55e;border-radius:1px;width:8px;height:15px;margin-left:2px;animation:.9s step-end infinite caretBlink;display:inline-block}@keyframes caretBlink{0%,to{opacity:1}50%{opacity:0}}.loader__progress-wrap{align-items:center;gap:12px;padding:0 24px 20px;display:flex}.loader__progress-track{background:#ffffff0f;border-radius:2px;flex:1;height:3px;overflow:hidden}.loader__progress-fill{background:linear-gradient(90deg,#16a34a,#4ade80);border-radius:2px;height:100%;transition:width 80ms linear;box-shadow:0 0 8px #22c55e99}.loader__progress-pct{color:#4ade80;text-align:right;min-width:34px;font-family:Fira Code,monospace;font-size:11px}@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:120px 24px 100px;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:2;text-align:center;flex-direction:column;align-items:center;gap:0;width:100%;max-width:820px;display:flex;position:relative}.hero__terminal-badge{background:#ffffff0a;border:1px solid #ffffff14;border-radius:10px;align-items:center;gap:6px;margin-bottom:28px;padding:7px 16px 7px 10px;animation:.7s cubic-bezier(.22,1,.36,1) both fadeSlideDown;display:inline-flex}.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:20px;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:24px;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:20px;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:40px;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:64px;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{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)}}@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{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;background:#f3f4f6;border-radius:20px 20px 0 0;overflow:hidden}.modal__image{object-fit:cover;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__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}@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}}[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)}.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-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__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{animation:.5s cubic-bezier(.22,1,.36,1) both cardIn}@keyframes cardIn{0%{opacity:0;transform:translateY(20px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.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}
