@import "https://fonts.googleapis.com/css2?family=Inter:wght@100..900&family=Newsreader:ital,wght@1,200..800&display=swap";:root{--font:"Inter", system-ui, -apple-system, sans-serif;--font-serif:"Newsreader", Georgia, serif;--font-code:"SF Mono", "Consolas", Menlo, monospace;--bg:#fdfdfc;--bg-subtle:#f8f8f8;--bg-surface:#0000000a;--bg-card:#00000005;--text:#111;--text-muted:#0006;--text-mid:#0009;--text-faint:#0000004d;--border:#0000000f;--border-mid:#0000001a;--border-rule:#e6e6e6;--accent:#3e9fff;--accent-hover:#74b1fd;--_accent-purple:#9896ff;--_accent-teal:#1ec6a2;--_accent-cyan:#00cbff;--_accent-orange:#f09637;--_accent-magenta:#f0a;--error:#ff0052;--success:#00ca48;--highlight:#fef9c0;--selection-bg:#ededed;--focus:#3e9fff80;--ink:#2c2d30;--ink-muted:#2c2d3099;--ink-faint:#2c2d304d;--text-hero:1.1875rem;--text-h1:1.1875rem;--text-h2:.9375rem;--text-h3:.9375rem;--text-h4:.8125rem;--text-body:.875rem;--text-small:.8125rem;--text-label:.75rem;--text-product-hero:2.875rem;--text-product-h1:2.875rem;--text-product-h2:1.75rem;--text-product-h3:1.625rem;--text-product-h5:1.125rem;--text-product-body:1rem;--text-product-lg:1.25rem;--weight-regular:400;--weight-text:450;--weight-ui:500;--weight-mid:550;--weight-heading:600;--tracking-normal:-.006em;--tracking-tight:-.02em;--tracking-button:-.09px;--leading-tight:1.25rem;--leading-base:1.55;--leading-copy:1.6;--space-1:.5rem;--space-2:1rem;--space-3:1.5rem;--space-4:2rem;--space-5:2.5rem;--space-6:3rem;--space-7:3.5rem;--max-width:36.375rem;--max-width-article:70ch;--max-width-wide:64rem;--gutter:var(--space-3);--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-pill:50px;--radius-full:9999px;--shadow-card:0 0 0 1px #0000000d;--shadow-card-hover:0 0 0 1px #0000001a;--shadow-elevated:0 4px 24px #0000001a;--shadow-nav:0 2px 8px #00000014, 0 4px 16px #0000000a, inset 0 0 0 1px #0000000f;--ease-snappy:cubic-bezier(.175, .885, .32, 1.1);--ease-swift:cubic-bezier(.175, .885, .32, 1.275);--ease-smooth:cubic-bezier(.19, 1, .22, 1);--dur-fast:.15s;--dur-base:.22s;--dur-slow:.3s;--dur-enter:.8s}*,:before,:after{box-sizing:border-box;margin:0;padding:0}button,input,select,textarea{font-family:inherit;font-size:inherit}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;scrollbar-gutter:stable;font-size:16px}body{font-family:var(--font);font-size:var(--text-body);font-weight:var(--weight-text);line-height:var(--leading-tight);letter-spacing:var(--tracking-normal);color:var(--text);background-color:var(--bg)}::selection{background:var(--selection-bg);color:var(--text)}:focus-visible{outline:2px solid var(--focus);outline-offset:2px;border-radius:var(--radius-sm)}h1,h2,h3,h4,h5,h6{font-family:var(--font);font-weight:var(--weight-heading);letter-spacing:var(--tracking-tight);color:var(--text);line-height:1.2}h1{font-size:var(--text-h1)}h2{font-size:var(--text-h2)}h3{font-size:var(--text-h3)}h4{font-size:var(--text-h4)}h5{font-size:var(--text-small);font-weight:var(--weight-ui)}h6{font-size:var(--text-label);font-weight:var(--weight-ui);text-transform:uppercase;letter-spacing:.04em}p{font-size:var(--text-body);font-weight:var(--weight-text);line-height:var(--leading-copy);color:var(--text)}p+p{margin-top:var(--space-3)}small{font-size:var(--text-small);color:var(--text-muted)}strong{font-weight:var(--weight-heading)}em{font-family:var(--font-serif);font-style:italic}a{color:inherit;text-decoration:none}.link{color:inherit;transition:color var(--dur-base) ease;display:inline;position:relative}.link:after{content:"";height:1px;transition:background var(--dur-base) ease;background:#d9d9d9;position:absolute;bottom:-1px;left:0;right:0}.link:hover:after{background:#666}.link-accent{color:var(--accent);transition:color var(--dur-base) ease}.link-accent:hover{color:var(--accent-hover)}hr{border:none;border-top:1px solid var(--border-rule);margin:var(--space-5) 0}code{font-family:var(--font-code);color:var(--text-mid);padding:.1em .2em;font-size:.9em;display:inline-block;position:relative}code:before{content:"";border-radius:var(--radius-sm);background:var(--bg-surface);z-index:-1;position:absolute;inset:-.1em 0}pre{border-radius:var(--radius-md);background:var(--bg-subtle);padding:var(--space-3) var(--space-3);display:block;overflow-x:auto}pre code{font-size:var(--text-small);line-height:var(--leading-base);color:var(--text);padding:0}pre code:before{display:none}blockquote{font-family:var(--font-serif);font-size:var(--text-small);color:var(--text-mid);padding:var(--space-4) 0 var(--space-4) var(--space-4);font-style:italic;line-height:1.6;position:relative}blockquote:before{content:"";background:var(--border-rule);width:2px;position:absolute;top:0;bottom:0;left:0}mark{color:inherit;background:0 0;display:inline;position:relative}mark:before{content:"";background:var(--highlight);z-index:-1;border-radius:2px;position:absolute;inset:55% -.1em 0}ul,ol{padding-left:var(--space-3);color:var(--text)}li{font-size:var(--text-body);line-height:var(--leading-copy);margin-bottom:var(--space-1)}time{font-size:var(--text-body);font-weight:var(--weight-text);color:var(--text-muted)}img{max-width:100%;height:auto;display:block}.container{width:100%;max-width:var(--max-width);padding-inline:var(--gutter);margin-inline:auto}.container--wide{max-width:var(--max-width-wide)}.container--article{max-width:var(--max-width-article)}.container--full{max-width:100%}.btn{border-radius:var(--radius-pill);font-family:var(--font);font-size:14px;font-weight:var(--weight-ui);letter-spacing:var(--tracking-button);white-space:nowrap;-webkit-user-select:none;user-select:none;cursor:pointer;transition:all var(--dur-base) ease;border:none;justify-content:center;align-items:center;gap:.375rem;line-height:18px;text-decoration:none;display:inline-flex}.btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.btn:not(:disabled):active{transform:scale(.99)}.btn--sm{height:30px;font-size:var(--text-small);padding:0 .75rem}.btn--md{height:36px;padding:0 1rem;font-size:14px}.btn--lg{height:40px;padding:0 1.125rem;font-size:.9375rem}.btn--xl{height:44px;padding:0 1.25rem;font-size:15px}.btn--default{background:var(--text);color:var(--bg)}.btn--default:not(:disabled):hover{background:#000}.btn--secondary{color:var(--text);box-shadow:var(--shadow-card);background:#fff}.btn--secondary:not(:disabled):hover{box-shadow:var(--shadow-card-hover)}.btn--ghost{color:var(--text);background:0 0}.btn--ghost:not(:disabled):hover{background:var(--bg-surface)}.btn--accent{background:var(--accent);color:#fff}.btn--accent:not(:disabled):hover{background:var(--accent-hover)}.btn--danger{color:#fff;background:#f43b5c}.btn--danger:not(:disabled):hover{background:#ec284c}.badge{border-radius:var(--radius-full);font-size:var(--text-label);font-weight:var(--weight-ui);background:var(--bg-surface);color:var(--text);align-items:center;gap:.25rem;padding:.125rem .5rem;line-height:1.5;display:inline-flex}.badge--new{color:#fff;background:#f0a}.badge--accent{background:var(--accent);color:#fff}.badge--success{color:#00a83c;background:#00ca481f}.badge--error{color:var(--error);background:#ff00521a}.card{border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:var(--space-4);transition:box-shadow var(--dur-base) ease;background:#fff}.card:hover{box-shadow:var(--shadow-card-hover)}.card--elevated{box-shadow:var(--shadow-elevated)}.card--subtle{background:var(--bg-card);box-shadow:none}.nav-back{z-index:100;border-radius:var(--radius-full);width:40px;height:40px;color:var(--text-muted);box-shadow:var(--shadow-nav);cursor:pointer;transition:all var(--dur-base) var(--ease-snappy);background:#fff;border:none;justify-content:center;align-items:center;text-decoration:none;display:flex;position:fixed;top:1.25rem;right:1.25rem}.nav-back:hover{color:var(--text);transform:scale(1.05)}.basic-link{color:inherit;transition:all var(--dur-base) ease;display:inline;position:relative}.basic-link:before{content:"";height:1px;transition:background var(--dur-base) ease;background:#d9d9d9;position:absolute;bottom:0;left:0;right:0}.basic-link:hover:before{background:#666}.styled-link{color:#2480ed;transition:color var(--dur-base) ease;align-items:center;gap:.25rem;display:inline-flex;position:relative}.styled-link:hover{color:var(--accent-hover)}.post-list{padding:0;list-style:none}.post-list-item{align-items:baseline;gap:var(--space-3);padding:var(--space-2) 0;border-bottom:1px solid var(--border-rule);display:flex}.post-list-item:last-child{border-bottom:none}.post-list-date{font-size:var(--text-small);color:var(--text-muted);font-weight:var(--weight-text);white-space:nowrap;flex-shrink:0}.post-list-title{font-size:var(--text-body);font-weight:var(--weight-text);color:var(--text);flex:1}.section-dark{background:var(--ink);color:#fff}.section-dark p,.section-dark h1,.section-dark h2,.section-dark h3{color:#fff}.section-dark .text-muted{color:var(--ink-muted)}.text-muted{color:var(--text-muted)}.text-mid{color:var(--text-mid)}.text-faint{color:var(--text-faint)}.text-accent{color:var(--accent)}.text-error{color:var(--error)}.text-label{font-size:var(--text-label);font-weight:var(--weight-ui)}.text-small{font-size:var(--text-small)}.text-body{font-size:var(--text-body)}.text-h2{font-size:var(--text-h2)}.text-h1{font-size:var(--text-h1)}.text-hero{font-size:var(--text-hero);font-weight:var(--weight-heading)}.mt-1{margin-top:var(--space-1)}.mt-2{margin-top:var(--space-2)}.mt-3{margin-top:var(--space-3)}.mt-4{margin-top:var(--space-4)}.mt-5{margin-top:var(--space-5)}.mt-6{margin-top:var(--space-6)}.mb-1{margin-bottom:var(--space-1)}.mb-2{margin-bottom:var(--space-2)}.mb-3{margin-bottom:var(--space-3)}.mb-4{margin-bottom:var(--space-4)}.mb-5{margin-bottom:var(--space-5)}.mb-6{margin-bottom:var(--space-6)}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.w-full{width:100%}.h-full{height:100%}
