:root{color-scheme:dark;--font: -apple-system, BlinkMacSystemFont, "PingFang SC", "Helvetica Neue", system-ui, sans-serif;--bg: #050507;--surface: #131318;--surface-2: #1d1d24;--text: #f4f4f7;--text-dim: #8d8d98;--line: #26262f;--accent: #6b6bff;--on-accent: #ffffff;--accent-soft: rgba(107, 107, 255, .14);--accent-grad: linear-gradient(140deg, #4f4e9e 0%, #6260c8 100%);--star: #f6c26b;--danger: #ff7070;--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: 24px;--sp-8: 32px;--sp-12: 48px;--r-sm: 10px;--r: 16px;--r-lg: 22px;--r-pill: 999px;--shadow: 0 12px 40px rgba(0, 0, 0, .55);--ease: .22s cubic-bezier(.2, .8, .2, 1);font-family:var(--font);background:var(--bg);color:var(--text)}*{box-sizing:border-box}body{margin:0;min-height:100vh}.app{max-width:760px;margin:0 auto;padding:var(--sp-6) var(--sp-4) var(--sp-12)}h1{margin:0 0 8px;font-size:28px;font-weight:600;letter-spacing:-.01em}.subtitle{color:var(--text-dim);margin-bottom:32px}.inputs{display:grid;grid-template-columns:1fr 1fr;gap:16px}.input-slot{background:var(--surface);border-radius:var(--r-lg);padding:var(--sp-5);display:flex;flex-direction:column;gap:var(--sp-3)}.slot-title{font-size:13px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em}.slot-description{margin:6px 0 0;color:#b8b8c0;font-size:13px;line-height:1.55}.slot-empty{flex:1;min-height:160px;border:1.5px dashed var(--line);border-radius:10px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;cursor:pointer;transition:border-color .15s,background .15s}.slot-empty.compact{flex:0 0 auto;min-height:74px}.slot-empty:hover{border-color:var(--accent);background:var(--accent-soft)}.slot-empty span:first-of-type{font-size:16px;color:var(--text)}.slot-hint{font-size:12px;color:var(--text-dim);line-height:1.35;text-align:center}.slot-filled{display:flex;flex-direction:column;gap:8px}.slot-preview{width:100%;border-radius:8px;max-height:200px;background:#000}.scene-frame-strip{display:grid;grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:6px}.scene-frame-strip img{width:100%;aspect-ratio:4 / 3;object-fit:cover;border-radius:6px;background:#000}.camera-coach{display:grid;gap:10px}.camera-coach:not(.open) .camera-grid,.camera-coach:not(.open) .person-frame,.camera-coach:not(.open) .live-guide{display:none}.camera-stage{position:relative;min-height:260px;overflow:hidden;border-radius:var(--r-lg);background:#000}.shutter-flash{position:absolute;top:0;right:0;bottom:0;left:0;z-index:6;background:#fff;pointer-events:none;animation:shutter-flash .22s ease-out forwards}@keyframes shutter-flash{0%{opacity:.85}to{opacity:0}}.camera-preview{width:100%;height:100%;min-height:260px;display:block;object-fit:cover;background:var(--bg)}.camera-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-content:center;gap:6px;padding:24px;text-align:center;background:linear-gradient(180deg,#ffffff0a,#fff0),var(--surface)}.camera-placeholder span{color:var(--text);font-size:16px;font-weight:600}.camera-placeholder p{max-width:260px;margin:0;color:var(--text-dim);font-size:12px;line-height:1.45}.camera-grid{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.camera-grid span{position:absolute;background:#ffffff1f}.camera-grid span:nth-child(1),.camera-grid span:nth-child(2){top:0;bottom:0;width:1px}.camera-grid span:nth-child(1){left:33.333%}.camera-grid span:nth-child(2){left:66.666%}.camera-grid span:nth-child(3),.camera-grid span:nth-child(4){left:0;right:0;height:1px}.camera-grid span:nth-child(3){top:33.333%}.camera-grid span:nth-child(4){top:66.666%}.person-frame{position:absolute;top:18%;left:50%;width:min(44%,180px);height:58%;transform:translate(-50%);border:1.5px solid rgba(107,107,255,.84);border-radius:999px 999px 22px 22px;box-shadow:0 0 0 999px #00000014;pointer-events:none}.person-frame span{position:absolute;left:50%;bottom:-28px;transform:translate(-50%);padding:4px 8px;border-radius:999px;background:#0000009e;color:var(--text-dim);font-size:11px;white-space:nowrap}.person-layer{position:absolute;top:0;right:0;bottom:0;left:0;z-index:4;pointer-events:none}.person-box{position:absolute;box-sizing:border-box;margin:0;padding:0;border:2px solid rgba(255,255,255,.72);border-radius:8px;background:#ffffff0a;cursor:pointer;pointer-events:auto;display:flex;align-items:flex-start;justify-content:flex-start;transition:border-color .15s ease,background .15s ease,opacity .15s ease}.person-box .tag{margin:4px;padding:3px 6px;font-size:11px;line-height:1;border-radius:6px;background:#0000008c;color:var(--text);white-space:nowrap}.person-box.selected{border-color:var(--accent);background:#6b6bff24;box-shadow:0 0 0 2px #6b6bff59}.person-box.selected .tag{background:var(--accent);color:var(--on-accent);font-weight:600}.person-layer:has(.person-box.selected) .person-box:not(.selected){opacity:.4}.capture-target{position:absolute;z-index:3;display:grid;place-items:center;gap:8px;width:110px;height:110px;border:2px solid rgba(107,107,255,.92);border-radius:50%;background:#08080a33;box-shadow:0 0 0 999px #00000005,0 0 34px #6b6bff38;color:var(--text);pointer-events:none;transform:translate(-50%,-50%);transition:left .28s ease,top .28s ease,border-color .2s ease,background .2s ease,box-shadow .2s ease,transform .2s ease}.capture-target.center{top:46%;left:50%}.capture-target.left{top:48%;left:24%}.capture-target.right{top:48%;left:76%}.capture-target.top{top:24%;left:50%}.capture-target.bottom{top:73%;left:50%}.capture-target.top-left{top:26%;left:24%}.capture-target.top-right{top:26%;left:76%}.capture-target.bottom-right{top:72%;left:76%}.capture-target.bottom-left{top:72%;left:24%}.capture-target:before,.capture-target:after{content:"";position:absolute;top:-12px;right:-12px;bottom:-12px;left:-12px;border:1px solid rgba(107,107,255,.42);border-radius:inherit;animation:target-pulse 1.25s ease-out infinite}.capture-target:after{top:-23px;right:-23px;bottom:-23px;left:-23px;opacity:.55;animation-delay:.2s}.capture-target.locked{border-color:#6b6bfffa;background:#114a3057;box-shadow:0 0 0 999px #6b6bff05,0 0 42px #6b6bff5c;transform:translate(-50%,-50%) scale(1.08)}.capture-target.locked:before,.capture-target.locked:after{border-color:#6b6bffb8;animation-duration:.58s}.target-arrow{position:relative;z-index:1;display:grid;place-items:center;width:38px;height:38px;border-radius:50%;background:#6b6bfff2;color:var(--surface);font-size:25px;font-weight:800;line-height:1;box-shadow:0 7px 24px #00000052}.target-arrow:before{content:"→"}.target-arrow.center:before{content:"•";font-size:34px;line-height:.65}.target-arrow.left:before{content:"←"}.target-arrow.right:before{content:"→"}.target-arrow.up:before{content:"↑"}.target-arrow.down:before{content:"↓"}.capture-target.locked .target-arrow{background:var(--accent)}.capture-target strong{position:relative;z-index:1;max-width:92px;padding:4px 7px;border-radius:999px;background:#0000009e;font-size:11px;font-weight:700;line-height:1.2;text-align:center}.capture-step-rail{position:absolute;z-index:4;top:10px;right:10px;display:flex;gap:5px;padding:6px;border-radius:999px;background:#0000008a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.capture-step-rail span{display:grid;place-items:center;width:21px;height:21px;border:1px solid rgba(255,255,255,.18);border-radius:50%;color:#a7a7af;font-size:11px;font-weight:700;font-variant-numeric:tabular-nums}.capture-step-rail span.active{border-color:#6b6bfff2;color:var(--star);box-shadow:0 0 0 3px #6b6bff24}.capture-step-rail span.done,.capture-step-rail span.locked{border-color:var(--accent);background:var(--accent);color:#0f1512}@keyframes target-pulse{0%{opacity:.9;transform:scale(.92)}to{opacity:0;transform:scale(1.24)}}.live-guide{position:absolute;left:50%;top:10px;transform:translate(-50%);max-width:min(calc(100% - 32px),320px);padding:5px 12px;border-radius:var(--r-pill);background:#0a0a0c8c;color:var(--text);font-size:12px;line-height:1.3;text-align:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 4px 12px #00000047}.live-guide.warn{background:#56462099}.live-guide.poor{background:#5626269e}.recording-pill{position:absolute;top:10px;left:10px;display:inline-flex;align-items:center;gap:6px;padding:6px 9px;border-radius:999px;background:#000000ad;color:var(--text);font-size:12px;font-variant-numeric:tabular-nums}.recording-pill span{width:7px;height:7px;border-radius:50%;background:#ff4d4d;box-shadow:0 0 0 4px #ff4d4d2e}.camera-sampler{display:none}.live-metrics{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:6px}.live-metrics span{min-width:0;padding:6px 7px;border:1px solid var(--line);border-radius:6px;background:var(--surface);color:var(--text-dim);font-size:11px;text-align:center;font-variant-numeric:tabular-nums}.camera-progress{height:6px;overflow:hidden;border-radius:999px;background:var(--surface-2)}.camera-progress div{height:100%;min-width:0;border-radius:inherit;background:linear-gradient(90deg,var(--accent),var(--star));transition:width .25s ease}.camera-actions{display:flex;gap:8px;flex-wrap:wrap}.camera-error{border:1px solid var(--line);border-radius:8px;background:var(--surface);color:var(--danger);padding:9px 10px;font-size:12px;line-height:1.45}.slot-meta{display:flex;align-items:center;justify-content:space-between;font-size:12px;color:var(--text-dim)}.slot-meta button{background:transparent;border:1px solid var(--line);color:var(--text-dim);border-radius:6px;padding:4px 10px;cursor:pointer;font-size:12px}.slot-meta button:hover{border-color:var(--danger);color:var(--danger)}.photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;flex:1}.photo-item{position:relative;aspect-ratio:1 / 1;border-radius:8px;overflow:hidden;background:var(--surface)}.photo-item img{width:100%;height:100%;object-fit:cover;display:block}.photo-remove{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:50%;border:none;background:#000000b3;color:var(--text);cursor:pointer;font-size:14px;line-height:1;padding:0}.photo-add{aspect-ratio:1 / 1;border:1.5px dashed var(--line);border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;cursor:pointer;transition:border-color .15s,background .15s}.photo-add:hover{border-color:var(--accent);background:var(--accent-soft)}.photo-add span:first-of-type{font-size:24px;color:var(--text-dim)}.quality-switch{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:14px}.quality-switch.preview-only{grid-template-columns:minmax(0,1fr)}.quality-switch button{border:1px solid var(--line);border-radius:var(--r);background:var(--surface);color:var(--text);padding:var(--sp-4);text-align:left;cursor:pointer;min-width:0;transition:border-color var(--ease),background var(--ease)}.quality-switch button:hover{border-color:var(--accent)}.quality-switch button.active{border-color:var(--accent);background:var(--accent-soft)}.quality-switch strong,.quality-switch span{display:block}.quality-switch strong{font-size:14px;font-weight:600}.quality-switch span{margin-top:4px;color:var(--text-dim);font-size:12px;line-height:1.4}.actions{display:flex;gap:12px;margin-top:16px}.btn-primary{flex:1;padding:16px;border-radius:var(--r-pill);border:none;background:var(--accent-grad);color:var(--on-accent);font-size:16px;font-weight:600;letter-spacing:.02em;cursor:pointer;box-shadow:0 6px 20px var(--accent-soft);transition:transform var(--ease),box-shadow var(--ease),opacity var(--ease)}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 28px #6b6bff4d}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.btn-secondary{padding:14px 22px;border-radius:var(--r-pill);border:1px solid var(--line);background:transparent;color:var(--text);font-size:14px;cursor:pointer;transition:border-color var(--ease)}.btn-secondary:disabled{opacity:.4;cursor:not-allowed}.btn-secondary:hover:not(:disabled){border-color:var(--accent)}.history-panel{margin-top:24px;background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:14px}.history-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px}.history-item{display:grid;grid-template-columns:64px 1fr;gap:10px;align-items:center;min-height:72px;padding:8px;border:1px solid var(--line);border-radius:8px;background:var(--surface);color:var(--text);text-align:left;cursor:pointer}.history-item:hover,.history-item.active{border-color:var(--accent);background:var(--accent-soft)}.history-thumb{width:64px;height:56px;border-radius:6px;overflow:hidden;background:var(--bg);display:flex;align-items:center;justify-content:center}.history-thumb img{width:100%;height:100%;object-fit:cover;display:block}.history-empty{font-size:11px;color:var(--text-dim)}.history-meta{min-width:0;display:flex;flex-direction:column;gap:4px}.history-meta strong{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.history-meta span{font-size:12px;color:var(--text-dim)}.history-more{width:100%;margin-top:12px;padding:10px 12px;border:1px solid var(--line);border-radius:8px;background:var(--surface);color:var(--text-dim);cursor:pointer}.history-more:hover{border-color:var(--accent);color:var(--text)}.showcase-panel{margin:0 0 24px}.showcase-head{display:flex;justify-content:space-between;align-items:flex-end;gap:16px}.showcase-head p{margin:0 0 10px;color:var(--text-dim);font-size:13px}.showcase-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.showcase-card{overflow:hidden;border:1px solid transparent;border-radius:var(--r);background:var(--surface);color:inherit;cursor:pointer;font:inherit;padding:0;text-align:left;transition:border-color var(--ease),background var(--ease),transform var(--ease)}.showcase-card:hover,.showcase-card.active{border-color:var(--accent);background:var(--surface-2)}.showcase-card:hover{transform:translateY(-1px)}.showcase-card img{width:100%;aspect-ratio:3 / 2;object-fit:cover;display:block;background:var(--bg)}.showcase-meta{display:flex;justify-content:space-between;gap:10px;align-items:center;padding:10px}.showcase-meta strong,.showcase-meta span{min-width:0;font-size:12px;white-space:nowrap}.showcase-meta strong{color:var(--text);font-weight:600}.showcase-meta span{overflow:hidden;color:var(--text-dim);text-overflow:ellipsis}.showcase-detail{display:grid;gap:18px;margin:-2px 0 26px;padding:18px;border:1px solid var(--line);border-radius:12px;background:var(--surface)}.showcase-detail-head{display:flex;justify-content:space-between;align-items:flex-end;gap:16px}.showcase-detail-head h2{margin:0;font-size:18px;font-weight:600}.showcase-detail-head>span{color:var(--star);font-size:24px;font-weight:700;font-variant-numeric:tabular-nums;white-space:nowrap}.showcase-hero img{max-height:720px;object-fit:contain;background:var(--bg)}.showcase-sources{display:grid;gap:18px}.drop{border:1.5px dashed var(--line);border-radius:14px;padding:56px 24px;text-align:center;cursor:pointer;transition:border-color .15s,background .15s}.drop:hover,.drop.drag{border-color:var(--accent);background:var(--accent-soft)}.drop input{display:none}.status{margin-top:24px;color:var(--text-dim);font-size:14px}.progress-panel{margin-top:18px;border:1px solid #2c2c34;border-radius:10px;background:var(--surface);padding:14px 16px}.progress-head,.progress-foot{display:flex;align-items:center;justify-content:space-between;gap:16px}.progress-head strong{display:block;margin-top:4px;font-size:14px;font-weight:500;color:#f1f1f3}.progress-head>span{font-variant-numeric:tabular-nums;font-size:22px;font-weight:600;color:var(--text)}.progress-track{height:8px;margin-top:14px;overflow:hidden;border-radius:999px;background:var(--surface-2)}.progress-fill{height:100%;min-width:8px;border-radius:inherit;background:linear-gradient(90deg,#77d7ff,#7b7cff 56%,var(--star));transition:width .35s ease}.progress-foot{margin-top:10px;color:var(--text-dim);font-size:12px}.recording-coach,.capture-review{margin-bottom:var(--sp-6);padding:var(--sp-5);border:1px solid var(--line);border-radius:var(--r-lg);background:var(--surface)}.coach-head,.capture-review-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px}.coach-head h2{margin:0;font-size:18px;font-weight:600}.coach-head>span,.capture-review-head>span{color:var(--star);font-weight:700;white-space:nowrap}.coach-head>span{font-size:20px}.coach-steps,.capture-checks{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:12px}.coach-step,.capture-check{min-width:0;border-radius:var(--r-sm);background:var(--surface-2);padding:var(--sp-3)}.coach-step strong,.capture-check strong{display:block;font-size:13px;font-weight:600}.coach-step p,.capture-check p{margin:7px 0 0;color:var(--text-dim);font-size:12px;line-height:1.55}.capture-review{margin-top:0}.capture-review-head strong{display:block;margin-top:3px;font-size:14px;font-weight:500}.capture-review-head>span{font-size:28px;font-variant-numeric:tabular-nums}.capture-check div{display:flex;align-items:center;justify-content:space-between;gap:8px}.capture-check span{font-size:13px;font-weight:700;font-variant-numeric:tabular-nums}.capture-check.good{border-color:#6b6bff59}.capture-check.warn{border-color:#6b6bff6b}.capture-check.poor{border-color:#ff707073}.capture-check.good span{color:var(--accent)}.capture-check.warn span{color:var(--star)}.capture-check.poor span{color:var(--danger)}.retake-box{margin-top:12px;border:1px solid #4b3720;border-radius:8px;background:#21180d;padding:12px}.retake-box strong{display:block;color:var(--star);font-size:13px}.retake-box ul{margin:8px 0 0;padding-left:18px;color:#d9c7aa;font-size:12px;line-height:1.6}.error{color:var(--danger)}.result{margin-top:32px;display:grid;grid-template-columns:1fr;gap:24px}.hero img{width:100%;border-radius:var(--r-lg);display:block}.hero-meta{margin-top:8px;font-size:13px;color:var(--text-dim)}.direction-board,.candidate-lab{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:var(--sp-5)}.direction-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.direction-card{overflow:hidden;border-radius:var(--r-sm);background:var(--surface-2)}.direction-card img{width:100%;aspect-ratio:4 / 3;object-fit:cover;display:block;filter:saturate(.92) contrast(1.04)}.direction-copy{padding:10px}.direction-copy strong,.candidate-copy strong{display:block;font-size:14px;font-weight:600}.direction-copy p,.candidate-header p{margin:5px 0 0;color:var(--text-dim);font-size:12px;line-height:1.45}.direction-copy dl{display:grid;gap:7px;margin:10px 0 0}.direction-copy dl div{min-width:0}.direction-copy dt{color:var(--star);font-size:11px;margin-bottom:2px}.direction-copy dd{margin:0;color:var(--text-dim);font-size:12px;line-height:1.35}.candidate-header{display:flex;justify-content:space-between;gap:16px;align-items:flex-end}.candidate-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:10px}.candidate-card{border:1px solid transparent;border-radius:var(--r-sm);overflow:hidden;background:var(--surface-2)}.candidate-card.selected{border-color:var(--accent);box-shadow:0 0 0 1px #6b6bff73}.candidate-card img{width:100%;aspect-ratio:3 / 2;object-fit:cover;display:block;background:var(--bg)}.candidate-copy{display:grid;gap:10px;padding:10px}.candidate-copy span{display:block;margin-top:4px;color:var(--text-dim);font-size:12px}.candidate-actions{display:flex;gap:8px;flex-wrap:wrap}.btn-mini{border:1px solid var(--line);border-radius:7px;background:transparent;color:var(--text);padding:7px 10px;font-size:12px;cursor:pointer}.btn-mini:hover:not(:disabled){border-color:var(--star)}.btn-mini.primary{border-color:#6f806b;background:#1a221a}.btn-mini.primary:hover:not(:disabled){border-color:#8fb083}.btn-mini:disabled{opacity:.45;cursor:not-allowed}.thumbs{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px}.thumb{position:relative;border-radius:8px;overflow:hidden;background:var(--surface)}.thumb img{width:100%;display:block;opacity:.55}.thumb.best img{opacity:1}.thumb.best{outline:2px solid var(--accent)}.thumb .tag{position:absolute;top:6px;left:6px;background:#0009;padding:2px 6px;border-radius:4px;font-size:11px;color:var(--text)}.section-title{font-size:14px;color:var(--text-dim);margin:16px 0 8px;text-transform:uppercase;letter-spacing:.04em}.warning{margin-top:12px;padding:10px 14px;background:#2a1e0e;border:1px solid #5a3e1e;border-radius:8px;color:var(--star);font-size:13px}.layers-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.layer{background:repeating-conic-gradient(var(--surface) 0 25%,var(--surface) 0 50%) 0 0 / 20px 20px;border-radius:10px;overflow:hidden;position:relative}.layer img{width:100%;display:block}.layer .label{position:absolute;top:8px;left:8px;background:#000000a6;padding:3px 8px;border-radius:5px;font-size:12px;color:var(--text)}.depth-wrap{display:grid;grid-template-columns:1fr 1fr;gap:12px;align-items:start}.depth-wrap img{width:100%;border-radius:10px;display:block}.composer{background:var(--surface);border-radius:14px;padding:16px}.stack{position:relative;width:100%;aspect-ratio:9 / 16;max-height:75vh;border-radius:10px;overflow:hidden;background:var(--bg)}.stack img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:contain}.slider-row{display:flex;align-items:center;gap:14px;margin-top:18px}.slider-row input[type=range]{flex:1;accent-color:var(--accent)}.slider-label{font-size:12px;color:var(--text-dim);white-space:nowrap}.aperture-readout{margin-top:8px;text-align:center;font-size:13px;color:var(--text-dim);font-feature-settings:"tnum"}.composition-score{background:var(--surface);border-radius:14px;padding:16px 20px}.score-body{display:flex;align-items:flex-start;gap:24px}.score-num{font-size:56px;font-weight:700;line-height:1;color:var(--accent);flex-shrink:0;font-feature-settings:"tnum"}.score-denom{font-size:22px;font-weight:400;color:var(--text-dim)}.score-detail{flex:1}.score-summary{margin:0 0 10px;font-size:15px;line-height:1.5}.score-tips{margin:0;padding-left:18px;color:var(--text-dim);font-size:13px;line-height:1.7}.intent-card{background:var(--surface);border-radius:14px;padding:16px 20px}.intent-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.intent-grid div{display:flex;flex-direction:column;gap:4px;min-width:0}.intent-grid span{color:var(--text-dim);font-size:12px}.intent-grid strong{color:var(--text);font-size:13px;font-weight:500;line-height:1.45}.intent-reason{margin:14px 0 0;color:var(--text-dim);font-size:13px;line-height:1.6}.frame-source{background:var(--surface);border-radius:14px;padding:16px 20px}.source-row{display:flex;gap:16px;align-items:flex-start}.source-item{display:flex;flex-direction:column;align-items:center;gap:6px;flex:1;max-width:200px}.source-item img{width:100%;border-radius:8px;display:block}.source-label{font-size:12px;color:var(--text-dim)}.source-note{font-size:13px;color:var(--text-dim);align-self:center}.badge{position:absolute;bottom:6px;left:6px;background:#6b6bffd9;padding:2px 6px;border-radius:4px;font-size:10px;color:var(--text);font-weight:500}@media (max-width: 760px){.app{padding:32px 16px}.inputs,.quality-switch,.showcase-grid,.coach-steps,.capture-checks,.direction-grid,.candidate-grid,.score-body,.depth-wrap,.layers-grid{grid-template-columns:1fr}.score-body{display:grid;gap:12px}.showcase-detail{padding:14px}.showcase-detail-head{align-items:flex-start;flex-direction:column}.camera-stage,.camera-preview{min-height:300px}.capture-target{width:88px;height:88px}.capture-target.left{left:26%}.capture-target.right{left:74%}.capture-target.bottom{top:70%}.capture-target strong{max-width:76px;font-size:10px}.target-arrow{width:32px;height:32px;font-size:21px}.capture-step-rail{top:48px;right:8px}.live-metrics{grid-template-columns:repeat(3,minmax(0,1fr))}.actions{flex-direction:column}}.feedback-fab{position:fixed;top:12px;right:12px;z-index:50;display:inline-flex;align-items:center;gap:4px;padding:8px 14px;border:none;border-radius:999px;background:var(--accent);color:var(--on-accent);font-size:14px;font-weight:600;cursor:pointer;box-shadow:0 4px 14px #00000059}.feedback-fab:hover{background:var(--accent)}.feedback-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;display:grid;place-items:center;padding:20px;background:#0000008c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.feedback-panel{width:100%;max-width:380px;display:flex;flex-direction:column;gap:12px;padding:18px;border:1px solid var(--line);border-radius:14px;background:#111118;box-shadow:0 12px 40px #00000080}.feedback-head{display:flex;align-items:center;justify-content:space-between}.feedback-head strong{font-size:16px}.feedback-close{border:none;background:transparent;color:var(--text-dim);font-size:22px;line-height:1;cursor:pointer}.feedback-stars{display:flex;align-items:center;gap:4px}.feedback-star{padding:0;border:none;background:transparent;color:var(--line);font-size:24px;line-height:1;cursor:pointer}.feedback-star.on{color:#ffce4d}.feedback-hint{margin-left:8px;font-size:12px;color:var(--text-dim)}.feedback-text,.feedback-contact,.feedback-name{width:100%;box-sizing:border-box;padding:10px 12px;border:1px solid var(--line);border-radius:8px;background:var(--bg);color:#e8e8ee;font-size:14px;font-family:inherit}.feedback-text{min-height:90px;resize:vertical}.feedback-text:focus,.feedback-contact:focus,.feedback-name:focus{outline:none;border-color:var(--accent)}.feedback-err{font-size:13px;color:var(--danger)}.feedback-submit{padding:10px;border:none;border-radius:8px;background:var(--accent);color:var(--on-accent);font-size:15px;font-weight:600;cursor:pointer}.feedback-submit:disabled{opacity:.6;cursor:default}.feedback-done{padding:24px 8px;text-align:center;font-size:16px;color:var(--accent)}
