:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--forest:#1a3d34;--forest-soft:#2d5c4e;--sunset:#e07a3a;--sunset-deep:#c45d28;--sky-dusk:#7eb8c9;--page-bg:#eef4f0;--card-bg:#fffffff0;--card-border:#1a3d341f;--text:#1a2e24;--text-muted:#3d5348;--shadow-soft:0 18px 40px #1a2d261f;--radius-lg:20px;--radius-md:14px;--radius-pill:999px;--font-display:"Fraunces", "Georgia", serif;--font-body:"DM Sans", system-ui, -apple-system, sans-serif}*,:before,:after{box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:var(--font-body);color:var(--text);background:var(--page-bg);margin:0;font-size:1.05rem;line-height:1.55}body:has(.skill-modal[open]){overflow:hidden}.hero{justify-content:center;align-items:center;min-height:100dvh;padding:clamp(1.5rem,4vw,3rem);display:flex;position:relative;overflow:hidden}.hero__media{background-image:-webkit-image-set(url(/ghibli-hero.webp) 1x type("image/webp"),url(/ghibli-hero.png) 1x type("image/png"));background-image:image-set("/ghibli-hero.webp" 1x type("image/webp"),"/ghibli-hero.png" 1x type("image/png"));background-position:50% 35%;background-size:cover;position:absolute;inset:0}.hero__scrim{pointer-events:none;background:linear-gradient(165deg,#0c1c188c 0%,#0c1c1840 38%,#0c1c1859 100%);position:absolute;inset:0}.hero__inner{z-index:1;text-align:center;width:100%;max-width:44rem;margin-left:auto;margin-right:auto;position:relative}.hero__title{font-family:var(--font-display);letter-spacing:-.02em;color:#fffef8;text-shadow:0 2px 24px #00000059,0 1px 3px #00000073;margin:0 0 .85rem;font-size:clamp(2.75rem,8vw,4.25rem);font-weight:700;line-height:1.05}.hero__tagline{color:#fffaf2f2;text-shadow:0 1px 12px #00000059;max-width:38rem;margin:0 auto 1.75rem;font-size:clamp(1rem,2.2vw,1.15rem)}.hero__tagline-link{color:#fffef8;text-underline-offset:.15em;text-shadow:0 1px 12px #00000059;font-weight:600;text-decoration:underline;text-decoration-thickness:.08em}.hero__tagline-link:hover{color:#fff;text-decoration-thickness:.12em}.hero__tagline-link:focus-visible{outline-offset:3px;border-radius:2px;outline:2px solid #fff}.install{border-radius:var(--radius-md);-webkit-backdrop-filter:blur(10px);text-align:center;background:#0a181473;border:1px solid #fff3;width:fit-content;max-width:calc(100% - 2rem);margin:0 auto;padding:1.1rem 1.25rem 1.25rem;box-shadow:0 12px 32px #0003}.install__code-bar{text-align:left;background:#00000059;border:1px solid #ffffff26;border-radius:10px;align-items:stretch;gap:0;max-width:100%;display:flex;overflow:hidden}.install__code{white-space:nowrap;word-break:normal;-webkit-overflow-scrolling:touch;color:#fff8ee;background:0 0;border:none;flex:0 auto;min-width:0;margin:0;padding:.65rem .75rem .65rem .85rem;font-family:ui-monospace,Cascadia Code,SF Mono,Menlo,monospace;font-size:clamp(.72rem,1.6vw,.88rem);display:block;overflow:auto hidden}.install__copy-icon{color:#fffaf2f2;cursor:pointer;background:#ffffff14;border:none;border-left:1px solid #ffffff1f;flex-shrink:0;place-items:center;width:2.75rem;padding:0;transition:background .12s,color .12s;display:grid}.install__icon{grid-area:1/1;transition:opacity .22s,transform .22s;display:block}.install__icon--check{opacity:0;pointer-events:none;transform:scale(.6)}.install__copy-icon.is-copied .install__icon--copy{opacity:0;pointer-events:none;transform:scale(.88)}.install__copy-icon.is-copied .install__icon--check{opacity:1;transform:scale(1)}.install__copy-icon:hover{color:#fff;background:#ffffff29}.install__copy-icon:focus-visible{outline-offset:-2px;outline:2px solid #fff}.install__copy-icon.is-copied{color:#e8faf0;background:#e07a3a59}.skills{max-width:72rem;margin:0 auto;padding:clamp(2.5rem,6vw,4.5rem) clamp(1.25rem,4vw,2.5rem) clamp(3rem,8vw,5rem)}.skills__intro h2{font-family:var(--font-display);color:var(--forest);margin:0 0 .5rem;font-size:clamp(1.75rem,4vw,2.35rem)}.skills__intro p{max-width:48rem;color:var(--text-muted);margin:0 0 2rem}.card-grid{grid-template-columns:repeat(auto-fill,minmax(min(100%,20rem),1fr));gap:1.25rem;margin:0;padding:0;list-style:none;display:grid}.card-li{margin:0;padding:0;list-style:none}.card{text-align:left;width:100%;height:100%;font:inherit;color:inherit;cursor:pointer;background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);flex-direction:column;align-items:stretch;gap:.65rem;margin:0;padding:1.35rem 1.4rem 1.45rem;transition:transform .2s,box-shadow .2s;display:flex}.card:hover{transform:translateY(-3px);box-shadow:0 22px 48px #1a2d2624}.card:focus-visible{outline:3px solid var(--sunset);outline-offset:2px}.card__title{font-family:var(--font-display);color:var(--forest);margin:0;font-size:1.25rem}.card__id{margin:0}.card__id code{color:var(--forest-soft);background:#7eb8c933;border-radius:6px;padding:.2rem .45rem;font-size:.78rem}.card__desc{color:var(--text-muted);margin:0;font-size:.98rem}.card__desc code{color:var(--sunset-deep);background:#e07a3a1f;border-radius:4px;padding:.05rem .3rem;font-size:.88em}.skill-modal{border-radius:var(--radius-lg);background:var(--card-bg);width:min(56rem,100vw - 2rem);max-height:calc(100dvh - 2rem);color:var(--text);border:none;margin:auto;padding:0;box-shadow:0 28px 80px #00000059}.skill-modal::backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0c1c188c}.skill-modal__shell{max-height:inherit;flex-direction:column;display:flex}.skill-modal__header{border-bottom:1px solid var(--card-border);flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:center;gap:.75rem;padding:1rem 1.15rem 1rem 1.35rem;display:flex}.skill-modal__title{font-family:var(--font-display);color:var(--forest);margin:0;font-size:1.2rem}.skill-modal__actions{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.skill-modal__contribute{border-radius:var(--radius-pill);border:1px solid var(--sunset);color:var(--sunset-deep);font-family:var(--font-body);cursor:pointer;background:#e07a3a24;justify-content:center;align-items:center;padding:.45rem .85rem;font-size:.88rem;font-weight:600;text-decoration:none;transition:background .15s,border-color .15s;display:inline-flex}.skill-modal__contribute:hover{border-color:var(--sunset-deep);color:var(--forest);background:#e07a3a3d}.skill-modal__contribute:focus-visible{outline:2px solid var(--sunset);outline-offset:2px}.skill-modal__copy{border-radius:var(--radius-pill);border:1px solid var(--card-border);background:var(--page-bg);color:var(--forest-soft);font-family:var(--font-body);cursor:pointer;align-items:center;gap:.4rem;padding:.45rem .85rem;font-size:.88rem;font-weight:600;transition:background .15s,border-color .15s;display:inline-flex}.skill-modal__copy:hover{background:#e4eee8;border-color:#1a3d3433}.skill-modal__copy:focus-visible{outline:2px solid var(--sunset);outline-offset:2px}.skill-modal__copy-label{line-height:1}.skill-modal__close{border-radius:var(--radius-pill);background:var(--forest);color:#fff;cursor:pointer;border:none;flex-shrink:0;justify-content:center;align-items:center;width:2.4rem;height:2.4rem;padding:0;display:inline-flex}.skill-modal__close-icon{display:block}.skill-modal__close:hover{background:var(--forest-soft)}.skill-modal__close:focus-visible{outline:2px solid var(--sunset);outline-offset:2px}.skill-modal__body-wrap{flex:1;min-height:0;padding:1rem 1.25rem 1.25rem;overflow:auto}.skill-modal__md{font-family:var(--font-body);color:var(--text);overflow-wrap:anywhere;font-size:.95rem;line-height:1.6}.skill-modal__md--loading{color:var(--text-muted);font-style:italic}.skill-modal__md--error{white-space:pre-wrap;color:var(--text-muted);font-family:ui-monospace,Cascadia Code,SF Mono,Menlo,monospace;font-size:.85rem;line-height:1.55}.skill-modal__md>:first-child{margin-top:0}.skill-modal__md>:last-child{margin-bottom:0}.skill-modal__md h1,.skill-modal__md h2,.skill-modal__md h3,.skill-modal__md h4{font-family:var(--font-display);color:var(--forest);margin:1.35rem 0 .5rem;font-weight:700;line-height:1.25}.skill-modal__md h1{font-size:1.45rem}.skill-modal__md h2{border-bottom:1px solid var(--card-border);padding-bottom:.25rem;font-size:1.2rem}.skill-modal__md h3{font-size:1.05rem}.skill-modal__md h4{font-size:1rem;font-weight:600}.skill-modal__md p{margin:.65rem 0}.skill-modal__md a{color:var(--sunset-deep);text-underline-offset:2px;font-weight:600;text-decoration:underline}.skill-modal__md a:hover{color:var(--forest)}.skill-modal__md ul,.skill-modal__md ol{margin:.65rem 0;padding-left:1.35rem}.skill-modal__md li{margin:.25rem 0}.skill-modal__md li>p{margin:.35rem 0}.skill-modal__md blockquote{border-radius:0 var(--radius-md) var(--radius-md) 0;color:var(--text-muted);background:#e07a3a14;border-left:4px solid #e07a3a8c;margin:.75rem 0;padding:.5rem .85rem}.skill-modal__md blockquote p{margin:.35rem 0}.skill-modal__md hr{border:none;border-top:1px solid var(--card-border);margin:1.25rem 0}.skill-modal__md :not(pre)>code{color:var(--forest-soft);background:#1a3d3414;border-radius:5px;padding:.12rem .38rem;font-family:ui-monospace,Cascadia Code,SF Mono,Menlo,monospace;font-size:.86em}.skill-modal__md pre{border-radius:var(--radius-md);border:1px solid var(--card-border);background:#1a2d260f;margin:.75rem 0;padding:.85rem 1rem;font-family:ui-monospace,Cascadia Code,SF Mono,Menlo,monospace;font-size:.82rem;line-height:1.5;overflow-x:auto}.skill-modal__md pre code{font-size:inherit;color:var(--text);background:0 0;border-radius:0;padding:0}.skill-modal__md table{border-collapse:collapse;width:100%;margin:.85rem 0;font-size:.88rem}.skill-modal__md th,.skill-modal__md td{border:1px solid var(--card-border);text-align:left;vertical-align:top;padding:.45rem .6rem}.skill-modal__md th{color:var(--forest);background:#1a3d3412;font-weight:600}.skill-modal__md img{border-radius:var(--radius-md);max-width:100%;height:auto}.skill-modal__copy:disabled{opacity:.5;cursor:not-allowed}.site-footer{text-align:center;background:linear-gradient(#0000,#1a3d340f);padding:2rem 1.25rem 2.75rem}.site-footer__link{color:var(--forest-soft);border-bottom:2px solid #e07a3a73;align-items:center;gap:.65rem;padding-bottom:4px;font-weight:600;text-decoration:none;transition:color .15s;display:inline-flex}.site-footer__link:hover{color:var(--sunset-deep)}.site-footer__github-icon{flex-shrink:0;display:block}.site-footer__label{font-size:.95rem}@media (width<=520px){.skill-modal__header{flex-direction:column;align-items:stretch}.skill-modal__actions{justify-content:stretch}.skill-modal__contribute,.skill-modal__copy{flex:1;justify-content:center}.skill-modal__copy{justify-content:center}.skill-modal__close{flex:none;margin-inline:auto}}
