/*! tailwindcss v4.1.17 | MIT License | https://tailwindcss.com */
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:"Inter",system-ui,-apple-system,sans-serif;--font-serif:"Playfair Display",Georgia,serif;--font-mono:"JetBrains Mono","Fira Code",monospace;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--color-primary:#1a1a2e;--color-secondary:#4a4e69;--color-accent:#e63946;--color-accent-hover:#d62839;--color-surface:#fff;--color-surface-alt:#f8f9fa;--color-border:#e9ecef;--color-text:#212529;--color-text-muted:#6c757d;--color-pinterest:#e60023;--color-twitter:#1da1f2;--color-code-bg:#1e1e2e;--color-code-text:#cdd6f4;--color-code-border:#313244;--container-max:1280px;--article-max:750px;--shadow-card:0 2px 8px #00000014}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);color:var(--color-text);background-color:var(--color-surface);line-height:1.7}h1,h2,h3,h4,h5,h6{font-family:var(--font-serif);color:var(--color-primary);font-weight:600;line-height:1.3}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.5rem}h4{font-size:1.25rem}a{color:var(--color-accent);text-decoration:none;transition:color .2s}a:hover{color:var(--color-accent-hover)}img{max-width:100%;height:auto}}@layer components{.container{width:100%;max-width:var(--container-max);margin-left:auto;margin-right:auto;padding-left:1.5rem;padding-right:1.5rem}.article-container{width:100%;max-width:var(--article-max);margin-left:auto;margin-right:auto;padding-left:1.5rem;padding-right:1.5rem}.header{z-index:50;background:var(--color-surface);border-bottom:1px solid var(--color-border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fffffff2;position:sticky;top:0}.header-inner{justify-content:space-between;align-items:center;height:4rem;display:flex}.logo{font-family:var(--font-serif);color:var(--color-primary);letter-spacing:-.02em;align-items:center;gap:.5rem;font-size:1.5rem;font-weight:700;text-decoration:none;display:flex}.logo:hover{color:var(--color-primary)}.logo-icon{background:linear-gradient(135deg,var(--color-accent)0%,#ff6b7a 100%);border-radius:6px;width:28px;height:28px;display:inline-block;position:relative}.logo-icon:after{content:"M";font-family:var(--font-serif);color:#fff;font-size:1rem;font-weight:700;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.logo-text{color:var(--color-primary)}.nav-link{color:var(--color-secondary);padding:.5rem 1rem;font-size:.9375rem;font-weight:500;transition:color .2s}.nav-link:hover{color:var(--color-accent)}.hamburger{cursor:pointer;flex-direction:column;gap:5px;padding:.5rem;display:none}.hamburger span{background:var(--color-primary);width:24px;height:2px;transition:all .3s;display:block}.mobile-menu{background:var(--color-surface);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-md);padding:1rem;display:none;position:absolute;top:100%;left:0;right:0}.mobile-menu.active{display:block}@media (max-width:768px){.hamburger{display:flex}.nav-desktop{display:none}}.hero{background:linear-gradient(135deg,var(--color-surface-alt)0%,var(--color-surface)100%);padding:6rem 0;position:relative;overflow:hidden}.hero:before{content:"";pointer-events:none;background:radial-gradient(circle,#e639460d 0%,#0000 70%);width:60%;height:200%;position:absolute;top:-50%;right:-20%}.hero-content{z-index:1;text-align:center;position:relative}.hero-title{margin-bottom:1.5rem;font-size:clamp(2.5rem,5vw,4rem)}.hero-subtitle{color:var(--color-text-muted);max-width:600px;margin:0 auto 2rem;font-size:1.25rem}.btn{cursor:pointer;border:none;border-radius:9999px;align-items:center;gap:.5rem;padding:.875rem 2rem;font-size:1rem;font-weight:600;transition:all .2s;display:inline-flex}.btn-primary{background:var(--color-accent);color:#fff;box-shadow:var(--shadow-md)}.btn-primary:hover{background:var(--color-accent-hover);box-shadow:var(--shadow-lg);color:#fff;transform:translateY(-2px)}.filter-tabs{flex-wrap:wrap;justify-content:center;gap:.75rem;margin-bottom:3rem;display:flex}.filter-tab{color:var(--color-secondary);background:var(--color-surface);border:1px solid var(--color-border);cursor:pointer;border-radius:9999px;padding:.625rem 1.25rem;font-size:.9375rem;font-weight:500;transition:all .2s}.filter-tab:hover{border-color:var(--color-accent);color:var(--color-accent)}.filter-tab.active{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.article-grid{grid-template-columns:repeat(1,1fr);gap:2rem;display:grid}@media (min-width:640px){.article-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width:1024px){.article-grid{grid-template-columns:repeat(3,1fr)}}.article-card{background:var(--color-surface);box-shadow:var(--shadow-card);border:1px solid var(--color-border);border-radius:1rem;transition:all .3s;overflow:hidden}.article-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.article-card-image{aspect-ratio:16/10;position:relative;overflow:hidden}.article-card-image img{object-fit:cover;width:100%;height:100%;transition:transform .3s}.article-card:hover .article-card-image img{transform:scale(1.05)}.article-card-body{padding:1.5rem}.article-card-category{text-transform:uppercase;letter-spacing:.05em;background:var(--color-surface-alt);color:var(--color-accent);border-radius:9999px;margin-bottom:.75rem;padding:.25rem .75rem;font-size:.75rem;font-weight:600;display:inline-block}.article-card-title{margin-bottom:.75rem;font-size:1.25rem;line-height:1.4}.article-card-title a{color:var(--color-primary)}.article-card-title a:hover{color:var(--color-accent)}.article-card-excerpt{color:var(--color-text-muted);margin-bottom:1rem;font-size:.9375rem;line-height:1.6}.article-card-meta{color:var(--color-text-muted);font-size:.8125rem}.article-header{text-align:center;padding:4rem 0 2rem}.article-title{max-width:800px;margin-bottom:1rem;margin-left:auto;margin-right:auto;font-size:clamp(2rem,4vw,3rem)}.article-meta{color:var(--color-text-muted);margin-bottom:2rem;font-size:.9375rem}.article-content{font-size:1.125rem;line-height:1.8}.article-content p{margin-bottom:1.5rem}.article-content h2{border-top:1px solid var(--color-border);margin-top:3rem;margin-bottom:1rem;padding-top:1.5rem}.article-content h3{margin-top:2rem;margin-bottom:.75rem}.article-content ul,.article-content ol{margin-bottom:1.5rem;padding-left:1.5rem}.article-content li{margin-bottom:.5rem}.article-content.visual img{border-radius:0;width:calc(100% + 3rem);max-width:none;margin-left:-1.5rem;margin-right:-1.5rem}@media (min-width:768px){.article-content.visual img{width:calc(100% + 6rem);margin-left:-3rem;margin-right:-3rem}}.article-content pre{background:var(--color-code-bg);border:1px solid var(--color-code-border);font-family:var(--font-mono);border-radius:.75rem;margin:1.5rem 0;padding:1.25rem;font-size:.875rem;line-height:1.6;position:relative;overflow-x:auto}.article-content pre code{color:var(--color-code-text);font-size:inherit;background:0 0;padding:0}.article-content code{font-family:var(--font-mono);background:var(--color-surface-alt);color:var(--color-accent);border-radius:.25rem;padding:.125rem .375rem;font-size:.875em}.copy-btn{color:var(--color-code-text);cursor:pointer;background:#ffffff1a;border:none;border-radius:.375rem;padding:.375rem .75rem;font-size:.75rem;font-weight:500;transition:all .2s;position:absolute;top:.75rem;right:.75rem}.copy-btn:hover{background:#fff3}.copy-btn.copied{color:#a6e3a1}.toc-wrapper{max-height:calc(100vh - 8rem);padding-right:1rem;position:sticky;top:6rem;overflow-y:auto}.toc-title{font-family:var(--font-sans);text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted);margin-bottom:1rem;font-size:.75rem;font-weight:600}.toc-list{margin:0;padding:0;list-style:none}.toc-list li{margin-bottom:.5rem}.toc-list a{color:var(--color-secondary);border-left:2px solid #0000;padding:.25rem 0 .25rem .75rem;font-size:.875rem;transition:all .2s;display:block}.toc-list a:hover,.toc-list a.active{color:var(--color-accent);border-left-color:var(--color-accent)}.toc-list .toc-h3{padding-left:1.5rem;font-size:.8125rem}.share-bar{z-index:40;flex-direction:column;gap:.75rem;display:flex;position:fixed;top:50%;left:2rem;transform:translateY(-50%)}@media (max-width:1280px){.share-bar{flex-direction:row;justify-content:center;margin:2rem 0;position:static;transform:none}}.share-btn{border:1px solid var(--color-border);background:var(--color-surface);width:44px;height:44px;color:var(--color-secondary);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex}.share-btn:hover{box-shadow:var(--shadow-md);transform:scale(1.1)}.share-btn.pinterest{background:var(--color-pinterest);border-color:var(--color-pinterest);color:#fff}.share-btn.pinterest:hover{background:#cc001f}.share-btn.twitter{background:var(--color-twitter);border-color:var(--color-twitter);color:#fff}.share-btn.twitter:hover{background:#1a91da}.share-btn.facebook{color:#fff;background:#1877f2;border-color:#1877f2}.share-btn.facebook:hover{background:#166fe5}.pin-wrapper{display:inline-block;position:relative}.pin-btn{background:var(--color-pinterest);color:#fff;opacity:0;visibility:hidden;cursor:pointer;border:none;border-radius:9999px;align-items:center;gap:.375rem;padding:.5rem .875rem;font-size:.8125rem;font-weight:600;transition:all .2s;display:flex;position:absolute;top:1rem;right:1rem}.pin-wrapper:hover .pin-btn{opacity:1;visibility:visible}.pin-btn:hover{background:#cc001f;transform:scale(1.05)}.footer{background:var(--color-surface-alt);border-top:1px solid var(--color-border);margin-top:4rem;padding:3rem 0}.footer-inner{text-align:center;flex-direction:column;align-items:center;gap:1.5rem;display:flex}@media (min-width:768px){.footer-inner{text-align:left;flex-direction:row;justify-content:space-between}}.footer-links{gap:1.5rem;display:flex}.footer-link{color:var(--color-text-muted);font-size:.875rem}.footer-link:hover{color:var(--color-accent)}.footer-social{gap:.75rem;display:flex}.footer-social a{background:var(--color-surface);width:40px;height:40px;color:var(--color-secondary);border:1px solid var(--color-border);border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex}.footer-social a:hover{box-shadow:var(--shadow-sm);transform:translateY(-2px)}.footer-social a.pinterest:hover{color:var(--color-pinterest);border-color:var(--color-pinterest)}.footer-social a.twitter:hover{color:var(--color-twitter);border-color:var(--color-twitter)}.footer-copyright{color:var(--color-text-muted);font-size:.875rem}.hidden{display:none!important}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.tags-list{flex-wrap:wrap;gap:.5rem;display:flex}.tag{background:var(--color-surface-alt);color:var(--color-secondary);border-radius:9999px;padding:.375rem .875rem;font-size:.875rem;transition:all .2s}.tag:hover{background:var(--color-accent);color:#fff}.share-section{border-top:1px solid var(--color-border);text-align:center;margin-top:3rem;padding-top:2rem}.share-label{text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin-bottom:1rem;font-size:.875rem;font-weight:600;display:block}.share-buttons{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.share-buttons .share-btn{border-radius:9999px;gap:.5rem;width:auto;height:auto;padding:.625rem 1.25rem;font-size:.875rem;font-weight:500}.share-buttons .share-btn.copy-link{background:var(--color-surface-alt);border-color:var(--color-border);color:var(--color-secondary)}.share-buttons .share-btn.copy-link:hover{background:var(--color-primary);color:#fff}.tech-layout{display:block}@media (min-width:1024px){.tech-layout{grid-template-columns:220px 1fr;align-items:start;gap:3rem;display:grid}}.toc-sidebar{display:none}@media (min-width:1024px){.toc-sidebar{display:block}}}@layer utilities{.relative{position:relative}.static{position:static}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.block{display:block}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}