:root{--brand-blue: #0099ff;--brand-blue-dark: #007acc;--brand-blue-light: #e6f4ff;--cta-orange: #f97316;--cta-orange-dark: #ea6b0a;--devtools: #0099ff;--appbuilder: #f1592d;--reveal: #ec417a;--slingshot: #20226f;--ang: #dd0031;--angular: #dd0031;--react: #61dafb;--react-text: #0b6c87;--blazor: #512bd4;--danger: #dc2626;--warning: #d97706;--success: #16a34a;--text-1: #111111;--text-2: #444444;--text-3: #666666;--border: #d9d9d9;--border-strong: #b0b0b0;--bg: #f0f6ff;--surface: #ffffff;--surface-2: #f0f0f0;--surface-3: #e8e8e8;--s2: #f0f0f0;--s3: #e8e8e8;--font: "Noto Sans JP", sans-serif;--font-mono: SFMono-Regular, Consolas, Menlo, monospace;--max-width: 1280px;--article-width: 720px;--radius: 8px;--radius-sm: 4px;--radius-pill: 99px;--shadow-1: 0 1px 3px rgba(0,0,0,.08);--shadow-2: 0 4px 12px rgba(0,0,0,.12);--shadow-3: 0 8px 24px rgba(0,0,0,.15)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:var(--font);background:radial-gradient(ellipse 80% 50% at 5% 10%,rgba(0,153,255,.07) 0%,transparent 55%),radial-gradient(ellipse 65% 60% at 95% 90%,rgba(107,33,168,.05) 0%,transparent 55%),radial-gradient(ellipse 55% 45% at 80% 5%,rgba(249,115,22,.04) 0%,transparent 50%),radial-gradient(ellipse 60% 50% at 20% 95%,rgba(13,122,122,.04) 0%,transparent 55%),#f0f6ff;background-attachment:fixed;color:var(--text-1);font-size:16px;line-height:1.7;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-wrap:break-word}a{color:inherit;text-decoration:none}button{font-family:var(--font);cursor:pointer;border:none;background:none;color:inherit}img,svg{max-width:100%;display:block}h1,h2,h3,h4{font-feature-settings:"palt" 1;letter-spacing:.04em;color:var(--text-1)}h1{font-size:32px;font-weight:700;line-height:1.35}h2{font-size:24px;font-weight:700;line-height:1.4}h3{font-size:20px;font-weight:700;line-height:1.4}h4{font-size:18px;font-weight:600;line-height:1.5}@media(max-width:767px){h1{font-size:24px}h2{font-size:20px}h3{font-size:18px}}.gnav{background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:900}.gnav-in{max-width:var(--max-width);margin:0 auto;padding:0 20px;height:56px;display:flex;align-items:center;gap:8px}@media(min-width:768px){.gnav-in{padding:0}}.logo{font-size:17px;font-weight:700;margin-right:32px;white-space:nowrap;color:var(--text-1);letter-spacing:.02em}.logo span,.logo-accent{color:var(--brand-blue)}.nav-links{display:flex;gap:2px;flex:1}.nl{padding:8px 14px;border-radius:var(--radius);font-size:14px;color:var(--text-2);cursor:pointer;transition:background .15s,color .15s;white-space:nowrap;font-weight:500}.nl:hover{background:var(--surface-2);color:var(--text-1)}.nl.active{background:var(--brand-blue-light);color:var(--brand-blue);font-weight:700}.nav-cta{margin-left:auto;background:transparent;color:var(--brand-blue);border:1.5px solid var(--brand-blue);padding:8px 18px;border-radius:var(--radius);font-size:14px;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .15s,color .15s}.nav-cta:hover{background:var(--brand-blue-light)}.hamburger{display:none;margin-left:auto;padding:8px;border-radius:var(--radius)}.hamburger:hover{background:var(--surface-2)}.hamburger span{display:block;width:22px;height:2px;background:var(--text-1);margin:4px 0;transition:all .2s}@media(max-width:768px){.nav-links,.nav-cta{display:none}.hamburger{display:block}.gnav-in{padding:0 16px}}.gnav-drawer{display:none;position:fixed;inset:0;z-index:950}.gnav-drawer.open{display:block}.gnav-overlay{position:absolute;inset:0;background:#0006}.gnav-panel{position:absolute;top:0;right:0;width:280px;height:100%;background:var(--surface);box-shadow:var(--shadow-3);display:flex;flex-direction:column;transform:translate(100%);transition:transform .25s cubic-bezier(.4,0,.2,1);overflow-y:auto;overscroll-behavior:contain}.gnav-drawer.open .gnav-panel{transform:translate(0)}.gnav-drawer-head{height:56px;display:flex;align-items:center;justify-content:space-between;padding:0 16px;border-bottom:1px solid var(--border);flex-shrink:0}.gnav-close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);font-size:18px;color:var(--text-2);cursor:pointer;transition:background .15s}.gnav-close:hover{background:var(--surface-2)}.gnav-drawer-links{display:flex;flex-direction:column;padding:8px 0;flex:1}.gnav-drawer-links .nl{padding:14px 20px;font-size:15px;font-weight:500;color:var(--text-1);border-radius:0;border-bottom:1px solid var(--border);display:block;width:100%;text-align:left;min-height:48px}.gnav-drawer-links .nl:last-child{border-bottom:none}.gnav-drawer-links .nl:hover{background:var(--surface-2)}.gnav-drawer-links .nl.active{color:var(--brand-blue);background:var(--brand-blue-light);font-weight:700}.gnav-drawer-cta{padding:16px;border-top:1px solid var(--border);flex-shrink:0}.gnav-drawer-cta .nav-cta{display:block;width:100%;text-align:center;padding:12px 18px;min-height:48px}.hamburger.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}body.drawer-open{overflow:hidden}footer{background:var(--surface);border-top:1px solid var(--border);padding:32px 20px}@media(min-width:768px){footer{padding:40px}}.fi{max-width:var(--max-width);margin:0 auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}.fl{font-size:16px;font-weight:700;letter-spacing:.02em}.fl span{color:var(--brand-blue)}.fls{display:flex;gap:24px;flex-wrap:wrap}.fla{font-size:13px;color:var(--text-2);cursor:pointer;transition:color .15s}.fla:hover{color:var(--brand-blue)}.fc2{font-size:12px;color:var(--text-3);width:100%;text-align:center;padding-top:16px;border-top:1px solid var(--border);margin-top:8px}@media(min-width:768px){.fc2{width:auto;text-align:right;padding-top:0;border-top:none;margin-top:0}}.bc{max-width:var(--max-width);margin:0 auto;padding:16px 20px 8px;display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:13px;color:var(--text-3)}.bc a{color:var(--brand-blue);cursor:pointer;text-decoration:underline}.bc a:hover{color:var(--brand-blue-dark)}.bc .sep{color:var(--border-strong)}.bc .cur{color:var(--text-2)}@media(min-width:768px){.bc{padding:16px 0 8px}}.tag{display:inline-flex;align-items:center;font-size:12px;font-weight:700;padding:3px 10px;border-radius:var(--radius-pill);letter-spacing:.02em;line-height:1.4}.tag-wp{background:#0099ff14;color:var(--brand-blue);border:1px solid rgba(0,153,255,.25)}.tag-case{background:#16a34a14;color:#15803d;border:1px solid rgba(22,163,74,.25)}.tag-col{background:#6b21a814;color:#6b21a8;border:1px solid rgba(107,33,168,.25)}.tag-vid{background:#f9731614;color:var(--cta-orange-dark);border:1px solid rgba(249,115,22,.25)}.tag-ev{background:#0d7a7a14;color:#0d7a7a;border:1px solid rgba(13,122,122,.25)}.tag-topic{background:var(--s2);color:var(--text-2);border:1px solid var(--border)}.tag-cat{background:#4f46e514;color:#4338ca;border:1px solid rgba(79,70,229,.25)}.tag-devtools{background:#0099ff14;color:var(--devtools);border:1px solid rgba(0,153,255,.25)}.tag-appbuilder{background:#f1592d14;color:var(--appbuilder);border:1px solid rgba(241,89,45,.25)}.tag-reveal{background:#ec417a14;color:var(--reveal);border:1px solid rgba(236,65,122,.25)}.tag-new,.tag-form{display:inline-flex;align-items:center;font-size:11px;font-weight:700;padding:2px 8px;border-radius:var(--radius-pill);background:#f973161a;color:var(--cta-orange-dark);border:1px solid rgba(249,115,22,.3)}.fw-badge{font-size:11px;font-weight:700;padding:3px 10px;border-radius:var(--radius-pill);letter-spacing:.04em}.fw-badge.angular{background:#dd003114;color:var(--ang);border:1px solid rgba(221,0,49,.25)}.fw-badge.react{background:#61dafb24;color:var(--react-text);border:1px solid rgba(97,218,251,.4)}.fw-badge.blazor{background:#512bd414;color:var(--blazor);border:1px solid rgba(81,43,212,.25)}.container{max-width:var(--max-width);margin:0 auto;padding:0 20px}@media(min-width:768px){.container{padding:0 40px}}.page-header{padding:8px 20px 28px}.page-header-in{max-width:var(--max-width);margin:0 auto}.ph-eyebrow{font-size:11px;font-weight:700;color:var(--text-3);letter-spacing:.1em;text-transform:uppercase;margin-bottom:10px}.ph-title{font-size:32px;font-weight:700;line-height:1.35;margin-bottom:12px;color:var(--text-1)}.ph-desc{font-size:15px;color:var(--text-2);line-height:1.8;margin-bottom:16px;letter-spacing:normal;font-feature-settings:normal}.ph-meta{display:flex;gap:24px;flex-wrap:wrap;padding-top:4px;font-size:13px;color:var(--text-3)}.ph-meta strong{color:var(--text-1);font-size:15px;font-weight:700}.ph-meta code{font-family:var(--font-mono);font-size:12px;color:var(--brand-blue);background:var(--brand-blue-light);padding:2px 8px;border-radius:var(--radius-sm)}.pagination{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:32px}.pg-btn{min-width:40px;height:40px;padding:0 10px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:500;cursor:pointer;border:1px solid var(--border);background:var(--surface);color:var(--text-2);transition:all .15s;font-family:var(--font)}.pg-btn:hover:not(:disabled){background:var(--brand-blue-light);color:var(--brand-blue);border-color:#0099ff4d}.pg-btn.active{background:var(--brand-blue);color:#fff;border-color:var(--brand-blue);font-weight:700}.pg-btn:disabled{opacity:.4;cursor:default}.toast{position:fixed;bottom:24px;right:24px;background:var(--text-1);color:#fff;border-radius:var(--radius);padding:12px 18px;font-size:13px;z-index:9999;opacity:0;transform:translateY(8px);transition:all .25s;pointer-events:none;max-width:320px;line-height:1.6;box-shadow:var(--shadow-3)}.toast.show{opacity:1;transform:translateY(0)}.toast .tu{font-size:11px;color:#94a3b8;word-break:break-all;margin-top:4px;font-family:var(--font-mono)}
