:root{color-scheme:light;font-family:Manrope,sans-serif;background:radial-gradient(circle at top left,rgba(0,168,150,.16),transparent 30%),radial-gradient(circle at top right,rgba(244,120,90,.18),transparent 22%),linear-gradient(180deg,#fff7ea,#f6efe2);color:#18243f}*{box-sizing:border-box}body{margin:0;min-height:100vh}button,input,select{font:inherit}#root{min-height:100vh}.app-shell{max-width:1560px;margin:0 auto;padding:32px 24px 40px}.hero{display:grid;grid-template-columns:minmax(0,1.6fr) minmax(320px,.9fr);gap:20px;align-items:end;margin-bottom:24px}.eyebrow{margin:0 0 8px;color:#0e9384;letter-spacing:.12em;text-transform:uppercase;font-size:.77rem;font-weight:700}.hero h1{margin:0;font-family:Fraunces,serif;font-size:clamp(2.8rem,5vw,4.8rem);line-height:.94}.hero-copy{max-width:76ch;margin:16px 0 0;color:#475467;font-size:1rem;line-height:1.7}.hero-disclaimer{max-width:76ch;margin:10px 0 0;padding:8px 12px;background:#fff8ec;border-left:3px solid #f79009;border-radius:4px;color:#b54708;font-size:.85rem;line-height:1.5;white-space:normal}.hero-stats{display:grid;gap:12px}.stat-card{display:flex;gap:12px;align-items:center;padding:16px 18px;border:1px solid rgba(24,36,63,.08);border-radius:20px;background:#fffaf2d6}.stat-card p{margin:0 0 3px;color:#667085;font-size:.9rem}.stat-card strong{font-size:1.1rem}.stat-icon{display:grid;place-items:center;width:42px;height:42px;border-radius:14px;background:linear-gradient(135deg,#e2fbf7,#fff1e6);color:#0f766e}.layout-grid{display:grid;grid-template-columns:minmax(320px,400px) minmax(0,1fr);gap:20px}.glass-panel{border:1px solid rgba(24,36,63,.08);border-radius:28px;background:#fffaf2d6;box-shadow:0 20px 60px #52301014;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.control-panel,.viewer-panel{padding:22px}.panel-header-row{display:flex;justify-content:space-between;gap:16px;align-items:center}.panel-header-row h2{margin:0;font-size:1.2rem}.panel-header-row p{margin:6px 0 0;color:#667085}.ghost-button{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(24,36,63,.12);border-radius:999px;padding:10px 14px;background:#ffffffa8;color:#18243f;cursor:pointer}.control-group{margin-top:22px;padding-top:18px;border-top:1px solid rgba(24,36,63,.08)}.control-group h3{margin:0 0 14px;font-size:.95rem;color:#344054}.slider-row,.select-row{display:grid;gap:8px;margin-bottom:14px}.slider-meta,.select-row{display:flex;justify-content:space-between;gap:12px;align-items:center}.slider-meta span,.select-row span{color:#344054}.slider-row input[type=range]{width:100%;accent-color:#0e9384}.select-row select{border:1px solid rgba(24,36,63,.16);border-radius:12px;padding:8px 10px;background:#ffffffdb}.toggle-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.toggle-row input{width:18px;height:18px}.status{margin:18px 0 0;color:#475467;font-weight:600}.status.ok{color:#027a48}.status.hint{color:#667085;font-weight:500;font-size:.9rem}.status.error{color:#b42318}.viewer-header{margin-bottom:18px}.panel-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.raster-panel{padding:8px;border-radius:24px;background:linear-gradient(180deg,#ffffffc7,#fff7eae0);border:1px solid rgba(24,36,63,.08);min-height:0}.plot-panel{display:block;width:100%;aspect-ratio:1 / 1;border-radius:18px;overflow:hidden}.empty-state{display:grid;place-items:center;min-height:480px;border-radius:24px;background:#ffffff80;color:#667085}@media(max-width:1120px){.hero,.layout-grid{grid-template-columns:1fr}}@media(max-width:720px){.app-shell{padding:20px 14px 28px}.panel-grid{grid-template-columns:1fr}.panel-header-row{flex-direction:column;align-items:flex-start}}
