:root{--bg:#f6f2ea;--bg-raised:#fffdf8;--bg-sunken:#efe8db;--border:#e5dccb;--border-strong:#d7cbb4;--text:#262119;--text-muted:#6d6455;--text-faint:#948a78;--accent:#bd5a37;--accent-hover:#a54a2b;--accent-soft:#f3e0d5;--on-accent:#fffaf5;--success:#4f7a52;--success-soft:#e3ecdd;--warn:#a97b28;--warn-soft:#f7edd6;--danger:#b23f36;--danger-soft:#f6ddd7;--code-bg:#efe7d8;--code-text:#8a4326;--shadow-sm:0 1px 2px rgba(60,48,30,0.06);--shadow:0 6px 20px -8px rgba(60,48,30,0.18);--shadow-lg:0 20px 45px -18px rgba(60,48,30,0.28);--font-sans:"IBM Plex Sans Thai","Noto Sans Thai","Leelawadee UI","Sukhumvit Set",-apple-system,BlinkMacSystemFont,"Segoe UI",system-ui,sans-serif;--font-mono:"JetBrains Mono","Cascadia Code",ui-monospace,"SF Mono","Consolas","Noto Sans Thai",monospace;--step--1:0.82rem;--step-0:1rem;--step-1:1.16rem;--step-2:1.4rem;--step-3:1.75rem;--step-4:2.3rem;--radius-sm:6px;--radius:10px;--radius-lg:16px;--measure:68ch;--sidebar-w:17.5rem;--topbar-h:3.25rem;color-scheme:light}*,:after,:before{box-sizing:border-box}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{margin:0;background:var(--bg);color:var(--text);font-family:var(--font-sans);font-size:var(--step-0);line-height:1.72;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}body:before{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;background:radial-gradient(60rem 60rem at 88% -12%,rgba(189,90,55,.06),transparent 60%),radial-gradient(50rem 50rem at -8% 8%,rgba(169,123,40,.05),transparent 55%)}a{color:var(--accent)}::selection{background:var(--accent-soft);color:var(--text)}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:var(--radius-sm)}.app-shell{display:flex;align-items:flex-start;min-height:100vh}.app-main{flex:1 1;min-width:0;padding:clamp(1.5rem,4vw,3.5rem) clamp(1rem,4vw,3rem) 5rem}.reading-progress{position:fixed;inset:0 0 auto 0;height:3px;z-index:60;background:transparent}.reading-progress__fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--warn));transition:width .08s linear}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.55rem 1.1rem;border-radius:var(--radius);border:1px solid transparent;font-family:inherit;font-size:var(--step--1);font-weight:600;line-height:1.2;text-decoration:none;cursor:pointer;transition:background .15s ease,transform .12s ease,box-shadow .15s ease,border-color .15s ease,color .15s ease}.btn:active{transform:translateY(1px)}.btn:disabled{cursor:default}.btn--primary{background:var(--accent);color:var(--on-accent);box-shadow:var(--shadow-sm)}.btn--primary:hover:not(:disabled){background:var(--accent-hover)}.btn--primary:disabled{background:var(--border-strong);color:var(--bg-raised)}.btn--success{background:var(--success);color:#fff}.btn--success:disabled{opacity:.85}.btn--ghost{background:var(--bg-raised);color:var(--text);border-color:var(--border);box-shadow:var(--shadow-sm)}.btn--ghost:hover:not(:disabled){border-color:var(--border-strong);color:var(--accent)}.chip{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .85rem;border-radius:999px;border:1px solid var(--border);background:var(--bg-raised);color:var(--text-muted);font-family:inherit;font-size:var(--step--1);font-weight:600;cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease}.chip:hover{border-color:var(--border-strong)}.chip[data-active=true]{background:var(--accent);color:var(--on-accent);border-color:var(--accent)}.landing{max-width:60rem;margin:0 auto}.hero{padding:clamp(1rem,3vw,2.5rem) 0 2.5rem;border-bottom:1px solid var(--border);margin-bottom:2.75rem}.hero__eyebrow{display:inline-flex;align-items:center;gap:.5rem;padding:.3rem .8rem;border-radius:999px;background:var(--accent-soft);color:var(--accent-hover);font-size:var(--step--1);font-weight:700;letter-spacing:.02em}.hero h1{font-size:clamp(1.9rem,5vw,var(--step-4));line-height:1.14;letter-spacing:-.02em;margin:1.1rem 0 .5rem;text-wrap:pretty}.hero__frame{font-size:var(--step-1);max-width:44ch}.hero__frame,.hero__lead{color:var(--text-muted);text-wrap:pretty;margin:0 0 1.5rem}.hero__lead{max-width:62ch}.hero__actions{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.section-title{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;margin:0 0 1.25rem}.section-title h2{font-size:var(--step-2);letter-spacing:-.01em;margin:0}.section-title span{color:var(--text-faint);font-size:var(--step--1);font-weight:600}.module-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(17rem,1fr));grid-gap:1rem;gap:1rem}.module-card{display:flex;flex-direction:column;gap:.65rem;padding:1.3rem 1.35rem 1.4rem;border-radius:var(--radius-lg);background:var(--bg-raised);border:1px solid var(--border);box-shadow:var(--shadow-sm);color:var(--text);text-decoration:none;position:relative;overflow:hidden;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}.module-card:before{content:"";position:absolute;inset:0 auto 0 0;width:3px;background:var(--accent);opacity:0;transition:opacity .16s ease}.module-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--border-strong)}.module-card:hover:before{opacity:1}.module-card__eyebrow{display:flex;align-items:center;justify-content:space-between;font-size:var(--step--1);font-weight:700;color:var(--text-faint);letter-spacing:.04em;text-transform:uppercase}.module-card__weight{padding:.15rem .6rem;border-radius:999px;background:var(--accent-soft);color:var(--accent-hover);letter-spacing:0;text-transform:none}.module-card__title{font-size:var(--step-1);font-weight:700;line-height:1.3;letter-spacing:-.01em;text-wrap:pretty}.module-card__meta{margin-top:auto;display:flex;align-items:center;gap:.5rem;color:var(--text-muted);font-size:var(--step--1)}.module-card__bar{flex:1 1;height:5px;border-radius:999px;background:var(--bg-sunken);overflow:hidden}.module-card__bar>span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--accent),var(--warn))}.callout{margin-top:2.5rem;padding:1rem 1.25rem;border-radius:var(--radius);border:1px dashed var(--border-strong);background:var(--bg-sunken);color:var(--text-muted);font-size:var(--step--1);text-wrap:pretty}.callout strong{color:var(--text)}.topbar{display:none}.sidebar{width:var(--sidebar-w);flex-shrink:0;position:-webkit-sticky;position:sticky;top:0;align-self:flex-start;height:100vh;overflow-y:auto;overscroll-behavior:contain;background:var(--bg-raised);border-right:1px solid var(--border);padding:1.25rem 1rem 2.5rem;transition:width .2s ease,padding .2s ease}.sidebar[data-collapsed=true]{width:0;padding-left:0;padding-right:0;border-right-color:transparent;overflow:hidden}.sidebar__collapse{display:flex;align-items:center;justify-content:center;gap:.35rem;width:100%;margin-bottom:.9rem;padding:.4rem .6rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-sunken);color:var(--text-muted);font-family:inherit;font-size:var(--step--1);cursor:pointer;transition:border-color .15s ease,color .15s ease}.sidebar__collapse:hover{border-color:var(--border-strong);color:var(--text)}.sidebar__reopen{position:fixed;top:1rem;left:.75rem;z-index:65;display:inline-flex;align-items:center;justify-content:center;width:2.1rem;height:2.1rem;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-raised);color:var(--text);box-shadow:var(--shadow);font-size:1rem;cursor:pointer;transition:border-color .15s ease,color .15s ease}.sidebar__reopen:hover{border-color:var(--border-strong);color:var(--accent)}.sidebar__brand{display:block;padding:.35rem .5rem .9rem;text-decoration:none;color:var(--text)}.sidebar__brand strong{display:block;font-size:var(--step-0);font-weight:700;letter-spacing:-.01em}.sidebar__brand span{font-size:var(--step--1);color:var(--text-faint)}.sidebar__search{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem .75rem;margin-bottom:1.5rem;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-sunken);color:var(--text-muted);font-family:inherit;font-size:var(--step--1);cursor:pointer;transition:border-color .15s ease,color .15s ease}.sidebar__search:hover{border-color:var(--border-strong);color:var(--text)}.sidebar__search kbd{margin-left:auto;padding:.1rem .4rem;border-radius:var(--radius-sm);border:1px solid var(--border-strong);background:var(--bg-raised);font-family:var(--font-mono);font-size:.7rem;color:var(--text-faint)}.sidebar__module{margin-bottom:1.6rem}.sidebar__module-head{display:flex;align-items:center;justify-content:space-between;gap:.5rem;width:100%;margin-bottom:.5rem;padding:.35rem .5rem;border:none;border-radius:var(--radius-sm);background:none;font:inherit;text-align:left;color:inherit;cursor:pointer;transition:background .13s ease}.sidebar__module-head:hover{background:var(--bg-sunken)}.sidebar__module-chevron{flex-shrink:0;font-size:.65rem;color:var(--text-faint);transition:transform .15s ease}.sidebar__module-head[aria-expanded=true] .sidebar__module-chevron{transform:rotate(90deg)}.sidebar__module-title{flex:1 1;min-width:0;font-weight:700;font-size:var(--step--1);letter-spacing:-.01em;color:var(--text);text-wrap:pretty}.sidebar__module-pct{font-weight:700;font-size:.72rem;color:var(--text-faint);font-feature-settings:"tnum";font-variant-numeric:tabular-nums;flex-shrink:0}.sidebar__module-bar{height:3px;border-radius:999px;background:var(--bg-sunken);margin:0 .5rem .6rem;overflow:hidden}.sidebar__module-bar>span{display:block;height:100%;background:var(--accent);border-radius:999px;transition:width .3s ease}.sidebar__chapter{margin-bottom:.6rem}.sidebar__chapter-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-faint);margin:.5rem .5rem .3rem}.sidebar__link{display:flex;align-items:flex-start;gap:.5rem;padding:.4rem .6rem;border-radius:var(--radius-sm);color:var(--text-muted);text-decoration:none;font-size:var(--step--1);line-height:1.45;text-wrap:pretty;transition:background .13s ease,color .13s ease}.sidebar__link:hover{background:var(--bg-sunken);color:var(--text)}.sidebar__link[aria-current=page]{background:var(--accent-soft);color:var(--accent-hover);font-weight:600}.sidebar__check{flex-shrink:0;width:1rem;text-align:center;color:var(--success);font-weight:700}.sidebar-overlay{display:none}.lesson{max-width:var(--measure);margin:0 auto}.lesson>h1{font-size:clamp(1.6rem,4vw,var(--step-3));line-height:1.2;letter-spacing:-.02em;margin:0 0 2rem;text-wrap:pretty}.lesson h2{font-size:var(--step-2);line-height:1.3;letter-spacing:-.01em;margin:2.75rem 0 1rem;padding-top:1.75rem;border-top:1px solid var(--border);text-wrap:pretty;display:flex;align-items:center;gap:.6rem}.lesson h2:before{content:"";width:.55rem;height:1.4rem;border-radius:3px;background:var(--accent);flex-shrink:0}.lesson h3{font-size:var(--step-1);margin:2rem 0 .75rem;text-wrap:pretty}.lesson p{margin:0 0 1.15rem;text-wrap:pretty}.lesson ol,.lesson ul{margin:0 0 1.15rem;padding-left:1.4rem}.lesson li{margin-bottom:.5rem;text-wrap:pretty}.lesson li::marker{color:var(--accent)}.lesson strong{font-weight:700;color:var(--text)}.lesson :not(pre)>code{font-family:var(--font-mono);font-size:.86em;color:var(--code-text);padding:.1rem .4rem;border-radius:var(--radius-sm);white-space:nowrap}.lesson :not(pre)>code,.lesson pre{background:var(--code-bg);border:1px solid var(--border)}.lesson pre{border-radius:var(--radius);padding:1rem 1.2rem;overflow-x:auto;margin:0 0 1.5rem;box-shadow:var(--shadow-sm);line-height:1.6}.lesson pre code{font-family:var(--font-mono);font-size:var(--step--1);color:var(--text);background:none;border:none;padding:0;white-space:pre}.lesson a{color:var(--accent);text-decoration:none;font-weight:600}.lesson li>a,.lesson p>a{display:inline-block;padding:.1rem .55rem;border-radius:var(--radius-sm);background:var(--accent-soft);color:var(--accent-hover);transition:background .14s ease,color .14s ease}.lesson li>a:hover,.lesson p>a:hover{background:var(--accent);color:var(--on-accent)}.lesson table{width:100%;border-collapse:collapse;margin:0 0 1.5rem;font-size:var(--step--1)}.lesson td,.lesson th{text-align:left;padding:.5rem .7rem;border-bottom:1px solid var(--border);vertical-align:top}.lesson th{color:var(--text-faint);font-weight:700}.lesson-nav{max-width:var(--measure);margin:3rem auto 0;display:flex;justify-content:space-between;gap:1rem}.lesson-nav__link{display:flex;flex-direction:column;gap:.2rem;max-width:46%;padding:.7rem 1rem;border-radius:var(--radius);background:var(--bg-raised);border:1px solid var(--border);box-shadow:var(--shadow-sm);color:var(--text);text-decoration:none;font-size:var(--step--1);text-wrap:pretty;transition:border-color .15s ease,transform .14s ease}.lesson-nav__link:hover{border-color:var(--border-strong);transform:translateY(-2px)}.lesson-nav__link--next{text-align:right;align-items:flex-end;margin-left:auto}.lesson-nav__dir{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-faint)}.lesson-nav__title{font-weight:600;color:var(--accent-hover)}.check{margin:1.25rem 0;padding:1.1rem 1.25rem;border-radius:var(--radius);background:var(--bg-raised);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.check__q{margin:0 0 .9rem;font-weight:600;text-wrap:pretty}.check__q:before{content:"เช็คความเข้าใจ";display:block;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--accent);margin-bottom:.35rem}.check__a{margin:.9rem 0 0;padding:.85rem 1rem;background:var(--success-soft);border-left:3px solid var(--success)}.check__a,.simnote{border-radius:var(--radius-sm);color:var(--text);text-wrap:pretty}.simnote{margin-top:1rem;padding:.75rem 1rem;border:1px solid var(--warn);border-left-width:3px;background:var(--warn-soft);font-size:var(--step--1)}.simnote strong{color:var(--warn)}.sim{margin:1.75rem 0;padding:1.25rem 1.35rem 1.4rem;border-radius:var(--radius-lg);background:var(--bg-raised);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.sim-table-wrap{overflow-x:auto;margin-top:.5rem}.sim-table-wrap .sim-table{margin-top:0}.sim__controls{display:flex;flex-wrap:wrap;gap:.5rem}.sim__controls+.sim__controls{margin-top:.5rem}.sim__row{margin-top:1rem;text-wrap:pretty}.sim__label{font-weight:600;color:var(--text-muted);margin-bottom:.4rem}.sim__field,.sim__label{display:block;font-size:var(--step--1)}.sim__field{width:100%;max-width:32rem;padding:.55rem .7rem;border-radius:var(--radius);border:1px solid var(--border-strong);background:var(--bg);color:var(--text);font-family:var(--font-mono)}.sim__field:focus-visible{border-color:var(--accent)}.sim__list{margin:.75rem 0 0;padding-left:1.25rem}.sim__list li{margin-bottom:.35rem;text-wrap:pretty}.sim code{font-family:var(--font-mono);font-size:.86em;background:var(--code-bg);color:var(--code-text);padding:.08rem .35rem;border-radius:var(--radius-sm);border:1px solid var(--border)}.sim-table{width:100%;border-collapse:collapse;margin-top:.5rem;font-size:var(--step--1)}.sim-table td,.sim-table th{text-align:left;padding:.45rem .6rem;vertical-align:top}.sim-table th{border-bottom:1px solid var(--border-strong);color:var(--text-faint);font-weight:700}.sim-table tbody tr+tr td{border-top:1px solid var(--border)}.sim-callout{margin-top:1rem;padding:.7rem 1rem;border-radius:var(--radius-sm);font-weight:700;text-wrap:pretty}.sim-callout--success{background:var(--success-soft);border-left:3px solid var(--success);color:var(--text)}.badge{display:inline-block;padding:.2rem .55rem;border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:.8rem;font-weight:600}.badge--neutral{background:var(--accent-soft);color:var(--accent-hover)}.badge--success{background:var(--success-soft);color:var(--success)}.badge--danger{background:var(--danger-soft);color:var(--danger)}.tag{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem .75rem;border-radius:var(--radius);font-size:var(--step--1);border:1px solid var(--border);background:var(--bg-sunken);color:var(--text-muted)}.tag[data-match=true]{background:var(--success-soft);border-color:var(--success);color:var(--success)}.tag strong{color:inherit}.tag code{background:transparent;border:none;padding:0}.sim-bars{display:flex;gap:2px;margin-top:1rem;align-items:flex-end;height:6rem;padding:.5rem .6rem;border-radius:var(--radius);background:var(--bg-sunken)}.sim-bars__bar{flex:1 1;border-radius:2px 2px 0 0;background:var(--accent);opacity:.55}.sim-bars__bar[data-key=true]{background:var(--warn);opacity:1}.search-overlay{position:fixed;inset:0;z-index:1000;background:rgba(38,33,25,.45);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:flex-start;justify-content:center;padding:12vh 1rem 1rem}.search-dialog{width:min(34rem,100%);max-height:72vh;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-raised);border:1px solid var(--border-strong);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}.search-input{padding:.95rem 1.15rem;font-size:var(--step-1);font-family:inherit;color:var(--text);background:transparent;border:none;border-bottom:1px solid var(--border);outline:none}.search-input::placeholder{color:var(--text-faint)}.search-results{overflow-y:auto;padding:.5rem}.search-empty{padding:1.25rem;text-align:center;color:var(--text-faint);font-size:var(--step--1)}.search-result{display:block;width:100%;text-align:left;padding:.6rem .8rem;margin-bottom:.2rem;border-radius:var(--radius);border:1px solid transparent;background:transparent;color:var(--text);font-family:inherit;cursor:pointer;transition:background .12s ease,border-color .12s ease}.search-result:hover{background:var(--bg-sunken);border-color:var(--border)}.search-result__title{font-weight:600;font-size:var(--step--1);text-wrap:pretty}.search-result__snippet{margin-top:.15rem;font-size:.78rem;color:var(--text-muted);text-wrap:pretty;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (prefers-color-scheme:dark){:root{--bg:#1b1915;--bg-raised:#252119;--bg-sunken:#201d16;--border:#383327;--border-strong:#4c452f;--text:#ede6d7;--text-muted:#a89e88;--text-faint:#7c745f;--accent:#d9805e;--accent-hover:#e79574;--accent-soft:#382318;--on-accent:#1b1512;--success:#7fa876;--success-soft:#26301f;--warn:#d3ab5c;--warn-soft:#322913;--danger:#d97b6f;--danger-soft:#37211d;--code-bg:#201d16;--code-text:#e79b74;--shadow-sm:0 1px 2px rgba(0,0,0,0.3);--shadow:0 6px 20px -8px rgba(0,0,0,0.55);--shadow-lg:0 20px 45px -18px rgba(0,0,0,0.7);color-scheme:dark}body:before{background:radial-gradient(60rem 60rem at 88% -12%,rgba(217,128,94,.08),transparent 60%),radial-gradient(50rem 50rem at -8% 8%,rgba(211,171,92,.05),transparent 55%)}}@media (max-width:860px){.app-shell{display:block}.app-main{padding-top:calc(var(--topbar-h) + 1.25rem);padding-left:clamp(1rem,5vw,1.5rem);padding-right:clamp(1rem,5vw,1.5rem)}.topbar{display:flex;align-items:center;gap:.75rem;position:fixed;inset:0 0 auto 0;height:var(--topbar-h);z-index:70;padding:0 .85rem;background:color-mix(in srgb,var(--bg-raised) 88%,transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--border)}.topbar__menu{display:inline-flex;align-items:center;justify-content:center;width:2.4rem;height:2.4rem;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-sunken);color:var(--text);font-size:1.2rem;cursor:pointer}.topbar__brand{font-weight:700;font-size:var(--step--1);letter-spacing:-.01em}.topbar__search{margin-left:auto;display:inline-flex;align-items:center;justify-content:center;width:2.4rem;height:2.4rem;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-sunken);color:var(--text);font-size:1.05rem;cursor:pointer}.sidebar{position:fixed;inset:0 auto 0 0;height:100vh;width:min(20rem,84vw);z-index:90;transform:translateX(-100%);transition:transform .24s ease;box-shadow:var(--shadow-lg);padding-top:1.25rem}.sidebar[data-open=true]{transform:translateX(0)}.sidebar__brand,.sidebar__collapse,.sidebar__reopen{display:none}.sidebar[data-collapsed=true]{width:min(20rem,84vw);padding-left:1rem;padding-right:1rem;border-right-color:var(--border)}.sidebar-overlay{display:block;position:fixed;inset:0;z-index:80;background:rgba(20,17,12,.5);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.hero{margin-bottom:2rem}.module-grid{grid-template-columns:1fr}.lesson h2{margin-top:2.25rem}.lesson-nav{flex-direction:column}.lesson-nav__link{max-width:100%}.lesson-nav__link--next{text-align:left;align-items:flex-start}}