:root{--bg:#fff;--panel:#fff;--text:#666;--text-h:#111;--muted:#8a8a8a;--border:#ebebeb;--border-strong:#d9d9d9;--accent:#111;--accent-soft:#f7f7f7;--shadow-soft:none;--sans:"Helvetica Neue", "Pretendard", "Apple SD Gothic Neo", sans-serif;--heading:"Helvetica Neue", "Pretendard", "Apple SD Gothic Neo", sans-serif;font-family:var(--sans);color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-weight:400;line-height:1.5}*{box-sizing:border-box}html{scroll-behavior:smooth}body{background:#fff;min-width:320px;min-height:100vh;margin:0}button,input{font:inherit}img{max-width:100%;display:block}#root{width:min(1080px,100%);margin:0 auto}h1,h2{font-family:var(--heading);color:var(--text-h);margin:0;font-weight:600}h1{letter-spacing:-.04em;max-width:12ch;font-size:clamp(2.8rem,5vw,4.5rem);line-height:1.02}h2{letter-spacing:-.03em;font-size:clamp(1.5rem,2.2vw,2rem);line-height:1.15}p{margin:0}@media (width<=960px){h1{max-width:100%}}.app-shell{min-height:100svh;padding:24px 20px 36px}.intake-panel{border:1px solid var(--border);background:var(--panel);border-radius:24px}.panel-head{border-bottom:1px solid var(--border);padding:36px 36px 28px}.panel-title-row{justify-content:space-between;align-items:flex-start;gap:24px;display:flex}.eyebrow{letter-spacing:.12em;text-transform:uppercase;color:var(--muted);align-items:center;margin:0 0 12px;font-size:.75rem;font-weight:600;display:inline-flex}.hero-description{max-width:34rem;margin-top:16px;font-size:.98rem;line-height:1.7}.progress-copy{white-space:nowrap;color:var(--muted);margin:6px 0 0;font-size:.92rem}.panel-body,.result-layout{grid-template-columns:minmax(0,1.05fr) minmax(340px,.95fr);display:grid}.photo-area,.intake-form,.result-aside,.result-report{padding:32px 36px 36px}.photo-area,.result-aside{border-right:1px solid var(--border)}.section-heading{margin-bottom:18px}.section-heading h2{margin-bottom:8px}.section-heading p{max-width:28rem;line-height:1.65}.upload-dropzone,.result-photo-frame{border:1px dashed var(--border-strong);background:var(--accent-soft);border-radius:18px;min-height:460px;display:flex;overflow:hidden}.upload-dropzone{cursor:pointer;transition:border-color .16s}.upload-dropzone:hover{border-color:var(--text-h)}.upload-placeholder{text-align:center;width:100%;color:var(--muted);place-items:center;gap:12px;padding:32px;display:grid}.upload-icon{border:1px solid var(--border-strong);width:52px;height:52px;color:var(--text-h);background:#fff;border-radius:999px;place-items:center;font-size:1.8rem;line-height:1;display:grid}.photo-preview{object-fit:cover;width:100%;height:100%}.upload-meta{color:var(--muted);justify-content:space-between;align-items:center;gap:16px;margin-top:12px;font-size:.94rem;display:flex}.intake-form{flex-direction:column;gap:14px;display:flex}.field{flex-direction:column;gap:8px;display:flex}.field span{color:var(--text-h);font-weight:600}.field input{border:1px solid var(--border);width:100%;min-height:52px;color:var(--text-h);background:#fff;border-radius:14px;padding:0 16px;transition:border-color .16s}.field input:focus{border-color:var(--text-h);outline:none}.field-hint{color:var(--muted);font-size:.83rem;line-height:1.5}.field-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.input-with-unit{position:relative}.input-with-unit input{padding-right:50px}.input-with-unit em{color:var(--muted);font-style:normal;font-weight:500;position:absolute;top:50%;right:16px;transform:translateY(-50%)}.primary-button,.secondary-button{font:inherit;cursor:pointer;border-radius:999px;justify-content:center;align-items:center;font-weight:600;transition:background-color .16s,color .16s,border-color .16s,opacity .16s;display:inline-flex}.primary-button{color:#fff;background:#111;border:1px solid #111;min-height:52px;margin-top:8px}.primary-button:hover{background:#000}.primary-button:disabled{opacity:.55;cursor:wait}.secondary-button{border:1px solid var(--border-strong);min-height:40px;color:var(--text-h);background:#fff;padding:0 16px}.secondary-button:hover{border-color:#111}.form-message{margin:4px 0 0;font-size:.94rem}.error-message{color:#b42318}.result-aside{flex-direction:column;gap:20px;display:flex}.result-note h2{margin-bottom:8px}.result-note p{margin-bottom:18px;line-height:1.7}.result-stats{gap:12px;margin:0 0 20px;display:grid}.result-stats div{border-bottom:1px solid var(--border);justify-content:space-between;gap:16px;padding-bottom:10px;display:flex}.result-stats dt,.result-stats dd{margin:0}.result-stats dt{color:var(--muted)}.result-stats dd{color:var(--text-h);font-weight:600}.back-button{min-width:140px}.report-heading{margin-bottom:12px}.report-content{white-space:pre-wrap;word-break:keep-all;color:var(--text-h);margin:0;font-family:inherit;font-size:.97rem;line-height:1.8}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@media (width<=960px){.app-shell{padding:16px}.panel-head,.photo-area,.intake-form,.result-aside,.result-report{padding:20px}.panel-title-row,.panel-body,.result-layout,.field-grid{grid-template-columns:1fr;display:grid}.progress-copy{white-space:normal}.photo-area,.result-aside{border-right:0;border-bottom:1px solid var(--border)}.upload-dropzone,.result-photo-frame{min-height:300px}.upload-meta{flex-direction:column;align-items:stretch}.secondary-button,.primary-button,.back-button{width:100%}}
