:root{
  --bg:#E9EBEE; --panel:#FBFBFC; --ink:#15181D; --muted:#6B7280;
  --line:#D5D8DD; --grid:#E3E6EA;
  --clay:#1F6F78; --sand:#C9A14A; --neutral:#9AA3AB;
  --action:#1F6F78; --action-ink:#0F4A50;
  --radius:10px;
  --sans:'IBM Plex Sans',system-ui,-apple-system,sans-serif;
  --mono:'IBM Plex Mono',ui-monospace,'SF Mono',Menlo,monospace;
}
*{box-sizing:border-box}
html,body{margin:0}
body{background:var(--bg);color:var(--ink);font-family:var(--sans);line-height:1.5;
  -webkit-font-smoothing:antialiased;padding:clamp(16px,3vw,40px)}
.wrap{max-width:1080px;margin:0 auto}

/* top nav */
.nav{max-width:1080px;margin:0 auto 26px;display:flex;align-items:center;gap:20px;font-size:14px;
  border-bottom:1px solid var(--line);padding-bottom:14px}
.nav .brand{font-weight:700;letter-spacing:-.01em;text-decoration:none;color:var(--ink)}
.nav a{color:var(--muted);text-decoration:none;font-weight:500}
.nav a:hover{color:var(--ink)}
.nav a.active{color:var(--action-ink);font-weight:600}
.nav .spacer{flex:1}

header{margin-bottom:22px}
.eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--action-ink);font-weight:600;margin:0 0 6px}
h1{font-size:clamp(22px,3.5vw,30px);font-weight:700;margin:0;letter-spacing:-.01em}
.sub{color:var(--muted);margin:6px 0 0;max-width:62ch;font-size:14px}

.grid{display:grid;grid-template-columns:340px 1fr;gap:20px;align-items:start}
@media (max-width:820px){.grid{grid-template-columns:1fr}}

.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:18px}
.card h2{font-size:13px;font-weight:600;margin:0 0 12px;letter-spacing:.02em;
  font-family:var(--mono);text-transform:uppercase;color:var(--muted)}

/* hub method cards */
.methods{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:8px}
@media (max-width:700px){.methods{grid-template-columns:1fr}}
.method{display:block;text-decoration:none;color:inherit;background:var(--panel);border:1px solid var(--line);
  border-radius:var(--radius);padding:22px;transition:border-color .15s, box-shadow .15s}
.method:hover{border-color:var(--action);box-shadow:0 2px 10px rgba(0,0,0,.05)}
.method .k{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--action-ink);font-weight:600}
.method h2{font-size:19px;font-weight:700;margin:8px 0 6px}
.method p{margin:0;color:#4a4f57;font-size:14px}
.method .go-link{display:inline-block;margin-top:14px;color:var(--action-ink);font-weight:600;font-size:14px}

label.field{display:block;font-size:13px;font-weight:500;margin:0 0 6px}
textarea{width:100%;min-height:200px;resize:vertical;font-family:var(--mono);font-size:13px;
  border:1px solid var(--line);border-radius:8px;padding:10px;background:#fff;color:var(--ink);line-height:1.55}
.row{display:flex;gap:12px;align-items:end;margin-top:14px;flex-wrap:wrap}
.num{display:flex;flex-direction:column;gap:6px}
.num input{width:96px;font-family:var(--mono);font-size:14px;padding:8px 10px;border:1px solid var(--line);border-radius:8px;background:#fff}
.hint{font-size:12px;color:var(--muted);margin-top:10px}
.hint code{font-family:var(--mono);background:#EEF0F2;padding:1px 5px;border-radius:4px}

button.go{font-family:var(--sans);font-weight:600;font-size:14px;cursor:pointer;background:var(--action);
  color:#fff;border:none;border-radius:8px;padding:10px 18px;transition:background .15s}
button.go:hover{background:var(--action-ink)}
button.go:disabled{background:#9AA3AB;cursor:not-allowed}
.filebtn{background:#fff;color:var(--action-ink);border:1px solid var(--line);font-weight:500;
  border-radius:8px;padding:10px 16px;cursor:pointer;font-size:14px}
.filebtn:hover{background:#F3F5F6}
:focus-visible{outline:2px solid var(--action);outline-offset:2px}

.status{font-family:var(--mono);font-size:12px;margin-top:12px;padding:8px 10px;border-radius:6px}
.status.ok{background:#E7F1F0;color:var(--action-ink)}
.status.warn{background:#FBF0E6;color:#8A4B1F}
.status.err{background:#FBE9E9;color:#9B2C2C}

.results{display:none}
.results.show{display:block}
.legend{display:flex;gap:18px;font-size:12px;color:var(--muted);margin:0 0 10px;font-family:var(--mono);flex-wrap:wrap}
.legend.hidden{display:none}
.swatch{display:inline-block;width:11px;height:11px;border-radius:2px;vertical-align:middle;margin-right:5px}

.scroll{overflow-x:auto}
table{border-collapse:collapse;width:100%;font-family:var(--mono);font-size:13px;min-width:520px}
th,td{text-align:right;padding:7px 12px;border-bottom:1px solid var(--grid);white-space:nowrap}
th{color:var(--muted);font-weight:600;font-size:11px;letter-spacing:.04em;text-transform:uppercase;border-bottom:1px solid var(--line)}
th.l,td.l{text-align:left}
td.soil-clay{color:var(--clay);font-weight:600}
td.soil-sand{color:var(--sand);font-weight:600}
tbody tr:hover{background:#F4F6F7}

svg{display:block;max-width:100%;height:auto}
.panel-title{font-family:var(--mono);font-size:11px;fill:var(--muted);font-weight:600}
.axis-label{font-family:var(--mono);font-size:10px;fill:var(--muted)}
.gridline{stroke:var(--grid);stroke-width:1}
.curve{fill:none;stroke-width:1.8}

/* SEO content */
.content{max-width:760px;margin:44px auto 0;padding:0 2px}
.content section{margin-bottom:34px}
.content h2{font-size:20px;font-weight:700;letter-spacing:-.01em;margin:0 0 12px}
.content h3{font-size:15px;font-weight:600;margin:18px 0 6px;color:var(--action-ink)}
.content p{margin:0 0 12px;color:#2b2f36}
.content dl{margin:0}
.content dt{font-weight:600;margin-top:12px}
.content dd{margin:2px 0 0 0;color:#4a4f57}
.content ul{margin:0;padding-left:18px;color:#2b2f36}
.content li{margin:5px 0}
.content a{color:var(--action-ink)}
.faq details{border-top:1px solid var(--line);padding:12px 0}
.faq details:last-child{border-bottom:1px solid var(--line)}
.faq summary{font-weight:600;cursor:pointer;list-style:none;display:flex;gap:8px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::before{content:'+';color:var(--action);font-weight:700}
.faq details[open] summary::before{content:'\2013'}
.faq p{margin:10px 0 2px;color:#4a4f57}
footer{max-width:760px;margin:24px auto 40px;padding:20px 2px 0;border-top:1px solid var(--line);font-size:13px;color:var(--muted)}
