:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;color:#0f172a;background-color:#f7f7f8;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{box-sizing:border-box}body{margin:0;background:#f7f7f8;min-width:320px}a{color:#0f766e;text-decoration:none}a:hover{text-decoration:underline}#root{max-width:800px;margin:0 auto;padding:1.5rem;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#1f2933}body{background:#f7f7f8;margin:0}.app{display:flex;flex-direction:column;gap:1.5rem}header{text-align:center}.subtitle{margin:.5rem 0 0;font-size:.95rem;color:#52606d}.unit-toggle{margin-top:1rem;display:inline-flex;align-items:center;gap:.35rem;padding:.25rem;background:#e2e8f0;border-radius:999px}.unit-toggle button{border:none;background:transparent;color:#334155;font-size:.85rem;font-weight:600;padding:.35rem .85rem;border-radius:999px;cursor:pointer;transition:background .15s ease,color .15s ease,box-shadow .15s ease}.unit-toggle button.active{background:#0f766e;color:#fff;box-shadow:0 1px 3px #0f172a33}.unit-toggle button:focus-visible{outline:2px solid #0f766e;outline-offset:2px}.inputs{display:flex;flex-direction:column;gap:1rem;background:#fff;padding:1rem;border-radius:12px;box-shadow:0 1px 3px #0f172a14}.field{display:flex;flex-direction:column;gap:.4rem}.field-label{display:flex;justify-content:space-between;font-size:.9rem;color:#334155}.field-value{font-variant-numeric:tabular-nums;font-weight:600}input[type=range]{width:100%;accent-color:#0f766e}.outputs{display:grid;gap:1rem}@media(min-width:420px){.outputs{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}}.output-card{background:#fff;padding:1.25rem;border-radius:12px;box-shadow:0 1px 3px #0f172a14;display:flex;flex-direction:column;gap:.4rem}.output-card h2{margin:0;font-size:1rem;color:#0f172a}.angles{display:flex;justify-content:space-between;gap:1rem;margin-top:.4rem}.angles div{display:flex;flex-direction:column;align-items:center;gap:.2rem;flex:1}.angles-label{font-size:.85rem;color:#64748b}.angles-value{font-size:1.4rem;font-variant-numeric:tabular-nums;font-weight:600;color:#0f766e}.tension-pair{font-size:.95rem;margin-top:.8rem}.primary-value{margin:0;font-size:1.75rem;font-weight:700;color:#0f766e}.secondary-value{margin:0;color:#4b5563;font-variant-numeric:tabular-nums}.caption{margin:0;font-size:.85rem;color:#64748b}.diagram-panel{margin-top:.5rem}.diagram-card{gap:1rem}.diagram{display:flex;flex-direction:column;gap:.6rem}.diagram canvas{width:360px;border-radius:12px;border:1px solid #e2e8f0;background:linear-gradient(#fff,#f8fafc);margin:0 auto}.diagram-legend{display:flex;flex-wrap:wrap;gap:.6rem 1rem;font-size:.8rem;color:#64748b}.legend-item{display:inline-flex;align-items:center;gap:.45rem}.legend{display:inline-block}.swatch{width:18px;height:3px;border-radius:4px}.swatch-left{background:#2563eb}.swatch-right{background:#059669}.dot{width:10px;height:10px;border-radius:50%;background:#2563eb}.legend-dashed{position:relative;padding-left:18px}.legend-dashed:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:14px;border-top:1.5px dashed rgba(15,23,42,.5)}.reference-content{display:flex;flex-direction:column;gap:2.5rem;margin-top:2.5rem;background:#fff;padding:1.5rem;border-radius:14px;box-shadow:0 1px 3px #0f172a1f}.guide h2,.guide h3,.faq h2,.code-sample h2{margin-top:0;color:#0f172a}.guide h3{margin-top:1.75rem;font-size:1.05rem}.guide p,.faq p,.code-sample p{line-height:1.65;color:#334155}.guide ul{padding-left:1.25rem;color:#334155}.guide li+li{margin-top:.35rem}.guide table{border-collapse:collapse;width:100%;margin:1rem 0 1.5rem;font-size:.95rem}.guide caption{text-align:left;margin-bottom:.5rem;font-weight:600;color:#0f172a}.guide th,.guide td{border:1px solid #e2e8f0;padding:.6rem .75rem;text-align:left;font-variant-numeric:tabular-nums}.formula{font-family:SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace;background:#f1f5f9;border-radius:6px;padding:.65rem .75rem;margin:1rem 0;color:#0f172a;font-size:.95rem}.faq details{border:1px solid #e2e8f0;border-radius:10px;padding:.85rem 1rem;background:#f8fafc;transition:border-color .15s ease,background .15s ease}.faq details+details{margin-top:.85rem}.faq summary{cursor:pointer;font-weight:600;color:#0f172a;list-style:none}.faq details[open]{border-color:#0f766e;background:#ecfdf5}.code-sample pre{background:#0f172a;color:#e2e8f0;padding:1rem;border-radius:10px;overflow-x:auto;font-size:.9rem;line-height:1.55;box-shadow:inset 0 0 0 1px #94a3b833}.code-sample code{font-family:SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace}
