:root{--bg: #050816;--bg-card: #0b1020;--bg-card-soft: #111827;--accent: #22c55e;--accent-soft: rgba(34, 197, 94, .18);--accent-2: #3b82f6;--text-main: #e5e7eb;--text-muted: #9ca3af;--border-subtle: #1f2937;--danger: #f97373;--font-sans: system-ui, -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", sans-serif}.matrix-psychro-wrapper{font-family:system-ui,-apple-system,BlinkMacSystemFont,Inter,sans-serif;font-size:14px;line-height:1.4}.matrix-psychro-wrapper h1{font-size:1.9rem;line-height:1.2;margin:0 0 .35rem}.matrix-psychro-wrapper h1+p{margin:0;font-size:.95rem;line-height:1.4;color:var(--text-muted)}.matrix-psychro-wrapper h2,.matrix-psychro-wrapper .section-title{font-size:1.05rem;line-height:1.25;margin:0 0 .6rem}.matrix-psychro-wrapper h3,.matrix-psychro-wrapper .state-block h3{font-size:.95rem;line-height:1.3;margin:0 0 .45rem}.matrix-psychro-wrapper p{margin:0 0 .45rem;font-size:.9rem;line-height:1.45}.matrix-psychro-wrapper .field>span{display:block;font-size:.8rem;line-height:1.3;margin-bottom:.25rem;color:var(--text-muted)}.matrix-psychro-wrapper .explanation-section li,.matrix-psychro-wrapper .explanation-section p{font-size:.9rem;line-height:1.4;margin-bottom:.25rem}.matrix-psychro-wrapper *,.matrix-psychro-wrapper *:before,.matrix-psychro-wrapper *:after{box-sizing:border-box}.matrix-psychro-wrapper{margin:0;font-family:var(--font-sans);background:radial-gradient(circle at top,#020617 0 35%,#000);color:var(--text-main)}.app-root{min-height:100vh;display:flex;flex-direction:column}.app-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 2rem;border-bottom:1px solid var(--border-subtle);background:linear-gradient(90deg,#2563eb33,#22c55e33);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);position:sticky;top:0;z-index:10}.app-header h1{margin:0;font-size:1.4rem}.app-header p{margin:.25rem 0 0;font-size:.9rem;color:var(--text-muted)}.header-badge{padding:.5rem .9rem;border-radius:999px;border:1px solid rgba(209,250,229,.3);background:#065f4666;font-size:.8rem;color:#bbf7d0}.app-main{flex:1;display:flex;gap:1.5rem;padding:1.5rem 2rem 2rem}.sidebar{width:320px;display:flex;flex-direction:column;gap:1rem}.chart-section{flex:1;display:flex;flex-direction:column;gap:1rem}.card{border-radius:1rem;background:radial-gradient(circle at top left,#111827,#020617);border:1px solid var(--border-subtle);padding:1rem 1.25rem;box-shadow:0 18px 40px #00000080}.card h2{margin-top:0;font-size:1rem}.field{display:flex;flex-direction:column;margin-bottom:.5rem;font-size:.85rem}.field span{margin-bottom:.2rem;color:var(--text-muted)}.field input{background:#020617;border-radius:.5rem;border:1px solid var(--border-subtle);padding:.35rem .5rem;color:var(--text-main);font-size:.85rem}.field input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 1px #22c55e66}.hint{font-size:.75rem;color:var(--text-muted);margin-top:.25rem}.state-block{margin-top:.75rem;padding-top:.4rem;border-top:1px dashed var(--border-subtle)}.state-block h3{margin:0 0 .4rem;font-size:.9rem}.state-mini-info{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.25rem .75rem;margin-top:.3rem;font-size:.78rem;color:var(--text-muted)}.toggle{display:flex;align-items:center;gap:.5rem;font-size:.85rem;margin-bottom:.25rem}.toggle input{accent-color:var(--accent)}.chart-card{position:relative}.chart-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:.5rem}.chart-header p{margin:.2rem 0 0;font-size:.8rem;color:var(--text-muted)}.chart-wrapper{position:relative;border-radius:.75rem;overflow:hidden;background:radial-gradient(circle at top,#020617,#020617 40%,#000);border:1px solid #1f2937}.psychro-svg{width:100%;max-width:800px;height:auto;display:block;margin:0 auto;cursor:crosshair}.grid-line{stroke:#94a3b826;stroke-width:.5}.axis-label{fill:var(--text-muted);font-size:9px}.axis-title{fill:var(--text-main);font-size:11px}.curve-rh{fill:none;stroke:#94a3b8b3;stroke-width:1}.curve-rh-sat{stroke:var(--accent);stroke-width:1.4}.curve-twb{fill:none;stroke:#818cf8e6;stroke-width:1;stroke-dasharray:4 3}.curve-v{fill:none;stroke:#2dd4bfe6;stroke-width:1;stroke-dasharray:6 4}.curve-dew{fill:none;stroke:#ef4444e6;stroke-width:.9;stroke-dasharray:3 3}.curve-h{fill:none;stroke:#fbbf24f2;stroke-width:.9;stroke-dasharray:5 3}.state-marker text{fill:var(--text-main);font-size:10px}.marker-1 circle{fill:var(--accent)}.marker-2 rect{fill:var(--accent-2)}.marker-3 polygon{fill:#f97316}.line-connection{stroke-width:1.2;fill:none}.line-12{stroke:#38bdf8b3}.line-13{stroke:#f97316cc;stroke-dasharray:4 3}.line-23{stroke:#5eead4cc;stroke-dasharray:4 3}.crosshair-line{stroke:#d1d5db66;stroke-width:.7;stroke-dasharray:2 3}.hover-panel{position:absolute;min-width:190px;max-width:220px;background:#0f172af2;border-radius:.75rem;border:1px solid rgba(148,163,184,.45);padding:.55rem .65rem;font-size:.75rem;pointer-events:none;box-shadow:0 16px 40px #0009}.hover-title{font-weight:600;margin-bottom:.35rem;font-size:.8rem}.hover-grid{display:grid;grid-template-columns:auto auto;column-gap:.75rem;row-gap:.15rem}.hover-grid span:nth-child(odd){color:var(--text-muted)}.hover-grid span:nth-child(2n){text-align:right}.hover-warning{margin:.35rem 0 0;font-size:.72rem;color:var(--danger)}.legend{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:.75rem;font-size:.78rem;color:var(--text-muted)}.legend-item{display:inline-flex;align-items:center;gap:.3rem}.legend-swatch{width:14px;height:4px;border-radius:999px;display:inline-block}.legend-swatch.rh{background:#94a3b8e6}.legend-swatch.twb{background:#818cf8e6}.legend-swatch.v{background:#2dd4bfe6}.legend-swatch.dew{background:#ef4444e6}.legend-swatch.h{background:#fbbf24f2}.explanations ul{margin:.5rem 0 .5rem 1.1rem;padding:0;font-size:.85rem}.explanations li{margin-bottom:.3rem;color:var(--text-muted)}@media(max-width:1024px){.app-main{flex-direction:column}.sidebar{width:100%;flex-direction:row;overflow-x:auto}.sidebar .card{min-width:260px}}.field input[type=range]{padding:0;background:transparent;border:none}.field input[type=range]:focus{outline:none;box-shadow:none}.mix-percents{display:flex;justify-content:space-between;font-size:.78rem;color:var(--text-muted);margin-top:.15rem}@media(max-width:768px){.psychro-svg{max-width:100%;width:100%;height:320px}.hover-panel{min-width:150px;max-width:180px;padding:.4rem .45rem;font-size:.68rem}.hover-title{font-size:.75rem}.hover-grid{column-gap:.4rem}}
