:root{--text:#5f5f5b;--text-h:#1f1f1d;--bg:#f2f1ec;--surface:#fbfaf6;--surface-pressed:#eeede8;--border:#d3d1c9;--border-strong:#8f918c;--code-bg:#e7e5de;--accent:#4f5d61;--accent-2:#3f565b;--accent-soft:#e1e2de;--focus:#6d7376;--shadow:#22221e1a 0 18px 34px -22px, #22221e1f 0 10px 18px -20px;--sans:Avenir, "Avenir Next", ui-sans-serif, system-ui, "Segoe UI", sans-serif;--heading:Georgia, Cambria, "Times New Roman", serif;--mono:"SFMono-Regular", Consolas, "Liberation Mono", monospace;font:16px/1.5 var(--sans);color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html{background:radial-gradient(circle at top left, #ffffffb3, transparent 34rem), radial-gradient(circle at 82% 20%, #5c5c5614, transparent 26rem), linear-gradient(135deg, #26262206 0 1px, transparent 1px 14px), var(--bg);min-width:320px}body{background:linear-gradient(#ffffff29,#2e2e2a09),radial-gradient(circle at 20% 10%,#ffffff73,#0000 22rem);min-width:320px;min-height:100svh;margin:0}button,input,textarea,select{font:inherit}h1,h2,p{margin:0}h1,h2{color:var(--text-h);font-family:var(--heading);letter-spacing:0;font-weight:700}h1{font-size:clamp(44px,7vw,74px);line-height:.98}code{color:var(--accent);background:var(--code-bg);font-family:var(--mono);border:1px solid #1f1f1d1f;border-radius:4px;margin-top:4px;padding:4px 8px;font-size:13px;display:inline-flex}.app-shell{box-sizing:border-box;width:min(100%,1120px);min-height:100svh;margin:0 auto;padding:10px}.contrast-app{box-sizing:border-box;grid-template-rows:auto minmax(0,1fr);width:100%;height:100svh;min-height:0;margin:0 auto;padding:10px;display:grid;overflow:hidden}.home-header{gap:10px;margin-bottom:34px;display:grid}.eyebrow{color:var(--accent);letter-spacing:.12em;text-transform:uppercase;margin:0;font-size:13px;font-weight:800}.tool-list{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;display:grid}.tool-card{border:1px solid var(--border);min-height:172px;color:var(--text-h);text-align:center;background:linear-gradient(155deg, #ffffff7a, transparent 42%), var(--surface);border-radius:8px;align-content:center;place-items:center;gap:14px;padding:28px 22px;text-decoration:none;transition:border-color .16s,transform .16s,box-shadow .16s;display:grid;position:relative;box-shadow:inset 0 1px #ffffff80}.tool-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow);transform:translateY(-1px)}.tool-card:focus-visible,.global-nav a:focus-visible,.tool-action:focus-visible{outline:3px solid var(--focus);outline-offset:3px}.tool-card strong{color:var(--text-h);font-size:17px;line-height:1.25;display:block}.tool-card-icon{width:64px;height:64px;color:var(--accent-2)}.top-nav{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;margin-bottom:18px;padding-bottom:14px;display:flex}.global-nav,.local-nav{align-items:center;min-height:36px;display:flex}.global-nav{gap:6px}.local-nav{border-left:1px solid var(--border-strong);justify-content:flex-end;gap:6px;min-width:48px;margin-left:auto;padding-left:14px}.global-nav a,.tool-action{width:36px;height:36px;color:var(--accent);background:0 0;border:0;border-radius:8px;place-items:center;transition:background-color .16s,color .16s,transform .16s;display:inline-grid}.global-nav a:hover,.tool-action:hover{color:var(--text-h);background:#1f1f1d0d;transform:translateY(-1px)}.tool-action:disabled{color:#5f5f5b5c;cursor:not-allowed}.tool-action:disabled:hover{color:#5f5f5b5c;background:0 0;transform:none}.global-nav svg,.tool-action svg{width:20px;height:20px}.tool-action{cursor:pointer;padding:0}.contrast-workspace{border:1px solid var(--border);background:var(--surface);width:min(100%,560px);min-height:460px;box-shadow:var(--shadow);border-radius:10px;grid-template-rows:auto minmax(0,1fr);gap:28px;margin:0 auto;padding:28px;display:grid;overflow:hidden}.contrast-app .contrast-workspace{height:100%;min-height:0}.contrast-workspace[data-state=done]{width:100%;min-height:680px}.contrast-app .contrast-workspace[data-state=done]{min-height:0}.contrast-header{justify-content:space-between;align-items:start;gap:20px;display:flex}.contrast-header>div{gap:3px;display:grid}.contrast-header h1{font-family:var(--sans);font-size:16px;font-weight:800;line-height:1.25}.contrast-header p{color:#5f5f5bb8;font-size:12px;font-weight:700}.photo-picker-input{clip:rect(0 0 0 0);white-space:nowrap;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.photo-picker-button{min-height:34px;color:var(--surface);background:var(--accent);cursor:pointer;border:0;border-radius:999px;justify-content:center;align-items:center;gap:8px;padding:8px 14px;font-size:13px;font-weight:800;transition:background-color .16s,border-color .16s,transform .16s;display:flex}.photo-picker-button:hover{border-color:var(--text-h);background:var(--text-h);transform:translateY(-1px)}.photo-picker-button:focus-visible,.photo-picker-input:focus-visible+.photo-picker-button{outline:3px solid var(--focus);outline-offset:3px}.photo-picker-button svg{width:15px;height:15px}.photo-prompt,.processing-view{place-self:center;width:min(100%,360px);display:grid}.photo-prompt{text-align:center;justify-items:center;gap:10px}.photo-prompt>svg{color:#3f565b9e;background:radial-gradient(circle at 50% 28%,#ffffffdb,#0000 34%),#e8edf0;border-radius:50%;width:92px;height:92px;margin-bottom:8px;padding:22px}.photo-prompt strong{color:var(--text-h);font-size:16px;font-weight:800;line-height:1.2}.photo-prompt span{color:#5f5f5bb3;margin-bottom:8px;font-size:12px;font-weight:700}.processing-view{gap:14px}.selected-photo{border:1px solid var(--border);background:var(--surface-pressed);border-radius:8px;gap:2px;min-width:0;padding:12px 14px;display:grid}.selected-photo strong{color:var(--text-h);text-overflow:ellipsis;white-space:nowrap;line-height:1.25;overflow:hidden}.selected-photo span{color:var(--text);font-size:13px;font-weight:700}.processing-panel{color:var(--text-h);background:var(--surface-pressed);border:0;border-radius:10px;gap:16px;padding:16px;display:grid}.processing-panel>div{justify-content:space-between;align-items:center;gap:14px;display:flex}.processing-panel span{color:var(--text);font-size:14px;font-weight:800}.processing-panel strong{font-size:26px;line-height:1;font-family:var(--heading);flex:none}.processing-checklist{gap:8px;margin:0;padding:0;list-style:none;display:grid}.processing-step{color:#5f5f5bb8;align-items:center;gap:9px;min-height:26px;font-size:13px;font-weight:700;display:flex}.processing-step svg{flex:none;width:18px;height:18px}.processing-step.active{color:var(--accent)}.processing-step.active svg{animation:.9s linear infinite spin}.processing-step.complete{color:var(--accent-2)}.processing-error{color:#8b2f2f;text-align:center;font-size:13px;font-weight:800}.result-view{height:100%;min-height:0;display:block}.result-photo-group{--contrast-card-rail-width:168px;grid-template-rows:minmax(0,1fr) auto;gap:16px;min-width:0;height:100%;min-height:0;display:grid}.result-photo-row{grid-template-columns:minmax(0, 1fr) var(--contrast-card-rail-width);min-width:0;min-height:0;display:grid}.result-photo-pane,.result-canvas-pane{background:#f8f8f5;border:1px solid #1f1f1d24;border-radius:10px;min-height:500px;overflow:hidden}.result-photo-pane{touch-action:none;background:#fff;border-radius:10px 0 0 10px}.contrast-app .result-photo-pane,.contrast-app .result-canvas-pane,.contrast-app .contrast-range-summary{min-height:0}.result-photo-zoom,.result-photo-zoom-content{width:100%;height:100%}.result-photo-zoom-content{cursor:grab}.result-photo-zoom-content:active{cursor:grabbing}.result-photo-zoom-content img{object-fit:fill;filter:grayscale();-webkit-user-select:none;user-select:none;-webkit-user-drag:none;width:100%;height:100%;display:block}.result-canvas-pane{background-color:#fbfbf8;background-image:linear-gradient(90deg,#1f1f1d0b 1px,#0000 1px),linear-gradient(#1f1f1d0b 1px,#0000 1px),none;background-position:0 0,0 0,0 0;background-repeat:repeat,repeat,repeat;background-size:24px 24px;background-attachment:scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box}.contrast-range-summary{grid-template-rows:minmax(0,1fr) minmax(0,1fr);min-height:500px;display:grid}.grayscale-card{border:1px solid #1f1f1d24;border-left:0;border-radius:0;align-content:end;gap:6px;padding:18px;display:grid;box-shadow:inset 0 1px #ffffff3d}.grayscale-card:first-child{border-radius:0 10px 0 0}.grayscale-card:last-child{border-top:0;border-radius:0 0 10px}.grayscale-card span,.grayscale-card strong{color:inherit}.grayscale-card span{text-transform:uppercase;font-size:12px;font-weight:800}.grayscale-card strong{font-family:var(--heading);font-size:36px;line-height:1}.result-controls-row{grid-template-columns:minmax(0, 1fr) var(--contrast-card-rail-width);align-items:stretch;gap:16px;display:grid}.contrast-slider-block{background:var(--surface-pressed);border:1px solid #1f1f1d1f;border-radius:8px;gap:16px;padding:18px 20px 16px;display:grid}.contrast-slider-header{justify-content:space-between;align-items:end;gap:16px;display:flex}.contrast-slider-header>div{gap:3px;display:grid}.contrast-slider-header h2{font-family:var(--sans);color:var(--text-h);font-size:15px;font-weight:800;line-height:1.25}.contrast-slider-header p{color:var(--text);font-size:12px;font-weight:700}.contrast-slider-header>strong{color:var(--text-h);text-align:right;font-size:14px;font-weight:800}.grayscale-slider{color:var(--text-h)}.speedometer-gauge{place-items:center;width:168px;min-height:112px;margin:0;display:grid}.speedometer-gauge-svg{width:100%;height:auto;display:block;overflow:visible}.speedometer-gauge-segment{fill:none;stroke:#1f1f1d;stroke-linecap:butt;stroke-width:26px}.speedometer-gauge-label{baseline-shift:-.18em;letter-spacing:0;paint-order:stroke;stroke:#1f1f1d47;stroke-linejoin:round;stroke-width:2px;text-transform:uppercase;font-size:11px;font-weight:900}.speedometer-gauge-separator{stroke:#fbfaf6;stroke-linecap:round;stroke-width:3px}.speedometer-gauge-label-path{fill:none;stroke:none}.speedometer-gauge-needle{stroke:var(--text-h);stroke-linecap:round;stroke-width:3px}.speedometer-gauge-hub{fill:var(--text-h);stroke:#fbfaf6;stroke-width:3px}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=760px){.app-shell,.contrast-app{padding:28px 18px}.contrast-workspace{grid-template-columns:1fr;gap:24px;padding:24px}.contrast-header{align-items:start}.result-photo-row{grid-template-rows:minmax(0,1fr) auto;grid-template-columns:1fr}.result-controls-row{grid-template-columns:1fr}.result-photo-pane,.result-canvas-pane{min-height:360px}.result-photo-pane{border-radius:10px 10px 0 0}.contrast-range-summary{grid-template-rows:auto;grid-template-columns:minmax(0,1fr) minmax(0,1fr);min-height:0}.grayscale-card{border-top:0;min-height:112px}.grayscale-card:first-child{border-left:1px solid #1f1f1d24;border-radius:0 0 0 10px}.grayscale-card:last-child{border-top:0;border-radius:0 0 10px}.contrast-slider-header{flex-direction:column;align-items:start}.contrast-slider-header>strong{text-align:left}}
