@layer reset,base,layout,components,utilities,groundy;@layer reset{*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}}@layer base{@font-face{font-family:"Noto Serif";src:url(/fonts/noto-serif-latin-700.woff2) format("woff2");font-weight:700;font-style:normal;font-display:swap;unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:"Noto Serif";src:url(/fonts/noto-serif-latin-700-italic.woff2) format("woff2");font-weight:700;font-style:italic;font-display:swap;unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Noto Sans;src:url(/fonts/noto-sans-latin-400.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap;unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Noto Sans;src:url(/fonts/noto-sans-latin-400-italic.woff2) format("woff2");font-weight:400;font-style:italic;font-display:swap;unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Noto Sans;src:url(/fonts/noto-sans-latin-500.woff2) format("woff2");font-weight:500;font-style:normal;font-display:swap;unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Noto Sans;src:url(/fonts/noto-sans-latin-600.woff2) format("woff2");font-weight:600;font-style:normal;font-display:swap;unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Noto Sans;src:url(/fonts/noto-sans-latin-700.woff2) format("woff2");font-weight:700;font-style:normal;font-display:swap;unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Noto Sans;src:url(/fonts/noto-sans-latin-800.woff2) format("woff2");font-weight:800;font-style:normal;font-display:swap;unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Noto Sans Mono;src:url(/fonts/noto-sans-mono-latin-400.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap;unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Noto Sans Mono;src:url(/fonts/noto-sans-mono-latin-500.woff2) format("woff2");font-weight:500;font-style:normal;font-display:swap;unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{--color-slate: #2E4A3E;--color-slate-light: #3D6354;--color-slate-dark: #1F362D;--color-parchment: #F5F1E8;--color-parchment-dark: #E8E4DC;--color-parchment-darker: #D4CFC3;--color-terracotta: #C65D3B;--color-terracotta-light: #D97B5C;--color-terracotta-dark: #A0482E;--color-ink: #1A1A1A;--color-stone: #6B6B6B;--color-stone-light: #767676;--color-clay: #E8E4DC;--color-clay-light: #F0EDE6;--color-cat-ai: #4A5568;--color-cat-security: #8B4513;--color-cat-business: #1B4332;--color-cat-opensource: #7C9885;--color-bg: var(--color-parchment);--color-bg-elevated: #FFFFFF;--color-bg-subtle: var(--color-clay-light);--color-text: var(--color-ink);--color-text-secondary: var(--color-stone);--color-text-muted: var(--color-stone-light);--color-text-tertiary: #8A857D;--color-primary: var(--color-slate);--color-primary-hover: var(--color-slate-light);--color-primary-subtle: rgba(46, 74, 62, .08);--color-primary-glass: rgba(46, 74, 62, .12);--color-accent: var(--color-terracotta);--color-accent-hover: var(--color-terracotta-light);--color-accent-subtle: rgba(198, 93, 59, .08);--color-tip: var(--color-cat-ai);--color-tip-bg: rgba(74, 85, 104, .06);--color-tip-border: rgba(74, 85, 104, .15);--color-caution: var(--color-cat-security);--color-caution-bg: rgba(139, 69, 19, .06);--color-caution-border: rgba(139, 69, 19, .15);--color-danger: #A05040;--color-danger-bg: rgba(160, 80, 64, .06);--color-danger-border: rgba(160, 80, 64, .15);--color-note: var(--color-cat-opensource);--color-note-bg: rgba(124, 152, 133, .06);--color-note-border: rgba(124, 152, 133, .15);--color-border: #D9D4CA;--color-border-light: #E8E4DC;--color-border-subtle: rgba(26, 26, 26, .06);--gradient-dawn: linear-gradient(180deg, #F5F1E8 0%, #E8E4DC 50%, #D4CFC3 100%);--gradient-focus: linear-gradient(135deg, #2E4A3E 0%, #1B4332 100%);--gradient-terracotta: linear-gradient(135deg, #C65D3B 0%, #A0482E 100%);--texture-noise: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");--font-serif: "Noto Serif", Georgia, serif;--font-sans: "Noto Sans", system-ui, -apple-system, sans-serif;--font-mono: "Noto Sans Mono", "SF Mono", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--text-5xl: 3rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--max-width: 1280px;--content-width: 75ch;--header-height: 72px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 24px;--radius-full: 9999px;--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .35s ease;--z-base: 0;--z-dropdown: 100;--z-sticky: 200;--z-header: 300;--z-modal: 400;--z-toast: 500;--shadow-sm: 0 2px 8px rgba(26, 26, 26, .04);--shadow-md: 0 4px 16px rgba(26, 26, 26, .08);--shadow-lg: 0 10px 30px rgba(26, 26, 26, .12);--glass-shadow: 0 4px 20px rgba(26, 26, 26, .08);--glass-shadow-lg: 0 20px 40px rgba(26, 26, 26, .12);--glass-blur: blur(8px);--glass-border: 1px solid rgba(232, 228, 220, .1);--glass-highlight: inset 0 1px 0 rgba(255, 255, 255, .1);--color-bg-glass: rgba(26, 28, 33, .4);--color-border-hover: var(--color-parchment-dark)}[data-theme=dark]{--color-bg: #0F1419;--color-bg-elevated: #1A2024;--color-bg-subtle: #252B30;--color-text: #E8E4DC;--color-text-secondary: #A8A298;--color-text-muted: #918C84;--color-text-tertiary: #767168;--color-primary: #5A7A6E;--color-primary-hover: #6B8B7F;--color-primary-subtle: rgba(90, 122, 110, .15);--color-primary-glass: rgba(90, 122, 110, .2);--color-accent: #A05040;--color-accent-hover: #B5604F;--color-accent-subtle: rgba(160, 80, 64, .15);--color-tip: #6B7B8C;--color-tip-bg: rgba(74, 85, 104, .12);--color-caution: #A67C52;--color-caution-bg: rgba(139, 69, 19, .12);--color-danger: #C07060;--color-danger-bg: rgba(160, 80, 64, .12);--color-note: #8BA690;--color-note-bg: rgba(124, 152, 133, .12);--color-border: rgba(232, 228, 220, .08);--color-border-light: rgba(232, 228, 220, .04);--color-border-subtle: rgba(232, 228, 220, .06)}}@layer base{body:before{content:"";position:fixed;inset:0;background-image:var(--texture-noise);opacity:.03;mix-blend-mode:multiply;pointer-events:none;z-index:9999}[data-theme=dark] body:before{opacity:.02;mix-blend-mode:overlay}}@layer layout{body{font-family:var(--font-sans);font-size:1.0625rem;font-optical-sizing:auto;font-weight:400;line-height:1.7;color:var(--color-text);background:var(--color-bg);transition:background-color var(--transition-base),color var(--transition-base);overflow-wrap:break-word;word-wrap:break-word}h1,h2,h3,h4,h5,h6{font-family:var(--font-sans);font-weight:700;line-height:1.2;letter-spacing:-.02em;color:var(--color-text);overflow-wrap:break-word;text-wrap:pretty;font-optical-sizing:auto}h1{font-size:var(--text-4xl);line-height:1.1}h2{font-size:var(--text-3xl);line-height:1.15}h3{font-size:var(--text-2xl)}h4{font-size:var(--text-xl);line-height:1.3}h5{font-size:var(--text-lg);line-height:1.3}h6{font-size:var(--text-base);line-height:1.3}@media(min-width:768px){h1{font-size:var(--text-5xl)}h2{font-size:var(--text-4xl)}h3{font-size:var(--text-3xl)}}p{margin-bottom:var(--space-5);color:var(--color-text-secondary)}a{color:var(--color-slate);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:.2em;transition:color var(--transition-fast)}a:hover{color:var(--color-terracotta)}::selection{background:var(--color-primary-subtle);color:var(--color-text)}}@layer components{.skip-link{position:absolute;top:-100%;left:var(--space-4);background:var(--color-slate);color:var(--color-parchment);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);text-decoration:none;font-weight:500;z-index:9999;transition:top var(--transition-fast);font-family:var(--font-sans)}.skip-link:focus{top:var(--space-4);outline:2px solid var(--color-terracotta);outline-offset:2px}.site-header{position:fixed;top:0;left:0;right:0;z-index:var(--z-header);height:var(--header-height);background:var(--color-bg-elevated);border-bottom:1px solid var(--color-border);transition:all var(--transition-base)}[data-theme=dark] .site-header{background:var(--color-bg-elevated);border-bottom-color:var(--color-border)}.nav-container{max-width:var(--max-width);margin:0 auto;padding:0 var(--space-6);height:100%;display:flex;align-items:center;justify-content:space-between;position:relative}.logo{display:flex;align-items:center;text-decoration:none;position:relative;z-index:1}.logo-text{font-family:var(--font-sans);font-size:1.75rem;font-weight:800;color:var(--color-slate);letter-spacing:-.03em;text-decoration:none}[data-theme=dark] .logo-text{color:var(--color-parchment)}.logo-badge{font-size:var(--text-xs);font-weight:500;color:var(--color-text-muted);margin-left:var(--space-2);padding:var(--space-1) var(--space-2);background:var(--color-primary-subtle);border-radius:var(--radius-sm);font-family:var(--font-sans)}.nav-menu{display:flex;align-items:center;gap:var(--space-6)}.nav-links{display:flex;align-items:center;gap:var(--space-1)}.nav-links a{color:var(--color-text-secondary);font-size:var(--text-sm);font-weight:500;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);position:relative;transition:all var(--transition-fast);text-decoration:none}.nav-links a:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:0;height:2px;background:var(--color-terracotta);border-radius:var(--radius-full);transition:width var(--transition-fast)}.nav-links a:hover{color:var(--color-text);background:var(--color-primary-subtle)}.nav-links a:hover:after{width:60%}.nav-actions{display:flex;align-items:center;gap:var(--space-3)}.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:var(--space-3);z-index:101;min-width:44px;min-height:44px;justify-content:center;align-items:center;border-radius:var(--radius-md);transition:background var(--transition-fast)}.hamburger:hover{background:var(--color-primary-subtle)}.hamburger span{width:24px;height:2px;background:var(--color-text);border-radius:var(--radius-full);transition:all var(--transition-base)}.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.hamburger.active span:nth-child(2){opacity:0;transform:scaleX(0)}.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}@media(max-width:768px){.nav-container{padding:0 var(--space-4)}.hamburger{display:flex}.nav-menu{position:fixed;top:var(--header-height);left:0;right:0;bottom:0;background:var(--color-bg-elevated);flex-direction:column;align-items:stretch;justify-content:flex-start;gap:0;padding:var(--space-4);transform:translate(100%);transition:transform var(--transition-base);overflow-y:auto}.nav-menu.active{transform:translate(0)}.nav-links{flex-direction:column;align-items:stretch;gap:var(--space-2)}.nav-links a{display:flex;align-items:center;padding:var(--space-4);font-size:var(--text-lg);border-radius:var(--radius-lg)}.nav-links a:after{display:none}.nav-links a:hover{background:var(--color-primary-subtle)}.nav-actions{margin-top:var(--space-4);flex-direction:column}}.main-content{min-height:calc(100vh - var(--header-height) - 400px);padding:calc(var(--header-height) + var(--space-12)) var(--space-6) var(--space-12);max-width:var(--max-width);margin:0 auto}@media(max-width:768px){.main-content{padding:calc(var(--header-height) + var(--space-8)) var(--space-4) var(--space-8)}}.site-footer{background:var(--color-bg-elevated);border-top:1px solid var(--color-border);margin-top:var(--space-24);position:relative}.footer-container{max-width:var(--max-width);margin:0 auto;padding:var(--space-16) var(--space-6)}.footer-main{display:grid;grid-template-columns:2fr 1fr 1fr;gap:var(--space-12);padding-bottom:var(--space-10);border-bottom:1px solid var(--color-border)}@media(max-width:768px){.footer-main{grid-template-columns:1fr;gap:var(--space-8)}}.footer-brand{max-width:320px}.footer-logo{font-family:var(--font-sans);font-size:var(--text-2xl);font-weight:800;color:var(--color-slate);letter-spacing:-.03em}[data-theme=dark] .footer-logo{color:var(--color-parchment)}.footer-tagline{color:var(--color-text-secondary);margin-top:var(--space-3);font-size:var(--text-sm);line-height:1.6}.footer-col h4{font-family:var(--font-sans);font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted);margin-bottom:var(--space-4)}.footer-col a{display:block;color:var(--color-text-secondary);text-decoration:none;font-size:var(--text-sm);padding:var(--space-2) 0;transition:color var(--transition-fast)}.footer-col a:hover{color:var(--color-terracotta)}.footer-bottom{padding-top:var(--space-8);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--space-4)}.footer-copyright{color:var(--color-text-muted);font-size:var(--text-sm)}.footer-meta{display:flex;gap:var(--space-4);font-size:var(--text-sm);color:var(--color-text-tertiary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);font-size:var(--text-sm);font-weight:500;font-family:var(--font-sans);text-decoration:none;border-radius:var(--radius-md);border:none;cursor:pointer;transition:all var(--transition-fast);min-height:44px;position:relative;overflow:hidden}.btn-primary{background:var(--color-slate);color:var(--color-parchment)}.btn-primary:hover{background:var(--color-slate-light);color:var(--color-parchment)}.btn-secondary{background:transparent;color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-primary-subtle);border-color:var(--color-slate);color:var(--color-slate)}.article-card{display:flex;flex-direction:column;padding:var(--space-6);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);text-decoration:none;color:inherit;transition:all var(--transition-base);position:relative;overflow:hidden}.article-card:hover{transform:translateY(-2px);box-shadow:0 4px 20px #1a1a1a14;border-color:var(--color-terracotta)}[data-theme=dark] .article-card:hover{box-shadow:0 4px 20px #0000004d}.article-card h3{font-family:var(--font-sans);font-size:var(--text-xl);color:var(--color-text);margin-bottom:var(--space-3);line-height:1.3}.article-card .description{color:var(--color-text-secondary);font-size:var(--text-sm);line-height:1.6;flex-grow:1;margin-bottom:var(--space-4)}.article-card .meta{display:flex;align-items:center;gap:var(--space-3);font-size:var(--text-xs);color:var(--color-text-muted)}.article-card .category{color:var(--color-terracotta);font-weight:500;font-variant-caps:all-small-caps;letter-spacing:.08em}.article-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:var(--space-6);margin-top:var(--space-8)}@media(max-width:640px){.article-grid{grid-template-columns:1fr;gap:var(--space-4)}}.tags{display:flex;gap:var(--space-2);flex-wrap:wrap}.tag{display:inline-flex;align-items:center;padding:var(--space-2) var(--space-3);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:500;color:var(--color-text-secondary);text-decoration:none;transition:all var(--transition-fast);min-height:32px}.tag:hover{background:var(--color-slate);color:var(--color-parchment);border-color:var(--color-slate)}@keyframes fade-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-out{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-10px)}}::view-transition-old(root){animation:fade-out .3s ease}::view-transition-new(root){animation:fade-in .3s ease}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes float{0%,to{transform:translate(0) rotate(0)}33%{transform:translate(30px,-30px) rotate(5deg)}66%{transform:translate(-20px,20px) rotate(-5deg)}}@keyframes fade-in-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.page-header{text-align:center;padding:var(--space-8) 0 var(--space-8);max-width:700px;margin:0 auto}.header-badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--color-primary-subtle);border:1px solid var(--color-primary-glass);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:500;color:var(--color-primary);margin-bottom:var(--space-6)}.badge-dot{width:8px;height:8px;background:var(--color-primary);border-radius:var(--radius-full);animation:pulse 2s ease-in-out infinite}.page-header h1{font-family:var(--font-sans);font-size:clamp(2.5rem,5vw,3.5rem);margin-bottom:var(--space-4)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-8);flex-wrap:wrap;gap:var(--space-4)}.section-header h2{font-family:var(--font-sans);font-size:var(--text-2xl);margin:0}.section-header p{color:var(--color-text-secondary);margin:0}}@layer groundy{.article-content{max-width:var(--content-width);margin:0 auto}.article-content h1,.article-content h2,.article-content h3,.article-content h4,.article-content h5,.article-content h6{scroll-margin-top:calc(var(--header-height) + var(--space-6))}.article-content h2{margin-top:var(--space-10);margin-bottom:var(--space-5)}.article-content h3{margin-top:var(--space-8);margin-bottom:var(--space-4)}.article-content h4,.article-content h5,.article-content h6{margin-top:var(--space-6);margin-bottom:var(--space-3)}.article-content h1:first-child,.article-content h2:first-child{margin-top:0}.article-content>h1:first-child{font-family:var(--font-serif)}.article-content p{margin-bottom:var(--space-5);line-height:1.8}.article-content ul,.article-content ol{margin:var(--space-5) 0;padding-left:var(--space-6)}.article-content li{margin:var(--space-2) 0;color:var(--color-text-secondary);line-height:1.7}.article-content ul li{list-style:none;position:relative}.article-content ul li:before{content:"";position:absolute;left:calc(-1 * var(--space-5));top:.6em;width:6px;height:6px;background:var(--color-terracotta);border-radius:50%;opacity:.8}.article-content ol li{padding-left:var(--space-2)}.article-content li>ul,.article-content li>ol{margin:var(--space-2) 0}.article-content blockquote{margin:var(--space-8) 0;padding:var(--space-6) var(--space-8);background:var(--color-bg-elevated);border-left:3px solid var(--color-terracotta);border-radius:0 var(--radius-lg) var(--radius-lg) 0;font-style:italic;color:var(--color-text-secondary);position:relative}.article-content blockquote:before{content:'"';position:absolute;top:var(--space-4);left:var(--space-4);font-family:var(--font-serif);font-size:var(--text-4xl);color:var(--color-terracotta);opacity:.2;line-height:1}.article-content blockquote p:last-child{margin-bottom:0}.table-wrapper{overflow-x:auto;margin:var(--space-8) 0;border-radius:var(--radius-lg);border:1px solid var(--color-border);background:var(--color-bg-elevated)}.article-content table{width:100%;border-collapse:separate;border-spacing:0;font-size:var(--text-sm)}.article-content thead{background:var(--color-bg-subtle)}.article-content th{padding:var(--space-4) var(--space-5);text-align:left;font-weight:600;font-size:var(--text-sm);color:var(--color-text);border-bottom:1px solid var(--color-border);white-space:nowrap}.article-content td{padding:var(--space-4) var(--space-5);font-size:var(--text-sm);color:var(--color-text-secondary);border-bottom:1px solid var(--color-border-light)}.article-content tr:last-child td{border-bottom:none}.article-content tbody tr:nth-child(2n){background:#2e4a3e05}[data-theme=dark] .article-content tbody tr:nth-child(2n){background:#5a7a6e0d}.article-content code{font-family:var(--font-mono);font-size:.9em;padding:var(--space-1) var(--space-2);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-slate)}.article-content pre code{padding:0;background:transparent;border:none;color:inherit}.article-content dl{margin:var(--space-6) 0}.article-content dt{font-weight:600;color:var(--color-text);margin-top:var(--space-4);font-family:var(--font-sans)}.article-content dd{margin-left:0;color:var(--color-text-secondary);margin-top:var(--space-1);padding-left:var(--space-4);border-left:2px solid var(--color-terracotta)}.article-content hr{margin:var(--space-12) 0;border:none;height:1px;background:linear-gradient(90deg,transparent,var(--color-border),transparent)}.aside{border-radius:var(--radius-lg);padding:var(--space-5) var(--space-6);margin:var(--space-8) 0;border:1px solid var(--color-border);position:relative;overflow:hidden;background:var(--color-bg-elevated)}.aside:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px}.aside-title{font-family:var(--font-sans);font-weight:600;font-size:var(--text-base);margin-bottom:var(--space-3);display:flex;align-items:center;gap:var(--space-2)}.aside-content{color:var(--color-text-secondary);font-size:var(--text-sm);line-height:1.7}.aside-content p:last-child{margin-bottom:0}.aside-content>*:first-child{margin-top:0}.aside-tip{border-color:var(--color-tip-border)}.aside-tip:before{background:var(--color-tip)}.aside-tip .aside-title{color:var(--color-tip)}.aside-caution{border-color:var(--color-caution-border)}.aside-caution:before{background:var(--color-caution)}.aside-caution .aside-title{color:var(--color-caution)}.aside-danger{border-color:var(--color-danger-border)}.aside-danger:before{background:var(--color-danger)}.aside-danger .aside-title{color:var(--color-danger)}.aside-note{border-color:var(--color-note-border)}.aside-note:before{background:var(--color-note)}.aside-note .aside-title{color:var(--color-note)}.expressive-code{margin:var(--space-8) 0;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--color-border)}.expressive-code .copy{opacity:0;transition:opacity var(--transition-fast)}.expressive-code:hover .copy{opacity:1}.expressive-code .line-numbers{color:var(--color-text-muted);font-size:var(--text-sm)}.footnotes{margin-top:var(--space-12);padding-top:var(--space-8);border-top:1px solid var(--color-border)}.footnotes-title{font-family:var(--font-sans);font-size:var(--text-lg);font-weight:600;color:var(--color-text);margin-bottom:var(--space-4)}.footnotes ol{padding-left:var(--space-5)}.footnotes li{font-size:var(--text-sm);color:var(--color-text-secondary);margin:var(--space-3) 0}.footnotes a[data-footnote-backref]{text-decoration:none;margin-left:var(--space-2)}sup a[data-footnote-ref]{text-decoration:none;font-weight:600;padding:0 var(--space-1);color:var(--color-terracotta)}.article-content input[type=checkbox]{appearance:none;width:1.2em;height:1.2em;border:2px solid var(--color-border);border-radius:var(--radius-sm);margin-right:var(--space-2);vertical-align:middle;position:relative;cursor:pointer}.article-content input[type=checkbox]:checked{background:var(--color-slate);border-color:var(--color-slate)}.article-content input[type=checkbox]:checked:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--color-parchment);font-size:.8em;font-weight:700}.article-content li:has(input[type=checkbox]){list-style:none;padding-left:0}.article-content li:has(input[type=checkbox]):before{display:none}.article-content li:has(input[type=checkbox]:checked){text-decoration:line-through;opacity:.6}.article-content h1:hover .anchor,.article-content h2:hover .anchor,.article-content h3:hover .anchor,.article-content h4:hover .anchor,.article-content h5:hover .anchor,.article-content h6:hover .anchor{opacity:1}.anchor{opacity:0;transition:opacity var(--transition-fast);margin-left:var(--space-2);text-decoration:none;color:var(--color-text-muted)}.anchor:hover{color:var(--color-terracotta)}}@layer utilities{:focus-visible{outline:2px solid var(--color-terracotta);outline-offset:2px;border-radius:var(--radius-sm)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}html{scroll-behavior:auto}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.gradient-dawn{background:var(--gradient-dawn)}.gradient-focus{background:var(--gradient-focus)}.text-slate{color:var(--color-slate)}.text-terracotta{color:var(--color-terracotta)}.text-parchment{color:var(--color-parchment)}.text-stone{color:var(--color-stone)}.bg-slate{background-color:var(--color-slate)}.bg-terracotta{background-color:var(--color-terracotta)}.bg-parchment{background-color:var(--color-parchment)}}.astro-route-announcer{position:absolute;left:0;top:0;clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;white-space:nowrap;width:1px;height:1px}
