:root{--bg:#fafafa;--bg-subtle:#f4f4f5;--panel:#fff;--panel-hover:#fafafa;--code-bg:#f8f8f9;--code-border:#e4e4e7;--border:#e4e4e7;--border-strong:#d4d4d8;--border-focus:#a1a1aa;--text:#09090b;--text-muted:#71717a;--text-subtle:#a1a1aa;--accent:#18181b;--accent-hover:#27272a;--accent-fg:#fff;--accent-soft:#f4f4f5;--danger:#dc2626;--danger-soft:#fef2f2;--danger-border:#fecaca;--success:#16a34a;--success-soft:#f0fdf4;--success-border:#bbf7d0;--warning:#ca8a04;--warning-soft:#fefce8;--warning-border:#fde68a;--info:#0284c7;--info-soft:#f0f9ff;--info-border:#bae6fd;--radius-sm:6px;--radius:8px;--radius-lg:12px;--shadow-sm:0 1px 2px 0 rgba(0,0,0,.04);--shadow:0 1px 3px 0 rgba(0,0,0,.06),0 1px 2px -1px rgba(0,0,0,.04);--shadow-md:0 4px 6px -1px rgba(0,0,0,.08),0 2px 4px -2px rgba(0,0,0,.04);--font-sans:ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;--font-mono:ui-monospace,SFMono-Regular,"SF Mono",Menlo,Monaco,Consolas,monospace}*{box-sizing:border-box}body{background:var(--bg);font-family:var(--font-sans);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a,body{color:var(--text)}a{text-decoration:none;transition:color .15s}a:hover{color:var(--text-muted)}code{font-family:var(--font-mono);font-size:.9em;background:var(--code-bg);border:1px solid var(--code-border);padding:1px 6px;border-radius:4px}code,h1,h2,h3,h4{color:var(--text)}h1,h2,h3,h4{margin:0;letter-spacing:-.015em}h1{font-size:24px;letter-spacing:-.025em}h1,h2{font-weight:600}h2{font-size:16px;margin-bottom:12px}h3{font-size:14px;font-weight:600}p{margin:0 0 12px}p:last-child{margin-bottom:0}.admin-shell{max-width:1040px;margin:0 auto;padding:24px 24px 64px}.admin-nav{display:flex;justify-content:space-between;align-items:center;padding:12px 0;margin-bottom:32px;border-bottom:1px solid var(--border)}.admin-nav>a:first-child{font-weight:600;font-size:15px;color:var(--text);letter-spacing:-.01em}.admin-nav .nav-links{display:flex;gap:4px;align-items:center}.admin-nav .nav-links a{color:var(--text-muted);padding:6px 12px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;transition:all .15s}.admin-nav .nav-links a:hover{color:var(--text);background:var(--accent-soft)}.admin-nav .nav-links .muted{padding:6px 8px;font-size:12px}.admin-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:24px;margin-bottom:16px;box-shadow:var(--shadow-sm)}.admin-card h2{display:flex;align-items:center;gap:8px;letter-spacing:-.01em}.admin-card>p:first-of-type{color:var(--text-muted)}.admin-card ul{padding-left:0;list-style:none;margin:0}.admin-card ul li{padding:4px 0;font-size:13px;color:var(--text-muted)}.admin-card ul li code{font-size:12px;color:var(--text);word-break:break-all}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--border)}.page-header h1{margin:0}.admin-form{display:grid;grid-gap:16px;gap:16px}.admin-form label{display:grid;grid-gap:6px;gap:6px;font-size:13px;font-weight:500;color:var(--text)}.admin-form input[type=password],.admin-form input[type=text],.admin-form input[type=url],.admin-form textarea{padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;background:var(--panel);color:var(--text);transition:all .15s;line-height:1.5}.admin-form textarea{font-family:var(--font-mono);font-size:13px;resize:vertical;min-height:80px}.admin-form input:hover,.admin-form textarea:hover{border-color:var(--border-strong)}.admin-form input:focus,.admin-form textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(0,0,0,.05)}.admin-form small{color:var(--text-muted);font-weight:400;font-size:12px;line-height:1.5}.admin-form small code{font-size:11px}.admin-form select{padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;background:var(--panel);color:var(--text);transition:all .15s;line-height:1.5;cursor:pointer}.admin-form select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(0,0,0,.05)}.form-grid-2{display:grid;grid-template-columns:1fr 1fr;grid-gap:16px;gap:16px}.form-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;grid-gap:16px;gap:16px}@media (max-width:720px){.form-grid-2,.form-grid-3{grid-template-columns:1fr}}.framework-picker{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));grid-gap:8px;gap:8px;margin-top:8px}.framework-option{display:block;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--panel);color:var(--text);font-size:13px;font-weight:500;text-align:left;transition:all .15s;text-decoration:none;cursor:pointer}.framework-option:hover{border-color:var(--border-strong);background:var(--bg-subtle);color:var(--text)}.framework-option.framework-active{border-color:var(--accent);background:var(--accent);color:var(--accent-fg);box-shadow:var(--shadow-sm)}.framework-option.framework-active:hover{color:var(--accent-fg);background:var(--accent-hover)}table.posts-table{font-size:13px}table.posts-table td{vertical-align:top}.btn,table.posts-table time{white-space:nowrap}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 14px;background:var(--accent);border:1px solid var(--accent);border-radius:var(--radius-sm);font-size:13px;font-weight:500;cursor:pointer;text-decoration:none;font-family:inherit;line-height:1;transition:all .15s}.btn,.btn:hover{color:var(--accent-fg)}.btn:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(0,0,0,.1)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--panel);color:var(--text);border-color:var(--border)}.btn-secondary:hover{background:var(--accent-soft);color:var(--text);border-color:var(--border-strong)}.btn-danger{background:var(--danger);border-color:var(--danger);color:#fff}.btn-danger:hover{background:#b91c1c;border-color:#b91c1c;color:#fff}.error-banner,.success-banner{padding:10px 14px;border-radius:var(--radius-sm);font-size:13px;border:1px solid;display:flex;align-items:flex-start;gap:8px}.error-banner{background:var(--danger-soft);border-color:var(--danger-border);color:var(--danger)}.success-banner{background:var(--success-soft);border-color:var(--success-border);color:var(--success)}.api-key-box{background:var(--warning-soft);border:1px solid var(--warning-border);border-radius:var(--radius);padding:16px;margin:0 0 16px;box-shadow:var(--shadow-sm)}.api-key-box strong{display:block;margin-bottom:10px;color:#854d0e;font-size:13px;font-weight:600;letter-spacing:-.005em}.api-key-value{display:block;background:var(--panel);border:1px solid var(--warning-border);padding:10px 12px;font-family:var(--font-mono);font-size:12px;word-break:break-all;border-radius:var(--radius-sm);-webkit-user-select:all;-moz-user-select:all;user-select:all;color:var(--text);line-height:1.5}.api-key-warning{color:#713f12;font-size:12px;margin-top:10px;line-height:1.5}table.sites{width:100%;border-collapse:collapse;font-size:13px}table.sites td,table.sites th{text-align:left;padding:10px 12px;border-bottom:1px solid var(--border)}table.sites tr:last-child td{border-bottom:none}table.sites th{font-weight:500;color:var(--text-muted);font-size:11px;text-transform:uppercase;letter-spacing:.05em;background:var(--bg-subtle);border-bottom:1px solid var(--border)}table.sites tbody tr{transition:background .1s}table.sites tbody tr:hover{background:var(--panel-hover)}table.sites a{color:var(--text);font-weight:500}table.sites a:hover{color:var(--accent-hover);text-decoration:underline;text-underline-offset:2px}.code-block{background:#22272e;color:#adbac7;border:1px solid #2d333b;padding:14px 16px;overflow-x:auto;font-family:var(--font-mono);font-size:12.5px;line-height:1.65;white-space:pre;-moz-tab-size:2;tab-size:2}.code-block,.code-block-wrap{border-radius:var(--radius-sm);margin:10px 0 0}.code-block-wrap{overflow:hidden;border:1px solid #2d333b;box-shadow:var(--shadow-sm)}.code-block-wrap pre.shiki{margin:0;padding:14px 16px;overflow-x:auto;font-family:var(--font-mono);font-size:12.5px;line-height:1.5;-moz-tab-size:2;tab-size:2;white-space:pre}.code-block-wrap pre.shiki code{background:transparent;border:0;padding:0;font-family:inherit;font-size:inherit;color:inherit;display:block}.code-block-wrap pre.shiki .line{display:inline}.code-block-wrap pre.shiki::-webkit-scrollbar,.code-block::-webkit-scrollbar{height:8px;width:8px}.code-block-wrap pre.shiki::-webkit-scrollbar-track,.code-block::-webkit-scrollbar-track{background:transparent}.code-block-wrap pre.shiki::-webkit-scrollbar-thumb,.code-block::-webkit-scrollbar-thumb{background:#434d58;border-radius:4px}.muted code,details code,li code,p code,small code{background:var(--code-bg);border:1px solid var(--code-border);color:var(--text)}.muted{color:var(--text-muted);font-size:13px;line-height:1.6}.inline-form{display:inline}.row-actions{display:flex;gap:8px}details{border:1px solid var(--border);border-radius:var(--radius);background:var(--panel);margin-bottom:10px;transition:all .15s;overflow:hidden}details:hover,details[open]{border-color:var(--border-strong)}details[open]{background:var(--panel);box-shadow:var(--shadow-sm)}details summary{list-style:none;padding:14px 16px;cursor:pointer;font-weight:500;font-size:14px;color:var(--text);display:flex;align-items:center;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:background .15s}details summary:hover{background:var(--bg-subtle)}details summary::-webkit-details-marker{display:none}details summary:before{content:"";display:inline-block;width:8px;height:8px;margin-right:10px;border-right:1.5px solid var(--text-muted);border-bottom:1.5px solid var(--text-muted);transform:rotate(-45deg);transition:transform .15s;flex-shrink:0}details[open] summary:before{transform:rotate(45deg)}details summary code{font-size:12px}details>:not(summary){padding:0 16px 16px 42px;color:var(--text-muted)}details>:not(summary):first-of-type{border-top:1px solid var(--border);margin-top:0;padding-top:16px}details p{line-height:1.65}details p,details ul{color:var(--text-muted);font-size:13px}details ul{padding-left:16px;list-style:disc}details ul li{padding:3px 0;line-height:1.65}details pre.code-block{margin:10px 0 0}.callout-info{background:var(--info-soft);border:1px solid var(--info-border);border-radius:var(--radius);padding:14px 16px;margin-bottom:20px;font-size:13px;line-height:1.6;color:#0c4a6e}.callout-info strong{display:block;margin-bottom:6px;color:#075985}.callout-info ol,.callout-info ul{padding-left:20px;margin:4px 0 0}.callout-info li{padding:2px 0}.admin-form label.checkbox-label{display:flex;flex-direction:row;align-items:flex-start;gap:10px;padding:12px;background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer}.admin-form label.checkbox-label input[type=checkbox]{width:16px;height:16px;margin-top:2px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}.admin-form label.checkbox-label span{font-weight:400;font-size:13px;color:var(--text-muted);line-height:1.5}.admin-form label.checkbox-label span strong{color:var(--text);font-weight:500}.button-group{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.tab-nav{display:flex;gap:2px;border-bottom:1px solid var(--border);margin-bottom:24px;overflow-x:auto;scrollbar-width:none}.tab-nav::-webkit-scrollbar{display:none}.tab-nav .tab{padding:10px 14px;font-size:13px;font-weight:500;color:var(--text-muted);border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .15s;white-space:nowrap}.tab-nav .tab:hover{color:var(--text)}.tab-nav .tab-active{color:var(--text);border-bottom-color:var(--accent)}.section-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:12px}.section-header h2{margin:0}.kv{display:grid;grid-template-columns:minmax(120px,180px) 1fr;grid-gap:10px 16px;gap:10px 16px;font-size:13px}.kv dt{color:var(--text-muted);font-weight:500}.kv dd{margin:0;color:var(--text);word-break:break-word}.kv dd code{font-size:12px}.step{border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:16px;background:var(--panel);transition:border-color .15s}.step:hover{border-color:var(--border-strong)}.step-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}.step-number{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;background:var(--accent);color:var(--accent-fg);border-radius:50%;font-size:12px;font-weight:600;flex-shrink:0}.step-title{font-size:15px;font-weight:600;margin:0;letter-spacing:-.01em}.step-description{color:var(--text-muted);font-size:13px;line-height:1.65;margin:0 0 12px}.step-description ul{padding-left:20px;margin:8px 0 0;list-style:disc}.step-description ul li{padding:2px 0;line-height:1.65}.step-note{color:var(--text-muted);font-size:12px;margin:10px 0 0;padding:8px 12px;background:var(--bg-subtle);border-radius:var(--radius-sm);border-left:3px solid var(--border-strong);line-height:1.6}.admin-card.danger{border-color:var(--danger-border);background:var(--danger-soft)}.admin-card.danger h2{color:var(--danger)}.admin-card.danger p{color:#991b1b}.split-pane{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);grid-gap:16px;gap:16px;align-items:flex-start}.split-pane>div{min-width:0}.split-pane-label{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin:0 0 8px}@media (max-width:880px){.split-pane{grid-template-columns:1fr}}.view-toggle{display:inline-flex;gap:2px;padding:3px;background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--radius-sm)}.view-toggle a{padding:6px 12px;font-size:13px;font-weight:500;color:var(--text-muted);border-radius:4px;transition:all .15s}.view-toggle a:hover{color:var(--text)}.view-toggle a.active{color:var(--text);background:var(--panel);box-shadow:var(--shadow-sm)}.browser-frame{border:1px solid var(--border-strong);border-radius:10px;overflow:hidden;background:var(--panel);box-shadow:var(--shadow-md)}.browser-chrome{display:flex;align-items:center;gap:10px;padding:8px 12px;background:#f3f4f6;border-bottom:1px solid var(--border)}.browser-dots{display:flex;gap:6px}.browser-dots span{width:10px;height:10px;border-radius:50%;background:#d4d4d8}.browser-dots span:first-child{background:#fca5a5}.browser-dots span:nth-child(2){background:#fde68a}.browser-dots span:nth-child(3){background:#bbf7d0}.browser-url{flex:1 1;padding:4px 10px;background:#fff;border:1px solid var(--border);border-radius:4px;font-family:var(--font-mono);font-size:11px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.browser-viewport{max-height:640px;overflow-y:auto;background:#fff}.preview-landing{max-width:100%;padding:24px;font-family:ui-sans-serif,-apple-system,system-ui,sans-serif;color:#1f2937;line-height:1.65}.preview-landing-header{margin-bottom:24px}.preview-landing-header h1{font-size:24px;font-weight:700;margin:0 0 4px;color:#0f172a}.preview-landing-header>p{color:#64748b;margin:0;font-size:14px}.preview-breadcrumb{font-size:12px;color:#64748b;margin-bottom:16px}.preview-breadcrumb a{color:#2563eb}.preview-breadcrumb span:last-child{color:#64748b}.preview-article-header{margin-bottom:20px}.preview-article-header h1{font-size:26px;font-weight:700;line-height:1.25;margin:0 0 8px;color:#0f172a;letter-spacing:-.01em}.preview-meta{color:#64748b;font-size:12px;margin:0}.preview-cover{width:100%;height:auto;border-radius:8px;margin:16px 0 20px;display:block}.preview-post-list{list-style:none;padding:0;margin:0}.preview-post-list li{border-bottom:1px solid #e5e7eb;padding:16px 0}.preview-post-list li:last-child{border-bottom:none}.preview-post-list h2{font-size:17px;font-weight:600;margin:0 0 4px;color:#0f172a}.preview-link{color:#0f172a;cursor:pointer}.preview-excerpt{color:#475569;font-size:14px;margin:4px 0 6px}.preview-body{font-size:15px;line-height:1.75;color:#1f2937}.preview-body h2{font-size:19px;font-weight:700;margin:28px 0 12px;color:#0f172a}.preview-body h3{font-size:16px;font-weight:600;margin:20px 0 10px;color:#0f172a}.preview-body p{margin:0 0 14px}.preview-body ol,.preview-body ul{padding-left:22px;margin:0 0 14px;color:#374151}.preview-body li{padding:2px 0}.preview-body blockquote{border-left:3px solid #3b82f6;padding:4px 0 4px 16px;color:#475569;font-style:italic;margin:16px 0;font-size:14px}.preview-body code{background:#f1f5f9;border:1px solid #e2e8f0;padding:1px 5px;border-radius:3px;font-size:.88em;color:#0f172a}.preview-body strong{color:#0f172a;font-weight:600}.preview-body a{color:#2563eb;text-decoration:underline;text-underline-offset:2px}.preview-seo-info{margin-top:32px;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:6px;font-size:12px}.preview-seo-info summary{padding:10px 12px;color:#166534;font-weight:500}.preview-seo-info ul{padding:0 12px 12px 28px;margin:0;list-style:none;color:#166534;line-height:1.8}.preview-seo-info ul li{padding:0}.preview-seo-info code{font-size:11px;background:rgba(22,101,52,.08);border:none;padding:1px 4px;color:#0f172a}.quickstart-hero{margin-bottom:24px;padding:4px 0}.quickstart-hero h2{font-size:22px;font-weight:600;margin:0 0 6px;letter-spacing:-.01em;color:var(--text)}.quickstart-hero p{margin:0;font-size:14px}.action-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));grid-gap:16px;gap:16px;margin-bottom:32px}.action-card{position:relative;display:flex;flex-direction:column;padding:24px;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--panel);text-decoration:none;color:var(--text);transition:border-color .15s,box-shadow .15s,transform .15s;min-height:200px}.action-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-md);transform:translateY(-2px);color:var(--text)}.action-card-primary{border-color:var(--accent);border-width:1.5px}.action-card-primary:hover{border-color:var(--accent-hover);box-shadow:0 8px 16px -4px rgba(24,24,27,.18)}.action-card-badge{position:absolute;top:-10px;left:20px;background:var(--accent);color:var(--accent-fg);font-size:10px;font-weight:700;padding:4px 10px;border-radius:999px;letter-spacing:.06em;text-transform:uppercase}.action-card-icon{font-size:28px;line-height:1;margin-bottom:14px}.action-card-title{font-size:16px;font-weight:600;margin-bottom:8px;color:var(--text);letter-spacing:-.01em}.action-card-desc{font-size:13px;line-height:1.6;color:var(--text-muted);flex-grow:1}.action-card-desc code{font-size:12px}.action-card-cta{margin-top:16px;font-size:13px;font-weight:600;color:var(--accent)}.link-secondary{font-size:12px;font-weight:500;color:var(--text-muted);white-space:nowrap}.link-secondary:hover{color:var(--text)}.mode-switcher{display:flex;gap:4px;margin-bottom:24px;background:var(--bg-subtle);padding:4px;border-radius:var(--radius);border:1px solid var(--border);overflow-x:auto}.mode-option{flex:1 1;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 14px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;color:var(--text-muted);text-decoration:none;white-space:nowrap;transition:background .15s,color .15s,box-shadow .15s}.mode-option:hover{color:var(--text)}.mode-option.active{background:var(--panel);color:var(--text);box-shadow:var(--shadow-sm)}.mode-icon{font-size:14px;line-height:1}.mode-label{font-weight:500}.mode-hint{font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);background:var(--accent-soft);padding:2px 6px;border-radius:999px}.mode-option:not(.active) .mode-hint{opacity:.6}@media (max-width:720px){.mode-option{padding:8px 10px;font-size:12px}.mode-hint{display:none}}.help-accordion{margin-top:32px;padding-top:16px;border-top:1px dashed var(--border)}.help-accordion>summary{cursor:pointer;font-size:13px;font-weight:600;color:var(--text-muted);padding:8px 0;list-style:none;display:inline-flex;align-items:center;gap:6px}.help-accordion>summary::-webkit-details-marker{display:none}.help-accordion>summary:before{content:"›";display:inline-block;transition:transform .15s;font-size:14px}.help-accordion[open]>summary{color:var(--text);margin-bottom:12px}.help-accordion[open]>summary:before{transform:rotate(90deg)}.help-accordion-body{padding:8px 0 4px}.help-accordion-body details{margin:0 0 8px;padding:10px 14px;background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--radius-sm)}.help-accordion-body details summary{cursor:pointer;font-size:13px;font-weight:500;color:var(--text)}.help-accordion-body details[open] summary{margin-bottom:8px}.help-accordion-body details p,.help-accordion-body details ul{margin:6px 0 0;font-size:13px;line-height:1.6;color:var(--text-muted)}.help-accordion-body details ul{padding-left:22px}.help-accordion-body details li{padding:2px 0}