:root{--color-bg: #eef1e6;--color-surface: #e1e6d3;--color-surface-elevated: #f5f7ed;--color-text: #1f2540;--color-text-muted: #5a6280;--color-accent: #b23a2a;--color-accent-muted: #2f5e4f;--color-border: #bfc6a8;--color-error: #9b2c2c;--color-success: #2f5e4f;--font-display: "IBM Plex Serif", "Source Serif 4", Georgia, "Times New Roman", serif;--font-body: "IBM Plex Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-mono: "IBM Plex Mono", ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;--text-xs: .64rem;--text-sm: .8rem;--text-base: 1rem;--text-lg: 1.25rem;--text-xl: 1.563rem;--text-2xl: 1.953rem;--text-3xl: 2.441rem;--text-4xl: 3.052rem;--leading-tight: 1.15;--leading-snug: 1.3;--leading-normal: 1.55;--leading-loose: 1.75;--space-0: 0;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.5rem;--space-6: 2rem;--space-7: 3rem;--space-8: 4rem;--radius-sm: 2px;--radius-md: 6px;--radius-lg: 12px;--radius-pill: 9999px;--measure: 68ch}@media (prefers-color-scheme: dark){:root{--color-bg: #14172a;--color-surface: #1c2138;--color-surface-elevated: #252a44;--color-text: #e3e6f0;--color-text-muted: #9ea6c0;--color-accent: #d97a6c;--color-accent-muted: #7eb3a2;--color-border: #353a55;--color-error: #e57373;--color-success: #7eb3a2}}@font-face{font-family:"IBM Plex Serif";font-style:normal;font-display:swap;font-weight:400;src:url(/assets/ibm-plex-serif-cyrillic-ext-400-normal-CxUI4jC_.woff2) format("woff2"),url(/assets/ibm-plex-serif-cyrillic-ext-400-normal-BcBv-TKp.woff) format("woff");unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:"IBM Plex Serif";font-style:normal;font-display:swap;font-weight:400;src:url(/assets/ibm-plex-serif-cyrillic-400-normal-CPQ8oqB-.woff2) format("woff2"),url(/assets/ibm-plex-serif-cyrillic-400-normal-C7IY3oUc.woff) format("woff");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:"IBM Plex Serif";font-style:normal;font-display:swap;font-weight:400;src:url(/assets/ibm-plex-serif-vietnamese-400-normal-DGubAMUE.woff2) format("woff2"),url(/assets/ibm-plex-serif-vietnamese-400-normal-BY9Vij9A.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:"IBM Plex Serif";font-style:normal;font-display:swap;font-weight:400;src:url(/assets/ibm-plex-serif-latin-ext-400-normal-CNMooFZX.woff2) format("woff2"),url(/assets/ibm-plex-serif-latin-ext-400-normal-DwktX9jl.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:"IBM Plex Serif";font-style:normal;font-display:swap;font-weight:400;src:url(/assets/ibm-plex-serif-latin-400-normal-BIGslYFI.woff2) format("woff2"),url(/assets/ibm-plex-serif-latin-400-normal-BB-zNvJB.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:"IBM Plex Serif";font-style:normal;font-display:swap;font-weight:600;src:url(/assets/ibm-plex-serif-cyrillic-ext-600-normal-DXSZftVr.woff2) format("woff2"),url(/assets/ibm-plex-serif-cyrillic-ext-600-normal-CDMeBxaJ.woff) format("woff");unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:"IBM Plex Serif";font-style:normal;font-display:swap;font-weight:600;src:url(/assets/ibm-plex-serif-cyrillic-600-normal-6oiym5iu.woff2) format("woff2"),url(/assets/ibm-plex-serif-cyrillic-600-normal-C8YEAlRA.woff) format("woff");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:"IBM Plex Serif";font-style:normal;font-display:swap;font-weight:600;src:url(/assets/ibm-plex-serif-vietnamese-600-normal-BBruYZNA.woff2) format("woff2"),url(/assets/ibm-plex-serif-vietnamese-600-normal-DZRaS25B.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:"IBM Plex Serif";font-style:normal;font-display:swap;font-weight:600;src:url(/assets/ibm-plex-serif-latin-ext-600-normal-CU6LeQOd.woff2) format("woff2"),url(/assets/ibm-plex-serif-latin-ext-600-normal-D1-_Ic5L.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:"IBM Plex Serif";font-style:normal;font-display:swap;font-weight:600;src:url(/assets/ibm-plex-serif-latin-600-normal-DAxitmSu.woff2) format("woff2"),url(/assets/ibm-plex-serif-latin-600-normal-D3rpGdkS.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:IBM Plex Sans;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/ibm-plex-sans-cyrillic-ext-400-normal-g30qAdWV.woff2) format("woff2"),url(/assets/ibm-plex-sans-cyrillic-ext-400-normal-Dsrv2Tcn.woff) format("woff");unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:IBM Plex Sans;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/ibm-plex-sans-cyrillic-400-normal-DZqxrq2p.woff2) format("woff2"),url(/assets/ibm-plex-sans-cyrillic-400-normal-BTotfTJu.woff) format("woff");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:IBM Plex Sans;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/ibm-plex-sans-greek-400-normal-_efipK4i.woff2) format("woff2"),url(/assets/ibm-plex-sans-greek-400-normal-D9ESIMu3.woff) format("woff");unicode-range:U+0370-0377,U+037A-037F,U+0384-038A,U+038C,U+038E-03A1,U+03A3-03FF}@font-face{font-family:IBM Plex Sans;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/ibm-plex-sans-vietnamese-400-normal-DG4YqDda.woff2) format("woff2"),url(/assets/ibm-plex-sans-vietnamese-400-normal-fK1oJ5dG.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:IBM Plex Sans;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/ibm-plex-sans-latin-ext-400-normal-C5H60-Va.woff2) format("woff2"),url(/assets/ibm-plex-sans-latin-ext-400-normal-RBey6euL.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:IBM Plex Sans;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/ibm-plex-sans-latin-400-normal-CDDApCn2.woff2) format("woff2"),url(/assets/ibm-plex-sans-latin-400-normal-CYLoc0-x.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:IBM Plex Sans;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/ibm-plex-sans-cyrillic-ext-500-normal-Cs5J6C77.woff2) format("woff2"),url(/assets/ibm-plex-sans-cyrillic-ext-500-normal-DB5PtV2g.woff) format("woff");unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:IBM Plex Sans;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/ibm-plex-sans-cyrillic-500-normal-CocWQlwt.woff2) format("woff2"),url(/assets/ibm-plex-sans-cyrillic-500-normal-ByOcLdNv.woff) format("woff");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:IBM Plex Sans;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/ibm-plex-sans-greek-500-normal-JMMifIXV.woff2) format("woff2"),url(/assets/ibm-plex-sans-greek-500-normal-CuWXN6rf.woff) format("woff");unicode-range:U+0370-0377,U+037A-037F,U+0384-038A,U+038C,U+038E-03A1,U+03A3-03FF}@font-face{font-family:IBM Plex Sans;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/ibm-plex-sans-vietnamese-500-normal-e4dixQRQ.woff2) format("woff2"),url(/assets/ibm-plex-sans-vietnamese-500-normal-BEb3_waV.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:IBM Plex Sans;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/ibm-plex-sans-latin-ext-500-normal-DakdToA3.woff2) format("woff2"),url(/assets/ibm-plex-sans-latin-ext-500-normal-D0aIdm-b.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:IBM Plex Sans;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/ibm-plex-sans-latin-500-normal-6ng42L7E.woff2) format("woff2"),url(/assets/ibm-plex-sans-latin-500-normal-BgVn5rGT.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:IBM Plex Sans;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/ibm-plex-sans-cyrillic-ext-600-normal-DUMzJB7m.woff2) format("woff2"),url(/assets/ibm-plex-sans-cyrillic-ext-600-normal-Bz0x94Yp.woff) format("woff");unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:IBM Plex Sans;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/ibm-plex-sans-cyrillic-600-normal-71GNu3SW.woff2) format("woff2"),url(/assets/ibm-plex-sans-cyrillic-600-normal-BGq0mW3O.woff) format("woff");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:IBM Plex Sans;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/ibm-plex-sans-greek-600-normal-DzTrcv_p.woff2) format("woff2"),url(/assets/ibm-plex-sans-greek-600-normal-D-CqTdkO.woff) format("woff");unicode-range:U+0370-0377,U+037A-037F,U+0384-038A,U+038C,U+038E-03A1,U+03A3-03FF}@font-face{font-family:IBM Plex Sans;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/ibm-plex-sans-vietnamese-600-normal-DpPYBSTl.woff2) format("woff2"),url(/assets/ibm-plex-sans-vietnamese-600-normal-DgdngZtN.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:IBM Plex Sans;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/ibm-plex-sans-latin-ext-600-normal-DOrvGEcy.woff2) format("woff2"),url(/assets/ibm-plex-sans-latin-ext-600-normal-DIrixKbi.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:IBM Plex Sans;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/ibm-plex-sans-latin-600-normal-CuJfVYMP.woff2) format("woff2"),url(/assets/ibm-plex-sans-latin-600-normal-Cu4Hd6ag.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:IBM Plex Mono;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/ibm-plex-mono-cyrillic-ext-400-normal-xuaO2J-f.woff2) format("woff2"),url(/assets/ibm-plex-mono-cyrillic-ext-400-normal-DMdlQ8Kv.woff) format("woff");unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:IBM Plex Mono;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/ibm-plex-mono-cyrillic-400-normal-BSMlKf0J.woff2) format("woff2"),url(/assets/ibm-plex-mono-cyrillic-400-normal-CEL4l2ZJ.woff) format("woff");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:IBM Plex Mono;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/ibm-plex-mono-vietnamese-400-normal-BulugwFq.woff2) format("woff2"),url(/assets/ibm-plex-mono-vietnamese-400-normal-DDuiU_S-.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:IBM Plex Mono;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/ibm-plex-mono-latin-ext-400-normal-BmRBH3aV.woff2) format("woff2"),url(/assets/ibm-plex-mono-latin-ext-400-normal-D3D2R8hC.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:IBM Plex Mono;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/ibm-plex-mono-latin-400-normal-DMJ8VG8y.woff2) format("woff2"),url(/assets/ibm-plex-mono-latin-400-normal-CvHOgSBP.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:IBM Plex Mono;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/ibm-plex-mono-cyrillic-ext-600-normal-V-xxqcpd.woff2) format("woff2"),url(/assets/ibm-plex-mono-cyrillic-ext-600-normal-9HEixskS.woff) format("woff");unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:IBM Plex Mono;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/ibm-plex-mono-cyrillic-600-normal-CTOM6hUh.woff2) format("woff2"),url(/assets/ibm-plex-mono-cyrillic-600-normal-fLZuRloM.woff) format("woff");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:IBM Plex Mono;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/ibm-plex-mono-vietnamese-600-normal-D2EvbN8M.woff2) format("woff2"),url(/assets/ibm-plex-mono-vietnamese-600-normal-iLQfcSjf.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:IBM Plex Mono;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/ibm-plex-mono-latin-ext-600-normal-D38SheWl.woff2) format("woff2"),url(/assets/ibm-plex-mono-latin-ext-600-normal-DmB0ttJJ.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:IBM Plex Mono;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/ibm-plex-mono-latin-600-normal-BgSNZQsw.woff2) format("woff2"),url(/assets/ibm-plex-mono-latin-600-normal-DWFSQ4vo.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}*,*:before,*:after{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;width:100%;overflow:hidden;background:var(--color-bg, #eef1e6);color:var(--color-text, #1f2540);font-family:var(--font-body, "IBM Plex Sans", system-ui, sans-serif)}button{font-family:inherit}.app-shell{display:flex;flex-direction:column;height:100%;width:100%}.app-header{display:flex;align-items:baseline;gap:1rem;padding:.5rem 1rem;border-bottom:1px solid var(--color-border, #bfc6a8);background:var(--color-surface, #e1e6d3);font-size:.8rem;flex:0 0 auto}.app-header h1{margin:0;font-family:var(--font-display, "IBM Plex Serif", Georgia, serif);font-size:1rem;font-weight:600}.app-header .tag{color:var(--color-text-muted, #5a6280)}.method-app{flex:1 1 auto;display:flex;flex-direction:column;min-height:0}.phase-breadcrumb{display:flex;gap:.25rem;padding:.5rem 1rem;border-bottom:1px solid var(--color-border, #bfc6a8);background:var(--color-surface, #e1e6d3);overflow-x:auto;flex:0 0 auto}.phase-crumb{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .7rem;border:1px solid transparent;background:transparent;border-radius:var(--radius-md, 6px);color:var(--color-text-muted, #5a6280);font-size:.85rem;cursor:pointer}.phase-crumb:disabled{opacity:.5;cursor:not-allowed}.phase-crumb.active{background:var(--color-surface-elevated, #f5f7ed);border-color:var(--color-border, #bfc6a8);color:var(--color-text, #1f2540)}.phase-crumb-num{display:inline-flex;align-items:center;justify-content:center;width:1.25rem;height:1.25rem;border-radius:999px;background:var(--color-border, #bfc6a8);color:var(--color-text, #1f2540);font-size:.7rem;font-weight:600}.phase-crumb.active .phase-crumb-num{background:var(--color-accent, #b23a2a);color:#fff}.method-main{flex:1 1 auto;min-height:0;overflow:auto}.method-screen{display:flex;flex-direction:column;gap:1rem;padding:1.25rem 1.5rem 2rem;max-width:1280px;margin:0 auto;width:100%}.method-header h2{margin:0 0 .25rem;font-family:var(--font-display, "IBM Plex Serif", Georgia, serif);font-size:1.4rem;font-weight:600}.method-lede{margin:0;max-width:68ch;color:var(--color-text, #1f2540);line-height:1.55}.method-meta{margin:0;color:var(--color-text-muted, #5a6280);font-size:.85rem}.method-error{margin:0;padding:.5rem .75rem;border:1px solid var(--color-error, #9b2c2c);background:var(--color-surface-elevated, #f5f7ed);color:var(--color-error, #9b2c2c);font-family:var(--font-mono, "IBM Plex Mono", ui-monospace, monospace);font-size:.8rem;border-radius:var(--radius-sm, 2px)}.method-button{appearance:none;border:1px solid var(--color-border, #bfc6a8);background:var(--color-surface-elevated, #f5f7ed);color:var(--color-text, #1f2540);padding:.5rem .85rem;border-radius:var(--radius-md, 6px);cursor:pointer;font-size:.9rem}.method-button:hover:not(:disabled){border-color:var(--color-accent-muted, #2f5e4f)}.method-button:disabled{opacity:.5;cursor:not-allowed}.method-button.primary{background:var(--color-accent, #b23a2a);color:#fff;border-color:var(--color-accent, #b23a2a)}.method-button.primary:hover:not(:disabled){filter:brightness(1.08)}.method-button.subtle{background:transparent;border-color:var(--color-border, #bfc6a8)}.subject-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem}.subject-card{appearance:none;display:flex;flex-direction:column;gap:.5rem;padding:.75rem;border:1px solid var(--color-border, #bfc6a8);background:var(--color-surface-elevated, #f5f7ed);border-radius:var(--radius-md, 6px);cursor:pointer;text-align:left}.subject-card:hover{border-color:var(--color-accent-muted, #2f5e4f)}.subject-thumb{width:100%;aspect-ratio:3 / 4;background:var(--color-surface, #e1e6d3);border-radius:var(--radius-sm, 2px);display:flex;align-items:center;justify-content:center;overflow:hidden}.subject-thumb img{max-width:100%;max-height:100%;object-fit:contain}.subject-thumb-empty{color:var(--color-text-muted, #5a6280);font-size:.9rem}.subject-label{font-size:.9rem;color:var(--color-text, #1f2540)}.observe-layout,.name-layout{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:1rem;align-items:start}@media (max-width: 800px){.observe-layout,.name-layout{grid-template-columns:1fr}}.reference-frame{position:relative;background:var(--color-surface-elevated, #f5f7ed);border:1px solid var(--color-border, #bfc6a8);border-radius:var(--radius-md, 6px);padding:.5rem;display:flex;justify-content:center;align-items:center;min-height:360px;user-select:none}.reference-image-box{position:relative;display:inline-block;line-height:0;max-width:100%}.reference-image-box img{display:block;max-width:100%;max-height:70vh;object-fit:contain;pointer-events:none}.reference-frame.is-marking{cursor:crosshair;outline:2px dashed var(--color-accent-muted, #2f5e4f);outline-offset:-4px}.landmark-pin{position:absolute;transform:translate(-50%,-50%);display:inline-flex;align-items:center;justify-content:center;width:1.4rem;height:1.4rem;border-radius:999px;background:var(--color-accent, #b23a2a);color:#fff;font-size:.75rem;font-weight:600;pointer-events:none;box-shadow:0 0 0 2px var(--color-surface-elevated, #f5f7ed)}.landmark-pin.is-draggable{cursor:grab;pointer-events:auto;touch-action:none}.landmark-pin.is-dragging{cursor:grabbing;transform:translate(-50%,-50%) scale(1.15);z-index:2}.image-filters{display:flex;flex-direction:column;gap:.5rem;padding:.5rem .75rem;background:var(--color-surface-elevated, #f5f7ed);border:1px solid var(--color-border, #bfc6a8);border-radius:var(--radius-md, 6px)}.image-filters-header{display:flex;align-items:center;justify-content:space-between}.image-filters-title{font-size:.75rem;text-transform:uppercase;letter-spacing:.12em;color:var(--color-text-muted, #6c7762);margin:0}.image-filters-reset{font-size:.7rem;background:transparent;border:1px solid var(--color-border, #bfc6a8);border-radius:4px;padding:.125rem .5rem;color:var(--color-text, #2a2a2a);cursor:pointer}.image-filters-reset:hover{border-color:var(--color-accent, #b23a2a)}.image-filter-row{display:grid;grid-template-columns:5.5rem 1fr 3rem;align-items:center;gap:.5rem;font-size:.8rem}.image-filter-row label{font-family:ui-monospace,SF Mono,monospace;font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted, #6c7762)}.image-filter-row input[type=range]{width:100%;accent-color:var(--color-accent, #b23a2a)}.image-filter-row span{font-family:ui-monospace,SF Mono,monospace;font-size:.7rem;text-align:right;color:var(--color-text, #2a2a2a)}.landmark-reorder{display:inline-flex;flex-direction:column;gap:1px;margin-right:.4rem}.landmark-reorder button{background:transparent;border:1px solid var(--color-border, #bfc6a8);border-radius:3px;width:1.1rem;height:.9rem;padding:0;font-size:.6rem;line-height:1;cursor:pointer;color:var(--color-text, #2a2a2a)}.landmark-reorder button:disabled{opacity:.35;cursor:not-allowed}.landmark-reorder button:not(:disabled):hover{border-color:var(--color-accent, #b23a2a)}.observe-panel,.name-panel{display:flex;flex-direction:column;gap:.75rem;background:var(--color-surface-elevated, #f5f7ed);border:1px solid var(--color-border, #bfc6a8);border-radius:var(--radius-md, 6px);padding:.75rem;position:sticky;top:.5rem;max-height:80vh;overflow:auto}.landmark-list,.metaphor-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.landmark-list li{display:flex;align-items:center;gap:.5rem}.landmark-index{display:inline-flex;align-items:center;justify-content:center;width:1.4rem;height:1.4rem;border-radius:999px;background:var(--color-accent, #b23a2a);color:#fff;font-size:.75rem;font-weight:600;flex:0 0 auto}.landmark-name-input,.metaphor-input,.fog-input{flex:1 1 auto;padding:.35rem .5rem;border:1px solid var(--color-border, #bfc6a8);background:var(--color-bg, #eef1e6);color:var(--color-text, #1f2540);border-radius:var(--radius-sm, 2px);font-size:.9rem;font-family:inherit}.landmark-remove{appearance:none;border:1px solid var(--color-border, #bfc6a8);background:transparent;color:var(--color-text-muted, #5a6280);width:1.6rem;height:1.6rem;border-radius:var(--radius-sm, 2px);cursor:pointer}.metaphor-list li{display:flex;flex-direction:column;gap:.3rem;padding:.5rem;border:1px solid var(--color-border, #bfc6a8);border-radius:var(--radius-sm, 2px);background:var(--color-bg, #eef1e6)}.metaphor-header{display:flex;align-items:center;gap:.5rem}.landmark-name{font-weight:600;font-size:.9rem}.metaphor-label{display:flex;flex-direction:column;gap:.2rem;font-size:.78rem;color:var(--color-text-muted, #5a6280)}.method-reproduce{height:100%}.reproduce-layout{display:grid;grid-template-columns:minmax(0,1fr) 280px;gap:1rem;flex:1 1 auto;min-height:0}@media (max-width: 800px){.reproduce-layout{grid-template-columns:1fr}}.reproduce-canvas-host{position:relative;background:var(--color-surface-elevated, #f5f7ed);border:1px solid var(--color-border, #bfc6a8);border-radius:var(--radius-md, 6px);min-height:480px;height:70vh;overflow:hidden}.reproduce-canvas{display:block;width:100%;height:100%;touch-action:none;cursor:crosshair}.recipe-panel{background:var(--color-surface-elevated, #f5f7ed);border:1px solid var(--color-border, #bfc6a8);border-radius:var(--radius-md, 6px);padding:.75rem;display:flex;flex-direction:column;gap:.75rem;max-height:80vh;overflow:auto}.recipe-panel.hidden{padding:.5rem}.recipe-controls{display:flex;gap:.4rem;flex-wrap:wrap}.recipe-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.4rem}.recipe-list li{display:flex;align-items:flex-start;gap:.5rem;padding:.4rem;border:1px solid var(--color-border, #bfc6a8);border-radius:var(--radius-sm, 2px);background:var(--color-bg, #eef1e6)}.recipe-text{display:flex;flex-direction:column;gap:.1rem;font-size:.85rem}.recipe-name{font-weight:600}.recipe-metaphor{color:var(--color-text-muted, #5a6280);font-style:italic}.fog-layout{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}@media (max-width: 800px){.fog-layout{grid-template-columns:1fr}}.fog-side{margin:0;display:flex;flex-direction:column;gap:.4rem}.fog-side figcaption{font-size:.85rem;color:var(--color-text-muted, #5a6280)}.fog-overlay{position:relative;background:var(--color-surface-elevated, #f5f7ed);border:1px solid var(--color-border, #bfc6a8);border-radius:var(--radius-md, 6px);height:50vh;cursor:crosshair;overflow:hidden}.reproduction-thumb{display:block;width:100%;height:100%}.fog-pin{position:absolute;transform:translate(-50%,-50%);width:1.6rem;height:1.6rem;border-radius:999px;background:var(--color-error, #9b2c2c);color:#fff;font-size:.75rem;font-weight:700;border:2px solid var(--color-surface-elevated, #f5f7ed);cursor:pointer;appearance:none}.fog-pin.pending{background:var(--color-accent-muted, #2f5e4f);cursor:default;pointer-events:none}.fog-form{display:flex;flex-wrap:wrap;align-items:end;gap:.5rem}.fog-label{display:flex;flex-direction:column;gap:.25rem;font-size:.8rem;color:var(--color-text-muted, #5a6280);flex:1 1 280px}.fog-actions{display:flex;justify-content:flex-end;padding-top:.5rem;border-top:1px solid var(--color-border, #bfc6a8)}.done-summary,.done-schedule{background:var(--color-surface-elevated, #f5f7ed);border:1px solid var(--color-border, #bfc6a8);border-radius:var(--radius-md, 6px);padding:.85rem 1rem}.done-summary h3,.done-schedule h3{margin:0 0 .5rem;font-family:var(--font-display, "IBM Plex Serif", Georgia, serif);font-size:1.05rem;font-weight:600}.summary-grid{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.5rem}.summary-grid li{display:flex;flex-direction:column;gap:.1rem}.summary-label{font-size:.75rem;color:var(--color-text-muted, #5a6280)}.summary-value{font-size:1.05rem;font-weight:600}.schedule-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.3rem}.schedule-list li{display:flex;justify-content:space-between;padding:.35rem .5rem;border:1px solid var(--color-border, #bfc6a8);border-radius:var(--radius-sm, 2px);background:var(--color-bg, #eef1e6);font-size:.9rem}.schedule-label{font-weight:600}.schedule-date{color:var(--color-text-muted, #5a6280);font-family:var(--font-mono, "IBM Plex Mono", ui-monospace, monospace)}.done-actions{display:flex;justify-content:flex-end;gap:.5rem}.done-actions.schedule-actions{justify-content:flex-start;margin-top:.5rem}.method-sessions{display:flex;flex-direction:column;gap:1rem;padding:1rem;overflow:auto}.sessions-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap}.sessions-header>div{flex:1 1 320px;min-width:0}.sessions-permission{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.85rem 1rem;background:var(--color-surface-elevated, #ffffff);border:1px solid var(--color-border, #d9d3c4);border-radius:var(--radius-md, 6px)}.sessions-permission.denied{border-color:var(--color-error, #9b2c2c)}.sessions-permission h3{margin:0 0 .3rem;font-size:.95rem;font-weight:600}.sessions-permission p{margin:0;font-size:.85rem;color:var(--color-text-muted, #5b5953);max-width:60ch}.sessions-filters{display:flex;gap:1rem;flex-wrap:wrap}.sessions-filters label{display:flex;flex-direction:column;gap:.2rem;font-size:.75rem;color:var(--color-text-muted, #5b5953)}.sessions-filters select{font:inherit;padding:.3rem .5rem;border:1px solid var(--color-border, #d9d3c4);border-radius:var(--radius-sm, 2px);background:var(--color-surface-elevated, #ffffff);color:var(--color-text, #1a1a1a);min-width:12rem}.sessions-empty{padding:1.5rem;background:var(--color-surface-elevated, #ffffff);border:1px dashed var(--color-border, #d9d3c4);border-radius:var(--radius-md, 6px);text-align:center;color:var(--color-text-muted, #5b5953)}.sessions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.85rem}.session-card{display:flex;flex-direction:column;gap:.5rem;padding:.85rem 1rem;background:var(--color-surface-elevated, #ffffff);border:1px solid var(--color-border, #d9d3c4);border-radius:var(--radius-md, 6px)}.session-card.status-overdue{border-color:var(--color-error, #9b2c2c)}.session-card.status-due{border-color:var(--color-accent, #7a3b2e)}.session-card.status-completed{opacity:.7}.session-card-head{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.session-card-head h3{margin:0;font-family:var(--font-display, serif);font-size:1rem;font-weight:600}.session-status-pill{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;padding:.15rem .45rem;border-radius:999px;background:var(--color-border, #d9d3c4);color:var(--color-text, #1a1a1a);font-weight:600}.session-status-pill.status-overdue{background:var(--color-error, #9b2c2c);color:#fff}.session-status-pill.status-due{background:var(--color-accent, #7a3b2e);color:#fff}.session-status-pill.status-completed{background:var(--color-bg, #f6f3ec);color:var(--color-text-muted, #5b5953)}.session-meta{margin:0;font-size:.8rem;color:var(--color-text-muted, #5b5953)}.session-progress{display:flex;flex-direction:column;gap:.3rem;margin:0;font-size:.8rem}.session-progress-bar{display:block;height:.4rem;background:var(--color-border, #d9d3c4);border-radius:999px;overflow:hidden}.session-progress-fill{display:block;height:100%;background:var(--color-accent, #7a3b2e)}.session-progress-text{color:var(--color-text-muted, #5b5953);font-size:.75rem}.session-next{margin:0;font-size:.85rem}.session-actions{display:flex;justify-content:flex-end}.phase-crumb.back{border-color:var(--color-border, #d9d3c4);background:var(--color-bg, #f6f3ec)}
