:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#2d6a4f;--accent-bg:#2d6a4f1a;--accent-border:#2d6a4f66;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#52b788;--accent-bg:#52b78826;--accent-border:#52b78880;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{margin:0}#root{box-sizing:border-box;flex-direction:column;width:100%;min-height:100svh;display:flex}h1,h2,h3{font-family:var(--heading);color:var(--text-h);margin:0}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}.nav{z-index:100;justify-content:space-between;align-items:center;padding:1.1rem 2rem;transition:background .2s,box-shadow .2s;display:flex;position:fixed;top:0;left:0;right:0}.nav--scrolled{background:var(--bg);box-shadow:0 1px 0 var(--border)}.nav-logo{color:var(--text-h);letter-spacing:-.5px;font-size:1.1rem;font-weight:800;text-decoration:none;transition:color .15s}.nav-logo:hover{color:var(--accent)}.nav-logo-img{object-fit:cover;border-radius:8px;width:36px;height:36px;transition:opacity .15s,transform .15s;display:block}.nav-logo:hover .nav-logo-img{opacity:.85;transform:scale(1.05)}.nav-desktop{align-items:center;gap:1.75rem;display:flex}.nav-link{color:var(--text);padding-bottom:2px;font-size:.9rem;font-weight:500;text-decoration:none;transition:color .15s;position:relative}.nav-link:after{content:"";background:var(--accent);transform-origin:0;border-radius:1px;height:2px;transition:transform .2s;position:absolute;bottom:-2px;left:0;right:0;transform:scaleX(0)}.nav-link:hover{color:var(--text-h)}.nav-link--active{color:var(--accent)!important}.nav-link--active:after{transform:scaleX(1)}.nav-cta{background:var(--accent);border-radius:8px;padding:.45rem 1.1rem;font-size:.88rem;font-weight:600;text-decoration:none;transition:opacity .15s,transform .15s;color:#fff!important}.nav-cta:hover{opacity:.85;transform:translateY(-1px)}.hamburger{cursor:pointer;z-index:200;background:0 0;border:none;flex-direction:column;justify-content:space-between;width:24px;height:17px;padding:0;display:none}.hamburger span{background:var(--text-h);transform-origin:50%;border-radius:2px;width:100%;height:2px;transition:transform .25s,opacity .25s;display:block}.hamburger--open span:first-child{transform:translateY(7.5px)rotate(45deg)}.hamburger--open span:nth-child(2){opacity:0;transform:scaleX(0)}.hamburger--open span:nth-child(3){transform:translateY(-7.5px)rotate(-45deg)}.mobile-menu{background:var(--bg);z-index:150;flex-direction:column;justify-content:center;width:280px;transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;bottom:0;right:0;transform:translate(100%);box-shadow:-8px 0 40px #0000001f}.mobile-menu--open{transform:translate(0)}.mobile-menu-inner{flex-direction:column;gap:0;padding:2rem;display:flex}.mobile-menu-inner a{color:var(--text-h);border-bottom:1px solid var(--border);letter-spacing:-.3px;padding:.85rem 0;font-size:1.4rem;font-weight:700;text-decoration:none;transition:color .15s}.mobile-menu-inner a:last-child{border-bottom:none}.mobile-menu-inner a:hover,.mobile-menu-inner .mob-active{color:var(--accent)}.mobile-menu-inner .mob-cta{margin-top:.5rem;color:var(--accent)!important}.overlay{z-index:140;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0006;position:fixed;inset:0}@media (width<=768px){.nav-desktop{display:none}.hamburger{display:flex}}.portfolio{flex-direction:column;min-height:100svh;display:flex}.hero{text-align:center;--text-h:#e8f5ee;--text:#a8d5bc;--bg:#0a1e128c;--border:#ffffff2e;--accent:#1c6e45;--accent-bg:#25f08a33;--accent-border:#74c69d8c;background:url(/assets/background-uHlTOCEK.jpeg) 50%/cover no-repeat;flex-direction:column;justify-content:center;align-items:center;gap:1.1rem;min-height:100svh;padding:10rem 2rem 6rem;display:flex;position:relative}.hero:before{content:"";pointer-events:none;background:linear-gradient(160deg,#081c12c7 0%,#0a28188c 50%,#081c12b8 100%);transition:background .35s;position:absolute;inset:0}.hero-hover{z-index:1;flex-direction:column;align-items:center;gap:1.1rem;width:100%;transition:--text-h .35s,--text .35s;display:flex;position:relative}.hero-hover:hover{--text-h:#fff;--text:#d4f0e0}.hero-badge{background:var(--accent-bg);color:var(--accent);border:1px solid var(--accent-border);letter-spacing:.3px;text-transform:uppercase;border-radius:20px;align-items:center;gap:.4rem;padding:.3rem .9rem;font-size:.8rem;font-weight:600;display:inline-flex}.hero-badge:before{content:"";background:var(--accent);border-radius:50%;width:6px;height:6px;animation:2s infinite pulse}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.hero-name{letter-spacing:-3px;color:var(--text-h);background:linear-gradient(135deg, var(--text-h) 50%, var(--accent));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0;font-size:clamp(3rem,12vw,6rem);font-weight:800;line-height:1}.hero-tagline{color:var(--text);max-width:500px;margin:0;font-size:clamp(1.1rem,3vw,1.35rem);line-height:1.55}.hero-br{display:none}.hero-actions{flex-wrap:wrap;justify-content:center;gap:.85rem;margin-top:.5rem;display:flex}.btn-primary{background:var(--accent);color:#fff;border-radius:10px;align-items:center;gap:.4rem;padding:.75rem 1.75rem;font-size:.95rem;font-weight:600;text-decoration:none;transition:opacity .15s,transform .15s;display:inline-flex}.btn-primary--lg{border-radius:12px;padding:.9rem 2.25rem;font-size:1.05rem}.btn-outline{border:1.5px solid var(--border);color:var(--text-h);background:0 0;border-radius:10px;padding:.75rem 1.75rem;font-size:.95rem;font-weight:600;text-decoration:none;transition:border-color .15s,color .15s,transform .15s}.btn-outline:hover{border-color:var(--accent-border);color:var(--accent);transform:translateY(-1px)}.hero-socials{flex-wrap:wrap;justify-content:center;align-items:center;gap:.6rem;margin-top:.5rem;display:flex}.social-pill{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:20px;align-items:center;gap:.4rem;padding:.4rem 1rem;font-size:.85rem;font-weight:500;text-decoration:none;transition:border-color .15s,color .15s,transform .15s;display:inline-flex}.social-pill:hover{border-color:var(--accent-border);color:var(--accent);transform:translateY(-1px)}.hero-scroll-hint{color:var(--text);opacity:.5;letter-spacing:.5px;text-transform:uppercase;flex-direction:column;align-items:center;gap:.3rem;font-size:.75rem;display:flex;position:absolute;bottom:2rem}.section{box-sizing:border-box;width:100%;max-width:900px;margin:0 auto;padding:5rem 2rem}.section--alt{background:var(--code-bg);max-width:100%;padding:5rem 2rem}.section--alt>*{max-width:900px;margin-left:auto;margin-right:auto}.section--alt>.section-label{display:block}.section-label{letter-spacing:1.8px;text-transform:uppercase;color:var(--accent);margin-bottom:.55rem;font-size:.72rem;font-weight:700}.section-heading{letter-spacing:-1px;color:var(--text-h);margin:0 0 2rem;font-size:clamp(1.7rem,4vw,2.4rem);font-weight:800;line-height:1.1}.section-more-link{color:var(--accent);align-items:center;gap:.35rem;margin-top:2rem;font-size:.9rem;font-weight:600;text-decoration:none;transition:gap .15s,opacity .15s;display:inline-flex}.section-more-link:hover{gap:.55rem}.about-grid{grid-template-columns:1fr auto;align-items:start;gap:3rem;display:grid}.about-text{color:var(--text);max-width:540px;font-size:1.05rem;line-height:1.75}.about-stats{flex-direction:column;gap:1.5rem;display:flex}.stat{flex-direction:column;align-items:flex-end;gap:.1rem;display:flex}.stat-num{color:var(--accent);letter-spacing:-1px;font-size:2rem;font-weight:800;line-height:1}.stat-label{color:var(--text);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;font-size:.78rem;font-weight:500}.cards{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem;display:grid}.card{border:1px solid var(--border);background:var(--bg);border-radius:16px;flex-direction:column;gap:.75rem;padding:1.75rem;transition:box-shadow .2s,transform .2s,border-color .2s;display:flex}.card:hover{border-color:var(--accent-border);transform:translateY(-3px);box-shadow:0 12px 40px #0000001a}.card-icon{margin-bottom:.25rem;font-size:2rem;line-height:1}.card-title{color:var(--text-h);letter-spacing:-.3px;margin:0;font-size:1.1rem;font-weight:700}.card-desc{color:var(--text);flex:1;margin:0;font-size:.9rem;line-height:1.6}.tags{flex-wrap:wrap;gap:.4rem;display:flex}.tag{background:var(--accent-bg);color:var(--accent);border-radius:5px;padding:.2rem .6rem;font-size:.72rem;font-weight:600}.card-cta{color:var(--accent);align-items:center;gap:.4rem;margin-top:.25rem;font-size:.9rem;font-weight:600;text-decoration:none;transition:gap .15s;display:inline-flex}.card-cta:hover{gap:.65rem}.skills{flex-wrap:wrap;gap:.7rem;display:flex}.skill-chip{color:var(--chip-color,var(--text));background:var(--chip-bg,var(--code-bg));cursor:default;border-radius:10px;padding:.5rem 1.1rem;font-size:.875rem;font-weight:700;transition:transform .15s,box-shadow .15s}.skill-chip:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.contact-strip{background:var(--accent);color:#fff;text-align:center;flex-direction:column;align-items:center;gap:1.5rem;padding:5rem 2rem;display:flex}.contact-heading{letter-spacing:-1px;color:#fff;margin:0;font-size:clamp(1.6rem,5vw,2.5rem);font-weight:800}.contact-strip .btn-primary--lg{color:var(--accent);background:#fff;font-weight:700}@media (width<=768px){.hero{padding:8rem 1.5rem 5rem}.hero-br{display:block}.about-grid{grid-template-columns:1fr;gap:2rem}.about-stats{flex-direction:row;justify-content:flex-start}.stat{align-items:flex-start}.section,.section--alt{padding:3.5rem 1.25rem}.cards{grid-template-columns:1fr}.footer{text-align:center;flex-direction:column}.hero-scroll-hint{display:none}}@media (width<=480px){.hero-name{letter-spacing:-2px}.hero-actions{flex-direction:column;width:100%}.btn-primary,.btn-outline{text-align:center;justify-content:center;width:100%}.social-pill{padding:.35rem .8rem;font-size:.8rem}}@keyframes pageIn{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.about-page{flex-direction:column;min-height:100svh;display:flex}.about-hero{background:var(--bg);padding:8rem 2rem 5rem;position:relative;overflow:hidden}.about-hero:before{content:"";background:radial-gradient(ellipse 70% 80% at 10% 50%, var(--accent-bg) 0%, transparent 70%);pointer-events:none;position:absolute;inset:0}.about-hero-inner{align-items:center;gap:3rem;max-width:900px;margin:0 auto;display:flex}.avatar{background:linear-gradient(135deg, var(--accent) 0%, #7c3aed 100%);color:#fff;letter-spacing:-1px;width:130px;height:130px;box-shadow:0 0 0 5px var(--bg), 0 0 0 7px var(--accent-border);-webkit-user-select:none;user-select:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:2.2rem;font-weight:800;display:flex}.about-hero-text{flex-direction:column;gap:.4rem;display:flex}.about-hero-title{letter-spacing:-2px;color:var(--text-h);margin:0;font-size:clamp(2rem,6vw,3.5rem);font-weight:800;line-height:1.05}.about-hero-sub{color:var(--text);margin:.2rem 0 .8rem;font-size:1rem}.about-hero-links{flex-wrap:wrap;gap:.75rem;display:flex}.icon-link{border:1px solid var(--border);color:var(--text);background:var(--bg);border-radius:8px;align-items:center;gap:.4rem;padding:.4rem .9rem;font-size:.85rem;font-weight:500;text-decoration:none;transition:border-color .15s,color .15s,transform .15s;display:inline-flex}.icon-link:hover{border-color:var(--accent-border);color:var(--accent);transform:translateY(-1px)}.about-story{background:var(--code-bg);padding:5rem 2rem}.about-story-inner{max-width:700px;margin:0 auto}.story-body{flex-direction:column;gap:1.25rem;display:flex}.story-body p{color:var(--text);font-size:1.05rem;line-height:1.8}.what-i-do{padding:5rem 2rem}.what-i-do-inner{max-width:900px;margin:0 auto}.pillars{grid-template-columns:repeat(3,1fr);gap:1.25rem;display:grid}.pillar{border:1px solid var(--border);background:var(--bg);border-radius:16px;flex-direction:column;gap:.75rem;padding:2rem 1.75rem;transition:box-shadow .2s,transform .2s,border-color .2s;display:flex}.pillar:hover{border-color:var(--accent-border);transform:translateY(-3px);box-shadow:0 12px 40px #00000014}.pillar-icon{font-size:2rem;line-height:1}.pillar-title{color:var(--text-h);letter-spacing:-.2px;margin:0;font-size:1.05rem;font-weight:700}.pillar-desc{color:var(--text);margin:0;font-size:.9rem;line-height:1.6}.interests-section{background:var(--code-bg);padding:5rem 2rem}.interests-inner{max-width:900px;margin:0 auto}.interest-chips{flex-wrap:wrap;gap:.75rem;display:flex}.interest-chip{border:1px solid var(--border);background:var(--bg);color:var(--text-h);cursor:default;border-radius:12px;align-items:center;gap:.5rem;padding:.6rem 1.2rem;font-size:.95rem;font-weight:500;transition:border-color .15s,transform .15s,box-shadow .15s;display:inline-flex}.interest-chip:hover{border-color:var(--accent-border);transform:translateY(-2px);box-shadow:0 4px 12px #00000012}.interest-emoji{font-size:1.1rem}.btn-primary{color:var(--accent);background:#fff;border-radius:10px;align-items:center;gap:.4rem;padding:.8rem 2rem;font-size:.95rem;font-weight:700;text-decoration:none;transition:opacity .15s,transform .15s;display:inline-flex}@media (width<=768px){.about-hero{padding:7rem 1.5rem 4rem}.about-hero-inner{flex-direction:column;align-items:flex-start;gap:1.75rem}.avatar{width:100px;height:100px;font-size:1.8rem}.about-hero-title{letter-spacing:-1.5px}.about-story,.what-i-do,.interests-section{padding:3.5rem 1.5rem}.pillars{grid-template-columns:1fr}.footer{text-align:center;flex-direction:column}}.projects-page{flex-direction:column;min-height:100svh;display:flex}.projects-hero{background:var(--bg);padding:8rem 2rem 5rem;position:relative;overflow:hidden}.projects-hero:before{content:"";background:radial-gradient(ellipse 80% 60% at 90% 50%, var(--accent-bg) 0%, transparent 70%);pointer-events:none;position:absolute;inset:0}.projects-hero-inner{max-width:900px;margin:0 auto}.projects-title{letter-spacing:-3px;color:var(--text-h);margin:0 0 1rem;font-size:clamp(3rem,10vw,5.5rem);font-weight:800;line-height:1}.projects-sub{color:var(--text);max-width:500px;margin:0 0 1.5rem;font-size:1.1rem;line-height:1.6}.project-count-badge{background:var(--accent-bg);color:var(--accent);border:1px solid var(--accent-border);letter-spacing:.3px;border-radius:20px;align-items:center;gap:.5rem;padding:.3rem .9rem;font-size:.8rem;font-weight:700;display:inline-flex}.filter-section{background:var(--bg);border-bottom:1px solid var(--border);padding:0 2rem 2rem}.filter-inner{max-width:900px;margin:0 auto}.filter-bar{flex-wrap:wrap;gap:.5rem;display:flex}.filter-btn{border:1px solid var(--border);color:var(--text);cursor:pointer;background:0 0;border-radius:20px;padding:.4rem 1rem;font-family:inherit;font-size:.85rem;font-weight:500;transition:border-color .15s,color .15s,background .15s}.filter-btn:hover{border-color:var(--accent-border);color:var(--accent)}.filter-btn--active{background:var(--accent);border-color:var(--accent);color:#fff!important}.project-list-section{background:var(--code-bg);padding:3rem 2rem}.project-list-inner{flex-direction:column;gap:1.5rem;max-width:900px;margin:0 auto;display:flex}.project-card{background:var(--bg);border:1px solid var(--border);border-radius:20px;grid-template-columns:1fr 200px;align-items:center;gap:2rem;padding:2.5rem;transition:box-shadow .2s,transform .2s,border-color .2s;display:grid}.project-card:hover{border-color:var(--accent-border);transform:translateY(-3px);box-shadow:0 16px 50px #0000001a}.project-card--featured{border-color:var(--accent-border);background:linear-gradient(135deg, var(--bg) 80%, var(--accent-bg))}.project-card-left{align-items:flex-start;gap:1.5rem;display:flex}.project-emoji{flex-shrink:0;margin-top:.2rem;font-size:2.5rem;line-height:1}.project-meta{flex-direction:column;gap:.6rem;display:flex}.project-highlight{letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);font-size:.72rem;font-weight:700}.project-title{color:var(--text-h);letter-spacing:-.5px;margin:0;font-size:1.5rem;font-weight:800;line-height:1.1}.project-tagline{color:var(--text);margin:0;font-size:.95rem;font-weight:500}.project-desc{color:var(--text);max-width:520px;margin:0;font-size:.9rem;line-height:1.65}.project-tags{flex-wrap:wrap;gap:.4rem;display:flex}.proj-tag{background:var(--accent-bg);color:var(--accent);cursor:pointer;border:none;border-radius:6px;padding:.2rem .65rem;font-family:inherit;font-size:.75rem;font-weight:600;transition:background .15s,transform .1s}.proj-tag:hover{transform:translateY(-1px)}.proj-tag--active{background:var(--accent);color:#fff}.project-cta{background:var(--accent);color:#fff;border-radius:10px;align-items:center;gap:.5rem;width:fit-content;padding:.65rem 1.4rem;font-size:.9rem;font-weight:600;text-decoration:none;transition:opacity .15s,transform .15s;display:inline-flex}.project-cta:hover{opacity:.87;transform:translateY(-1px)}.project-card-right{justify-content:center;align-items:center;display:flex}.project-preview{background:var(--accent-bg);border:1px solid var(--accent-border);border-radius:20px;justify-content:center;align-items:center;width:160px;height:160px;display:flex}.preview-emoji{filter:drop-shadow(0 4px 12px #00000026);font-size:5rem;line-height:1}.more-section{background:var(--code-bg);border-top:1px solid var(--border);padding:2rem}.more-inner{max-width:900px;margin:0 auto}.more-card{border:2px dashed var(--border);text-align:center;border-radius:16px;flex-direction:column;align-items:center;gap:.6rem;padding:2.5rem;display:flex}.more-icon{font-size:2rem}.more-card h3{color:var(--text-h);margin:0;font-size:1.1rem;font-weight:700}.more-card p{color:var(--text);max-width:380px;font-size:.9rem;line-height:1.6}.more-link{color:var(--accent);margin-top:.25rem;font-size:.9rem;font-weight:600;text-decoration:none;transition:opacity .15s}.more-link:hover{opacity:.7}.no-results{color:var(--text);text-align:center;padding:3rem 0;font-size:1rem}@media (width<=768px){.projects-hero{padding:7rem 1.5rem 4rem}.filter-section{padding:0 1.5rem 2rem}.project-list-section,.more-section{padding:2rem 1.5rem}.project-card{grid-template-columns:1fr;padding:1.75rem}.project-card-right{display:none}.project-card-left{flex-direction:column;gap:1rem}.footer{text-align:center;flex-direction:column}}.page-enter{animation:.4s ease-out both pageIn}.page-label{letter-spacing:1.8px;text-transform:uppercase;color:var(--accent);margin-bottom:.55rem;font-size:.72rem;font-weight:700}.section-h2{letter-spacing:-1px;color:var(--text-h);margin:0 0 2.25rem;font-size:clamp(1.7rem,4vw,2.4rem);font-weight:800;line-height:1.1}.skills-page{flex-direction:column;min-height:100svh;display:flex}.skills-hero{background:var(--bg);padding:8rem 2rem 5rem;position:relative;overflow:hidden}.skills-hero:before{content:"";background:radial-gradient(ellipse 80% 60% at 50% 0%, var(--accent-bg) 0%, transparent 65%);pointer-events:none;position:absolute;inset:0}.skills-hero-inner{text-align:center;max-width:900px;margin:0 auto}.skills-title{letter-spacing:-3px;color:var(--text-h);background:linear-gradient(135deg, var(--text-h) 50%, var(--accent));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0 0 1rem;font-size:clamp(2.5rem,8vw,5rem);font-weight:800;line-height:1}.skills-sub{color:var(--text);margin:0;font-size:1.1rem;line-height:1.6}.categories-section{background:var(--code-bg);padding:5rem 2rem}.categories-inner{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.5rem;max-width:900px;margin:0 auto;display:grid}.category-card{background:var(--bg);border:1px solid var(--border);border-radius:16px;flex-direction:column;gap:1.5rem;padding:2rem;transition:box-shadow .2s,transform .2s;display:flex}.category-card:hover{transform:translateY(-2px);box-shadow:0 12px 40px #00000014}.cat-header{align-items:center;gap:.75rem;display:flex}.cat-icon{font-size:1.5rem;line-height:1}.cat-title{color:var(--text-h);letter-spacing:-.2px;margin:0;font-size:1.05rem;font-weight:700}.skill-bars{flex-direction:column;gap:1.1rem;display:flex}.skill-row{flex-direction:column;gap:.35rem;display:flex}.skill-meta{justify-content:space-between;align-items:center;display:flex}.skill-name{color:var(--text-h);font-size:.875rem;font-weight:600}.skill-pct{color:var(--text);font-variant-numeric:tabular-nums;font-size:.8rem;font-weight:500}.bar-track{background:var(--border);border-radius:8px;height:8px;overflow:hidden}.bar-fill{background:var(--bar-color,var(--accent));width:0;height:100%;animation:1.1s cubic-bezier(.4,0,.2,1) forwards fillBar;animation-delay:var(--delay,0s);border-radius:8px}@keyframes fillBar{to{width:var(--pct)}}.tech-cloud-section{padding:5rem 2rem}.tech-cloud-inner{max-width:900px;margin:0 auto}.tech-cloud{flex-wrap:wrap;gap:.65rem;display:flex}.tech-chip{color:var(--chip-color);background:var(--chip-bg);cursor:default;border-radius:10px;align-items:center;padding:.5rem 1.1rem;font-size:.875rem;font-weight:700;transition:transform .15s,box-shadow .15s;display:inline-flex}.tech-chip:hover{transform:translateY(-2px);box-shadow:0 4px 14px #0000001a}.page-cta-strip{background:var(--accent);text-align:center;flex-direction:column;align-items:center;gap:1.75rem;padding:5rem 2rem;display:flex}.page-cta-strip h2{letter-spacing:-1px;color:#fff;margin:0;font-size:clamp(1.6rem,5vw,2.5rem);font-weight:800}.page-cta-actions{flex-wrap:wrap;justify-content:center;gap:.85rem;display:flex}.btn-primary{color:var(--accent);background:#fff;border-radius:10px;padding:.8rem 2rem;font-size:.95rem;font-weight:700;text-decoration:none;transition:opacity .15s,transform .15s}.btn-primary:hover{opacity:.9;transform:translateY(-1px)}.btn-ghost{color:#fff;border:2px solid #ffffff80;border-radius:10px;padding:.8rem 2rem;font-size:.95rem;font-weight:600;text-decoration:none;transition:border-color .15s,transform .15s}.btn-ghost:hover{border-color:#fff;transform:translateY(-1px)}.footer{border-top:1px solid var(--border);color:var(--text);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;padding:2rem;font-size:.85rem;display:flex}.footer-logo{color:var(--text-h);letter-spacing:-.3px;font-weight:700}.footer-links{gap:1.25rem;display:flex}.footer-links a{color:var(--text);text-decoration:none;transition:color .15s}.footer-links a:hover{color:var(--accent)}@media (width<=768px){.skills-hero{padding:7rem 1.5rem 4rem}.categories-section,.tech-cloud-section{padding:3.5rem 1.5rem}.categories-inner{grid-template-columns:1fr}.footer{text-align:center;flex-direction:column}}.ttt-page{min-height:100svh;font-family:var(--sans);background:var(--bg);justify-content:center;align-items:center;padding:2rem;display:flex}.ttt-container{flex-direction:column;align-items:center;gap:1.25rem;width:100%;max-width:420px;display:flex}.back-link{color:var(--text);align-self:flex-start;font-size:.9rem;text-decoration:none;transition:color .15s}.back-link:hover{color:var(--accent)}.ttt-title{letter-spacing:-1px;color:var(--text-h);margin:0;font-size:2.2rem;font-weight:700}.ttt-subtitle{color:var(--text);margin:0;font-size:.9rem}.scoreboard{border:1px solid var(--border);box-sizing:border-box;border-radius:10px;justify-content:space-around;gap:1.5rem;width:100%;padding:.9rem 1.5rem;display:flex}.score-item{flex-direction:column;align-items:center;gap:.2rem;display:flex}.score-label{color:var(--text);text-transform:uppercase;letter-spacing:.5px;font-size:.75rem}.score-value{font-size:1.8rem;font-weight:700;font-family:var(--mono);line-height:1}.wins{color:#22c55e}.losses{color:#ef4444}.draws{color:var(--text)}.status{color:var(--text);min-height:1.5rem;font-size:1rem;font-weight:500;transition:color .2s}.status-over{color:var(--accent);font-size:1.1rem}.board{aspect-ratio:1;grid-template-columns:repeat(3,1fr);gap:8px;width:100%;display:grid}.cell{background:var(--code-bg);border:1px solid var(--border);cursor:pointer;aspect-ratio:1;border-radius:10px;justify-content:center;align-items:center;padding:0;font-size:clamp(2rem,8vw,3rem);font-weight:700;transition:background .15s,border-color .15s,transform .1s;display:flex}.cell-hover:hover{background:var(--accent-bg);border-color:var(--accent-border)}.cell-filled{cursor:default}.cell-win{background:var(--accent-bg)!important;border-color:var(--accent)!important}.mark-x{color:var(--accent);animation:.15s pop}.mark-o{color:#f97316;animation:.15s pop}@keyframes pop{0%{opacity:0;transform:scale(.4)}to{opacity:1;transform:scale(1)}}.reset-btn{background:var(--accent);color:#fff;cursor:pointer;font-size:.95rem;font-weight:500;font-family:var(--sans);border:none;border-radius:8px;padding:.65rem 2rem;transition:opacity .15s}.reset-btn:hover{opacity:.85}@media (width<=480px){.ttt-page{align-items:flex-start;padding:2rem 1rem 1.5rem}}.mtg-page{color:#e2e2e9;min-height:100svh;font-family:var(--sans);background:#0f0f13;flex-direction:column;display:flex}.mtg-header{border-bottom:1px solid #2a2a35;align-items:center;gap:1.5rem;padding:1.25rem 2rem;display:flex}.mtg-back{color:#888;white-space:nowrap;flex-shrink:0;font-size:.875rem;text-decoration:none;transition:color .15s}.mtg-back:hover{color:#e2e2e9}.mtg-header-text h1{color:#f0f0f5;letter-spacing:-.3px;-webkit-text-fill-color:unset;background:0 0;margin:0;font-size:1.25rem;font-weight:600}.mtg-header-text p{color:#666;margin:.15rem 0 0;font-size:.8rem}.mtg-main{box-sizing:border-box;flex:1;width:100%;max-width:1100px;margin:0 auto;padding:2.5rem 2rem}.mtg-error{color:#fca5a5;background:#ef44441f;border:1px solid #ef444459;border-radius:8px;margin-bottom:1.5rem;padding:.8rem 1.2rem;font-size:.875rem}.choose-prompt{color:#888;text-align:center;margin:0 0 1.5rem;font-size:1rem}.set-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem;display:grid}.set-card{background:var(--bg);text-align:left;cursor:pointer;border:1px solid #ffffff0f;border-radius:14px;flex-direction:column;gap:.6rem;padding:1.75rem;transition:transform .2s,border-color .2s,box-shadow .2s;display:flex;position:relative;overflow:hidden}.set-card:before{content:"";background:var(--bg);opacity:.9;z-index:0;position:absolute;inset:0}.set-card>*{z-index:1;position:relative}.set-card:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:0 8px 32px #00000080}.set-card-sub{color:#888;text-transform:uppercase;letter-spacing:.5px;font-size:.75rem;font-family:var(--mono)}.set-card-name{color:#f0f0f5;letter-spacing:-.5px;-webkit-text-fill-color:unset;background:0 0;margin:0;font-size:1.3rem;font-weight:700}.set-card-desc{color:#999;flex:1;font-size:.85rem;line-height:1.5}.set-card-stats{color:#666;font-size:.75rem;font-family:var(--mono);border-top:1px solid #ffffff0f;margin-top:.25rem;padding-top:.5rem}.set-card-cta{letter-spacing:.2px;margin-top:.25rem;font-size:.85rem;font-weight:600}.mtg-loading{color:#888;flex-direction:column;justify-content:center;align-items:center;gap:1rem;font-size:.95rem;display:flex}.spinner{border:3px solid #2a2a35;border-top-color:#8b5cf6;border-radius:50%;width:40px;height:40px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-sub{color:#555;font-size:.8rem}.pack-meta{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.pack-meta-left h2{color:#f0f0f5;letter-spacing:-.4px;-webkit-text-fill-color:unset;background:0 0;margin:0;font-size:1.4rem;font-weight:700}.pack-meta-sub{color:#666;font-size:.8rem;font-family:var(--mono)}.pack-value{flex-direction:column;align-items:flex-end;gap:.1rem;display:flex}.pack-value-label{color:#666;text-transform:uppercase;letter-spacing:.5px;font-size:.7rem}.pack-value-amount{color:var(--accent);font-size:1.8rem;font-weight:700;font-family:var(--mono);letter-spacing:-1px;line-height:1}.cards-grid{grid-template-columns:repeat(5,1fr);gap:10px;margin-bottom:1.5rem;display:grid}.card-slot{aspect-ratio:5/7;opacity:0;cursor:pointer;border:2px solid #0000;border-radius:8px;text-decoration:none;transition:opacity .35s,transform .35s,box-shadow .2s;display:block;position:relative;overflow:hidden;transform:scale(.85)translateY(12px)}.card-slot.revealed{opacity:1;transform:scale(1)translateY(0)}.card-slot:hover{z-index:5;box-shadow:0 12px 40px #000000b3;transform:scale(1.05)translateY(-4px)!important}.card-slot img{object-fit:cover;border-radius:6px;width:100%;height:100%;display:block}.card-slot.rarity-mythic{border-color:#f97316}.card-slot.rarity-rare{border-color:#f59e0b}.card-slot.rarity-uncommon{border-color:#cbd5e1}.card-slot.rarity-common{border-color:#4b5563}.card-slot.foil img{position:relative}.card-slot.foil:after{content:"";pointer-events:none;background:linear-gradient(115deg,#0000 30%,#ffffff2e 50%,#0000 70%) 0 0/200% 200%;border-radius:6px;animation:2.5s linear infinite foil-shimmer;position:absolute;inset:0}@keyframes foil-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.card-badges{opacity:0;background:linear-gradient(#0000,#000000bf 60%);border-radius:0 0 6px 6px;justify-content:space-between;align-items:flex-end;padding:.3rem .4rem;transition:opacity .2s;display:flex;position:absolute;bottom:0;left:0;right:0}.card-slot:hover .card-badges{opacity:1}.badge-foil{background:linear-gradient(90deg,#a78bfa,#f9a8d4,#67e8f9,#a78bfa) 0 0/200%;-webkit-text-fill-color:transparent;letter-spacing:.3px;-webkit-background-clip:text;background-clip:text;font-size:.6rem;font-weight:700;animation:2s linear infinite foil-text}@keyframes foil-text{0%{background-position:0%}to{background-position:200%}}.badge-price{color:#fff;font-size:.7rem;font-family:var(--mono);text-shadow:0 1px 3px #000c;font-weight:600}.pack-actions{flex-wrap:wrap;gap:.75rem;margin-bottom:2rem;display:flex}.btn-another{color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;font-family:var(--sans);border:none;border-radius:8px;padding:.65rem 1.5rem;transition:opacity .15s,transform .1s}.btn-another:hover{opacity:.88;transform:translateY(-1px)}.btn-change{color:#888;cursor:pointer;font-size:.95rem;font-family:var(--sans);background:0 0;border:1px solid #2a2a35;border-radius:8px;padding:.65rem 1.5rem;transition:border-color .15s,color .15s}.btn-change:hover{color:#ccc;border-color:#555}.rarity-breakdown{border:1px solid #2a2a35;border-radius:10px;flex-direction:column;gap:.5rem;padding:1.25rem 1.5rem;display:flex}.rarity-breakdown h3{text-transform:uppercase;letter-spacing:.5px;color:#555;-webkit-text-fill-color:unset;background:0 0;margin:0 0 .5rem;font-size:.8rem;font-weight:500}.rarity-row{align-items:baseline;gap:.75rem;font-size:.85rem;display:flex}.rarity-label{font-family:var(--mono);text-transform:uppercase;letter-spacing:.5px;flex-shrink:0;width:70px;font-size:.7rem;font-weight:600}.rarity-label.rarity-mythic{color:#f97316}.rarity-label.rarity-rare{color:#f59e0b}.rarity-label.rarity-uncommon{color:#cbd5e1}.rarity-label.rarity-common{color:#6b7280}.rarity-names{color:#888;flex-wrap:wrap;flex:1;gap:.35rem;line-height:1.5;display:flex}.rarity-names span:after{content:"·";color:#444;margin-left:.35rem}.rarity-names span:last-child:after{content:""}.foil-name{background:linear-gradient(90deg,#a78bfa,#f9a8d4,#67e8f9);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.rarity-subtotal{font-family:var(--mono);color:#aaa;white-space:nowrap;font-size:.8rem}.session-stats{color:#555;font-size:.78rem;font-family:var(--mono);border-top:1px solid #2a2a35;margin-top:.75rem;padding-top:.75rem}@media (width<=768px){.mtg-main{padding:1.5rem 1rem}.cards-grid{grid-template-columns:repeat(4,1fr);gap:6px}.pack-value-amount{font-size:1.4rem}}@media (width<=500px){.mtg-header{flex-direction:column;align-items:flex-start;gap:.5rem;padding:1rem}.cards-grid{grid-template-columns:repeat(3,1fr)}.rarity-row{flex-wrap:wrap}.rarity-subtotal{text-align:right;width:100%}}
