#article-content{font-size:1.0625rem;line-height:1.85;letter-spacing:.03em;word-spacing:.05em;color:var(--color-base-content);max-width:100%;overflow-wrap:break-word;word-break:break-word;text-align:justify;text-justify:inter-ideograph;hanging-punctuation:allow-end;min-width:0;--art-radius: 1rem;--art-radius-sm: .5rem;--art-radius-lg: 1.25rem;--art-shadow-sm: 0 2px 8px -2px color-mix(in srgb, var(--color-base-content) 6%, transparent);--art-shadow: 0 4px 20px -4px color-mix(in srgb, var(--color-base-content) 10%, transparent);--art-shadow-lg: 0 8px 30px -6px color-mix(in srgb, var(--color-base-content) 12%, transparent);--art-shadow-hover: 0 12px 40px -8px color-mix(in srgb, var(--color-base-content) 15%, transparent);--art-border: 1px solid color-mix(in srgb, var(--color-base-content) 6%, transparent);--art-transition: all .25s cubic-bezier(.4, 0, .2, 1);--art-accent-subtle: color-mix(in srgb, var(--color-primary) 8%, transparent);--art-accent-light: color-mix(in srgb, var(--color-primary) 20%, transparent);--art-accent-medium: color-mix(in srgb, var(--color-primary) 40%, transparent);--art-gap-xs: .5em;--art-gap-sm: .75em;--art-gap-md: 1.25em;--art-gap-lg: 1.75em;--art-gap-xl: 2.5em}#article-content *{max-width:100%}#article-content h1,#article-content h2,#article-content h3,#article-content h4,#article-content h5,#article-content h6{display:block;width:-moz-fit-content;width:fit-content;max-width:100%;margin-top:var(--art-gap-xl);margin-bottom:var(--art-gap-md);font-weight:700;line-height:1.4;letter-spacing:.01em;color:var(--color-base-content);position:relative;text-align:left;transition:all .3s ease}#article-content h1+h2,#article-content h2+h3,#article-content h3+h4,#article-content h4+h5,#article-content h5+h6{margin-top:var(--art-gap-lg)}#article-content h1+p,#article-content h2+p,#article-content h3+p{margin-top:0}#article-content h1{font-size:1.875rem;font-weight:800;margin-top:0;margin-bottom:1.5em;padding:.15em .4em .15em .35em;background:linear-gradient(180deg,transparent 40%,color-mix(in srgb,var(--color-primary) 25%,transparent) 45%,color-mix(in srgb,var(--color-primary) 40%,transparent) 55%,color-mix(in srgb,var(--color-primary) 35%,transparent) 85%,transparent 95%);border-radius:4px 12px 4px 8px}#article-content h2{font-size:1.5rem;font-weight:700;padding:.12em .35em .12em .3em;background:linear-gradient(180deg,transparent 45%,color-mix(in srgb,var(--color-secondary) 22%,transparent) 50%,color-mix(in srgb,var(--color-secondary) 38%,transparent) 60%,color-mix(in srgb,var(--color-secondary) 30%,transparent) 88%,transparent 96%);border-radius:3px 10px 3px 6px}#article-content h3{font-size:1.25rem;font-weight:700;padding:.1em .3em .1em .25em;background:linear-gradient(180deg,transparent 50%,color-mix(in srgb,var(--color-accent) 18%,transparent) 55%,color-mix(in srgb,var(--color-accent) 35%,transparent) 65%,color-mix(in srgb,var(--color-accent) 25%,transparent) 90%,transparent 97%);border-radius:2px 8px 2px 5px}#article-content h4{font-size:1.125rem;font-weight:600;padding:.08em .25em .08em .2em;background:linear-gradient(180deg,transparent 55%,color-mix(in srgb,var(--color-info) 15%,transparent) 60%,color-mix(in srgb,var(--color-info) 30%,transparent) 70%,color-mix(in srgb,var(--color-info) 22%,transparent) 92%,transparent 98%);border-radius:2px 6px 2px 4px}#article-content h5{font-size:1rem;font-weight:600;padding:.06em .2em .06em .15em;background:linear-gradient(180deg,transparent 58%,color-mix(in srgb,var(--color-success) 12%,transparent) 62%,color-mix(in srgb,var(--color-success) 25%,transparent) 72%,color-mix(in srgb,var(--color-success) 18%,transparent) 94%,transparent 99%);border-radius:2px 5px 2px 3px}#article-content h6{font-size:.9375rem;font-weight:600;padding:.05em .18em .05em .12em;background:linear-gradient(180deg,transparent 60%,color-mix(in srgb,var(--color-neutral) 10%,transparent) 65%,color-mix(in srgb,var(--color-neutral) 22%,transparent) 75%,color-mix(in srgb,var(--color-neutral) 15%,transparent) 95%,transparent 100%);border-radius:1px 4px 1px 2px}#article-content h1:hover,#article-content h2:hover,#article-content h3:hover{filter:brightness(.98);transform:translate(2px)}[data-color-scheme=dark] #article-content h1{background:linear-gradient(180deg,transparent 40%,color-mix(in srgb,var(--color-primary) 35%,transparent) 45%,color-mix(in srgb,var(--color-primary) 55%,transparent) 55%,color-mix(in srgb,var(--color-primary) 45%,transparent) 85%,transparent 95%)}[data-color-scheme=dark] #article-content h2{background:linear-gradient(180deg,transparent 45%,color-mix(in srgb,var(--color-secondary) 32%,transparent) 50%,color-mix(in srgb,var(--color-secondary) 52%,transparent) 60%,color-mix(in srgb,var(--color-secondary) 42%,transparent) 88%,transparent 96%)}[data-color-scheme=dark] #article-content h3{background:linear-gradient(180deg,transparent 50%,color-mix(in srgb,var(--color-accent) 28%,transparent) 55%,color-mix(in srgb,var(--color-accent) 48%,transparent) 65%,color-mix(in srgb,var(--color-accent) 38%,transparent) 90%,transparent 97%)}[data-color-scheme=dark] #article-content h4{background:linear-gradient(180deg,transparent 55%,color-mix(in srgb,var(--color-info) 25%,transparent) 60%,color-mix(in srgb,var(--color-info) 42%,transparent) 70%,color-mix(in srgb,var(--color-info) 32%,transparent) 92%,transparent 98%)}[data-color-scheme=dark] #article-content h5{background:linear-gradient(180deg,transparent 58%,color-mix(in srgb,var(--color-success) 22%,transparent) 62%,color-mix(in srgb,var(--color-success) 38%,transparent) 72%,color-mix(in srgb,var(--color-success) 28%,transparent) 94%,transparent 99%)}[data-color-scheme=dark] #article-content h6{background:linear-gradient(180deg,transparent 60%,color-mix(in srgb,var(--color-neutral) 18%,transparent) 65%,color-mix(in srgb,var(--color-neutral) 32%,transparent) 75%,color-mix(in srgb,var(--color-neutral) 24%,transparent) 95%,transparent 100%)}#article-content p{margin-top:0;margin-bottom:var(--art-gap-md)}#article-content p+p{margin-top:var(--art-gap-sm)}#article-content a{color:var(--color-primary);text-decoration:underline;text-decoration-color:color-mix(in srgb,var(--color-primary) 40%,transparent);text-underline-offset:2px;text-decoration-thickness:1px;transition:var(--art-transition)}#article-content a:hover{text-decoration-color:var(--color-primary)}#article-content strong{font-weight:700;color:var(--color-base-content)}#article-content em{font-style:italic}#article-content u{text-decoration:underline;text-decoration-color:var(--color-primary);text-underline-offset:3px}#article-content del,#article-content s{text-decoration:line-through;opacity:.65}#article-content mark{background:linear-gradient(transparent 55%,color-mix(in srgb,var(--color-primary) 25%,transparent) 55%);padding:.05em .15em;border-radius:3px;color:inherit}#article-content sub,#article-content sup{font-size:.75em;line-height:0;position:relative;vertical-align:baseline}#article-content sub{bottom:-.25em}#article-content sup{top:-.5em}#article-content blockquote{margin:var(--art-gap-xl) 0;padding:1.5rem 2.5rem 1.5rem 3rem;background:color-mix(in srgb,var(--color-primary) 5%,var(--color-base-100));border:none;border-radius:var(--art-radius);color:color-mix(in srgb,var(--color-base-content) 85%,transparent);font-size:1em;line-height:1.85;position:relative;transition:var(--art-transition)}#article-content blockquote:hover{background:color-mix(in srgb,var(--color-primary) 8%,var(--color-base-100))}#article-content blockquote:before{content:'"';position:absolute;top:.25rem;left:.75rem;font-size:3.5rem;font-family:Georgia,"Noto Serif SC",serif;font-weight:400;font-style:normal;color:var(--color-primary);line-height:1;opacity:.35;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}#article-content blockquote:after{content:'"';position:absolute;bottom:-.5rem;right:.75rem;font-size:3.5rem;font-family:Georgia,"Noto Serif SC",serif;font-weight:400;font-style:normal;color:var(--color-primary);line-height:1;opacity:.35;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}#article-content blockquote p{margin:.5em 0;position:relative;z-index:1}#article-content blockquote p:first-child{margin-top:0}#article-content blockquote p:last-child{margin-bottom:0}#article-content blockquote blockquote{margin:1.25em 0;padding:1rem 1.5rem;background:color-mix(in srgb,var(--color-secondary) 8%,var(--color-base-100));border-left:3px solid color-mix(in srgb,var(--color-secondary) 50%,transparent);border-radius:var(--art-radius-sm)}#article-content blockquote blockquote:before,#article-content blockquote blockquote:after{display:none}#article-content blockquote blockquote p:first-child{margin-top:0}#article-content code{padding:.15em .5em;font-size:.85em;background:color-mix(in srgb,var(--color-primary) 10%,var(--color-base-100));border:1px solid color-mix(in srgb,var(--color-primary) 15%,transparent);border-radius:.5em;font-family:JetBrains Mono,ui-monospace,SF Mono,Menlo,Monaco,monospace;color:var(--color-primary);font-weight:500;white-space:nowrap}#article-content pre code{padding:0;font-size:inherit;background:transparent;border:none;color:inherit;font-weight:400}#article-content ul,#article-content ol{margin:var(--art-gap-md) 0;padding-left:1.75em;line-height:1.85}#article-content li{margin:var(--art-gap-sm) 0;padding-left:.35em}#article-content li:has(>p:only-child){margin:var(--art-gap-xs) 0}#article-content li>p{display:inline;margin:0}#article-content li>ul,#article-content li>ol{margin:var(--art-gap-xs) 0;padding-left:1.5em}#article-content ul>li::marker,#article-content ul ul>li::marker,#article-content ul ul ul>li::marker,#article-content ul ul ul ul>li::marker,#article-content ul ul ul ul ul>li::marker,#article-content ul ul ul ul ul ul>li::marker{color:var(--color-primary);font-size:.9em}#article-content ol>li::marker,#article-content ol ol>li::marker,#article-content ol ol ol>li::marker,#article-content ol ol ol ol>li::marker,#article-content ol ol ol ol ol>li::marker,#article-content ol ol ol ol ol ol>li::marker{color:var(--color-primary);font-weight:600}#article-content ul{list-style-type:disc}#article-content ul ul{list-style-type:circle}#article-content ul ul ul{list-style-type:square}#article-content ul ul ul ul{list-style-type:"◆ "}#article-content ul ul ul ul ul{list-style-type:"▸ "}#article-content ul ul ul ul ul ul{list-style-type:"– "}#article-content ol{list-style-type:decimal}#article-content ol ol{list-style-type:lower-alpha}#article-content ol ol ol{list-style-type:lower-roman}#article-content ol ol ol ol{list-style-type:upper-alpha}#article-content ol ol ol ol ol{list-style-type:upper-roman}#article-content ol ol ol ol ol ol{list-style-type:decimal}#article-content ul[data-type=taskList]{list-style:none;padding-left:0;margin:var(--art-gap-lg) 0}#article-content li[data-type=taskItem]{display:flex;align-items:flex-start;gap:0;padding:.4em 0;margin:0;background:transparent;border:none;border-radius:0;transition:var(--art-transition)}#article-content li[data-type=taskItem]>label{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;width:1.5em;height:1.5em;margin-right:.75em;margin-top:.1em}#article-content li[data-type=taskItem]>label>span{display:none}#article-content ul[data-type=taskList] input[type=checkbox]{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:1.25em;height:1.25em;min-width:1.25em;min-height:1.25em;border:2px solid var(--color-primary);border-radius:6px;background:transparent;cursor:pointer;position:relative;flex-shrink:0;margin:0;transition:var(--art-transition)}#article-content ul[data-type=taskList] input[type=checkbox]:hover{border-color:var(--color-primary);background:var(--art-accent-subtle)}#article-content ul[data-type=taskList] input[type=checkbox]:checked{background:var(--color-primary);border-color:var(--color-primary)}#article-content ul[data-type=taskList] input[type=checkbox]:checked:after{content:"";position:absolute;left:4px;top:1px;width:5px;height:9px;border:solid var(--color-primary-content);border-width:0 2.5px 2.5px 0;transform:rotate(45deg)}#article-content li[data-type=taskItem]>div{flex:1;line-height:1.7;padding-top:.05em}#article-content li[data-type=taskItem]>div>p{margin:0;display:inline}#article-content li[data-type=taskItem][data-checked=true]>div{text-decoration:line-through;opacity:.55;color:color-mix(in srgb,var(--color-base-content) 60%,transparent)}#article-content img{max-width:100%;height:auto;border-radius:var(--art-radius);margin:var(--art-gap-lg) auto;display:block;box-shadow:var(--art-shadow);transition:var(--art-transition)}#article-content img:hover{box-shadow:var(--art-shadow-hover);transform:translateY(-2px)}#article-content figure{margin:var(--art-gap-xl) 0;padding:0;background:transparent;border:none;box-shadow:none}#article-content figure img{margin:0 auto;border-radius:var(--art-radius)}#article-content figcaption{margin-top:.75em;font-size:.875em;color:color-mix(in srgb,var(--color-base-content) 60%,transparent);text-align:center;font-style:italic}#article-content table{width:100%;max-width:100%;margin:var(--art-gap-xl) 0;border-collapse:separate;border-spacing:0;font-size:.9375em;background:var(--color-base-100);border:var(--art-border);border-radius:var(--art-radius);box-shadow:var(--art-shadow);overflow:hidden}#article-content table th,#article-content table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid color-mix(in srgb,var(--color-base-content) 8%,transparent);vertical-align:middle}#article-content table thead{background:var(--art-accent-subtle)}#article-content table th{font-weight:600;color:var(--color-base-content);white-space:nowrap}#article-content table thead tr:first-child th:first-child{border-top-left-radius:var(--art-radius)}#article-content table thead tr:first-child th:last-child{border-top-right-radius:var(--art-radius)}#article-content table tbody tr{transition:background-color .2s ease}#article-content table tbody tr:hover{background:var(--art-accent-subtle)}#article-content table tbody tr:last-child td{border-bottom:none}#article-content table tbody tr:last-child td:first-child{border-bottom-left-radius:var(--art-radius)}#article-content table tbody tr:last-child td:last-child{border-bottom-right-radius:var(--art-radius)}#article-content table p{margin:0}@media(max-width:768px){#article-content table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}#article-content table th,#article-content table td{white-space:nowrap}}#article-content hr{margin:calc(var(--art-gap-xl) * 1.2) 0;border:none;height:1px;background:linear-gradient(90deg,transparent,var(--art-accent-medium) 20%,var(--art-accent-medium) 80%,transparent);position:relative}#article-content hr:after{content:"✦";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);background:var(--color-base-100);padding:0 .75em;color:var(--art-accent-medium);font-size:.875rem}#article-content kbd{padding:.15em .5em;font-size:.85em;font-family:inherit;color:var(--color-base-content);background:var(--color-base-200);border:1px solid var(--color-base-300);border-radius:4px;box-shadow:0 2px 0 var(--color-base-300)}#article-content video{width:100%;max-width:100%;height:auto;margin:var(--art-gap-xl) auto;border-radius:var(--art-radius-lg);display:block;box-shadow:var(--art-shadow)}#article-content audio{width:100%;margin:var(--art-gap-lg) auto;display:block;border-radius:var(--art-radius);background:var(--color-base-100);padding:.5rem;border:var(--art-border)}#article-content iframe{width:100%;max-width:100%;margin:var(--art-gap-lg) auto;display:block;border-radius:var(--art-radius-lg);border:var(--art-border);background:var(--color-base-100)}#article-content details{margin:var(--art-gap-lg) 0;background:var(--color-base-100);border:var(--art-border);border-radius:var(--art-radius);overflow:hidden;box-shadow:var(--art-shadow)}#article-content summary{padding:.875rem 1.25rem .875rem 2.5rem;font-weight:600;background:transparent;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:background .2s ease;position:relative;list-style:none}#article-content summary::-webkit-details-marker{display:none}#article-content summary:before{content:"";position:absolute;left:1rem;top:50%;width:0;height:0;border-left:6px solid var(--color-base-content);border-top:4px solid transparent;border-bottom:4px solid transparent;opacity:.5;transform:translateY(-50%);transition:transform .2s ease}#article-content details[open] summary:before{transform:translateY(-50%) rotate(90deg)}#article-content summary:hover{background:var(--art-accent-subtle)}#article-content details[open] summary{border-bottom:var(--art-border)}#article-content details>*:not(summary){padding:1rem 1.25rem}#article-content .columns{display:flex;gap:1.5rem;margin:var(--art-gap-lg) 0;align-items:flex-start}#article-content .column{flex:1;min-width:0}#article-content .column>*:first-child{margin-top:0}#article-content .column>*:last-child{margin-bottom:0}#article-content dl{margin:1.5em 0;padding:1.25rem 1.5rem;background:var(--color-base-100);border:var(--art-border);border-radius:var(--art-radius);box-shadow:var(--art-shadow)}#article-content dt{margin-top:1em;font-weight:600;color:var(--color-base-content)}#article-content dt:first-child{margin-top:0}#article-content dd{margin-left:1.5em;margin-top:.5em;color:color-mix(in srgb,var(--color-base-content) 75%,transparent)}#article-content small{font-size:.875em;color:color-mix(in srgb,var(--color-base-content) 75%,transparent)}#article-content cite{font-style:italic;color:color-mix(in srgb,var(--color-base-content) 80%,transparent)}#article-content abbr{-webkit-text-decoration:underline dotted;text-decoration:underline dotted;cursor:help}#article-content var{font-family:ui-monospace,monospace;font-style:normal;font-weight:600;color:var(--color-secondary)}#article-content samp{font-family:ui-monospace,monospace;font-size:.875em;padding:.2em .5em;background:var(--art-accent-subtle);border-radius:4px;color:var(--color-secondary)}#article-content dfn{font-style:italic;font-weight:600;color:var(--color-primary)}#article-content q{font-style:italic}#article-content q:before{content:'"'}#article-content q:after{content:'"'}#article-content address{margin:1em 0;font-style:normal;line-height:1.6}#article-content time{color:color-mix(in srgb,var(--color-base-content) 75%,transparent)}#article-content ruby{font-size:inherit}#article-content rt{font-size:.6em;color:color-mix(in srgb,var(--color-base-content) 65%,transparent)}#article-content fieldset{margin:1.5em 0;padding:1.5rem;background:var(--color-base-100);border:var(--art-border);border-radius:var(--art-radius);box-shadow:var(--art-shadow)}#article-content legend{padding:.25rem .75rem;font-weight:600;color:var(--color-primary);background:var(--color-base-100);border-radius:4px}#article-content progress{width:100%;height:.5rem;margin:1em 0;border-radius:9999px;background:var(--color-base-300);border:none;overflow:hidden}#article-content progress::-webkit-progress-bar{background:transparent}#article-content progress::-webkit-progress-value{background:var(--color-primary);border-radius:inherit}#article-content progress::-moz-progress-bar{background:var(--color-primary);border-radius:inherit}#article-content output{display:inline-block;padding:.25rem .75rem;background:var(--art-accent-subtle);border-radius:4px;font-family:ui-monospace,monospace;color:var(--color-primary);font-weight:600}#article-content .callout-note,#article-content .callout-tip,#article-content .callout-warning,#article-content .callout-danger,#article-content .callout-info{margin:1.5em 0;padding:1rem 1.25rem;border-radius:var(--art-radius);box-shadow:var(--art-shadow)}#article-content .callout-note{background:color-mix(in srgb,var(--color-info) 8%,var(--color-base-100));border-left:4px solid var(--color-info)}#article-content .callout-tip{background:color-mix(in srgb,var(--color-success) 8%,var(--color-base-100));border-left:4px solid var(--color-success)}#article-content .callout-warning{background:color-mix(in srgb,var(--color-warning) 8%,var(--color-base-100));border-left:4px solid var(--color-warning)}#article-content .callout-danger{background:color-mix(in srgb,var(--color-error) 8%,var(--color-base-100));border-left:4px solid var(--color-error)}#article-content .callout-info{background:color-mix(in srgb,var(--color-accent) 8%,var(--color-base-100));border-left:4px solid var(--color-accent)}#article-content .footnote-ref,#article-content a[href^="#fn"],#article-content sup a{text-decoration:none;font-weight:600;color:var(--color-primary);padding:0 .15em}#article-content .footnotes,#article-content .footnote-list{margin-top:3em;padding:1.25rem;background:var(--color-base-200);border-radius:var(--art-radius);font-size:.9em;color:color-mix(in srgb,var(--color-base-content) 80%,transparent)}#article-content .footnotes ol,#article-content .footnote-list ol{padding-left:1.5em;margin:.5em 0}#article-content .footnotes li,#article-content .footnote-list li{margin-top:.5em}halo-contact-form{--halo-contact-form-color-primary: var(--color-primary);--halo-contact-form-color-label: var(--color-base-content);--halo-contact-form-color-input: var(--color-base-content);--halo-contact-form-color-placeholder: color-mix(in srgb, var(--color-base-content) 50%, transparent);--halo-contact-form-color-help: color-mix(in srgb, var(--color-base-content) 60%, transparent);--halo-contact-form-color-border: var(--color-base-300);--halo-contact-form-color-danger: var(--color-error);--halo-contact-form-color-button: var(--color-primary-content);--halo-contact-form-bg-input: var(--color-base-100);--halo-contact-form-border-radius: .5rem;display:block;margin:1.5em 0}.post-like-button .heart-icon{transition:all .3s cubic-bezier(.4,0,.2,1)}.post-like-button.liked .heart-icon{animation:heart-beat .6s ease}@keyframes heart-beat{0%,to{transform:scale(1)}25%{transform:scale(1.3)}50%{transform:scale(1.1)}75%{transform:scale(1.2)}}.toc-container{max-height:min(70vh,600px);overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:var(--color-base-300) transparent}.toc-container::-webkit-scrollbar{width:4px}.toc-container::-webkit-scrollbar-track{background:transparent}.toc-container::-webkit-scrollbar-thumb{background:var(--color-base-300);border-radius:2px}.toc-list{list-style:none;padding:0;margin:0}.toc-item-wrapper{margin:0;padding:0;padding-left:calc(var(--toc-indent-multiplier, 0) * var(--toc-indent-unit))}.toc-link{display:flex;align-items:center;padding:6px var(--toc-base-padding);margin:2px 0;min-height:var(--toc-link-height);font-size:.875rem;font-weight:400;line-height:1.4;color:color-mix(in srgb,var(--color-base-content) 60%,transparent);text-decoration:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;border-radius:4px;transition:all .2s cubic-bezier(.4,0,.2,1)}.toc-link:hover{background:var(--toc-hover-bg);color:var(--color-base-content)}.toc-link.active{background:var(--toc-active-bg);color:var(--color-primary);font-weight:600}.toc-link[data-relative-level="0"]{font-weight:500;font-size:.9rem}.toc-item-wrapper .toc-list{border-left:1px solid color-mix(in srgb,var(--color-base-content) 10%,transparent);margin-left:8px;padding-left:0}.post-toc-overlay{position:fixed;inset:0;z-index:60;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}.post-toc-overlay.open{opacity:1;visibility:visible}.post-toc-drawer{position:fixed;top:0;right:0;z-index:61;height:100%;width:85vw;max-width:360px;background:var(--color-base-100);box-shadow:-4px 0 20px #00000026;display:flex;flex-direction:column;transform:translate(100%);transition:transform .3s ease}.post-toc-drawer.open{transform:translate(0)}halo-comment{--halo-comment-bg: transparent !important;--halo-comment-card-bg: color-mix(in srgb, var(--color-base-100) 50%, transparent) !important;--halo-comment-border-color: color-mix(in srgb, var(--color-base-content) 10%, transparent) !important;--halo-comment-font-family: inherit !important;--halo-comment-text-color: var(--color-base-content) !important;--halo-comment-secondary-text-color: color-mix(in srgb, var(--color-base-content) 60%, transparent) !important;--halo-comment-input-bg: color-mix(in srgb, var(--color-base-200) 80%, transparent) !important;--halo-comment-input-border: 1px solid color-mix(in srgb, var(--color-base-content) 10%, transparent) !important;--halo-comment-btn-primary-bg: var(--color-primary) !important;--halo-comment-btn-primary-color: #fff !important}halo-comment::part(container),halo-comment::part(comment-list),.halo-comment-widget{background:transparent!important}@media(max-width:1023px){article.flex-1{width:100%}#article-content img,#article-content pre,#article-content table{max-width:100%;overflow-x:auto}}@media(max-width:640px){#article-content{font-size:1rem;line-height:1.85}#article-content h1{font-size:1.625rem}#article-content h2{font-size:1.375rem;padding-left:.875em}#article-content h3{font-size:1.125rem;padding-left:.75em}#article-content blockquote{padding:1.25rem 2rem;margin:1.25em 0}#article-content blockquote:before{font-size:2.5rem;top:.15rem;left:.5rem}#article-content blockquote:after{font-size:2.5rem;bottom:-.25rem;right:.5rem}#article-content ul,#article-content ol{padding-left:1.25em}#article-content table th,#article-content table td{padding:.5rem .75rem}#article-content .columns{flex-direction:column;gap:1rem}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media print{#article-content{font-size:12pt;line-height:1.6;color:#000}#article-content a{color:#000;text-decoration:underline}#article-content img{box-shadow:none;page-break-inside:avoid}#article-content blockquote{background:transparent;border:1px solid #ccc}#article-content blockquote:before,#article-content blockquote:after{color:#999}}.about-squareform{background:var(--color-base-100);color:var(--color-base-content);min-height:100vh;overflow-x:hidden;margin-top:-1.5rem;padding-top:1.5rem}@media(min-width:768px){.about-squareform{margin-top:-2rem;padding-top:2rem}}.sf-container{max-width:1200px;margin:0 auto;padding:0 2rem}@media(min-width:768px){.sf-container{padding:0 3rem}}.sf-hero{position:relative;min-height:90vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:8rem 0;background-image:linear-gradient(to right,color-mix(in oklch,var(--color-base-content) 3%,transparent) 1px,transparent 1px),linear-gradient(to bottom,color-mix(in oklch,var(--color-base-content) 3%,transparent) 1px,transparent 1px);background-size:40px 40px}.sf-hero-content{max-width:900px;margin:0 auto}.sf-role-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.375rem 1rem;background:transparent;border:1px solid color-mix(in oklch,var(--color-base-content) 20%,transparent);border-radius:2rem;font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--color-base-content);margin-bottom:2rem;font-weight:500}.sf-badge-dot{width:6px;height:6px;background:var(--color-success);border-radius:50%;animation:pulse-dot 2s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.sf-hero-title{font-size:clamp(3rem,12vw,8rem);font-weight:900;line-height:1;margin:0 0 2rem;letter-spacing:.15em;text-transform:uppercase;font-family:ui-monospace,SF Mono,Menlo,Monaco,Courier New,monospace}.sf-title-line{display:block;color:var(--color-base-content)}.sf-hero-desc{font-size:1.125rem;line-height:1.8;color:color-mix(in oklch,var(--color-base-content) 70%,transparent);margin:0 auto 2.5rem;max-width:650px}.sf-hero-actions{display:flex;gap:1rem;justify-content:center;margin-bottom:3rem}.sf-hero-actions .btn{position:relative;overflow:hidden;border:none;isolation:isolate;transition:all .4s cubic-bezier(.4,0,.2,1)}.sf-hero-actions .btn-neutral{background:var(--color-base-content);color:var(--color-base-100);box-shadow:0 4px 15px color-mix(in oklch,var(--color-base-content) 30%,transparent),inset 0 1px color-mix(in oklch,white 15%,transparent)}.sf-hero-actions .btn-neutral:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent 0%,color-mix(in oklch,white 10%,transparent) 50%,transparent 100%);opacity:0;transition:opacity .4s ease}.sf-hero-actions .btn-neutral:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,color-mix(in oklch,white 25%,transparent),transparent);transition:left .6s ease}.sf-hero-actions .btn-neutral:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 8px 25px color-mix(in oklch,var(--color-base-content) 40%,transparent),0 0 40px color-mix(in oklch,var(--color-primary) 20%,transparent),inset 0 1px color-mix(in oklch,white 20%,transparent)}.sf-hero-actions .btn-neutral:hover:before{opacity:1}.sf-hero-actions .btn-neutral:hover:after{left:100%}.sf-hero-actions .btn-outline{background:transparent;color:var(--color-base-content);border:2px solid color-mix(in oklch,var(--color-base-content) 30%,transparent);box-shadow:0 2px 10px color-mix(in oklch,var(--color-base-content) 10%,transparent)}.sf-hero-actions .btn-outline:before{content:"";position:absolute;inset:-2px;background:conic-gradient(from 0deg,var(--color-primary),var(--color-secondary),var(--color-accent),var(--color-primary));border-radius:inherit;opacity:0;z-index:-2;transition:opacity .4s ease;animation:border-spin 3s linear infinite paused}.sf-hero-actions .btn-outline:after{content:"";position:absolute;inset:2px;background:var(--color-base-100);border-radius:calc(var(--radius-field) * 2 - 2px);z-index:-1;transition:background .3s ease}@keyframes border-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sf-hero-actions .btn-outline:hover{transform:translateY(-4px) scale(1.02);border-color:transparent;color:var(--color-base-content);box-shadow:0 8px 30px color-mix(in oklch,var(--color-primary) 30%,transparent),0 0 20px color-mix(in oklch,var(--color-primary) 15%,transparent)}.sf-hero-actions .btn-outline:hover:before{opacity:1;animation-play-state:running}.sf-hero-actions .btn-outline:hover:after{background:color-mix(in oklch,var(--color-primary) 5%,var(--color-base-100))}.sf-hero-actions .btn span,.sf-hero-actions .btn{z-index:1}.sf-hero-actions .btn:active{transform:translateY(-2px) scale(.98);transition-duration:.1s}.sf-hero-actions .btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:4px}.sf-social-icons{display:flex;gap:.75rem;justify-content:center}.sf-social-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--color-base-content);color:var(--color-base-100);border-radius:0;text-decoration:none;transition:all .3s ease}.sf-social-icon:hover{background:var(--color-primary);transform:translateY(-3px)}.sf-social-icon svg{width:18px;height:18px}.sf-clients-section{padding:3rem 0;background:var(--color-base-200);border-top:1px solid color-mix(in oklch,var(--color-base-content) 10%,transparent);border-bottom:1px solid color-mix(in oklch,var(--color-base-content) 10%,transparent)}.sf-clients-label{font-size:.6875rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:color-mix(in oklch,var(--color-base-content) 60%,transparent);margin-bottom:2rem;text-align:center}.sf-tech-marquee{overflow:hidden}.sf-marquee-track{display:flex;gap:4rem;animation:marquee-scroll 50s linear infinite;width:-moz-max-content;width:max-content;will-change:transform}.sf-tech-marquee:hover .sf-marquee-track{animation-play-state:paused}@keyframes marquee-scroll{0%{transform:translate(0)}to{transform:translate(-33.333%)}}.sf-tech-tag{display:inline-flex;align-items:center;gap:.75rem;font-size:1.25rem;font-weight:600;color:color-mix(in oklch,var(--color-base-content) 40%,transparent);white-space:nowrap;transition:color .3s ease}.sf-tech-tag:hover{color:var(--color-base-content)}.sf-tech-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;opacity:.7}.sf-tech-icon svg,.sf-tech-icon img{width:100%;height:100%}.sf-section{padding:6rem 0;position:relative}.sf-section-header{margin-bottom:4rem;text-align:center}.sf-section-tag{display:inline-block;font-size:.6875rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:color-mix(in oklch,var(--color-base-content) 60%,transparent);margin-bottom:1.25rem}.sf-section-title{font-size:clamp(1.75rem,4vw,2.75rem);font-weight:800;line-height:1.3;color:var(--color-base-content);max-width:850px;margin:0 auto;text-transform:uppercase;letter-spacing:.05em}.sf-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;max-width:900px;margin:0 auto}@media(min-width:768px){.sf-stats-grid{grid-template-columns:repeat(4,1fr);gap:3rem}}.sf-stat-item{text-align:center;padding:2.5rem 1.5rem;background:var(--color-base-100);border:1px solid color-mix(in oklch,var(--color-base-content) 12%,transparent);clip-path:polygon(12px 0,100% 0,100% calc(100% - 12px),calc(100% - 12px) 100%,0 100%,0 12px);transition:all .4s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px color-mix(in oklch,var(--color-base-content) 5%,transparent)}.sf-stat-item:hover{border-color:color-mix(in oklch,var(--color-primary) 30%,transparent);transform:translateY(-6px);box-shadow:0 12px 30px color-mix(in oklch,var(--color-primary) 25%,transparent),0 0 20px color-mix(in oklch,var(--color-primary) 15%,transparent)}.sf-stat-number{font-size:3.5rem;font-weight:900;line-height:1;color:var(--color-base-content);font-variant-numeric:tabular-nums;min-width:2ch;display:inline-block}.sf-stat-plus{font-size:2rem;font-weight:700;color:var(--color-base-content)}.sf-stat-label{display:block;font-size:.875rem;color:color-mix(in oklch,var(--color-base-content) 60%,transparent);margin-top:.75rem}.sf-stat-item>div:first-child{min-height:4rem;display:flex;align-items:baseline;justify-content:center}.sf-projects-grid{display:grid;grid-template-columns:1fr;gap:2.5rem}@media(min-width:768px){.sf-projects-grid{grid-template-columns:repeat(2,1fr)}}.sf-project-card{background:var(--color-base-100);border:1px solid color-mix(in oklch,var(--color-base-content) 12%,transparent);clip-path:polygon(20px 0,100% 0,100% calc(100% - 20px),calc(100% - 20px) 100%,0 100%,0 20px);padding:2rem;transition:all .4s cubic-bezier(.4,0,.2,1);overflow:hidden;box-shadow:0 2px 8px color-mix(in oklch,var(--color-base-content) 5%,transparent)}.sf-project-card:hover{border-color:color-mix(in oklch,var(--color-primary) 30%,transparent);transform:translateY(-8px) scale(1.02);box-shadow:0 16px 40px color-mix(in oklch,var(--color-primary) 25%,transparent),0 0 20px color-mix(in oklch,var(--color-primary) 15%,transparent)}.sf-card-wide{grid-column:span 1}@media(min-width:768px){.sf-card-wide{grid-column:span 2}}.sf-card-header{display:flex;align-items:center;gap:.875rem;margin-bottom:1.5rem}.sf-card-icon{font-size:1.25rem}.sf-card-title{font-size:1rem;font-weight:700;color:var(--color-base-content);margin:0;flex:1;text-transform:uppercase;letter-spacing:.05em}.sf-card-badge{font-size:.75rem;font-weight:600;color:color-mix(in oklch,var(--color-base-content) 70%,transparent);background:color-mix(in oklch,var(--color-base-content) 8%,transparent);padding:.25rem .75rem;border-radius:1rem}.sf-card-link{display:flex;align-items:center;gap:.375rem;font-size:.8125rem;color:color-mix(in oklch,var(--color-base-content) 60%,transparent);text-decoration:none;transition:color .3s}.sf-card-link:hover{color:var(--color-base-content)}.sf-heatmap-wrapper{overflow-x:auto;margin-bottom:1rem;padding-bottom:.5rem;scrollbar-width:thin;scrollbar-color:color-mix(in oklch,var(--color-base-content) 20%,transparent) transparent;-webkit-overflow-scrolling:touch}@media(max-width:640px){.sf-heatmap-wrapper{margin-left:-.5rem;margin-right:-.5rem;padding-left:.5rem;padding-right:.5rem}.sf-heatmap-wrapper:after{content:"";position:absolute;right:0;top:0;bottom:0;width:40px;background:linear-gradient(to right,transparent,var(--color-base-100));pointer-events:none;opacity:.8}}.heatmap-canvas{min-height:100px;min-width:700px}@media(min-width:768px){.heatmap-canvas{min-height:120px;min-width:auto}}.article-heatmap-svg{width:100%;height:auto;min-width:680px}@media(min-width:768px){.article-heatmap-svg{min-width:auto}}.heatmap-label,.heatmap-month-label{font-size:9px;fill:color-mix(in oklch,var(--color-base-content) 50%,transparent)}@media(min-width:768px){.heatmap-label,.heatmap-month-label{font-size:10px}}.article-heatmap-cell{cursor:pointer;transition:all .2s ease}.article-heatmap-cell:hover{stroke:var(--color-base-content);stroke-width:2;filter:brightness(.85)}@keyframes cell-pop{0%{opacity:0;transform:scale(0)}60%{transform:scale(1.15)}to{opacity:1;transform:scale(1)}}.heatmap-cell-animated{animation:cell-pop .4s cubic-bezier(.4,0,.2,1) backwards}.sf-heatmap-legend{display:flex;align-items:center;justify-content:flex-end;gap:.375rem;font-size:.625rem;color:color-mix(in oklch,var(--color-base-content) 50%,transparent);margin-top:.5rem}@media(min-width:768px){.sf-heatmap-legend{gap:.5rem;font-size:.6875rem}}.sf-legend-dot{width:10px;height:10px;border-radius:2px}@media(min-width:768px){.sf-legend-dot{width:11px;height:11px}}.sf-l0{background:color-mix(in oklch,var(--color-base-content) 10%,transparent)}.sf-l1{background:color-mix(in oklch,var(--color-primary) 30%,transparent)}.sf-l2{background:color-mix(in oklch,var(--color-primary) 60%,transparent)}.sf-l3{background:var(--color-primary)}.heatmap-tooltip{position:fixed;z-index:9999;padding:.875rem 1.125rem;background:var(--color-base-content);color:var(--color-base-100);border-radius:.5rem;font-size:.8125rem;pointer-events:none;box-shadow:0 8px 24px color-mix(in oklch,var(--color-base-content) 30%,transparent);display:none;max-width:260px}.heatmap-tooltip-date{font-weight:600;margin-bottom:.5rem}.heatmap-tooltip-count{opacity:.9;font-weight:600}.heatmap-tooltip-posts{margin-top:.75rem;padding-top:.75rem;border-top:1px solid color-mix(in oklch,var(--color-base-100) 20%,transparent)}.heatmap-tooltip-post{display:block;font-size:.75rem;opacity:.8;margin-top:.375rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sf-github-wrapper{min-height:100px}.sf-loading{display:flex;align-items:center;justify-content:center;min-height:100px;color:color-mix(in oklch,var(--color-base-content) 50%,transparent)}.github-heatmap-img,.sf-github-stats img{width:100%;border-radius:.5rem}.sf-projects-grid>.sf-project-card:has(.sf-github-stats){display:flex;flex-direction:column;min-height:220px}.sf-projects-grid>.sf-project-card:has(.sf-github-stats) .sf-github-stats{flex:1;display:flex;align-items:center;justify-content:center;min-height:150px}.sf-projects-grid>.sf-project-card:has(.sf-github-stats) .sf-github-stats img{max-height:160px;width:auto;max-width:100%;-o-object-fit:contain;object-fit:contain}@media(min-width:768px){.sf-projects-grid>.sf-project-card:has(.sf-github-stats){min-height:260px}.sf-projects-grid>.sf-project-card:has(.sf-github-stats) .sf-github-stats{min-height:180px}.sf-projects-grid>.sf-project-card:has(.sf-github-stats) .sf-github-stats img{max-height:180px}}.sf-toolkit-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem}@media(min-width:768px){.sf-toolkit-grid{grid-template-columns:repeat(3,1fr)}}.sf-tool-card{background:var(--color-base-100);border:1px solid color-mix(in oklch,var(--color-base-content) 12%,transparent);clip-path:polygon(16px 0,100% 0,100% calc(100% - 16px),calc(100% - 16px) 100%,0 100%,0 16px);padding:2rem 1.5rem;text-align:center;transition:all .4s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px color-mix(in oklch,var(--color-base-content) 5%,transparent)}.sf-tool-card:hover{border-color:color-mix(in oklch,var(--color-primary) 30%,transparent);transform:translateY(-6px);box-shadow:0 12px 30px color-mix(in oklch,var(--color-primary) 25%,transparent),0 0 20px color-mix(in oklch,var(--color-primary) 15%,transparent)}.sf-tool-icon{width:48px;height:48px;margin:0 auto 1.25rem;display:flex;align-items:center;justify-content:center;color:var(--color-base-content)}.sf-tool-icon svg{width:100%;height:100%}.sf-tool-name{font-size:.9375rem;font-weight:700;color:var(--color-base-content);margin:0 0 1.25rem;text-transform:uppercase;letter-spacing:.05em}.sf-tool-card .progress{margin-bottom:.75rem;height:.375rem;background:var(--color-base-300);border-radius:.25rem}.sf-tool-card .progress::-webkit-progress-value{background:var(--color-primary);border-radius:.25rem}.sf-tool-card .progress::-moz-progress-bar{background:var(--color-primary);border-radius:.25rem}.sf-tool-card .progress::-webkit-progress-bar{background:var(--color-base-300);border-radius:.25rem}.sf-tool-percent{font-size:.8125rem;color:color-mix(in oklch,var(--color-base-content) 70%,transparent);font-weight:600}.sf-location-card{display:grid;grid-template-columns:1fr;gap:1.5rem;background:var(--color-base-100);border:1px solid color-mix(in oklch,var(--color-base-content) 12%,transparent);clip-path:polygon(20px 0,100% 0,100% calc(100% - 20px),calc(100% - 20px) 100%,0 100%,0 20px);padding:1.5rem;overflow:hidden;box-shadow:0 2px 8px color-mix(in oklch,var(--color-base-content) 5%,transparent);transition:all .4s cubic-bezier(.4,0,.2,1)}.sf-location-card:hover{border-color:color-mix(in oklch,var(--color-primary) 30%,transparent);transform:translateY(-6px);box-shadow:0 12px 30px color-mix(in oklch,var(--color-primary) 25%,transparent),0 0 20px color-mix(in oklch,var(--color-primary) 15%,transparent)}@media(min-width:768px){.sf-location-card{grid-template-columns:1fr 1.2fr;align-items:center;gap:3rem;padding:3rem}}.sf-location-info{text-align:center;order:2}@media(min-width:768px){.sf-location-info{text-align:left;order:1}}.sf-location-name{font-size:1.5rem;font-weight:800;color:var(--color-base-content);margin:0 0 .75rem;text-transform:uppercase;letter-spacing:.05em}@media(min-width:768px){.sf-location-name{font-size:2rem;margin:0 0 1rem}}.sf-location-desc{font-size:.9375rem;color:color-mix(in oklch,var(--color-base-content) 65%,transparent);line-height:1.7;margin:0 0 1rem}@media(min-width:768px){.sf-location-desc{font-size:1.0625rem;margin:0 0 1.5rem}}.sf-location-coords{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:color-mix(in oklch,var(--color-base-content) 60%,transparent);margin-bottom:1rem;justify-content:center;flex-wrap:wrap}@media(min-width:768px){.sf-location-coords{justify-content:flex-start;font-size:.875rem;margin-bottom:1.5rem}}.sf-location-coords svg{color:var(--color-primary);flex-shrink:0}.sf-location-map{min-height:200px;aspect-ratio:16 / 10;background:var(--color-base-200);border-radius:.75rem;overflow:hidden;border:1px solid color-mix(in oklch,var(--color-base-content) 8%,transparent);order:1;background-image:linear-gradient(to right,color-mix(in oklch,var(--color-base-content) 4%,transparent) 1px,transparent 1px),linear-gradient(to bottom,color-mix(in oklch,var(--color-base-content) 4%,transparent) 1px,transparent 1px),var(--color-base-200);background-size:30px 30px,30px 30px,100% 100%}@media(min-width:768px){.sf-location-map{min-height:320px;aspect-ratio:auto;order:2}}.sf-location-map img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.sf-location-map a{display:block;width:100%;height:100%}.sf-content-card{background:var(--color-base-100);border:1px solid color-mix(in oklch,var(--color-base-content) 12%,transparent);clip-path:polygon(20px 0,100% 0,100% calc(100% - 20px),calc(100% - 20px) 100%,0 100%,0 20px);padding:1.5rem;box-shadow:0 2px 8px color-mix(in oklch,var(--color-base-content) 5%,transparent);transition:all .4s cubic-bezier(.4,0,.2,1)}.sf-content-card:hover{border-color:color-mix(in oklch,var(--color-primary) 30%,transparent);transform:translateY(-6px);box-shadow:0 12px 30px color-mix(in oklch,var(--color-primary) 20%,transparent),0 0 20px color-mix(in oklch,var(--color-primary) 10%,transparent)}@media(min-width:768px){.sf-content-card{padding:2.5rem}}.sf-content-visible{opacity:1!important;transform:none!important;transition:none!important}.sf-prose{overflow-wrap:break-word;word-wrap:break-word}.sf-content-card #article-content{margin:0;padding:0}.sf-empty{text-align:center;padding:4rem 2rem;color:color-mix(in oklch,var(--color-base-content) 50%,transparent)}.sf-cta-card{text-align:center;padding:3rem 1.5rem;background:var(--color-base-200);border-radius:1rem;position:relative;overflow:hidden;border:1px solid color-mix(in oklch,var(--color-primary) 20%,transparent);background-image:linear-gradient(to right,color-mix(in oklch,var(--color-base-content) 3%,transparent) 1px,transparent 1px),linear-gradient(to bottom,color-mix(in oklch,var(--color-base-content) 3%,transparent) 1px,transparent 1px),var(--color-base-200);background-size:40px 40px,40px 40px,100% 100%;transition:all .4s cubic-bezier(.4,0,.2,1)}@media(min-width:768px){.sf-cta-card{padding:5rem 3rem}}.sf-cta-card:hover{border-color:color-mix(in oklch,var(--color-primary) 40%,transparent);box-shadow:0 8px 30px color-mix(in oklch,var(--color-primary) 15%,transparent),inset 0 0 60px color-mix(in oklch,var(--color-primary) 3%,transparent)}.sf-cta-card:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 50% 50%,color-mix(in oklch,var(--color-primary) 8%,transparent) 0%,transparent 50%);opacity:0;transition:opacity .4s ease;pointer-events:none}.sf-cta-card:hover:before{opacity:1}.sf-cta-title{font-size:clamp(1.25rem,4vw,2.25rem);font-weight:800;color:var(--color-base-content);margin:0 0 2rem;line-height:1.35;letter-spacing:.03em;position:relative;z-index:1}@media(min-width:768px){.sf-cta-title{margin:0 0 2.5rem;letter-spacing:.05em}}.sf-cta-btn{position:relative;z-index:1;transition:all .3s cubic-bezier(.4,0,.2,1)}.sf-cta-btn:hover{transform:translateY(-3px);box-shadow:0 8px 20px color-mix(in oklch,var(--color-neutral) 30%,transparent)}.sf-comment-card{background:var(--color-base-100);border:1px solid color-mix(in oklch,var(--color-base-content) 12%,transparent);clip-path:polygon(20px 0,100% 0,100% calc(100% - 20px),calc(100% - 20px) 100%,0 100%,0 20px);padding:2.5rem;box-shadow:0 2px 8px color-mix(in oklch,var(--color-base-content) 5%,transparent);transition:all .4s cubic-bezier(.4,0,.2,1)}.sf-comment-card:hover{border-color:color-mix(in oklch,var(--color-primary) 30%,transparent);transform:translateY(-6px);box-shadow:0 12px 30px color-mix(in oklch,var(--color-primary) 20%,transparent),0 0 20px color-mix(in oklch,var(--color-primary) 10%,transparent)}[data-reveal]{opacity:0;transition:all .8s cubic-bezier(.4,0,.2,1)}[data-reveal].revealed{opacity:1}[data-reveal=fade-up]{transform:translateY(30px)}[data-reveal=fade-up].revealed{transform:translateY(0)}[data-reveal-delay="100"].revealed{transition-delay:.1s}[data-reveal-delay="200"].revealed{transition-delay:.2s}[data-reveal-delay="300"].revealed{transition-delay:.3s}[data-reveal-delay="400"].revealed{transition-delay:.4s}@media(prefers-reduced-motion:reduce){.sf-badge-dot,.sf-marquee-track,.heatmap-cell-animated{animation:none}[data-reveal]{opacity:1;transform:none}}@media(max-width:640px){.sf-container{padding:0 1rem}.sf-hero{padding:3rem 0;min-height:auto}.sf-hero-title{font-size:2.5rem;letter-spacing:.08em}.sf-hero-desc{font-size:1rem}.sf-hero-actions{flex-direction:column;gap:1rem;padding:0 1rem}.sf-hero-actions .btn{width:100%;padding:1rem 2rem}.sf-hero-actions .btn-outline:before{animation:none;background:linear-gradient(135deg,var(--color-primary),var(--color-secondary))}.sf-section{padding:3rem 0}.sf-section-header{margin-bottom:2rem}.sf-stats-grid{gap:1rem}.sf-stat-item{padding:1.5rem 1rem}.sf-stat-number{font-size:2rem}.sf-stat-plus{font-size:1.25rem}.sf-stat-label{font-size:.75rem}.sf-stat-item>div:first-child{min-height:2.75rem}.sf-project-card{padding:1.25rem}.sf-card-header{flex-wrap:wrap;gap:.5rem}.sf-card-title{font-size:.875rem}.sf-comment-card{padding:1.25rem}.sf-toolkit-grid{grid-template-columns:repeat(2,1fr);gap:1rem}.sf-tool-card{padding:1.25rem 1rem}.sf-tool-icon{width:36px;height:36px;margin-bottom:1rem}.sf-tool-name{font-size:.8125rem}.sf-tool-percent{font-size:.75rem}.sf-github-stats img{border-radius:.375rem}}
