:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--bg:#f7f4ee;--paper:#fffdf8;--ink:#24201b;--muted:#6e665f;--line:#e4ddd2;--accent:#c9653a;--accent-2:#2f6f73;--accent-soft:#ffe8da;--blue-soft:#e6f2f2;--green-soft:#eaf5e5;--danger-soft:#ffe5e5;--shadow:0 20px 50px #392b1b1a;--radius:22px}*{box-sizing:border-box}html{scroll-behavior:smooth}body{background:radial-gradient(circle at top left, #c9653a2e, transparent 32rem), radial-gradient(circle at bottom right, #2f6f732b, transparent 28rem), var(--bg);color:var(--ink);margin:0;font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}button,input,textarea,select{font:inherit}button{cursor:pointer}code,pre{font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace}.app-shell{grid-template-columns:310px minmax(0,1fr);min-height:100vh;display:grid}.sidebar{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#fffdf8b8;border-right:1px solid #24201b17;height:100vh;padding:28px;position:sticky;top:0;overflow:auto}.logo-row{align-items:center;gap:14px;margin-bottom:22px;display:flex}.logo{background:var(--accent);color:#fff;border-radius:16px;place-items:center;width:52px;height:52px;font-size:25px;font-weight:900;display:grid;box-shadow:0 12px 28px #c9653a47}h1{letter-spacing:-.04em;margin:0;font-size:25px;line-height:1.05}h2{letter-spacing:-.055em;margin:0 0 10px;font-size:clamp(28px,5vw,58px);line-height:.96}h3{letter-spacing:-.03em;margin:0 0 12px;font-size:20px}h4{margin:0 0 8px;font-size:16px}p{color:var(--muted);line-height:1.75}.small{color:var(--muted);font-size:13px}.tiny{color:var(--muted);font-size:12px;line-height:1.55}.main{width:100%;max-width:1420px;margin:0 auto;padding:34px}.hero{grid-template-columns:minmax(0,1.3fr) minmax(320px,.7fr);gap:22px;margin-bottom:22px;display:grid}.hero-card,.card,.explain-card,.side-card{border-radius:var(--radius);box-shadow:var(--shadow);background:#fffdf8e0;border:1px solid #24201b14}.hero-card{padding:clamp(24px,5vw,46px)}.card{padding:20px}.side-card{margin-top:16px;padding:18px}.kicker{background:var(--blue-soft);color:var(--accent-2);border-radius:999px;align-items:center;gap:8px;margin-bottom:18px;padding:7px 12px;font-size:13px;font-weight:800;display:inline-flex}.grid{grid-template-columns:repeat(12,1fr);gap:16px;display:grid}.span-3{grid-column:span 3}.span-4{grid-column:span 4}.span-5{grid-column:span 5}.span-6{grid-column:span 6}.span-7{grid-column:span 7}.span-8{grid-column:span 8}.span-12{grid-column:span 12}.metric{flex-direction:column;gap:8px;min-height:120px;display:flex}.metric strong{letter-spacing:-.05em;font-size:31px}.metric span{color:var(--muted);font-size:13px}.pill-row{flex-wrap:wrap;gap:8px;display:flex}.pill{border:1px solid var(--line);color:var(--muted);background:#ffffff94;border-radius:999px;align-items:center;gap:6px;padding:7px 10px;font-size:13px;display:inline-flex}.pill.strong{color:var(--ink);background:#fff;font-weight:800}.tabs{flex-wrap:wrap;gap:8px;margin:18px 0 22px;display:flex}.tab{border:1px solid var(--line);color:var(--muted);background:#fffdf8b8;border-radius:999px;padding:10px 14px}.tab.active{background:var(--ink);color:#fff;border-color:var(--ink)}.progress-wrap{margin:18px 0 12px}.progress-label{color:var(--muted);justify-content:space-between;margin-bottom:7px;font-size:12px;display:flex}.progress-track{background:#ece4d8;border-radius:99px;height:9px;overflow:hidden}.progress-fill{background:linear-gradient(90deg, var(--accent), var(--accent-2));border-radius:inherit;height:100%}.actions{flex-wrap:wrap;align-items:center;gap:9px;display:flex}.btn{background:var(--ink);color:#fff;border:0;border-radius:14px;padding:10px 13px;font-weight:800;box-shadow:0 10px 24px #24201b26}.btn.secondary{color:var(--ink);border:1px solid var(--line);box-shadow:none;background:#fff}.btn.accent{background:var(--accent)}.btn:disabled{opacity:.45;cursor:not-allowed}.stack-bar{background:#ece4d8;border:1px solid #24201b0f;border-radius:999px;height:26px;display:flex;overflow:hidden}.bar-ham{background:var(--accent-2)}.bar-spam{background:var(--accent)}.legend{color:var(--muted);flex-wrap:wrap;gap:12px;margin-top:10px;font-size:13px;display:flex}.dot{border-radius:99px;width:10px;height:10px;margin-right:6px;display:inline-block}.dot.ham{background:var(--accent-2)}.dot.spam{background:var(--accent)}.controls{flex-wrap:wrap;align-items:center;gap:12px;margin:0 0 16px;display:flex}.input,.select,.textarea{border:1px solid var(--line);color:var(--ink);background:#ffffffbd;border-radius:14px;outline:none;padding:11px 13px}.input{min-width:240px}.select{min-width:220px}.textarea{resize:vertical;width:100%;min-height:125px;line-height:1.55}.input:focus,.select:focus,.textarea:focus{border-color:var(--accent);box-shadow:0 0 0 4px #c9653a1f}.codewalk-grid{grid-template-columns:minmax(0,1.05fr) minmax(330px,.95fr);align-items:start;gap:18px;display:grid}.code-list{max-height:74vh;padding-right:6px;overflow:auto}.cell-card{border:1px solid var(--line);background:#ffffff94;border-radius:18px;margin-bottom:12px;overflow:hidden}.cell-head{border-bottom:1px solid var(--line);padding:14px 16px 10px}.cell-meta{color:var(--muted);flex-wrap:wrap;align-items:center;gap:8px;font-size:12px;display:flex}.code-lines{flex-direction:column;display:flex}.code-line{text-align:left;color:var(--ink);background:#ffffff8c;border:0;border-bottom:1px solid #e4ddd2a6;grid-template-columns:48px minmax(0,1fr) 84px;align-items:start;gap:10px;padding:10px 12px;display:grid}.code-line:hover{background:#fff3eb}.code-line.active{background:var(--accent-soft);box-shadow:inset 4px 0 0 var(--accent)}.code-line.comment .code-text{color:#7a756f}.code-line.blank .code-text{color:#aaa}.line-number{color:var(--muted);text-align:right;padding-top:2px;font-size:12px}.code-text{white-space:pre-wrap;overflow-wrap:anywhere;font-size:13px;line-height:1.55}.kind-badge{color:var(--muted);background:#f1eadf;border-radius:999px;justify-self:end;padding:4px 7px;font-size:11px}.kind-badge.code{background:var(--blue-soft);color:var(--accent-2)}.kind-badge.comment{background:var(--green-soft);color:#52704b}.kind-badge.blank{color:#888;background:#f0f0f0}.explain-card{padding:22px;position:sticky;top:24px}.explain-title{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.selected-code{color:#fff8ef;background:#27231f;border-radius:16px;margin:12px 0 16px;padding:14px;overflow:auto}.explain-item{border-top:1px solid var(--line);padding:14px 0}.explain-item b{margin-bottom:6px;display:block}.explain-item div{color:var(--muted);line-height:1.7}.callout{border:1px solid var(--line);color:var(--muted);background:#ffffffb8;border-radius:16px;padding:14px 16px;line-height:1.65}.callout.good{background:var(--green-soft);color:#3d6237;border-color:#cfe6c7}.callout.warn{color:#7a5c1c;background:#fff2d8;border-color:#f0d596}.callout.info{background:var(--blue-soft);color:#345f62;border-color:#c8e0e1}.table-wrap{border:1px solid var(--line);background:#ffffff9e;border-radius:16px;overflow:auto}table{border-collapse:collapse;width:100%;font-size:13px}th,td{border-bottom:1px solid var(--line);text-align:left;vertical-align:top;padding:10px 12px}th{color:var(--muted);white-space:nowrap;background:#f6efe4;font-weight:800}tr:last-child td{border-bottom:0}.label{border-radius:999px;padding:4px 8px;font-size:12px;font-weight:900;display:inline-block}.label.ham{background:var(--blue-soft);color:var(--accent-2)}.label.spam{background:var(--accent-soft);color:var(--accent)}.pipeline{gap:10px;display:grid}.step-card{border:1px solid var(--line);background:#ffffff9e;border-radius:16px;padding:14px}.step-card.active{border-color:var(--accent);background:var(--accent-soft)}.step-card pre{white-space:pre-wrap;margin:8px 0 0;line-height:1.55}.range{width:min(100%,560px);accent-color:var(--accent)}.heat-grid{gap:4px;min-width:620px;display:grid}.heat-head,.heat-label,.heat-cell{border-radius:10px;padding:7px 8px;font-size:12px}.heat-head{color:var(--muted);text-align:center;font-weight:800}.heat-label{text-overflow:ellipsis;white-space:nowrap;background:#f6efe4;overflow:hidden}.heat-cell{text-align:center;background:rgba(201,101,58, calc(.13 + var(--heat) * .62));color:#3b281b;font-weight:800}.yes{background:var(--accent-soft);color:var(--accent);border-radius:999px;padding:4px 8px;font-weight:900}.no{color:var(--muted)}.word-cloud{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.word-chip{border:1px solid var(--line);background:#ffffffb8;border-radius:999px;align-items:baseline;gap:6px;padding:7px 10px;display:inline-flex}.word-chip.spam{background:var(--accent-soft);color:var(--accent);border-color:#f3c8b4}.word-chip.ham{background:var(--blue-soft);color:var(--accent-2);border-color:#c5dddd}.word-chip small{opacity:.72}.bar-list{gap:8px;display:grid}.bar-row{grid-template-columns:82px minmax(0,1fr) 48px;align-items:center;gap:10px;font-size:13px;display:grid}.mini-track{background:#eee5d9;border-radius:99px;height:10px;overflow:hidden}.mini-fill{background:var(--accent);border-radius:inherit;height:100%}.mini-fill.ham{background:var(--accent-2)}.prob-box{border:1px solid var(--line);background:#ffffffb8;border-radius:18px;padding:16px}.prob-line{justify-content:space-between;gap:12px;margin-bottom:7px;font-weight:900;display:flex}.prob-track{background:#e7ded1;border-radius:999px;height:14px;overflow:hidden}.prob-fill{border-radius:inherit;background:var(--accent);height:100%}.token-row{flex-wrap:wrap;gap:7px;display:flex}.token{color:var(--muted);background:#f3eadf;border-radius:999px;padding:6px 9px;font-size:12px}.token.hit{background:var(--accent-soft);color:var(--accent);font-weight:900}.confusion-table{max-width:620px}.confusion-cell{text-align:center;letter-spacing:-.04em;font-size:24px;font-weight:950}.confusion-cell.good{background:var(--green-soft);color:#3d6237}.confusion-cell.bad{background:var(--danger-soft);color:#9b3b35}.command{color:#fff8ef;background:#24201b;border-radius:16px;padding:16px;line-height:1.7;overflow:auto}@media (width<=1100px){.app-shell{grid-template-columns:1fr}.sidebar{height:auto;position:relative}.hero,.codewalk-grid{grid-template-columns:1fr}.explain-card{position:relative;top:0}.span-3,.span-4,.span-5,.span-6,.span-7,.span-8{grid-column:span 12}}@media (width<=680px){.main{padding:18px}.sidebar{padding:20px}.code-line{grid-template-columns:34px minmax(0,1fr)}.kind-badge{display:none}.hero-card{padding:24px}}
