:root{--bg-deep: #06111f;--bg-canvas: #f4f7fb;--surface: #ffffff;--surface-soft: #f8fbff;--surface-muted: #edf3f8;--border: #dde7f2;--border-strong: #cbd5e1;--text: #111827;--text-muted: #4b5f73;--text-soft: #708195;--primary: #0f766e;--primary-strong: #115e59;--primary-soft: #d7f4ee;--accent: #c9892b;--success: #159947;--warning: #b7791f;--danger: #c24135;--shadow-card: 0 18px 45px rgba(15, 23, 42, .1);--shadow-soft: 0 8px 22px rgba(15, 23, 42, .07);--radius-card: 22px;--radius-control: 14px;--radius-pill: 999px;font-family:Aptos,Segoe UI Variable,Segoe UI,sans-serif;color:var(--text)}*{box-sizing:border-box}body{margin:0;background:var(--bg-deep);color:var(--text);-webkit-font-smoothing:antialiased;text-rendering:geometricPrecision}code{padding:1px 6px;border-radius:6px;background:#0f172a14;font-family:ui-monospace,JetBrains Mono,SF Mono,Consolas,monospace;font-size:12px}.app-shell{min-height:100vh;padding:26px 18px 42px;background:radial-gradient(circle at 16% 6%,rgba(20,184,166,.24),transparent 30%),radial-gradient(circle at 82% 18%,rgba(201,137,43,.2),transparent 26%),linear-gradient(135deg,rgba(255,255,255,.035) 25%,transparent 25%) 0 0 / 22px 22px,linear-gradient(160deg,#06111f,#111c2c 48%,#071523)}.phone-frame{width:min(100%,480px);min-height:calc(100vh - 64px);margin:0 auto;padding:16px;border:1px solid rgba(255,255,255,.16);border-radius:34px;background:linear-gradient(180deg,#fffffff5,#f4f7fbfa),var(--bg-canvas);box-shadow:0 34px 90px #02061794}.app-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px;border-radius:24px;background:radial-gradient(circle at 100% 0%,rgba(20,184,166,.28),transparent 34%),linear-gradient(135deg,#07111f,#132238 58%,#1a2f3c);color:#fff;box-shadow:0 16px 36px #0f172a3d}.app-header strong{display:block;font-size:19px;letter-spacing:.2px}.app-header span{display:block;margin-top:2px;color:#b8c4d2;font-size:12px}.header-credit{display:inline-flex;margin-top:7px;padding:4px 9px;border:1px solid rgba(255,255,255,.22);border-radius:var(--radius-pill);background:#ffffff1a;color:#e8f7f3;font-size:11px;font-weight:800;line-height:1;text-decoration:none;letter-spacing:.01em}.header-credit:hover{background:#ffffff24;color:#fff}.header-actions{display:flex;gap:8px}.app-message{margin:14px 0 0;padding:12px 14px;border:1px solid #f0d28d;border-radius:16px;background:linear-gradient(135deg,#fff8df,#fff3c4);color:#6b4612;font-size:14px;box-shadow:var(--shadow-soft)}.error-text{color:var(--danger)}.card,.scanner-card{margin-top:15px;padding:17px;border:1px solid var(--border);border-radius:var(--radius-card);background:linear-gradient(180deg,#fffffff5,#ffffffe0),var(--surface);box-shadow:var(--shadow-card)}.scanner-card{overflow:hidden;border-color:#0f766e47;background:radial-gradient(circle at 0% 0%,rgba(20,184,166,.12),transparent 38%),linear-gradient(180deg,#fff,#f8fbff)}.scanner-title h1{margin:0;font-size:28px;font-weight:850;line-height:1.05;letter-spacing:-.02em}.scanner-title span{display:block;margin-top:5px;color:var(--text-soft);font-size:14px}h2{margin:0 0 10px;font-size:17px;font-weight:850;letter-spacing:-.01em}input,button,select{width:100%;min-height:46px;margin-top:8px;padding:11px 13px;border:1px solid var(--border);border-radius:var(--radius-control);background:var(--surface);color:var(--text);font:inherit;transition:border-color .15s ease,box-shadow .15s ease,transform .08s ease,background .15s ease}input:focus,select:focus,button:focus-visible,a:focus-visible{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px #0f766e2e}button{background:linear-gradient(135deg,var(--primary),var(--primary-strong));color:#fff;border:none;font-weight:850;letter-spacing:.01em;cursor:pointer;box-shadow:0 10px 20px #0f766e38}button:hover:not(:disabled){filter:brightness(1.04);transform:translateY(-1px)}button:active:not(:disabled){transform:translateY(1px)}button:disabled{cursor:not-allowed;opacity:.55;box-shadow:none}.ghost-button{background:#ffffffb8;color:var(--text);border:1px solid var(--border);box-shadow:none}.ghost-button:hover:not(:disabled){background:#e2e8f0}.danger-button{background:linear-gradient(135deg,#d84a3d,#b92f28);box-shadow:0 10px 20px #c2413538}.full-width{width:100%}.camera-preview{width:100%;min-height:290px;max-height:60vh;margin-top:10px;border-radius:18px;background:radial-gradient(circle at center,#162033,#020617 70%);object-fit:cover;transform:scaleX(-1)}.scanner-preview{aspect-ratio:3 / 4}.scan-stage{position:relative;margin-top:12px;border:4px solid #0b1726;border-radius:26px;overflow:hidden;background:#020617;box-shadow:inset 0 0 0 1px #ffffff14,0 20px 50px #02061738;transition:border-color .18s ease,box-shadow .18s ease}.scan-stage:before{content:"";position:absolute;top:14px;right:14px;bottom:14px;left:14px;z-index:1;pointer-events:none;border:1px solid rgba(255,255,255,.28);border-radius:18px;box-shadow:0 0 0 999px #02061714}.scan-stage:after{content:"";position:absolute;left:18px;right:18px;top:18%;z-index:1;height:2px;pointer-events:none;background:linear-gradient(90deg,transparent,rgba(45,212,191,.9),transparent);box-shadow:0 0 22px #2dd4bfbf;animation:scanLine 2.3s ease-in-out infinite}@keyframes scanLine{0%,to{transform:translateY(0);opacity:.35}50%{transform:translateY(190px);opacity:.95}}.scan-stage .camera-preview{display:block;margin-top:0;border-radius:0}.scan-stage.scan-success{border-color:var(--success);box-shadow:0 0 0 4px #16a34a2e,0 0 36px #16a34a80}.scan-stage.scan-already{border-color:var(--warning);box-shadow:0 0 0 4px #f59e0b2e,0 0 36px #f59e0b6b}.scan-stage.scan-error{border-color:var(--danger);box-shadow:0 0 0 4px #ef44442e,0 0 36px #ef444473}.recognition-overlay{position:absolute;left:14px;right:14px;bottom:16px;z-index:2;pointer-events:none;padding:13px;border-radius:16px;text-align:center;font-size:18px;font-weight:800;letter-spacing:.3px;color:#fff;animation:feedbackPop .2s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.recognition-overlay strong,.recognition-overlay span{display:block}.recognition-overlay span{margin-top:4px;font-size:12px;font-weight:700;opacity:.9;text-transform:capitalize}.recognition-overlay.success{background:#16a34aeb}.recognition-overlay.already{background:#d97706f0}.recognition-overlay.error{background:#dc2626eb}@keyframes feedbackPop{0%{transform:translateY(8px) scale(.98);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.pose-panel,.scanner-status{display:grid;gap:4px;margin-top:10px;padding:12px;border-radius:14px;background:#ecfeff;color:#0f3a44;border:1px solid #cffafe}.pose-panel{grid-template-columns:1fr auto;align-items:center}.pose-panel span,.scanner-status span{color:#0e7490;font-size:13px}.sample-dots{display:flex;gap:8px;margin-top:10px}.dot{width:16px;height:16px;border-radius:var(--radius-pill);background:var(--border-strong);transition:background .18s ease,transform .18s ease}.dot.done{background:var(--success);transform:scale(1.06)}.split-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}.summary-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:14px}.summary-grid div{padding:14px;border:1px solid var(--border);border-radius:16px;background:var(--surface);box-shadow:var(--shadow-soft)}.summary-grid strong{display:block;font-size:22px;font-weight:700;color:var(--text)}.summary-grid span{color:var(--text-soft);font-size:12px;text-transform:uppercase;letter-spacing:.05em}.section-heading{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:6px}.section-heading h2{margin:0}.status-pill{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-pill);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.status-pill.small{padding:2px 8px;font-size:10px}.status-pill.ok{background:#dcfce7;color:#166534}.status-pill.off{background:var(--surface-muted);color:var(--text-soft)}.table-wrap{margin-top:6px;overflow-x:auto;border:1px solid var(--border);border-radius:14px}table{width:100%;min-width:760px;border-collapse:collapse;font-size:13px;background:var(--surface)}th{background:var(--surface-soft);font-weight:700;color:var(--text-muted);font-size:11px;text-transform:uppercase;letter-spacing:.05em}th,td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--border);white-space:nowrap}tr:last-child td{border-bottom:none}tr:hover td{background:var(--surface-soft)}.scan-toast{margin-top:10px;padding:14px;border-radius:16px;text-align:center;font-size:18px;font-weight:800}.scan-toast.success{background:#dcfce7;border:2px solid var(--success);color:#166534}.scan-toast.already{background:#fef3c7;border:2px solid var(--warning);color:#78350f}.scan-toast.error{background:#fee2e2;border:2px solid var(--danger);color:#7f1d1d}.login-card{margin-top:18px}.auth-tabs{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px;padding:4px;border-radius:14px;background:var(--surface-muted)}.auth-tabs button{margin:0;min-height:38px;padding:8px;font-size:13px;border:none;border-radius:10px;background:transparent;color:var(--text-muted);box-shadow:none;font-weight:700}.auth-tabs button:not(.ghost-button){background:var(--surface);color:var(--primary);box-shadow:var(--shadow-soft)}.override-form{margin-top:12px;padding:12px;border:1px dashed rgba(15,118,110,.35);border-radius:16px;background:#d7f4ee73}.field-label{display:block;margin-top:12px;color:var(--text-muted);font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.06em}.hint-text{margin:10px 0 0;color:var(--text-soft);font-size:13px;line-height:1.45}.scanner-note{margin:8px 0 12px;padding:9px 11px;border:1px solid #bfdbfe;border-radius:12px;background:#eff6ff;color:#1d4ed8;font-size:12px;font-weight:800;line-height:1.35}.scanner-note.inline{display:inline-flex;margin:9px 0 0;padding:6px 9px}.dms-empty-hint{display:grid;gap:4px;margin-top:12px;padding:12px 14px;border-radius:14px;background:#fff7ed;color:#7c2d12;border:1px dashed #fdba74}.dms-empty-hint strong{font-size:13px;letter-spacing:-.01em}.dms-empty-hint span{color:#7c2d12;font-size:12px;line-height:1.45}.dms-empty-hint em{font-style:normal;font-weight:700;color:#92400e}.price-card,.amount-box,.org-banner{display:grid;gap:4px;margin:12px 0;padding:14px;border-radius:14px}.price-card{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}.price-card strong,.amount-box strong,.org-banner strong{font-size:20px;letter-spacing:-.01em}.org-banner.compact strong{font-size:14px;word-break:break-all}.price-card span,.amount-box span,.amount-box small,.org-banner span,.org-banner small{color:var(--text-soft);font-size:12px}.amount-box{background:var(--primary-soft);color:#1e3a8a;border:1px solid #bfdbfe}.org-banner{background:linear-gradient(135deg,#0f172a,#1e293b);color:#fff}.org-banner span,.org-banner small{color:#94a3b8}.org-banner.compact{margin:10px 0;padding:12px 14px}.decision-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:grid;place-items:center;padding:18px;background:#020617a8;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.decision-modal{width:min(100%,420px);padding:20px;border-radius:22px;background:var(--surface);box-shadow:0 30px 80px #02061766}.decision-modal.duplicate{border:2px solid var(--warning)}.decision-modal.new{border:2px solid var(--success)}.decision-kicker{display:inline-flex;margin-bottom:8px;padding:5px 11px;border-radius:var(--radius-pill);background:var(--surface-muted);color:var(--text-muted);font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.05em}.decision-modal h2{margin-bottom:8px;font-size:22px;line-height:1.15;font-weight:700}.decision-modal p{color:var(--text-muted);line-height:1.5}.match-card{display:grid;gap:5px;margin-top:12px;padding:14px;border-radius:14px;background:#fff7ed;color:#7c2d12;border:1px solid #fed7aa}.match-card.soft{background:#ecfdf5;color:#065f46;border-color:#a7f3d0}.match-card strong{font-size:17px;letter-spacing:-.01em}.match-card span{font-size:13px}.decision-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:16px}.brand-footer{display:grid;place-items:center;gap:4px;margin:16px 0 2px;padding:14px 12px 4px;color:var(--text-soft);font-size:11px;text-align:center}.brand-footer a{color:var(--primary-strong);font-size:13px;font-weight:900;text-decoration:none;letter-spacing:.01em}.brand-footer a:hover{text-decoration:underline}@media (min-width: 900px){.phone-frame{width:min(100%,540px)}}@media (min-width: 1280px){.app-shell{padding:32px 24px 48px}}
