:root{--max-width:1400px;--content-padding:2rem;--bg-main:#fff;--bg-card:#fff;--bg-callout:#f3f4f6;--text-primary:#111827;--text-secondary:#374151;--text-muted:#6b7280;--accent-blue:#2563eb;--accent-green:#059669;--accent-red:#dc2626;--rating-gold:#eab308;--accent-primary:#047857;--border-color:#e5e7eb;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f}[data-theme=dark]{--bg-main:#111827;--bg-card:#1f2937;--bg-callout:#232d3c;--text-primary:#f3f4f6;--text-secondary:#d1d5db;--text-muted:#9ca3afcc;--accent-blue:#60a5fa;--accent-green:#6ee7b7;--accent-red:#f87171;--accent-primary:#26d07c;--border-color:#ffffff1a}@media (prefers-color-scheme:dark){:root:not([data-theme=light]){--bg-main:#111827;--bg-card:#1f2937;--bg-callout:#232d3c;--text-primary:#f3f4f6;--text-secondary:#d1d5db;--text-muted:#9ca3afcc;--accent-blue:#60a5fa;--accent-green:#6ee7b7;--accent-red:#f87171;--accent-primary:#26d07c;--border-color:#ffffff1a}}*,:before,:after{box-sizing:border-box}body{background-color:var(--bg-main);color:var(--text-primary);isolation:isolate;flex-direction:column;min-height:100vh;margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;display:flex}.header{z-index:100;background-color:var(--bg-main);border-bottom:1px solid var(--border-color);-webkit-backdrop-filter:blur(12px);position:sticky;top:0}.nav{max-width:var(--max-width);justify-content:space-between;align-items:center;width:90%;margin:0 auto;padding:.75rem 0;display:flex}.logo a{color:var(--accent-primary);letter-spacing:-.02em;font-size:1.25rem;font-weight:700;text-decoration:none}.logo a:hover{opacity:.85;text-decoration:none}#menu{align-items:center;gap:.25rem;margin:0;padding:0;list-style:none;display:flex}#menu li{margin:0;padding:0}#menu li a{color:var(--text-secondary);border-radius:6px;padding:.4rem .75rem;font-size:.9rem;font-weight:500;text-decoration:none;transition:color .2s,background-color .2s;display:block}#menu li a:hover{color:var(--accent-primary);background-color:var(--bg-callout);text-decoration:none}#theme-toggle{border:1px solid var(--border-color);cursor:pointer;color:var(--text-secondary);background:0 0;border-radius:6px;justify-content:center;align-items:center;padding:.4rem;transition:color .2s,border-color .2s,background-color .2s;display:inline-flex}#theme-toggle:hover{color:var(--accent-primary);border-color:var(--accent-primary);background-color:var(--bg-callout)}[data-theme=light] #moon{display:block}[data-theme=light] #sun,[data-theme=dark] #moon{display:none}[data-theme=dark] #sun,:root:not([data-theme]) #moon{display:block}:root:not([data-theme]) #sun{display:none}.theme-toggle-icon{width:18px;height:18px}.footer{border-top:1px solid var(--border-color);text-align:center;color:var(--text-muted);margin-top:auto;padding:1.5rem 0;font-size:.85rem}.footer a{color:var(--accent-primary);text-decoration:none}.footer a:hover{text-decoration:underline}.main{max-width:var(--max-width);width:90%;padding:var(--content-padding) 0;flex:1;margin:0 auto}.main-container,.container,.prose,article,.article-content{width:100%!important;max-width:100%!important;padding-left:0!important;padding-right:0!important}h1,h2,h3,h4{color:var(--accent-primary);margin:2rem 0 1rem;font-weight:600;line-height:1.3}h1{font-size:2.25rem}h2{font-size:1.875rem}h3{font-size:1.5rem}h4{font-size:1.25rem}p{color:var(--text-secondary);margin:0 0 1.5rem}a{color:var(--accent-primary);text-decoration:none;transition:color .2s}a:hover{color:color-mix(in srgb, var(--accent-primary), white 20%);text-decoration:underline}.article-content{background-color:var(--bg-card);border-radius:1rem;margin:2rem auto!important;padding:2rem!important}img{border-radius:.5rem;max-width:100%;height:auto;margin:2rem auto;display:block}pre,code{background-color:#0003;border-radius:.25rem;padding:.2em .4em;font-family:ui-monospace,monospace;font-size:.9em}pre code{background-color:#0000;padding:0}pre{padding:1rem;overflow-x:auto}.review-callout{transition:transform .2s,border-color .2s,box-shadow .2s;background:0 0!important;border:1px solid #ffffff4d!important;border-radius:8px!important;margin:1.5rem 0!important;padding:1.25rem 2rem!important}.review-callout:hover{border-color:var(--accent-primary);transform:translateY(-2px);box-shadow:0 6px 20px #26d07c1a}.review-header{align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.reviewer-name{color:var(--accent-primary);font-size:1.2rem;font-weight:600}.review-rating{background:#eab30826;border-radius:4px;align-items:center;gap:.15rem;padding:.15rem .4rem;display:inline-flex}.rating-star{color:var(--rating-gold);font-size:.7rem}.rating-number{color:var(--rating-gold);font-size:.75rem;font-weight:700}.review-content{color:var(--text-secondary);padding:0;font-size:1rem;line-height:1.6}.review-content p{margin:.25rem 0}.review-content p:first-child{margin-top:0}.review-content p:last-child{margin-bottom:0}.review-content strong{font-weight:600;font-size:inherit;margin:0;display:inline}.review-content strong:first-of-type{color:var(--accent-green)}.review-content strong:nth-of-type(2){color:var(--accent-red)}.review-content strong:nth-of-type(3){color:var(--accent-blue)}@media (width<=640px){.main{width:95%!important;padding:1rem 0!important}.article-content{padding:1rem!important}.review-callout{padding:1.75rem}.review-content{padding:0 .25rem}.review-title-group{flex-direction:column;align-items:flex-start;gap:1rem}.review-title{font-size:1.125rem}.rating-star,.rating-number{font-size:1rem}}@media (width>=1536px){:root{--max-width:1600px}}@media print{:root{--bg-main:white;--bg-card:white;--bg-callout:white;--text-primary:black;--text-secondary:#374151;--border-color:#eee}.review-callout{border:1px solid var(--border-color);box-shadow:none;break-inside:avoid}a{color:#000;text-decoration:underline}}.comments-section{border-top:1px solid var(--border-color);margin-top:3rem;padding-top:2rem}.comments-section h3{color:var(--text-primary);margin:2rem 0 1.5rem;font-size:1.5rem;font-weight:600}.comment{background-color:var(--bg-callout);box-shadow:var(--shadow-md);border-radius:1rem;margin-bottom:1.5rem;padding:1.5rem}.comment-header{border-bottom:1px solid var(--border-color);justify-content:space-between;margin-bottom:1rem;padding-bottom:.75rem;font-size:.95rem;display:flex}.comment-author{color:var(--accent-blue);font-weight:600}.comment-date{color:var(--text-muted)}.comment-content{color:var(--text-secondary);line-height:1.5}.comment-form{background-color:var(--bg-card);box-shadow:var(--shadow-md);border-radius:1rem;margin-top:2.5rem;padding:2rem}.comment-form h4{color:var(--text-primary);margin-top:0;margin-bottom:1.5rem;font-size:1.25rem}.form-group{margin-bottom:1.5rem}.form-group label{color:var(--text-secondary);margin-bottom:.5rem;font-weight:500;display:block}.form-group input,.form-group textarea{border:1px solid var(--border-color);width:100%;color:var(--text-primary);background-color:#0003;border-radius:.5rem;padding:.75rem;font-family:inherit;font-size:1rem;transition:border-color .2s}.form-group input:focus,.form-group textarea:focus{border-color:var(--accent-blue);outline:none}button[type=submit]{background-color:var(--accent-blue);color:var(--text-primary);cursor:pointer;border:none;border-radius:.5rem;padding:.75rem 1.5rem;font-weight:600;transition:background-color .2s}button[type=submit]:hover{background-color:color-mix(in srgb, var(--accent-blue), white 15%)}.comment-notification{border-radius:.5rem;margin-top:1.5rem;padding:1rem}.comment-notification.success{color:var(--accent-green);background-color:#6ee7b71a;border:1px solid #6ee7b74d}.comment-notification.error{color:var(--accent-red);background-color:#f871711a;border:1px solid #f871714d}@media (width<=640px){.comment-form,.comment{padding:1.25rem}.comment-header{flex-direction:column;align-items:flex-start;gap:.3rem}}.post-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.75rem;display:grid}.post-entry{border:1px solid var(--border-color);flex-direction:column;height:100%;margin-bottom:0;transition:transform .2s,border-color .2s,box-shadow .2s;display:flex;background:0 0!important;border-radius:6px!important;padding:.75rem 1rem!important}.post-entry:hover{border-color:var(--accent-primary);transform:translateY(-3px);box-shadow:0 8px 25px #26d07c26}.post-entry .entry-header h2{line-height:1.3;margin:0 0 .4rem!important;font-size:.95rem!important}.post-entry .entry-content{flex-grow:1}.post-entry .entry-content p{-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.45;display:-webkit-box;overflow:hidden;margin:0!important;font-size:.8rem!important}.post-entry .entry-footer{margin-top:.5rem;font-size:.7rem!important}.section-heading{text-transform:uppercase;letter-spacing:.05em;border-bottom:none;padding-bottom:0;font-weight:600;color:var(--text-muted)!important;margin:.75rem 0 .5rem!important;font-size:.8rem!important}.first-entry{border:1px solid var(--border-color);margin-bottom:.5rem;transition:transform .2s,border-color .2s,box-shadow .2s;background:0 0!important;border-radius:6px!important;min-height:auto!important;padding:.75rem 1rem!important}.first-entry:hover{border-color:var(--accent-primary);transform:translateY(-3px);box-shadow:0 8px 25px #26d07c26}.first-entry .entry-header h2{line-height:1.3;margin:0 0 .4rem!important;font-size:.95rem!important}.first-entry .entry-content{display:block!important}.first-entry .entry-content p{-webkit-line-clamp:2;color:var(--text-secondary);-webkit-box-orient:vertical;line-height:1.45;display:-webkit-box;overflow:hidden;margin:0!important;font-size:.8rem!important}.first-entry .entry-footer{margin-top:.5rem;font-size:.7rem!important}.more-card{border:1px solid var(--border-color);justify-content:center;align-items:center;text-decoration:none;transition:transform .2s,border-color .2s,box-shadow .2s;background:0 0!important;display:flex!important}.more-card:hover{border-color:var(--accent-primary);transform:translateY(-3px);box-shadow:0 8px 25px #26d07c26}.more-card .more-text{color:var(--accent-primary);font-size:.85rem;font-weight:500}.notice-box{background-color:var(--bg-callout);border-left:4px solid var(--accent-primary);box-shadow:var(--shadow-sm);border-radius:6px;margin:1.5rem 0;padding:1.25rem 1.75rem;transition:transform .2s,box-shadow .2s}.notice-box:hover{box-shadow:var(--shadow-md);transform:translate(4px)}.notice-title{color:var(--accent-primary);letter-spacing:.05em;margin-bottom:.75rem;font-size:1.1rem;font-weight:700}.notice-content{color:var(--text-secondary);font-size:.95rem;line-height:1.6}.notice-content p:last-child{margin-bottom:0}.notice-content ul{margin-bottom:0;padding-left:1.25rem}.notice-content li{margin-bottom:.25rem}.gif-container{margin:1.5rem 0}.gif-container img{border-radius:4px;max-width:100%;height:auto}.gif-container figcaption{color:#666;text-align:center;margin-top:.5rem;font-size:.9em}.project-grid{flex-wrap:wrap;gap:1rem;display:flex}.project-card{border:1px solid #ffffff40;border-radius:8px;flex:300px;max-width:400px;padding:1rem 1.5rem;transition:transform .2s,border-color .2s,box-shadow .2s;display:block;background:0 0!important}.project-card:hover{border-color:var(--accent-primary);transform:translateY(-3px);box-shadow:0 8px 25px #26d07c26}.project-header{margin-bottom:.4rem}.project-title{color:var(--accent-primary);font-size:1.1rem;font-weight:600}.project-description{color:var(--text-secondary);margin:0 0 .75rem;font-size:.9rem;line-height:1.5}.project-links{flex-wrap:wrap;gap:.5rem;display:flex}.project-link{border-radius:4px;padding:.25rem .6rem;font-size:.75rem;font-weight:600;transition:opacity .2s;box-shadow:none!important;border:none!important;text-decoration:none!important}.project-link:hover{opacity:.8;text-decoration:none!important}.link-blog,.link-project,.link-demo{color:var(--accent-primary);background:#26d07c26}.expandable{background-color:var(--bg-callout);border:1px solid var(--border-color);box-shadow:var(--shadow-md);border-radius:1rem;margin:1.5rem 0}.expandable summary{cursor:pointer;color:var(--text-primary);align-items:center;gap:.5rem;padding:1rem 1.25rem;font-weight:600;list-style:none;display:flex}.expandable summary::-webkit-details-marker{display:none}.expandable summary:before{content:"▶";color:var(--accent-primary);font-size:.75rem;transition:transform .2s}.expandable[open] summary:before{transform:rotate(90deg)}.expandable summary:hover{color:var(--accent-primary)}.expandable>:not(summary){color:var(--text-secondary);padding:0 1.25rem 1.25rem;line-height:1.6}.expandable>:not(summary) p:last-child{margin-bottom:0}@media (width<=640px){.expandable summary{padding:.875rem 1rem}.expandable>:not(summary){padding:0 1rem 1rem}}.expandable::details-content{block-size:0;transition:block-size .25s ease, content-visibility .25s allow-discrete;overflow:hidden}.expandable[open]::details-content{block-size:auto}@supports (interpolate-size:allow-keywords){:root{interpolate-size:allow-keywords}}
