@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-ease:initial}}}@layer theme{:root,:host{--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--ease-in-out:cubic-bezier(.4,0,.2,1);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--font-inter,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.container{margin-inline:auto;padding-inline:1.5rem}@media (min-width:40rem){.container{max-width:none}}@media (min-width:1440px){.container{max-width:1440px}}.contents{display:contents}.flex{display:flex}.grid{display:grid}.inline-block{display:inline-block}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.whitespace-pre-wrap{white-space:pre-wrap}.lowercase{text-transform:lowercase}.uppercase{text-transform:uppercase}.italic{font-style:italic}.underline{text-decoration-line:underline}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}}:root{--paper:#f4eee2;--paper-2:#ede6d6;--paper-3:#e5dcc7;--ink:#1a1714;--ink-2:#4a4137;--ink-3:#8a7f6f;--ink-4:#b8ac97;--rule:#d4c8ae;--accent:#a33a2a;--accent-2:#5a6b3a;--accent-3:#8a6a2e;--shadow:0 1px 0 #1a17140a,0 8px 24px -12px #1a17142e;--serif-display:"Cormorant Garamond","EB Garamond","Sarabun",Georgia,serif;--serif-body:"Newsreader","Source Serif Pro","Sarabun",Georgia,serif;--mono:"JetBrains Mono","IBM Plex Mono",ui-monospace,monospace;--thai:"IBM Plex Sans Thai","Sarabun","Noto Sans Thai",var(--serif-body)}[data-theme=ivory]{--paper:#faf6ec;--paper-2:#f2ebdb;--paper-3:#e9dfc8;--ink:#221c16;--rule:#dcd0b6}[data-theme=dusk]{--paper:#1f1b16;--paper-2:#28231c;--paper-3:#322c24;--ink:#f0e6d2;--ink-2:#c4b89e;--ink-3:#8a7f6a;--ink-4:#5a4f3f;--rule:#3d362c;--accent:#c8553d;--accent-2:#8da060;--accent-3:#c49a4e;--shadow:0 1px 0 #0003,0 12px 32px -12px #00000080}html,body{margin:0;padding:0}body.commonplace{font-family:var(--serif-body);background:var(--paper);color:var(--ink);-webkit-font-smoothing:antialiased;font-feature-settings:"kern","liga","onum";font-size:17px;line-height:1.55}body.commonplace:before{content:"";pointer-events:none;z-index:0;background-image:radial-gradient(circle at 1px 1px,#1a171406 1px,#0000 0);background-size:3px 3px;position:fixed;inset:0}body.commonplace[data-theme=dusk]:before{background-image:radial-gradient(circle at 1px 1px,#fff5dc05 1px,#0000 0)}.commonplace-root{z-index:1;min-height:100vh;position:relative}.masthead{border-bottom:1px solid var(--rule);grid-template-columns:1fr auto 1fr;align-items:end;gap:24px;padding:28px 56px 20px;display:grid}.masthead .left,.masthead .right{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);align-items:center;gap:22px;font-size:12px;display:flex}.masthead .right{justify-content:flex-end}.masthead .center{text-align:center}.masthead h1{font-family:var(--serif-display);letter-spacing:.01em;margin:0;font-size:34px;font-style:italic;font-weight:500;line-height:1}.masthead .tagline{font-family:var(--mono);letter-spacing:.25em;text-transform:uppercase;color:var(--ink-3);margin-top:6px;font-size:11px}.nav-link{cursor:pointer;color:var(--ink-3);padding:4px 0;text-decoration:none;position:relative}.nav-link.active{color:var(--ink)}.nav-link.active:after{content:"";background:var(--ink);height:1px;position:absolute;bottom:-2px;left:0;right:0}.nav-link:hover{color:var(--ink)}.date-stamp{font-family:var(--mono);color:var(--ink-3);letter-spacing:.08em;font-size:11px}.nav-link.nav-admin{border-left:1px solid var(--rule);color:var(--accent);margin-left:8px;padding-left:16px}.nav-link.nav-admin:hover{color:var(--accent);opacity:.75}.eyebrow{font-family:var(--mono);letter-spacing:.25em;text-transform:uppercase;color:var(--ink-3);font-size:11px}.pos{font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;border:1px solid;border-radius:2px;padding:2px 6px;font-size:9.5px;line-height:1.2;display:inline-block}.pos.noun{color:#5a6b3a}.pos.verb{color:#a33a2a}.pos.adjective{color:#8a6a2e}.pos.adverb{color:#5c6b7a}.pos.phrase{color:#7a4a6a}.pos.preposition{color:#4a6a7a}.pos.other{color:var(--ink-3)}[data-theme=dusk] .pos.noun{color:#a8bc78}[data-theme=dusk] .pos.verb{color:#d87060}[data-theme=dusk] .pos.adjective{color:#d8a858}[data-theme=dusk] .pos.adverb{color:#8fa6bd}[data-theme=dusk] .pos.phrase{color:#c088a8}[data-theme=dusk] .pos.preposition{color:#88b0c4}.btn{font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--ink);border:1px solid var(--ink);cursor:pointer;background:0 0;padding:8px 14px;font-size:11px;line-height:1;transition:all .15s}.btn:hover,.btn.solid{background:var(--ink);color:var(--paper)}.btn.solid:hover{background:var(--accent);border-color:var(--accent)}.icon-btn{border:1px solid var(--rule);width:28px;height:28px;color:var(--ink-2);cursor:pointer;background:0 0;border-radius:2px;justify-content:center;align-items:center;transition:all .15s;display:inline-flex}.icon-btn:hover{color:var(--ink);border-color:var(--ink-3);background:var(--paper-2)}.page{max-width:1400px;margin:0 auto;padding:24px 56px 80px}.section-head{justify-content:space-between;align-items:baseline;gap:24px;margin:24px 0 16px;display:flex}.section-head h2{font-family:var(--serif-display);letter-spacing:-.005em;margin:0;font-size:44px;font-weight:400}.section-head h2 em{color:var(--ink-2);font-style:italic}.stats{border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);grid-template-columns:repeat(4,1fr);margin-top:16px;display:grid}.stat{border-right:1px solid var(--rule);flex-direction:column;gap:4px;padding:18px 20px;display:flex}.stat:last-child{border-right:0}.stat .label{font-family:var(--mono);letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3);font-size:11px}.stat .value{font-family:var(--serif-display);letter-spacing:-.01em;font-size:44px;font-weight:400;line-height:1}.stat .sub{font-family:var(--mono);color:var(--ink-3);letter-spacing:.04em;font-size:11px}.toolbar{border-bottom:1px solid var(--rule);flex-wrap:wrap;align-items:center;gap:16px;margin-bottom:16px;padding:16px 0;display:flex}.search{border-bottom:1px solid var(--ink-3);flex:1;align-items:center;gap:8px;min-width:200px;padding:4px 0;display:flex}.search input{font-family:var(--serif-body);color:var(--ink);background:0 0;border:0;outline:0;flex:1;font-size:17px;font-style:italic}.search input::placeholder{color:var(--ink-4);font-style:italic}.filter-group{border:1px solid var(--rule);gap:0;display:flex}.filter-group .chip{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;cursor:pointer;color:var(--ink-3);border:0;border-right:1px solid var(--rule);background:0 0;padding:6px 10px;font-size:11px}.filter-group .chip:last-child{border-right:0}.filter-group .chip.active{background:var(--ink);color:var(--paper)}.filter-group .chip:hover:not(.active){color:var(--ink);background:var(--paper-2)}.grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;display:grid}.card{background:var(--paper-2);border:1px solid var(--rule);cursor:pointer;flex-direction:column;gap:8px;min-height:110px;padding:16px 16px 14px;transition:all .15s;display:flex;position:relative}.card:hover{background:var(--paper);border-color:var(--ink-3);box-shadow:var(--shadow);transform:translateY(-1px)}.card .num{font-family:var(--mono);color:var(--ink-4);letter-spacing:.04em;font-size:9.5px;position:absolute;top:8px;right:10px}.card .word{font-family:var(--serif-display);letter-spacing:-.005em;margin-top:2px;font-size:26px;font-weight:500;line-height:1.1}.card .trans{font-family:var(--thai);color:var(--ink-2);font-size:15px;font-style:normal;line-height:1.35}.card .meta{align-items:center;gap:8px;margin-top:auto;display:flex}.card .mastery-dot{background:var(--ink-4);border-radius:50%;width:6px;height:6px}.card .mastery-dot.learning{background:var(--accent-3)}.card .mastery-dot.mastered{background:var(--accent-2)}.index-list{border-top:1px solid var(--rule)}.index-row{border-bottom:1px solid var(--rule);cursor:pointer;grid-template-columns:56px minmax(160px,1.2fr) 100px minmax(180px,2fr) 100px 36px;align-items:baseline;gap:24px;padding:14px 8px;transition:background .12s;display:grid}.index-row:hover{background:var(--paper-2)}.index-row .ix{font-family:var(--mono);color:var(--ink-4);letter-spacing:.04em;font-size:11.5px}.index-row .word{font-family:var(--serif-display);font-size:26px;font-weight:500;line-height:1.1}.index-row .trans{font-family:var(--thai);color:var(--ink-2);white-space:normal;font-size:17px;font-style:normal;line-height:1.35;overflow:visible}.index-row .leader{color:var(--ink-4);flex-wrap:nowrap;align-items:baseline;gap:10px;display:flex;overflow:hidden}.index-row .leader .dots{border-bottom:1px dotted var(--ink-4);flex:1;margin-bottom:4px}.index-row .leader .trans{flex:0 auto;min-width:0}.index-row .mastery-cell{font-family:var(--mono);color:var(--ink-3);letter-spacing:.08em;text-transform:uppercase;justify-content:flex-end;align-items:center;gap:6px;font-size:11px;display:flex}.group-block{margin:32px 0}.group-head{border-bottom:2px solid var(--ink);align-items:baseline;gap:16px;margin-bottom:14px;padding-bottom:8px;display:flex}.group-head h3{font-family:var(--serif-display);margin:0;font-size:28px;font-style:italic;font-weight:500}.group-head .count{font-family:var(--mono);color:var(--ink-3);letter-spacing:.08em;font-size:11px}.entry-list{-moz-columns:2;columns:2;-moz-column-rule:1px solid var(--rule);column-rule:1px solid var(--rule);-moz-column-gap:48px;column-gap:48px}.entry{-moz-column-break-inside:avoid;break-inside:avoid;border-bottom:1px solid var(--rule);grid-template-columns:1fr auto;align-items:baseline;gap:4px 12px;padding:10px 0;display:grid}.entry .word{font-family:var(--serif-display);font-size:23px;font-weight:500}.entry .trans{font-family:var(--thai);color:var(--ink-2);grid-column:1/-1;font-size:16px;font-style:normal;line-height:1.4}.colophon{border-top:1px solid var(--rule);font-family:var(--mono);letter-spacing:.15em;text-transform:uppercase;color:var(--ink-3);justify-content:space-between;margin-top:40px;padding:20px 56px;font-size:10px;display:flex}.review-stage{grid-template-rows:auto 1fr auto;gap:24px;max-width:1400px;min-height:calc(100vh - 90px);margin:0 auto;padding:24px 56px 32px;display:grid}.review-top{grid-template-columns:1fr auto 1fr;align-items:center;gap:24px;display:grid}.review-top .left{justify-self:start}.review-top .right{justify-self:end;align-items:center;gap:12px;display:flex}.session-banner{border:1px solid var(--rule);background:var(--paper-2);align-items:center;gap:14px;padding:8px 14px;display:flex}.session-banner .dot{background:var(--accent);border-radius:50%;width:8px;height:8px;box-shadow:0 0 0 4px #a33a2a1f}.session-banner .text{font-family:var(--mono);letter-spacing:.08em;color:var(--ink-2);font-size:11px}.session-banner .text strong{color:var(--ink);font-weight:500}.session-banner .resume{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--accent);cursor:pointer;background:0 0;border:0;padding:0;font-size:10px}.session-banner .resume:hover{text-decoration:underline}.ring-center{align-items:center;gap:10px;display:inline-flex}.ring-center svg{display:block}.ring-center .label{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);font-size:10px}.ring-center .label strong{color:var(--ink);font-family:var(--serif-display);font-size:22px;font-style:italic;font-weight:500;line-height:1;display:block}.card-stage{perspective:2000px;justify-content:center;align-items:center;display:flex;position:relative}.flash{width:min(700px,90%);height:460px;transition:transform .6s cubic-bezier(.45,.05,.2,1);position:relative}.flash.slide-out-left{animation:.35s forwards slideOutLeft}.flash.slide-out-right{animation:.35s forwards slideOutRight}.flash.slide-in-left{animation:.35s forwards slideInLeft}.flash.slide-in-right{animation:.35s forwards slideInRight}@keyframes slideOutLeft{to{opacity:0;transform:translate(-40px)}}@keyframes slideOutRight{to{opacity:0;transform:translate(40px)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(-40px)}to{opacity:1;transform:translate(0)}}.face{background:var(--paper-2);border:1px solid var(--rule);box-shadow:var(--shadow);flex-direction:column;padding:36px 44px;display:flex;position:absolute;inset:0}.face .corner-tl{font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);font-size:11px;position:absolute;top:14px;left:18px}.face .corner-tr{font-family:var(--mono);color:var(--ink-3);letter-spacing:.04em;font-size:11px;position:absolute;top:14px;right:18px}.face .corner-bl{font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--ink-4);font-size:11px;position:absolute;bottom:14px;left:18px}.face .corner-br{gap:6px;display:flex;position:absolute;bottom:14px;right:18px}.face .center-stack{text-align:center;flex-direction:column;align-items:center;gap:18px;margin:auto;display:flex}.face .word{font-family:var(--serif-display);letter-spacing:-.015em;color:var(--ink);align-items:center;gap:18px;font-size:clamp(56px,8vw,96px);font-style:italic;font-weight:500;line-height:1;display:flex}.face .word .audio{border:1px solid var(--ink-3);width:36px;height:36px;color:var(--ink-2);cursor:pointer;background:0 0;border-radius:50%;justify-content:center;align-items:center;transition:all .15s;display:inline-flex}.face .word .audio:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}.face .translation{font-family:var(--thai);letter-spacing:0;font-size:64px;font-weight:500;line-height:1.2}.face .phrase-block{max-width:620px;font-family:var(--serif-body);color:var(--ink-2);margin:6px auto 0;padding:0 28px;font-size:28px;font-style:italic;line-height:1.45;position:relative}.face .phrase-block:before{content:"“";font-family:var(--serif-display);color:var(--ink-4);font-size:56px;line-height:1;position:absolute;top:-16px;left:-2px}.face .phrase-block:after{content:"”";font-family:var(--serif-display);color:var(--ink-4);font-size:56px;line-height:1;position:absolute;bottom:-36px;right:-2px}.face .phrase-block .target{color:var(--accent);border-bottom:1px solid var(--accent);font-style:normal;font-weight:500}.notes-block{text-align:left;flex-direction:column;gap:12px;max-width:640px;margin:0 auto;display:flex}.notes-line{border-bottom:1px dotted var(--rule);grid-template-columns:110px 1fr;align-items:baseline;gap:16px;padding-bottom:10px;display:grid}.notes-line:last-child{border-bottom:0}.notes-label{font-family:var(--mono);letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3);font-size:10px}.notes-text{font-family:var(--serif-body);color:var(--ink);font-size:20px;line-height:1.4}.nav-arrows{justify-content:center;align-items:center;gap:24px;display:flex}.nav-arrows .arrow{border:1px solid var(--rule);background:var(--paper);cursor:pointer;width:48px;height:48px;color:var(--ink-2);border-radius:50%;justify-content:center;align-items:center;transition:all .15s;display:inline-flex}.nav-arrows .arrow:hover{color:var(--ink);border-color:var(--ink);background:var(--paper-2)}.nav-arrows .keyhint{font-family:var(--mono);color:var(--ink-4);letter-spacing:.14em;text-transform:uppercase;font-size:9.5px}.controls-strip{border-top:1px solid var(--rule);grid-template-columns:1fr auto 1fr;align-items:center;gap:24px;padding-top:16px;display:grid}.control-group{flex-direction:column;gap:8px;display:flex}.control-group .label{font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);font-size:11px}.control-group.right{align-items:flex-end}.control-group.center{align-items:center}.face-toggle,.func-toggle{border:1px solid var(--ink);gap:0;display:flex}.face-toggle .opt,.func-toggle .opt{font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;cursor:pointer;border:0;border-right:1px solid var(--ink);color:var(--ink);background:0 0;padding:9px 16px;font-size:12px;line-height:1}.face-toggle .opt:last-child,.func-toggle .opt:last-child{border-right:0}.face-toggle .opt.active,.func-toggle .opt.active{background:var(--ink);color:var(--paper)}.face-toggle .opt:hover:not(.active),.func-toggle .opt:hover:not(.active){background:var(--paper-2)}.mastery-row{justify-content:center;gap:8px;display:flex}.mastery-row .m{font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;border:1px solid var(--rule);cursor:pointer;color:var(--ink-2);background:0 0;padding:9px 18px;font-size:11px;line-height:1}.mastery-row .m.again:hover{border-color:var(--accent);color:var(--accent)}.mastery-row .m.learning:hover{border-color:var(--accent-3);color:var(--accent-3)}.mastery-row .m.mastered:hover{border-color:var(--accent-2);color:var(--accent-2)}.tweaks-panel{background:var(--paper);border:1px solid var(--ink);z-index:1000;width:280px;font-family:var(--mono);font-size:11px;position:fixed;bottom:20px;right:20px;box-shadow:0 20px 60px #1a171440}.tweaks-panel .head{border-bottom:1px solid var(--rule);background:var(--ink);color:var(--paper);letter-spacing:.14em;text-transform:uppercase;justify-content:space-between;align-items:center;padding:10px 14px;font-size:10px;display:flex}.tweaks-panel .body{flex-direction:column;gap:14px;padding:14px;display:flex}.tweaks-panel label{letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);margin-bottom:6px;font-size:10px;display:block}.tweaks-panel .opts{flex-wrap:wrap;gap:4px;display:flex}.tweaks-panel .opts button{font-family:var(--mono);letter-spacing:.08em;border:1px solid var(--rule);color:var(--ink-2);cursor:pointer;background:0 0;padding:6px 10px;font-size:10px}.tweaks-panel .opts button.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}.tweaks-panel .close{color:var(--paper);cursor:pointer;font-family:var(--mono);background:0 0;border:0;font-size:14px}.test-prompt{font-family:var(--mono);letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3);margin-bottom:8px;font-size:10px}.test-input-wrap{align-items:center;gap:12px;width:min(420px,80%);margin-top:16px;display:flex}.test-input-wrap input{font-family:var(--serif-display);text-align:center;border:0;border-bottom:1px solid var(--ink-3);color:var(--ink);background:0 0;outline:0;flex:1;padding:6px 10px;font-size:32px;font-style:italic}.test-result{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;margin-top:14px;font-size:11px}.test-result.right{color:var(--accent-2)}.test-result.wrong{color:var(--accent)}.admin-login{place-items:center;min-height:100vh;padding:40px;display:grid}.admin-login-form{background:var(--paper-2);border:1px solid var(--rule);width:min(360px,100%);box-shadow:var(--shadow);flex-direction:column;gap:14px;padding:32px;display:flex}.admin-login-form h2{font-family:var(--serif-display);margin:0;font-size:44px;font-weight:400;line-height:1}.admin-login-form h2 em{color:var(--ink-2);font-style:italic}.admin-login-form label{font-family:var(--mono);letter-spacing:.25em;text-transform:uppercase;color:var(--ink-3);margin-top:4px;font-size:10px}.admin-login-form input{font-family:var(--serif-body);border:0;border-bottom:1px solid var(--ink-3);color:var(--ink);background:0 0;outline:0;padding:8px 4px;font-size:17px}.admin-login-form input:focus{border-bottom-color:var(--ink)}.admin-login-form button{align-self:stretch;margin-top:12px}.admin-error{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--accent);font-size:11px}.admin-head{justify-content:space-between;align-items:flex-end;gap:16px;margin:16px 0 20px;display:flex}.admin-title{font-family:var(--serif-display);margin:6px 0 0;font-size:44px;font-weight:400;line-height:1}.admin-title em{color:var(--ink-2);font-style:italic}.admin-head-actions{align-items:center;gap:8px;display:flex}.admin-rows{border-top:1px solid var(--rule)}.admin-row{border-bottom:1px solid var(--rule);grid-template-columns:48px 1fr 100px auto;align-items:center;gap:20px;padding:14px 8px;display:grid}.admin-row:hover{background:var(--paper-2)}.admin-row .ix{font-family:var(--mono);color:var(--ink-4);letter-spacing:.04em;font-size:11.5px}.admin-word{flex-direction:column;gap:2px;display:flex}.admin-word .word{font-family:var(--serif-display);font-size:24px;font-weight:500;line-height:1.1}.admin-word .trans{font-family:var(--thai);color:var(--ink-2);font-size:16px}.admin-phrase{font-family:var(--serif-body);color:var(--ink-3);margin-top:4px;font-size:14px;font-style:italic}.admin-row-actions{gap:6px;display:flex}.admin-audio-flags{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--ink-4);gap:4px;margin-right:8px;font-size:10px;display:inline-flex}.admin-audio-flags .on{color:var(--accent-2);border:1px solid;border-radius:2px;padding:2px 4px;line-height:1}.admin-audio-flags .off{color:var(--ink-4);border:1px dashed var(--rule);border-radius:2px;padding:2px 4px;line-height:1}.bulk-status{border:1px solid var(--rule);background:var(--paper-2);flex-direction:column;gap:8px;margin:12px 0 14px;padding:10px 14px;display:flex}.bulk-status-bar{background:var(--rule);height:2px;position:relative}.bulk-status-fill{background:var(--accent);height:100%;transition:width .2s}.bulk-status-text{font-family:var(--mono);letter-spacing:.08em;color:var(--ink-2);justify-content:space-between;align-items:center;gap:12px;font-size:11px;display:flex}.bulk-status-text strong{font-family:var(--serif-display);color:var(--ink);font-size:16px;font-style:italic;font-weight:500}.admin-btn-danger{border-color:var(--accent);color:var(--accent)}.admin-btn-danger:hover{background:var(--accent);border-color:var(--accent);color:var(--paper)}.admin-empty{text-align:center;font-family:var(--serif-display);color:var(--ink-4);padding:40px;font-size:22px;font-style:italic}.modal-backdrop{z-index:1100;background:#1a171480;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:var(--paper);border:1px solid var(--ink);flex-direction:column;width:min(560px,100%);max-height:calc(100vh - 40px);display:flex;box-shadow:0 24px 80px #00000059}.modal-head{border-bottom:1px solid var(--rule);justify-content:space-between;align-items:center;padding:14px 20px;display:flex}.modal-head-actions{align-items:center;gap:8px;display:flex}.modal-head-voice{color:var(--ink-4);letter-spacing:.08em;text-transform:none;margin-left:8px}.modal-close{color:var(--ink-2);cursor:pointer;background:0 0;border:0;font-size:22px;line-height:1}.modal-close:hover{color:var(--ink)}.modal-body{flex-direction:column;gap:16px;padding:18px 20px;display:flex;overflow-y:auto}.modal-body .field{flex-direction:column;gap:6px;display:flex}.modal-body .field-head{justify-content:space-between;align-items:center;gap:8px;display:flex}.gen-btn{font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--accent);border:1px solid var(--accent);cursor:pointer;background:0 0;border-radius:2px;padding:4px 8px;font-size:10px;line-height:1;transition:all .15s}.gen-btn:hover:not(:disabled){background:var(--accent);color:var(--paper)}.gen-btn:disabled{opacity:.4;cursor:not-allowed}.audio-row{flex-wrap:wrap;align-items:center;gap:10px;margin-top:4px;display:flex}.audio-tiny{border:1px solid var(--rule);background:var(--paper-2);border-radius:2px;align-items:center;gap:12px;padding:5px 12px 5px 5px;transition:border-color .15s;display:inline-flex}.audio-tiny:hover{border-color:var(--ink-3)}.audio-tiny-play{border:1px solid var(--ink-3);width:24px;height:24px;color:var(--ink-2);cursor:pointer;background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:all .15s;display:inline-flex}.audio-tiny-play:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}.audio-tiny-play svg{display:block}.audio-tiny-bar{cursor:pointer;align-items:center;width:140px;height:14px;display:flex;position:relative}.audio-tiny-bar:before{content:"";background:var(--rule);height:1px;position:absolute;top:50%;left:0;right:0;transform:translateY(-50%)}.audio-tiny-fill{background:var(--ink);pointer-events:none;height:1px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.audio-tiny-dot{background:var(--ink);pointer-events:none;border-radius:50%;width:6px;height:6px;position:absolute;top:50%;transform:translate(-50%,-50%)}.audio-tiny-time{font-family:var(--mono);letter-spacing:.08em;color:var(--ink-3);font-variant-numeric:tabular-nums;white-space:nowrap;font-size:10px}.audio-tiny-time .sep{color:var(--ink-4);margin:0 2px}.audio-link{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);cursor:pointer;background:0 0;border:0;padding:0;font-size:10px}.audio-link:hover{color:var(--ink)}.audio-link.danger{color:var(--accent)}.audio-link.danger:hover{color:var(--ink)}.audio-status{font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);font-size:10px}.suggest-modal{width:min(720px,100%)}.suggest-hint{color:var(--ink-4);text-transform:none;letter-spacing:0}.suggest-results{border-top:1px solid var(--rule);flex-direction:column;gap:12px;margin-top:4px;padding-top:16px;display:flex}.suggest-results-head{justify-content:space-between;align-items:center;display:flex}.suggest-cards{flex-direction:column;gap:10px;display:flex}.suggest-card{background:var(--paper-2);border:1px solid var(--rule);flex-direction:column;gap:8px;padding:12px 14px;transition:all .2s;display:flex}.suggest-card.added{opacity:.55;background:var(--paper)}.suggest-card-head{align-items:center;gap:12px;display:flex}.suggest-front{font-family:var(--serif-display);flex:1;font-size:24px;font-weight:500;line-height:1}.suggest-status{font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);font-size:10px}.suggest-status.ok{color:var(--accent-2)}.suggest-back{font-family:var(--thai);color:var(--ink-2);font-size:15px}.suggest-phrase{font-family:var(--serif-body);color:var(--ink-3);font-size:14px;font-style:italic}.suggest-ety{font-family:var(--serif-body);color:var(--ink-2);background:var(--paper);border-left:2px solid var(--rule);white-space:pre-wrap;margin:0;padding:8px 12px;font-size:13px;line-height:1.5}.modal-body label{font-family:var(--mono);letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3);font-size:10px}.modal-body input,.modal-body textarea{font-family:var(--serif-body);background:var(--paper-2);border:1px solid var(--rule);color:var(--ink);resize:vertical;outline:0;padding:8px 10px;font-size:17px}.modal-body textarea.thai,.modal-body input.thai{font-family:var(--thai)}.modal-body input:focus,.modal-body textarea:focus{border-color:var(--ink-3);background:var(--paper)}.pos-picker{flex-wrap:wrap;gap:4px;display:flex}.pos-picker .chip{font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;border:1px solid var(--rule);cursor:pointer;color:var(--ink-3);background:0 0;padding:6px 10px;font-size:10px}.pos-picker .chip.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}.modal-foot{border-top:1px solid var(--rule);justify-content:flex-end;gap:8px;padding:14px 20px;display:flex}@media (max-width:768px){.masthead,.page,.review-stage,.colophon{padding-left:20px;padding-right:20px}.stats{grid-template-columns:repeat(2,1fr)}.stat:nth-child(2){border-right:0}.index-row{grid-template-columns:32px 1fr 60px 60px;gap:10px}.index-row .leader,.index-row .trans{display:none}.face{padding:28px 20px}.controls-strip{grid-template-columns:1fr}.control-group.right{align-items:center}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}
