:root,[data-theme=light]{--bg:#f8f9fc;--bg-soft:#eef1f6;--card:#fff;--card-2:#f3f5f9;--text:#1a1e2e;--text-secondary:#4a5068;--muted:#6b7394;--line:#00000014;--primary:#3b6df0;--primary-strong:#2a56d4;--primary-bg:#3b6df014;--accent:#00a991;--accent-bg:#00a99114;--danger:#e54d4d;--success:#17a87e;--shadow:0 4px 24px #0000000f;--shadow-hover:0 12px 40px #0000001a;--radius:18px;--radius-sm:12px;--container:1180px;--nav-bg:#f8f9fce0;--terminal-bg:#1e1e2e;--terminal-text:#cdd6f4}[data-theme=dark]{--bg:#0b1120;--bg-soft:#101828;--card:#151e30;--card-2:#1a2540;--text:#e8edf8;--text-secondary:#b0bdd4;--muted:#7a8ba8;--line:#ffffff12;--primary:#5b8cff;--primary-strong:#3d6ef0;--primary-bg:#5b8cff1a;--accent:#00d4b8;--accent-bg:#00d4b814;--danger:#ff6b6b;--success:#20c997;--shadow:0 4px 30px #00000040;--shadow-hover:0 16px 50px #00000059;--nav-bg:#0b1120e0;--terminal-bg:#0d1117;--terminal-text:#c9d1d9}*,:before,:after{box-sizing:border-box}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);min-width:320px;margin:0;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;transition:background .3s,color .3s}a{color:inherit;text-decoration:none}button,input,textarea{font:inherit}button{cursor:pointer}img{max-width:100%;display:block}main{min-height:70vh}ul{padding-left:1.2rem}li{margin-bottom:.4rem}.container{width:min(var(--container), calc(100% - 2rem));margin-inline:auto}.section{padding:5rem 0}.muted-section{background:var(--bg-soft);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.section-header{text-align:center;max-width:760px;margin:0 auto 2.2rem}.section-header.left{text-align:left;margin-left:0}.eyebrow{text-transform:uppercase;letter-spacing:.18em;color:var(--accent);margin:0 0 .5rem;font-size:.78rem;font-weight:700}.section-title,.hero-title{letter-spacing:-.03em;margin:0;line-height:1.15}.section-title{font-size:clamp(1.8rem,4vw,2.6rem)}.hero-title{font-size:clamp(2.2rem,5.5vw,3.8rem)}.section-subtitle,.hero-text{color:var(--muted);margin-top:.5rem;font-size:1rem;line-height:1.8}.strong-text{color:var(--text-secondary);font-weight:600}.small-text{color:var(--muted);font-size:.88rem}.subsection-title,.mini-title{margin:1.5rem 0 1rem;font-size:1.05rem}.muted-text{color:var(--muted)}.scroll-progress{background:linear-gradient(90deg, var(--primary), var(--accent));z-index:200;height:3px;transition:width .1s;position:fixed;top:0;left:0}.navbar{z-index:100;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:var(--nav-bg);border-bottom:1px solid var(--line);position:sticky;top:0}.nav-inner{justify-content:space-between;align-items:center;gap:.6rem;min-height:62px;display:flex}.nav-left,.nav-right{flex-shrink:0;align-items:center;gap:.5rem;display:flex}.brand-button,.footer-brand{color:var(--text);background:0 0;border:0;align-items:center;gap:.6rem;padding:0;display:inline-flex}.brand-mark{background:linear-gradient(135deg, var(--primary), var(--accent));color:#fff;border-radius:10px;flex-shrink:0;place-items:center;width:36px;height:36px;font-size:.85rem;font-weight:800;display:grid}.brand-mark.large{border-radius:14px;width:58px;height:58px;font-size:1.1rem}.brand-mark.small{border-radius:8px;width:30px;height:30px;font-size:.75rem}.brand-text{letter-spacing:.02em;font-size:.95rem;font-weight:700}.nav-links{-ms-overflow-style:none;scrollbar-width:none;flex:1;justify-content:center;align-items:center;gap:.15rem;display:flex;overflow-x:auto}.nav-links::-webkit-scrollbar{display:none}.nav-link{color:var(--muted);white-space:nowrap;background:0 0;border:0;border-radius:999px;padding:.5rem .65rem;font-size:.82rem;transition:all .2s}.nav-link:hover{background:var(--primary-bg);color:var(--text)}.nav-link.active{color:var(--primary);font-weight:600}.nav-cta{padding:.55rem 1rem;font-size:.82rem}.theme-toggle{border:1px solid var(--line);width:36px;height:36px;color:var(--muted);background:0 0;border-radius:10px;flex-shrink:0;place-items:center;transition:all .2s;display:grid}.theme-toggle:hover{background:var(--primary-bg);color:var(--primary)}.nav-toggle{border:1px solid var(--line);background:0 0;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:4px;width:40px;height:40px;padding:0;display:none}.nav-toggle span{background:var(--text);border-radius:2px;width:18px;height:2px;transition:all .3s;display:block}.nav-toggle.is-open span:first-child{transform:rotate(45deg)translate(4px,4px)}.nav-toggle.is-open span:nth-child(2){opacity:0}.nav-toggle.is-open span:nth-child(3){transform:rotate(-45deg)translate(4px,-4px)}.search-bar-wrap{flex-shrink:0;position:relative}.search-input-wrap{background:var(--bg-soft);border:1px solid var(--line);border-radius:999px;align-items:center;gap:.4rem;padding:.35rem .7rem;transition:all .2s;display:flex}.search-input-wrap:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-bg)}.search-icon{color:var(--muted);flex-shrink:0}.search-input{color:var(--text);background:0 0;border:0;outline:none;width:120px;font-size:.85rem}.search-input::placeholder{color:var(--muted)}.search-dropdown{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);width:320px;max-height:360px;box-shadow:var(--shadow-hover);z-index:200;position:absolute;top:calc(100% + .5rem);right:0;overflow-y:auto}.search-loading,.search-empty{text-align:center;color:var(--muted);padding:1rem;font-size:.88rem}.search-result{text-align:left;width:100%;color:var(--text);border:0;border-bottom:1px solid var(--line);cursor:pointer;background:0 0;flex-direction:column;gap:.15rem;padding:.8rem 1rem;transition:all .15s;display:flex}.search-result:last-child{border-bottom:0}.search-result:hover{background:var(--primary-bg)}.search-result-type{text-transform:uppercase;letter-spacing:.1em;color:var(--accent);font-size:.7rem;font-weight:700}.search-result-title{font-size:.92rem;font-weight:600}.search-result-sub{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;font-size:.8rem;overflow:hidden}.btn{border:1px solid #0000;border-radius:999px;justify-content:center;align-items:center;gap:.4rem;padding:.75rem 1.2rem;font-size:.88rem;font-weight:700;transition:all .25s;display:inline-flex}.btn:hover{transform:translateY(-2px)}.btn:active{transform:translateY(0)}.btn-primary{background:linear-gradient(135deg, var(--primary), var(--primary-strong));color:#fff;box-shadow:0 6px 20px #3b6df02e}.btn-primary:hover{box-shadow:0 10px 28px #3b6df047}.btn-secondary{background:var(--card);color:var(--text);border-color:var(--line)}.btn-ghost{color:var(--muted);border-color:var(--line);background:0 0}.btn-sm{padding:.45rem .85rem;font-size:.82rem}.full-width{width:100%}.text-link,.mini-links a{color:var(--primary);font-size:.88rem;font-weight:600;transition:all .2s}.text-link:hover,.mini-links a:hover{opacity:.8}.mini-links{gap:.7rem;display:flex}.inline-copy{color:var(--primary);cursor:pointer;background:0 0;border:0;padding:0;font-weight:600}.inline-copy:hover{text-decoration:underline}.hero{min-height:88vh;padding-top:3.5rem;position:relative;overflow:hidden}.hero-bg-grid{background-image:radial-gradient(circle, var(--line) 1px, transparent 1px);opacity:.5;pointer-events:none;background-size:40px 40px;position:absolute;inset:0}.hero-bg-media{pointer-events:none;z-index:0;justify-content:center;align-items:center;display:flex;position:absolute;inset:0;overflow:hidden}.hero-bg-media img{object-fit:cover;object-position:center center;opacity:0;width:100%;min-height:100%}[data-theme=dark] .hero-bg-media img{opacity:.3}.hero-grid{grid-template-columns:1.1fr .9fr;align-items:start;gap:2rem;display:grid;position:relative}.hero-copy,.hero-panel{min-width:0}.status-pill{border:1px solid var(--accent-bg);background:var(--accent-bg);color:var(--accent);border-radius:999px;align-items:center;gap:.5rem;margin-bottom:1rem;padding:.4rem .85rem;font-size:.82rem;font-weight:600;display:inline-flex}.status-dot{background:var(--accent);border-radius:50%;width:8px;height:8px;animation:2s infinite pulse-dot}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.hero-brand{align-items:center;gap:1rem;margin-bottom:.8rem;display:flex}.typed-role{color:var(--primary)}.typed-cursor{color:var(--primary);font-weight:300;animation:.9s infinite blink}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.action-row{flex-wrap:wrap;gap:.6rem;margin-top:1.2rem;display:flex}.action-row.split{justify-content:space-between;align-items:center}.hero-socials{flex-wrap:wrap;gap:.8rem;margin-top:1rem;display:flex}.hero-socials a{color:var(--primary);font-size:.9rem;font-weight:600}.hero-panel{gap:1rem;display:grid}.scroll-hint{text-align:center;color:var(--muted);flex-direction:column;align-items:center;gap:.3rem;padding:1.5rem 0 0;font-size:.82rem;animation:2.5s infinite bounce-hint;display:flex}@keyframes bounce-hint{0%,to{transform:translateY(0)}50%{transform:translateY(6px)}}.terminal-3d-wrap{perspective:800px}.terminal{background:var(--terminal-bg);border-radius:var(--radius);border:1px solid var(--line);box-shadow:var(--shadow);transform-style:preserve-3d;will-change:transform;font-family:Fira Code,Cascadia Code,JetBrains Mono,monospace;font-size:.85rem;transition:transform .15s,box-shadow .15s;overflow:hidden}.terminal-bar{background:#00000040;align-items:center;gap:.5rem;padding:.6rem 1rem;display:flex}.terminal-dot{border-radius:50%;width:11px;height:11px}.terminal-dot.red{background:#ff5f57}.terminal-dot.yellow{background:#febc2e}.terminal-dot.green{background:#28c840}.terminal-title{color:#888;margin-left:.5rem;font-size:.75rem}.terminal-body{color:var(--terminal-text);padding:.8rem 1rem;line-height:1.8}.terminal-body p{margin:0}.t-prompt{color:var(--accent);margin-right:.5rem;font-weight:700}.t-output{color:#a3beff;padding-left:1rem}.t-typing{min-height:1.4em}.t-cursor{color:var(--accent);animation:.9s infinite blink}.t-available{color:var(--accent)}.card,.project-detail-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);transition:all .3s;overflow:hidden}.hover-lift:hover{box-shadow:var(--shadow-hover);transform:translateY(-4px)}.card-body{padding:1.2rem}.card h3,.project-detail-card h1,.project-detail-card h2{margin-top:0;font-size:1.05rem}.card p{color:var(--text-secondary);margin-bottom:.5rem;line-height:1.7}.card-meta{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.6rem;display:flex}.pill,.level-badge{border-radius:999px;justify-content:center;align-items:center;padding:.3rem .6rem;font-size:.72rem;font-weight:700;display:inline-flex}.pill{background:var(--primary-bg);color:var(--primary);border:1px solid #3b6df026}.pill.leetcode{color:#d4930a;background:#ffae001a;border-color:#ffae002e}[data-theme=dark] .pill.leetcode{color:#ffdb8c}.level-badge{background:var(--accent-bg);color:var(--accent)}.card-image{aspect-ratio:16/9;background:var(--bg-soft);position:relative;overflow:hidden}.card-image img{object-fit:cover;width:100%;height:100%;transition:all .4s}.hover-lift:hover .card-image img{transform:scale(1.04)}.card-image.placeholder{color:var(--primary);place-items:center;font-size:1.8rem;font-weight:800;display:grid}.card-image.clickable{cursor:pointer}.image-overlay{opacity:0;background:#0000008c;place-items:center;transition:all .3s;display:grid;position:absolute;inset:0}.card-image.clickable:hover .image-overlay{opacity:1}.image-overlay span{color:#fff;background:var(--primary);border-radius:999px;padding:.45rem 1rem;font-size:.88rem;font-weight:700}.placeholder-inner{width:100%;height:100%;color:var(--primary);place-items:center;font-size:1.8rem;font-weight:800;display:grid}.placeholder-inner.note-icon{color:var(--muted)}.project-default-image{background:var(--bg-soft);color:var(--muted);aspect-ratio:16/9;place-items:center;display:grid}.scroll-row{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;gap:1.1rem;padding-bottom:1rem;display:flex;overflow-x:auto}.scroll-row::-webkit-scrollbar{height:6px}.scroll-row::-webkit-scrollbar-track{background:0 0}.scroll-row::-webkit-scrollbar-thumb{background:var(--line);border-radius:999px}.scroll-card{scroll-snap-align:start;flex:0 0 320px;max-width:320px}.about-grid,.contact-grid,.timeline-grid,.dashboard-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:1.5rem;display:grid}.metric-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.7rem;margin:.8rem 0;display:grid}.metric-grid.three-col{grid-template-columns:repeat(3,minmax(0,1fr))}.metric-grid.two-col{grid-template-columns:repeat(2,minmax(0,1fr))}.info-list{gap:.7rem;display:grid}.stat-card,.metric-box{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:1rem;transition:all .25s}.stat-card:hover,.metric-box:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px)}.stat-card h3,.metric-box h3{color:var(--primary);margin:0;font-size:1.6rem}.stat-card p,.metric-box p{color:var(--muted);margin:.2rem 0 0;font-size:.82rem}.skill-icon-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.7rem;display:grid}.skill-icon-card{border-radius:var(--radius-sm);background:var(--card);border:1px solid var(--line);cursor:default;flex-direction:column;align-items:center;gap:.4rem;padding:.8rem .4rem;transition:all .25s;display:flex;position:relative}.skill-icon-card:hover{border-color:var(--primary);box-shadow:var(--shadow-hover);transform:translateY(-3px)}.skill-icon-wrap{place-items:center;width:38px;height:38px;display:grid}.skill-icon-wrap img{object-fit:contain;width:32px;height:32px}.skill-icon-fallback{background:var(--primary-bg);width:32px;height:32px;color:var(--primary);border-radius:8px;justify-content:center;align-items:center;font-size:.78rem;font-weight:800;display:flex}.skill-icon-name{text-align:center;color:var(--text-secondary);font-size:.72rem;font-weight:600;line-height:1.2}.skill-dot{border-radius:50%;width:6px;height:6px;position:absolute;top:.4rem;right:.4rem}.skill-dot.beginner{background:#94a3b8}.skill-dot.intermediate{background:#f59e0b}.skill-dot.advanced{background:var(--primary)}.skill-dot.expert{background:var(--accent)}.filter-bar{flex-wrap:wrap;gap:.4rem;margin-bottom:1.5rem;display:flex}.filter-btn{border:1px solid var(--line);background:var(--card);color:var(--muted);border-radius:999px;padding:.4rem .85rem;font-size:.82rem;font-weight:600;transition:all .2s}.filter-btn:hover{border-color:var(--primary);color:var(--primary)}.filter-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.skill-matcher{display:none}.social-stack,.chip-list{flex-wrap:wrap;gap:.5rem;margin-top:.6rem;display:flex}.social-pill,.chip{color:var(--text-secondary);background:var(--bg-soft);border:1px solid var(--line);border-radius:999px;padding:.35rem .7rem;font-size:.8rem;transition:all .2s}.social-pill:hover,.chip:hover{border-color:var(--primary);color:var(--primary)}.chip.mini{padding:.15rem .4rem;font-size:.68rem}.about-highlights{gap:1rem;margin-top:1.2rem;display:grid}.highlight-item{align-items:flex-start;gap:.8rem;display:flex}.highlight-icon{text-align:center;flex-shrink:0;width:36px;font-size:1.4rem}.highlight-item strong{color:var(--text);margin-bottom:.15rem;font-size:.95rem;display:block}.highlight-item p{margin:0;font-size:.88rem}.offer-grid{grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem;display:grid}.offer-item{border-radius:var(--radius-sm);background:var(--bg-soft);border:1px solid var(--line);padding:.9rem}.offer-number{color:var(--primary);opacity:.25;margin-bottom:.2rem;font-size:1.3rem;font-weight:800;display:block}.offer-item h4{margin:0 0 .2rem;font-size:.92rem}.offer-item p{color:var(--muted);margin:0;font-size:.82rem}.progress{background:var(--bg-soft);border-radius:999px;width:100%;height:8px;overflow:hidden}.progress-bar{background:linear-gradient(90deg, var(--primary), var(--accent));border-radius:999px;height:100%}.progress-bar.animate-bar{width:0;animation:1.2s forwards grow-bar}@keyframes grow-bar{to{width:var(--bar-width)}}.timeline{padding-left:1.6rem;position:relative}.timeline:before{content:"";background:var(--line);width:2px;position:absolute;top:0;bottom:0;left:6px}.timeline-item{margin-bottom:1.2rem;position:relative}.timeline-dot{background:var(--primary);border:3px solid var(--bg);z-index:1;border-radius:50%;width:12px;height:12px;position:absolute;top:1.4rem;left:-1.6rem}.dashboard-block{margin-top:1.2rem}.lang-bar{border-radius:999px;height:24px;margin-bottom:.5rem;display:flex;overflow:hidden}.lang-segment{color:#fff;white-space:nowrap;justify-content:center;align-items:center;padding:0 .3rem;font-size:.65rem;font-weight:700;display:flex;overflow:hidden}.lang-segment:first-child{background:#3572a5}.lang-segment:nth-child(2){color:#333;background:#f1e05a}.lang-segment:nth-child(3){background:#2b7489}.lang-segment:nth-child(4){background:#e34c26}.lang-segment:nth-child(5){background:#563d7c}.lang-segment:nth-child(6){background:#00add8}.lang-legend{flex-wrap:wrap;gap:.7rem;margin-top:.3rem;display:flex}.lang-label{color:var(--muted);font-size:.72rem}.repo-list{gap:.5rem;display:grid}.repo-item{background:var(--bg-soft);border:1px solid var(--line);color:var(--text-secondary);border-radius:12px;justify-content:space-between;gap:.8rem;padding:.7rem .9rem;font-size:.88rem;transition:all .2s;display:flex}.repo-item:hover{border-color:var(--primary);color:var(--primary)}.repo-info{align-items:center;gap:.4rem;min-width:0;display:flex}.repo-name{white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.repo-stars{color:var(--primary);white-space:nowrap;font-weight:700}.difficulty-visual{gap:.6rem;display:grid}.diff-row{grid-template-columns:60px 1fr 45px;align-items:center;gap:.7rem;display:grid}.diff-label{color:var(--text-secondary);font-size:.82rem;font-weight:600}.diff-track{background:var(--bg-soft);border-radius:999px;height:8px;overflow:hidden}.diff-fill{border-radius:999px;height:100%;transition:width 1.2s}.diff-fill.easy{background:linear-gradient(90deg,#00b8a3,#00d4b8)}.diff-fill.medium{background:linear-gradient(90deg,#ffc01e,#f5a623)}.diff-fill.hard{background:linear-gradient(90deg,#ef4743,#ff6b6b)}.diff-count{text-align:right;color:var(--text);font-size:.85rem;font-weight:700}.lc-summary{flex-wrap:wrap;align-items:center;gap:1.5rem;display:flex}.lc-ring-visual{flex-shrink:0;width:120px;height:120px}.lc-ring{width:100%;height:100%}.lc-ring-bg{fill:none;stroke:var(--line);stroke-width:6px}.lc-ring-fill{fill:none;stroke-width:6px;stroke-linecap:round;transform-origin:50%;transition:stroke-dasharray 1.2s;transform:rotate(-90deg)}.easy-ring{stroke:#00d4b8}.medium-ring{stroke:#f5a623}.hard-ring{stroke:#ff6b6b}.lc-ring-text{fill:var(--text);font-size:1.4rem;font-weight:800}.lc-ring-subtext{fill:var(--muted);font-size:.65rem}.lc-legend{gap:.5rem;display:grid}.lc-legend span{color:var(--text-secondary);align-items:center;gap:.4rem;font-size:.85rem;display:flex}.legend-dot{border-radius:50%;flex-shrink:0;width:9px;height:9px}.easy-dot{background:#00d4b8}.med-dot{background:#f5a623}.hard-dot{background:#ff6b6b}.contact-grid{grid-template-columns:.85fr 1.15fr}.contact-info-col{align-content:start;gap:1rem;display:grid}.contact-socials{margin-top:.4rem}.contact-socials strong{margin-bottom:.4rem;display:block}.email-preview{border-left:3px solid var(--accent)}.preview-block{font-size:.85rem;line-height:1.7}.preview-block p{margin:.2rem 0}.form-grid{grid-template-columns:1fr 1fr;gap:.8rem;display:grid}.form-group{gap:.3rem;margin-bottom:.7rem;display:grid}.form-group label{color:var(--text);justify-content:space-between;align-items:center;font-size:.88rem;font-weight:600;display:flex}.char-count{color:var(--muted);font-size:.75rem;font-weight:400}.form-group input,.form-group textarea{background:var(--bg-soft);border:1px solid var(--line);width:100%;color:var(--text);border-radius:12px;outline:none;padding:.8rem .9rem;font-size:.92rem;transition:all .2s}.form-group input:focus,.form-group textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-bg)}.form-group input:invalid:not(:placeholder-shown){border-color:var(--danger)}.form-error{color:var(--danger);background:#e54d4d1a;border:1px solid #e54d4d33;border-radius:12px;margin-bottom:.7rem;padding:.7rem .9rem;font-size:.88rem;font-weight:600}.form-success{background:var(--accent-bg);color:var(--accent);border:1px solid #00a99133;border-radius:12px;margin-bottom:.7rem;padding:.7rem .9rem;font-size:.88rem;font-weight:600}.social-icon-bar{flex-wrap:wrap;gap:.5rem;padding:.3rem 0;display:flex;overflow-x:auto}.social-icon-bar::-webkit-scrollbar{display:none}.social-icon-link{background:var(--card);border:1px solid var(--line);width:40px;height:40px;color:var(--muted);border-radius:12px;flex-shrink:0;place-items:center;transition:all .2s;display:grid}.social-icon-link:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-bg)}.social-svg{justify-content:center;align-items:center;width:20px;height:20px;display:flex}.social-svg svg{width:100%;height:100%}.note-title-row{align-items:center;gap:.6rem;display:flex}.note-tech-icon{object-fit:contain;flex-shrink:0;width:28px;height:28px}.note-access-info{margin:.4rem 0}.access-badge{border-radius:999px;align-items:center;gap:.3rem;padding:.25rem .6rem;font-size:.72rem;font-weight:700;display:inline-flex}.access-badge.members{color:#d4930a;background:#ffae001a;border:1px solid #ffae0033}[data-theme=dark] .access-badge.members{color:#ffdb8c}.access-badge.locked{background:var(--primary-bg);color:var(--primary);border:1px solid #3b6df026}.course-title-row{align-items:center;gap:.6rem;display:flex}.course-tech-icon{object-fit:contain;flex-shrink:0;width:28px;height:28px}.credential-id{color:var(--muted);margin:.2rem 0 .4rem;font-family:Fira Code,Cascadia Code,monospace;font-size:.78rem}.modal-overlay{z-index:500;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#000000b3;place-items:center;padding:1rem;display:grid;position:fixed;inset:0}.modal-content{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);width:min(960px,95vw);height:88vh;box-shadow:var(--shadow-hover);flex-direction:column;display:flex;overflow:hidden}.modal-header{border-bottom:1px solid var(--line);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.8rem;padding:.8rem 1.2rem;display:flex}.modal-header h3{margin:0;font-size:1rem}.modal-actions{align-items:center;gap:.4rem;display:flex}.modal-close{border:1px solid var(--line);width:34px;height:34px;color:var(--muted);cursor:pointer;background:0 0;border-radius:10px;place-items:center;font-size:1rem;display:grid}.modal-close:hover{background:var(--danger);color:#fff;border-color:var(--danger)}.modal-body{flex:1;overflow:hidden}.modal-body iframe{border:0;width:100%;height:100%}.modal-image-wrap{background:var(--bg-soft);place-items:center;height:100%;padding:1.5rem;display:grid;overflow:auto}.modal-image-wrap img{object-fit:contain;border-radius:var(--radius-sm);max-width:100%;max-height:100%}.login-modal{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);width:min(400px,92vw);box-shadow:var(--shadow-hover)}.login-form{padding:1.2rem}.viewer-locked-badge{color:#d4930a;background:#ffae001a;border:1px solid #ffae0033;border-radius:999px;align-items:center;gap:.3rem;padding:.35rem .7rem;font-size:.78rem;font-weight:700;display:inline-flex}[data-theme=dark] .viewer-locked-badge{color:#ffdb8c}.note-secure-overlay,.note-secure-content{-webkit-user-select:none;user-select:none}.note-secure-body{-webkit-user-select:none;user-select:none;position:relative}.note-secure-body:after{content:"";z-index:10;pointer-events:none;background:0 0;position:absolute;inset:0}.toast{z-index:300;box-shadow:var(--shadow-hover);border-radius:14px;align-items:center;gap:.8rem;max-width:380px;padding:.85rem 1.1rem;font-size:.88rem;font-weight:600;animation:.35s slide-in-toast;display:flex;position:fixed;bottom:1.5rem;right:1.5rem}.toast-success{background:var(--accent);color:#fff}.toast-error{background:var(--danger);color:#fff}.toast-close{color:#fff;background:0 0;border:0;margin-left:auto;padding:0;font-size:1.2rem}@keyframes slide-in-toast{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.back-to-top{z-index:150;background:var(--card);border:1px solid var(--line);width:42px;height:42px;color:var(--text);box-shadow:var(--shadow);opacity:0;pointer-events:none;border-radius:50%;place-items:center;transition:all .3s;display:grid;position:fixed;bottom:1.5rem;left:1.5rem}.back-to-top.show{opacity:1;pointer-events:all}.back-to-top:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.welcome-hint{z-index:200;background:var(--card);border:1px solid var(--line);box-shadow:var(--shadow-hover);border-radius:999px;padding:.7rem 1.3rem;animation:.5s fade-in-hint,.5s 4s forwards fade-out-hint;position:fixed;bottom:4rem;left:50%;transform:translate(-50%)}.welcome-hint p{margin:0;font-size:.88rem}@keyframes fade-in-hint{0%{opacity:0;transform:translate(-50%)translateY(10px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@keyframes fade-out-hint{to{opacity:0;pointer-events:none}}.loader-wrap{text-align:center;place-items:center;gap:.8rem;max-width:400px;margin:2.5rem auto;padding:2.5rem;display:grid}.loader-ring{width:44px;height:44px;position:relative}.loader-ring div{box-sizing:border-box;border:3px solid #0000;border-top-color:var(--primary);border-radius:50%;width:36px;height:36px;animation:1.2s cubic-bezier(.5,0,.5,1) infinite ring;position:absolute}.loader-ring div:first-child{animation-delay:-.45s}.loader-ring div:nth-child(2){animation-delay:-.3s}.loader-ring div:nth-child(3){animation-delay:-.15s}@keyframes ring{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.empty-state,.error-state{text-align:center;border-radius:var(--radius);background:var(--bg-soft);border:1px solid var(--line);color:var(--muted);padding:1.5rem;font-size:.92rem}.error-state{color:var(--danger)}.not-found-page{place-items:center;min-height:60vh;display:grid}.not-found-content{text-align:center}.not-found-content h1{color:var(--primary);margin:0;font-size:7rem;line-height:1}.not-found-content p{color:var(--muted);margin:.8rem 0 1.5rem;font-size:1rem}.project-detail-page .project-detail-card{padding:1.3rem}.project-banner-full{border-radius:var(--radius);background:var(--bg-soft);margin:1rem 0;overflow:hidden}.project-banner-full img{width:100%;height:auto;display:block}.project-detail-body{gap:.8rem;display:grid}.back-row,.related-block{margin-bottom:1.5rem}.related-block .scroll-row{margin-top:1rem}.project-html-content{color:var(--text-secondary);line-height:1.8}.project-html-content h1,.project-html-content h2,.project-html-content h3,.project-html-content h4{color:var(--text);margin:1.2rem 0 .5rem}.project-html-content p{margin:.5rem 0}.project-html-content ul,.project-html-content ol{margin:.5rem 0;padding-left:1.5rem}.project-html-content li{margin-bottom:.3rem}.project-html-content code{background:var(--bg-soft);border-radius:6px;padding:.15rem .4rem;font-family:Fira Code,monospace;font-size:.88rem}.project-html-content pre{background:var(--terminal-bg);color:var(--terminal-text);border-radius:var(--radius-sm);margin:.8rem 0;padding:1rem;font-size:.85rem;overflow-x:auto}.project-html-content pre code{background:0 0;padding:0}.project-html-content a{color:var(--primary);text-decoration:underline}.project-html-content img{border-radius:var(--radius-sm);max-width:100%;margin:.8rem 0}.project-html-content blockquote{border-left:3px solid var(--primary);color:var(--muted);margin:.8rem 0;padding-left:1rem;font-style:italic}.project-html-content table{border-collapse:collapse;width:100%;margin:.8rem 0}.project-html-content th,.project-html-content td{border:1px solid var(--line);text-align:left;padding:.5rem .8rem}.project-html-content th{background:var(--bg-soft);font-weight:700}.project-html-content hr{border:none;border-top:1px solid var(--line);margin:1.2rem 0}.footer{border-top:1px solid var(--line);background:var(--bg-soft);padding:2rem 0}.footer-center{text-align:center;flex-direction:column;align-items:center;gap:.8rem;display:flex}.footer-copy{color:var(--muted);margin:0;font-size:.78rem}.auth-links{flex-direction:column;gap:.4rem;margin-top:.8rem;display:flex}.auth-switch{width:100%;color:var(--primary);text-align:center;cursor:pointer;background:0 0;border:0;font-size:.85rem;font-weight:600;display:block}.auth-switch:hover{text-decoration:underline}.user-dropdown-wrap{position:relative}.user-dropdown{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);width:220px;box-shadow:var(--shadow-hover);z-index:200;position:absolute;top:calc(100% + .5rem);right:0;overflow:hidden}.user-dropdown-info{border-bottom:1px solid var(--line);flex-direction:column;gap:.2rem;padding:.9rem 1rem;display:flex}.user-dropdown-name{color:var(--text);font-size:.92rem;font-weight:700}.user-dropdown-email{color:var(--muted);font-size:.78rem}.user-dropdown-badge{background:var(--accent-bg);color:var(--accent);border-radius:999px;width:fit-content;margin-top:.2rem;padding:.15rem .5rem;font-size:.68rem;font-weight:700;display:inline-block}.user-dropdown-item{text-align:left;width:100%;color:var(--text);cursor:pointer;background:0 0;border:0;padding:.7rem 1rem;font-size:.88rem;font-weight:600;transition:all .15s;display:block}.user-dropdown-item:hover{background:var(--primary-bg);color:var(--primary)}.user-dropdown-item.logout{color:var(--danger);border-top:1px solid var(--line)}.user-dropdown-item.logout:hover{background:#e54d4d14}.dropdown-pw-form{border-top:1px solid var(--line);flex-direction:column;gap:.5rem;padding:.7rem 1rem;display:flex}.dropdown-pw-form input{border:1px solid var(--line);background:var(--bg-soft);width:100%;color:var(--text);border-radius:10px;outline:none;padding:.55rem .7rem;font-size:.82rem}.dropdown-pw-form input:focus{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-bg)}.dropdown-pw-error{color:var(--danger);font-size:.78rem;font-weight:600}.dropdown-pw-success{color:var(--accent);font-size:.78rem;font-weight:600}.dropdown-pw-warn{color:#d4930a;padding:.3rem 0;font-size:.78rem;font-weight:700;display:block}[data-theme=dark] .dropdown-pw-warn{color:#ffdb8c}.protected-mode{-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}.protected-mode img{pointer-events:none}.protected-mode ::selection{background:0 0}.protected-mode ::selection{background:0 0}.protected-mode input,.protected-mode textarea{-webkit-user-select:text;user-select:text}.pre-anim{opacity:0;transform:translateY(25px)}.fade-in-up{opacity:1;transition:opacity .6s,transform .6s;transform:translateY(0)}@media (width<=1100px){.nav-links{gap:.1rem}.nav-link{padding:.45rem .55rem;font-size:.78rem}.search-input{width:90px}}@media (width<=900px){.hero-grid,.about-grid,.contact-grid,.timeline-grid,.dashboard-grid{grid-template-columns:1fr}.scroll-card{flex:0 0 280px;max-width:280px}}@media (width<=820px){.nav-toggle{display:flex}.nav-links{background:var(--card);border:1px solid var(--line);box-shadow:var(--shadow-hover);border-radius:16px;flex-direction:column;align-items:stretch;gap:.1rem;padding:.8rem;display:none;position:absolute;top:calc(100% + .4rem);left:.8rem;right:.8rem}.nav-links.open{display:flex}.nav-link{text-align:left;padding:.6rem .8rem;font-size:.88rem}.nav-right .nav-cta{display:none}.search-input{width:100px}.hero-title{font-size:2rem}.hero-brand{align-items:flex-start}.stat-grid,.metric-grid,.metric-grid.three-col{grid-template-columns:1fr 1fr}.offer-grid,.form-grid{grid-template-columns:1fr}.diff-row{grid-template-columns:55px 1fr 40px}.lc-summary{flex-direction:column;align-items:flex-start}}@media (width<=520px){.section{padding:3.5rem 0}.container{width:min(var(--container), calc(100% - 1rem))}.hero-title{font-size:1.7rem}.brand-text{font-size:.85rem}.stat-grid,.metric-grid,.metric-grid.three-col,.metric-grid.two-col{grid-template-columns:1fr}.card-body,.project-detail-page .project-detail-card{padding:.9rem}.toast{max-width:none;bottom:.8rem;left:.8rem;right:.8rem}.skill-icon-grid{grid-template-columns:repeat(auto-fill,minmax(85px,1fr))}.scroll-card{flex:0 0 260px;max-width:260px}.modal-content{height:82vh}.modal-header{flex-direction:column;align-items:flex-start}.search-input{width:80px;font-size:.8rem}.search-dropdown{width:280px;right:-1rem}.nav-left{gap:.3rem}}
