:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color:#1f2328;background-color:#f6f8fa;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px}#root{padding:1rem}.app{width:min(920px,100%);margin:0 auto;display:grid;gap:.9rem}.camera-panel{border:1px solid #d0d7de;border-radius:14px;padding:.95rem;background:#fff;box-shadow:0 8px 22px #0f172a0d}.camera-frame{position:relative;overflow:hidden;border-radius:12px}.camera{width:100%;max-height:430px;object-fit:cover;border-radius:12px;background:#111}.serial-guide{position:absolute;left:12%;top:42%;width:76%;height:18%;border:2px dashed #1f6feb;border-radius:10px;box-shadow:0 0 0 9999px #0000003d;pointer-events:none;display:flex;align-items:flex-start;justify-content:center}.serial-guide span{margin-top:-1.8rem;background:#000000ad;color:#fff;padding:.2rem .52rem;border-radius:6px;font-size:.78rem;font-weight:700}.retro-hud{position:absolute;left:10px;right:10px;bottom:10px;display:flex;flex-wrap:wrap;gap:.35rem;padding:.45rem;border-radius:10px;background:#0307128f;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);pointer-events:none;transition:opacity .26s ease}.retro-hud.is-dimmed{opacity:.5}.hud-chip{border-radius:999px;padding:.18rem .5rem;font-size:.72rem;font-weight:700;letter-spacing:.02em;border:1px solid rgba(148,163,184,.35)}.hud-chip.ok{color:#86efac;background:#14532d6b}.hud-chip.warn{color:#fcd34d;background:#78350f6b}.hud-chip.bad{color:#fca5a5;background:#7f1d1d6b}.hud-chip.neutral{color:#bfdbfe;background:#1e40af57}.hidden-canvas,.file-input{display:none}.actions{margin-top:.8rem;display:grid;gap:.58rem}.precision-controls{width:100%;display:flex;align-items:center;justify-content:space-between;gap:.65rem}.precision-controls span{font-size:.9rem;font-weight:700;color:#334155}.mode-segmented{display:inline-flex;align-items:center;gap:.35rem;background:#eef2ff;border:1px solid #c7d2fe;border-radius:999px;padding:.25rem}button.mode-option{border:none;border-radius:999px;padding:.42rem .7rem;background:transparent;color:#334155;font-size:.84rem;font-weight:700;display:inline-flex;align-items:center;gap:.38rem;width:auto}button.mode-option.is-active{background:#2563eb;color:#fff;box-shadow:0 6px 12px #2563eb47}button.mode-option:not(:disabled):hover{filter:brightness(1.03)}.mode-icon{font-size:.8rem}.mode-help{width:100%;margin:0;font-size:.86rem;font-weight:600;color:#64748b}.control-deck{width:100%;min-height:76px;display:flex;align-items:center;justify-content:center;gap:.6rem}button{border:none;border-radius:10px;padding:.7rem 1rem;background:#1f6feb;color:#fff;font-weight:600;transition:transform .12s ease,opacity .12s ease,filter .16s ease}button:not(:disabled):active{transform:translateY(1px)}button:disabled{opacity:.7;cursor:not-allowed}button.secondary{background:#6e7781}button.text-button{padding:0;border:none;border-radius:0;background:none;color:#1f6feb;text-decoration:underline;font-weight:600;width:auto}button.main-control{width:66px;height:66px;border-radius:999px;border:1px solid #1e3a8a;background:radial-gradient(circle at 30% 22%,#93c5fd,#3b82f6 45%,#1d4ed8);color:#fff;font-size:1.6rem;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 12px 28px #1d4ed861,inset 0 1px #ffffff59}button.main-control.is-active{background:radial-gradient(circle at 32% 22%,#60a5fa,#2563eb 40%,#1e40af);box-shadow:0 0 0 4px #3b82f629,0 14px 30px #1e40af70,inset 0 1px #fff6}button.side-control{width:44px;height:44px;border-radius:999px;font-size:1.1rem;display:inline-flex;align-items:center;justify-content:center}button.camera-control{border:1px solid #b91c1c;background:radial-gradient(circle at 32% 22%,#fda4af,#ef4444,#b91c1c);color:#fff;box-shadow:0 8px 18px #b91c1c59,inset 0 1px #ffffff52}button.camera-control.is-off{border-color:#0f766e;background:radial-gradient(circle at 32% 22%,#5eead4,#14b8a6,#0f766e);box-shadow:0 8px 18px #0f766e54,inset 0 1px #ffffff4d}button.gallery-control{border:1px solid #334155;background:radial-gradient(circle at 32% 22%,#e2e8f0,#94a3b8 55%,#475569);color:#fff;box-shadow:0 8px 18px #33415559,inset 0 1px #ffffff47}button.main-control:hover:not(:disabled),button.side-control:hover:not(:disabled){transform:translateY(-1px) scale(1.02);filter:saturate(1.06)}button.main-control:focus-visible,button.side-control:focus-visible,button.mode-option:focus-visible,button.text-button:focus-visible{outline:3px solid rgba(59,130,246,.34);outline-offset:2px}.control-icon{font-size:1.45rem}button.camera-control .control-icon{font-size:1.1rem}.error{margin-top:.75rem;color:#b42318;font-weight:700}.analysis-progress{margin-top:.75rem;padding:.6rem .75rem;border-radius:8px;border:1px solid #d8dee4;background:#f8fafc}.analysis-progress p{margin:0 0 .45rem;font-size:.9rem;color:#334155;font-weight:700}.progress-track{height:8px;border-radius:999px;background:#e2e8f0;overflow:hidden}.progress-fill{height:100%;background:#1f6feb;transition:width .2s ease}.process-message{margin:.75rem 0 0;padding:.55rem .7rem;border:1px solid #d8dee4;border-radius:8px;background:#f6f8fa;color:#334155;font-weight:600}.process-message.legal{border-color:#86efac;background:#dcfce7;color:#166534}.process-message.illegal{border-color:#fca5a5;background:#fee2e2;color:#991b1b}.process-message.warning{border-color:#fcd34d;background:#fef3c7;color:#92400e}.analysis-details{margin-top:.65rem;border:1px solid #d8dee4;border-radius:10px;background:#f8fafc;padding:.4rem .6rem}.analysis-details summary{cursor:pointer;font-weight:700;color:#334155;list-style:none}.analysis-details summary::-webkit-details-marker{display:none}.analysis-details summary:before{content:"▸";margin-right:.45rem}.analysis-details[open] summary:before{content:"▾"}.analysis-details-grid{margin-top:.55rem;display:flex;flex-wrap:wrap;gap:.38rem}.manual-entry{margin-top:.75rem;border:1px solid #d8dee4;border-radius:10px;background:#f8fafc;padding:.75rem;display:grid;gap:.6rem}.manual-entry h3,.manual-entry p{margin:0}.manual-entry-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.6rem}.manual-field{display:grid;gap:.35rem;font-size:.92rem;font-weight:600;color:#334155}.manual-field input,.manual-field select{padding:.45rem .55rem;border-radius:8px;border:1px solid #c9d1d9;font:inherit;background:#fff}.confirm-box{margin-top:.75rem;border:1px solid #d8dee4;border-radius:10px;background:#f8fafc;padding:.75rem;display:grid;gap:.55rem}.confirm-box h3,.confirm-box p{margin:0}.confirm-actions{display:flex;flex-wrap:wrap;gap:.5rem}.correction-label{display:grid;gap:.35rem;font-size:.92rem}.correction-label select{padding:.45rem .55rem;border-radius:8px;border:1px solid #c9d1d9;font:inherit}.compact-actions{display:flex;justify-content:flex-end}.app-footer{border-top:1px solid #d8dee4;padding-top:.75rem;display:grid;gap:.25rem}.app-footer p{margin:0;font-size:.86rem;color:#57606a}.footer-links{margin-top:.15rem;display:flex;align-items:center;gap:.7rem;flex-wrap:wrap}.footer-links a{color:#1f6feb;font-weight:600;text-decoration:underline}.modal-overlay{position:fixed;inset:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;padding:1rem;z-index:30}.modal{width:min(640px,100%);max-height:85vh;overflow:auto;background:#fff;border-radius:12px;border:1px solid #d0d7de;padding:1rem;display:grid;gap:.7rem}.modal h2,.modal p{margin:0}.modal-actions{display:flex;justify-content:flex-end}.welcome-check{display:flex;align-items:center;gap:.5rem}@media(max-width:680px){.camera-panel{padding:.75rem}.precision-controls{align-items:flex-start;flex-direction:column}.mode-segmented{width:100%;display:grid;grid-template-columns:1fr 1fr;gap:.35rem}button.mode-option{justify-content:center}button.main-control{width:58px;height:58px}button.side-control{width:42px;height:42px}.footer-links{align-items:flex-start;flex-direction:column;gap:.3rem}.manual-entry-grid{grid-template-columns:1fr}}
