@import url("https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@500;600;700&family=IBM+Plex+Mono:wght@400;500&family=Source+Serif+4:wght@400;600&display=swap");:root{--paper:#f3efe6;--paper-strong:#ece6da;--ink:#1f2622;--ink-soft:#5b645d;--edge:rgba(31,38,34,0.12);--accent:#234b39;--accent-soft:rgba(35,75,57,0.14);--canvas:#faf7f0;--shadow:0 20px 48px rgba(34,40,36,0.08);--radius:18px}*{box-sizing:border-box}html,body{margin:0;min-height:100%;color:var(--ink);background:radial-gradient(circle at top left,rgba(35,75,57,0.08),transparent 32%),linear-gradient(180deg,rgba(255,255,255,0.56),rgba(255,255,255,0)),var(--paper);font-family:"Source Serif 4",Georgia,serif}body::before{content:"";position:fixed;inset:0;pointer-events:none;background-image:linear-gradient(rgba(31,38,34,0.035) 1px,transparent 1px),linear-gradient(90deg,rgba(31,38,34,0.035) 1px,transparent 1px);background-size:28px 28px;mask-image:linear-gradient(180deg,rgba(0,0,0,0.34),transparent 84%)}.page-shell{width:min(1320px,calc(100vw - 28px));margin:0 auto;padding:18px 0 36px}.hero{margin-bottom:14px;padding:8px 2px 2px;animation:rise-in 520ms ease-out}.eyebrow{margin:0 0 6px;color:var(--ink-soft);font-family:"IBM Plex Mono",monospace;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase}.hero h1{margin:0;font-family:"Cormorant Garamond",Georgia,serif;font-size:clamp(2.35rem,4.4vw,4rem);font-weight:600;line-height:.96;letter-spacing:.01em}.lede{max-width:680px;margin:8px 0 0;color:var(--ink-soft);font-size:.95rem;line-height:1.45}.layout{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:12px}.card{position:relative;overflow:hidden;padding:16px 18px;border:1px solid var(--edge);border-radius:var(--radius);background:linear-gradient(180deg,rgba(255,255,255,0.72),rgba(255,255,255,0.58)),var(--paper-strong);box-shadow:var(--shadow);animation:rise-in 420ms ease-out}.card::after{content:"";position:absolute;inset:0;pointer-events:none;border-radius:inherit;box-shadow:inset 0 1px 0 rgba(255,255,255,0.55)}.card-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:10px}.card-head h2{margin:0;font-family:"Cormorant Garamond",Georgia,serif;font-size:1.55rem;font-weight:600}.card-note{margin:0;color:var(--ink-soft);font-family:"IBM Plex Mono",monospace;font-size:.68rem;text-transform:uppercase;letter-spacing:.06em}.controls-card,.chart-card{grid-column:span 12}.list-card{grid-column:span 6}.controls-grid{display:grid;grid-template-columns:minmax(260px,2.35fr) minmax(88px,0.8fr) minmax(104px,0.9fr) minmax(126px,1fr) minmax(188px,1.5fr);gap:12px;align-items:start}.controls-grid label{display:grid;gap:6px}.controls-grid .wide{grid-column:auto}.controls-grid span{color:var(--ink-soft);font-family:"IBM Plex Mono",monospace;font-size:.72rem;letter-spacing:.06em;text-transform:uppercase}input{width:100%;min-height:42px;padding:10px 12px;border:1px solid rgba(31,38,34,0.16);border-radius:10px;background:rgba(255,255,255,0.8);color:var(--ink);font:inherit}input:focus{outline:2px solid rgba(35,75,57,0.18);border-color:rgba(35,75,57,0.35)}.slider-shell{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center}input[type="range"]{padding:0;border:0;border-radius:999px;background:transparent}input[type="range"]::-webkit-slider-runnable-track{height:8px;border-radius:999px;background:linear-gradient(90deg,rgba(35,75,57,0.18),rgba(35,75,57,0.48))}input[type="range"]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;margin-top:-5px;border-radius:50%;border:1px solid rgba(31,38,34,0.16);background:#f8f6f1}input[type="range"]::-moz-range-track{height:8px;border-radius:999px;background:linear-gradient(90deg,rgba(35,75,57,0.18),rgba(35,75,57,0.48))}input[type="range"]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;border:1px solid rgba(31,38,34,0.16);background:#f8f6f1}.slider-value{min-width:46px;text-align:right;font-size:.94rem}.button-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.button{padding:9px 14px;border:1px solid rgba(31,38,34,0.14);border-radius:999px;background:rgba(255,255,255,0.72);color:var(--ink);font:inherit;font-size:.94rem;cursor:pointer;transition:transform 180ms ease,background 180ms ease,border-color 180ms ease}.button:hover:not(:disabled){transform:translateY(-1px);border-color:rgba(35,75,57,0.36);background:rgba(255,255,255,0.9)}.button:disabled{cursor:wait;opacity:.55}.button-primary{background:var(--accent);border-color:var(--accent);color:#f7f4ee}.button-primary:hover:not(:disabled){background:#1b3b2c}.button-ghost{background:transparent}.status-row{display:flex;align-items:center;gap:12px;margin-top:12px;padding-top:12px;border-top:1px solid var(--edge)}.status-label{font-family:"IBM Plex Mono",monospace;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft)}.status-text{color:var(--accent);font-family:"IBM Plex Mono",monospace;font-size:.82rem}.mono{font-family:"IBM Plex Mono",monospace}.chart-card canvas{width:100%;height:clamp(280px,41vh,360px);display:block;border-radius:14px;background:var(--canvas);border:1px solid rgba(31,38,34,0.09)}.history-strip{display:flex;flex-wrap:wrap;gap:10px}.history-pill{padding:8px 12px;border-radius:999px;background:rgba(35,75,57,0.08);border:1px solid rgba(35,75,57,0.12);color:var(--ink);font-family:"IBM Plex Mono",monospace;font-size:.88rem}.table-shell{overflow:auto}table{width:100%;border-collapse:collapse;font-variant-numeric:tabular-nums}th,td{padding:10px 8px;border-bottom:1px solid rgba(31,38,34,0.08);text-align:left}.permutation-cell{display:flex;align-items:center;gap:10px}.cell-swatch{width:.85rem;height:.85rem;border-radius:999px;border:1px solid rgba(31,38,34,0.12);box-shadow:inset 0 1px 0 rgba(255,255,255,0.38);flex:none}th{color:var(--ink-soft);font-family:"IBM Plex Mono",monospace;font-size:.76rem;text-transform:uppercase;letter-spacing:.06em}.empty-state{background:rgba(255,255,255,0.56);border:1px solid rgba(31,38,34,0.08);border-radius:14px}.empty-state{padding:18px;color:var(--ink-soft);font-family:"IBM Plex Mono",monospace;font-size:.88rem}@keyframes rise-in{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media(max-width:980px){.controls-card,.chart-card,.list-card{grid-column:span 12}.controls-grid,.controls-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:640px){.page-shell{width:min(100vw - 24px,100%);padding-top:28px}.controls-grid,.controls-grid{grid-template-columns:1fr}.button-row{flex-direction:column}.card-head{align-items:flex-start;flex-direction:column}}