:root,[data-theme=dark]{--bg:#0a0a0c;--bg-soft:#111114;--panel:rgba(255,255,255,0.04);--panel-strong:rgba(255,255,255,0.06);--border:rgba(255,255,255,0.09);--border-strong:rgba(255,255,255,0.16);--fg:#f4f4f5;--fg-dim:#c9c9d2;--muted:#8a8a93;--accent:#8b8bf4;--accent-fg:#0a0a0c;--chip:rgba(139,139,244,0.12);--chip-border:rgba(139,139,244,0.3);--radius:18px;--shadow:0 10px 40px rgba(0,0,0,0.45)}[data-theme=light]{--bg:#f7f7fb;--bg-soft:#ffffff;--panel:rgba(13,13,20,0.025);--panel-strong:rgba(13,13,20,0.05);--border:rgba(13,13,20,0.1);--border-strong:rgba(13,13,20,0.18);--fg:#14141a;--fg-dim:#33333d;--muted:#5b5b67;--accent:#0e7490;--accent-fg:#ffffff;--chip:rgba(14,116,144,0.1);--chip-border:rgba(14,116,144,0.3);--shadow:0 8px 30px rgba(13,13,20,0.1)}*{box-sizing:border-box}body,html{margin:0;padding:0;background:var(--bg);color:var(--fg);font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Noto Sans Thai,sans-serif;-webkit-font-smoothing:antialiased}:lang(th),[lang=th]{font-family:Noto Sans Thai,Inter,ui-sans-serif,system-ui,sans-serif}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.display,h1,h2,h3{font-family:Sora,Inter,ui-sans-serif,system-ui,sans-serif;letter-spacing:-.02em}.nav{position:-webkit-sticky;position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:1.25rem;padding:.85rem clamp(1rem,4vw,2.5rem);background:color-mix(in srgb,var(--bg) 80%,transparent);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom:1px solid var(--border)}.nav__brand{font-family:Sora,sans-serif;font-weight:800;font-size:1.15rem;color:var(--fg);letter-spacing:-.03em}.nav__links{display:flex;gap:1.1rem;align-items:center;margin-left:auto}.nav__links a{color:var(--fg-dim);font-size:.95rem;font-weight:500}.nav__links a:hover{color:var(--accent);text-decoration:none}.theme-toggle{cursor:pointer;border:1px solid var(--border-strong);background:var(--panel);color:var(--fg-dim);border-radius:999px;padding:.35rem .7rem;font-size:.85rem;line-height:1}.blog{max-width:1240px;margin:0 auto;padding:clamp(1.25rem,3vw,2.5rem) clamp(1rem,4vw,2.5rem) 4rem}.blog__head h1{font-size:clamp(2rem,5vw,3rem);margin:0 0 .4rem;background:linear-gradient(180deg,var(--fg),color-mix(in srgb,var(--fg) 55%,transparent));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.blog__head p{color:var(--muted);margin:0 0 1.5rem;max-width:48rem}.blog__layout{display:grid;grid-template-columns:280px 1fr;grid-gap:clamp(1rem,3vw,2rem);gap:clamp(1rem,3vw,2rem);align-items:start}@media (max-width:860px){.blog__layout{grid-template-columns:1fr}}.sidebar{position:-webkit-sticky;position:sticky;top:70px;max-height:calc(100vh - 90px);overflow-y:auto;padding-right:.4rem}@media (max-width:860px){.sidebar{position:static;max-height:none}}.sidebar__section{margin-bottom:1.4rem}.sidebar__title{font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin:0 0 .5rem;font-weight:700}.langseg{display:inline-flex;border:1px solid var(--border);border-radius:999px;overflow:hidden;background:var(--panel)}.langseg button{border:0;background:transparent;color:var(--fg-dim);padding:.4rem .85rem;font-size:.85rem;cursor:pointer}.langseg button[aria-pressed=true]{background:var(--accent);color:var(--accent-fg);font-weight:600}.catgroup__name{font-size:.78rem;font-weight:700;color:var(--fg-dim);margin:.9rem 0 .35rem;text-transform:uppercase;letter-spacing:.06em}.catlist{list-style:none;margin:0;padding:0}.catlist--child{margin-left:.85rem;border-left:1px solid var(--border);padding-left:.5rem}.catitem{display:flex;align-items:center;gap:.4rem;width:100%;text-align:left;border:0;background:transparent;color:var(--fg-dim);cursor:pointer;padding:.28rem .45rem;border-radius:9px;font-size:.88rem;line-height:1.3}.catitem:hover{background:var(--panel-strong)}.catitem[aria-pressed=true]{background:var(--chip);color:var(--accent);font-weight:600}.catitem--parent{font-weight:600;color:var(--fg)}.catitem__count{margin-left:auto;font-size:.72rem;color:var(--muted);background:var(--panel-strong);border-radius:999px;padding:.05rem .45rem}.catitem[aria-pressed=true] .catitem__count,.sidebar__clear{color:var(--accent)}.sidebar__clear{margin-top:.5rem;font-size:.82rem;background:none;border:0;cursor:pointer;padding:0}.search{position:relative;margin-bottom:1.2rem}.search input{width:100%;padding:.8rem 1rem;border-radius:12px;border:1px solid var(--border-strong);background:var(--panel);color:var(--fg);font-size:1rem;outline:none}.search input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--chip)}.search__meta{margin:.6rem 0 0;color:var(--muted);font-size:.85rem}.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:1.1rem;gap:1.1rem}.card{display:flex;flex-direction:column;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease}.card:hover{transform:translateY(-3px);border-color:var(--border-strong);box-shadow:var(--shadow);text-decoration:none}.card__cover{aspect-ratio:16/9;width:100%;object-fit:cover;background:var(--bg-soft);display:block}.card__cover--ph{aspect-ratio:16/9;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--panel-strong),var(--bg-soft));color:var(--muted);font-family:Sora,sans-serif;font-weight:700;font-size:1.6rem}.card__body{padding:.95rem 1.05rem 1.1rem;display:flex;flex-direction:column;gap:.5rem;flex:1 1}.card__title{font-family:Sora,sans-serif;font-weight:700;font-size:1.05rem;line-height:1.3;margin:0;color:var(--fg)}.card__excerpt{color:var(--muted);font-size:.88rem;line-height:1.45;margin:0;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.card__chips{display:flex;flex-wrap:wrap;gap:.35rem}.chip{font-size:.72rem;padding:.12rem .5rem;border-radius:999px;background:var(--chip);border:1px solid var(--chip-border);color:var(--accent);white-space:nowrap}.card__meta{display:flex;align-items:center;gap:.5rem;margin-top:auto;color:var(--muted);font-size:.78rem}.badge{font-size:.68rem;font-weight:700;letter-spacing:.04em;padding:.1rem .45rem;border-radius:6px;border:1px solid var(--border-strong);color:var(--fg-dim)}.badge--en{border-color:var(--chip-border);color:var(--accent)}.badge--th{border-color:rgba(244,139,196,.4);color:#f48bc4}.loadmore{display:block;margin:2rem auto 0;padding:.7rem 1.6rem;border-radius:999px;border:1px solid var(--border-strong);background:var(--panel);color:var(--fg);font-size:.95rem;cursor:pointer}.loadmore:hover{border-color:var(--accent);color:var(--accent)}.empty{padding:3rem 1rem;text-align:center;color:var(--muted)}.post{max-width:820px;margin:0 auto;padding:clamp(1.25rem,3vw,2.5rem) clamp(1rem,4vw,1.5rem) 5rem}.post__back{font-size:.9rem;color:var(--muted)}.post__head h1{font-size:clamp(1.8rem,4.5vw,2.8rem);line-height:1.15;margin:.8rem 0 .6rem}.post__meta{align-items:center;gap:.6rem;color:var(--muted);font-size:.88rem;margin-bottom:1rem}.post__chips,.post__meta{display:flex;flex-wrap:wrap}.post__chips{gap:.4rem;margin-bottom:1.5rem}.post__cover{width:100%;border-radius:var(--radius);border:1px solid var(--border);margin-bottom:1.8rem;display:block}.prose{font-size:1.06rem;line-height:1.75;color:var(--fg-dim);overflow-wrap:break-word}.prose h1,.prose h2,.prose h3,.prose h4{color:var(--fg);line-height:1.25;margin:2rem 0 .8rem}.prose h2{font-size:1.6rem}.prose h3{font-size:1.3rem}.prose p{margin:0 0 1.15rem}.prose a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}.prose img{max-width:100%;height:auto;border-radius:12px;margin:1.4rem auto;display:block;border:1px solid var(--border)}.prose ol,.prose ul{margin:0 0 1.2rem;padding-left:1.4rem}.prose li{margin:.35rem 0}.prose blockquote{border-left:3px solid var(--accent);margin:1.4rem 0;padding:.4rem 0 .4rem 1.1rem;color:var(--muted);font-style:italic}.prose pre{background:var(--bg-soft);border:1px solid var(--border);border-radius:12px;padding:1rem 1.1rem;overflow-x:auto;font-size:.9rem}.prose code{background:var(--panel-strong);border-radius:6px;padding:.1rem .35rem;font-size:.92em}.prose pre code{background:none;padding:0}.prose table{width:100%;border-collapse:collapse;margin:1.4rem 0;font-size:.92rem;display:block;overflow-x:auto}.prose td,.prose th{border:1px solid var(--border);padding:.5rem .7rem;text-align:left}.prose iframe,.prose video{max-width:100%;border-radius:12px;margin:1.4rem 0}.prose .katex-display{overflow-x:auto;overflow-y:hidden;padding:.4rem 0}.auth-wrap{min-height:calc(100vh - 56px);display:flex;align-items:center;justify-content:center;padding:2rem 1rem;background:radial-gradient(1200px 600px at 50% -10%,color-mix(in srgb,var(--accent) 14%,transparent),transparent 60%)}.auth-card{width:100%;max-width:420px;background:var(--panel-strong);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:2rem;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.auth-card--wide{max-width:460px}.auth-title{font-family:Sora,sans-serif;font-size:1.6rem;font-weight:800;margin:0 0 .35rem;color:var(--fg)}.auth-sub{color:var(--muted);font-size:.95rem;margin:0 0 1.4rem}.auth-field{margin-bottom:.9rem}.auth-label{display:block;font-size:.82rem;font-weight:600;color:var(--fg-dim);margin-bottom:.35rem}.auth-input{width:100%;padding:.7rem .9rem;border-radius:12px;border:1px solid var(--border-strong);background:var(--bg-soft);color:var(--fg);font-size:.95rem;font-family:inherit;outline:none;transition:border-color .15s,box-shadow .15s}.auth-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 22%,transparent)}.auth-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.75rem 1rem;border-radius:999px;font-weight:600;font-size:.95rem;cursor:pointer;border:1px solid transparent;font-family:inherit;text-decoration:none}.auth-btn--primary{background:var(--accent);color:var(--accent-fg)}.auth-btn--primary:hover{text-decoration:none;filter:brightness(1.06)}.auth-btn--primary:disabled{opacity:.6;cursor:not-allowed}.auth-btn--google{background:var(--bg-soft);color:var(--fg);border:1px solid var(--border-strong)}.auth-btn--google:hover{text-decoration:none;border-color:var(--accent)}.auth-divider{display:flex;align-items:center;gap:.75rem;color:var(--muted);font-size:.8rem;margin:1.1rem 0}.auth-divider:after,.auth-divider:before{content:"";flex:1 1;height:1px;background:var(--border)}.auth-foot{margin-top:1.2rem;font-size:.9rem;color:var(--muted);text-align:center}.auth-msg{border-radius:12px;padding:.7rem .9rem;font-size:.9rem;margin-bottom:1rem}.auth-msg--error{background:color-mix(in srgb,#ef4444 14%,transparent);border:1px solid color-mix(in srgb,#ef4444 35%,transparent);color:color-mix(in srgb,#ef4444 80%,var(--fg))}.auth-msg--ok{background:color-mix(in srgb,#10b981 14%,transparent);border:1px solid color-mix(in srgb,#10b981 35%,transparent);color:color-mix(in srgb,#10b981 75%,var(--fg))}.auth-hp{position:absolute!important;left:-9999px!important;top:-9999px!important;width:1px;height:1px;opacity:0;pointer-events:none}.account-wrap{max-width:760px;margin:0 auto;padding:2.5rem 1rem 4rem}.account-head{gap:1rem;margin-bottom:1.8rem}.account-avatar,.account-head{display:flex;align-items:center}.account-avatar{width:64px;height:64px;border-radius:999px;background:var(--chip);border:1px solid var(--chip-border);justify-content:center;font-family:Sora,sans-serif;font-weight:800;font-size:1.6rem;color:var(--accent)}.account-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));grid-gap:.9rem;gap:.9rem;margin:1.5rem 0}.account-stat{background:var(--panel-strong);border:1px solid var(--border);border-radius:14px;padding:1rem}.account-stat__label{font-size:.78rem;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.account-stat__value{font-family:Sora,sans-serif;font-weight:800;font-size:1.5rem;color:var(--fg);margin-top:.2rem}.account-badge{display:inline-block;padding:.25rem .7rem;border-radius:999px;font-size:.78rem;font-weight:600;background:var(--chip);border:1px solid var(--chip-border);color:var(--accent);text-transform:capitalize}.account-badge--warn{background:color-mix(in srgb,#f59e0b 14%,transparent);border-color:color-mix(in srgb,#f59e0b 35%,transparent);color:color-mix(in srgb,#f59e0b 80%,var(--fg))}.account-badge--ok{background:color-mix(in srgb,#10b981 14%,transparent);border-color:color-mix(in srgb,#10b981 35%,transparent);color:color-mix(in srgb,#10b981 75%,var(--fg))}