:root{--paper: oklch(96.5% .012 83);--paper-sunk: oklch(93.5% .014 82);--card: oklch(99% .006 86);--ink: oklch(25% .02 55);--ink-soft: oklch(46% .018 58);--ink-faint: oklch(60% .015 62);--line: oklch(87% .014 80);--line-strong: oklch(78% .018 78);--brand: oklch(48% .094 158);--brand-ink: oklch(36% .082 158);--brand-tint: oklch(93.5% .045 158);--on-brand: oklch(98% .01 95);--accent: oklch(60% .135 47);--accent-tint: oklch(92% .05 52);--ok: oklch(50% .115 158);--ok-tint: oklch(93% .05 158);--warn: oklch(58% .12 66);--warn-tint: oklch(93% .07 75);--danger: oklch(54% .19 25);--shadow-sm: 0 1px 2px oklch(35% .04 60 / .06), 0 1px 1px oklch(35% .04 60 / .05);--shadow-md: 0 6px 18px oklch(35% .04 60 / .08), 0 2px 5px oklch(35% .04 60 / .06);--shadow-lg: 0 18px 48px oklch(35% .05 60 / .14);--radius: 16px;--radius-sm: 11px;--pill: 999px;--space: 1rem;--font-display: "Fraunces", Georgia, "Times New Roman", serif;--font-sans: "IBM Plex Sans", system-ui, -apple-system, sans-serif;--font-mono: "IBM Plex Mono", ui-monospace, "SFMono-Regular", monospace;font-family:var(--font-sans);color-scheme:light}*{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{margin:0;background:var(--paper);color:var(--ink);font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;min-height:100dvh}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:-2;background:radial-gradient(120% 80% at 50% -10%,oklch(99% .02 90) 0%,transparent 60%),radial-gradient(90% 60% at 100% 0%,var(--accent-tint) 0%,transparent 45%),var(--paper)}body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;pointer-events:none;opacity:.035;mix-blend-mode:multiply;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.82' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}body>#root:before{content:"";position:fixed;top:0;left:0;right:0;height:3px;z-index:10;background:linear-gradient(90deg,var(--accent) 0%,var(--brand) 60%,var(--brand-ink) 100%)}.app-shell{max-width:560px;margin:0 auto;padding:calc(var(--space) * 1.25) var(--space) calc(var(--space) * 3);min-height:100dvh;animation:shell-in .5s cubic-bezier(.16,1,.3,1) both}.app-shell.auth{display:flex;flex-direction:column;justify-content:center;max-width:420px}@keyframes shell-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}h1,h2,h3{font-family:var(--font-display);font-optical-sizing:auto;font-weight:600;color:var(--ink);line-height:1.1;letter-spacing:-.01em;margin:0 0 .5rem}h1{font-size:clamp(1.6rem,1.2rem + 1.8vw,2.1rem)}h2{font-size:1.35rem;font-weight:550}h3{font-size:1.1rem;font-weight:550}header.row-between{margin-bottom:calc(var(--space) * 1.25);padding-bottom:.9rem;border-bottom:1px solid var(--line)}header.row-between h1{margin:0}.row-between{display:flex;align-items:center;justify-content:space-between;gap:var(--space)}.stack{display:flex;flex-direction:column;gap:.55rem}.stack label,label{color:var(--ink-soft);font-size:.82rem;font-weight:500;letter-spacing:.01em;margin-top:.4rem}input,select,textarea{width:100%;padding:.8rem .9rem;border-radius:var(--radius-sm);border:1px solid var(--line-strong);background:var(--card);color:var(--ink);font:inherit;font-size:1rem;transition:border-color .15s,box-shadow .15s}input::placeholder,textarea::placeholder{color:var(--ink-faint)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-tint)}textarea{resize:vertical;min-height:4.5rem}input[type=checkbox]{width:auto;margin-right:.4rem;accent-color:var(--brand)}button{margin-top:0;padding:.85rem 1.2rem;border:1px solid transparent;border-radius:var(--radius-sm);background:var(--brand);color:var(--on-brand);font:inherit;font-weight:600;font-size:1rem;letter-spacing:.005em;cursor:pointer;transition:transform .12s,box-shadow .15s,background .15s,border-color .15s;box-shadow:var(--shadow-sm)}button:hover:not(:disabled){background:var(--brand-ink);transform:translateY(-1px);box-shadow:var(--shadow-md)}button:active:not(:disabled){transform:translateY(0);box-shadow:var(--shadow-sm)}button:disabled{opacity:.5;cursor:default;box-shadow:none}button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.stack>button{margin-top:.6rem}.ghost{background:transparent;color:var(--ink-soft);border:1px solid var(--line-strong);box-shadow:none;font-weight:550}.ghost:hover:not(:disabled){background:var(--paper-sunk);color:var(--ink);border-color:var(--ink-faint);transform:none;box-shadow:none}.tabs{display:inline-flex;gap:.25rem;margin:var(--space) 0;padding:4px;background:var(--paper-sunk);border:1px solid var(--line);border-radius:var(--pill);flex-wrap:wrap}.tabs button{margin:0;padding:.5rem 1rem;font-size:.9rem;font-weight:550;border-radius:var(--pill);background:var(--card);color:var(--ink);box-shadow:var(--shadow-sm)}.tabs button:hover:not(:disabled){transform:none}.tabs button.ghost{background:transparent;color:var(--ink-soft);border-color:transparent;box-shadow:none}.tabs button.ghost:hover:not(:disabled){background:#fefcf799;color:var(--ink)}.muted{color:var(--ink-soft)}.error{color:var(--danger);background:#ffe7e4;background:oklch(95% .04 25);border:1px solid oklch(85% .07 25);padding:.6rem .8rem;border-radius:var(--radius-sm);font-size:.92rem}p{margin:.5rem 0}code{font-family:var(--font-mono);font-size:.85em;word-break:break-all;background:var(--paper-sunk);border:1px solid var(--line);border-radius:6px;padding:.12rem .4rem;color:var(--brand-ink)}.camera{display:flex;flex-direction:column;gap:var(--space);margin-top:var(--space)}.camera-feed{width:100%;aspect-ratio:3 / 4;object-fit:cover;background:#1a1512;border-radius:var(--radius);border:1px solid var(--line-strong);box-shadow:var(--shadow-md),inset 0 0 0 1px #ffffff0a}.result{background:var(--card);border:1px solid var(--line);padding:calc(var(--space) * 1.1);border-radius:var(--radius);box-shadow:var(--shadow-sm);margin-top:var(--space)}.result h2{margin-top:0}.badges{list-style:none;padding:0;margin:.75rem 0 0;display:flex;flex-direction:column;gap:.5rem}.badge{display:inline-flex;align-items:center;gap:.35rem;width:fit-content;padding:.42rem .75rem;border-radius:var(--pill);font-family:var(--font-mono);font-size:.72rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;border:1px solid transparent;box-shadow:inset 0 1px #fff9}.badge.ok{background:var(--ok-tint);color:var(--brand-ink);border-color:#72b68f}.badge.warn{background:var(--warn-tint);color:#6f4100;color:oklch(42% .1 66);border-color:#e1ac6e}.app-shell.client{font-size:1.06rem}.app-shell.client h1{font-size:clamp(1.7rem,1.3rem + 2vw,2.3rem)}.milestone-card{position:relative;overflow:hidden;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:calc(var(--space) * 1.15) calc(var(--space) * 1.15) calc(var(--space) * 1.15) calc(var(--space) * 1.4);margin:var(--space) 0;box-shadow:var(--shadow-sm);transition:box-shadow .2s,transform .2s}.milestone-card:hover{box-shadow:var(--shadow-md)}.milestone-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:var(--line-strong)}.milestone-card[data-status=submitted]:before{background:var(--accent)}.milestone-card[data-status=certified]:before{background:var(--brand)}.milestone-card[data-status=released]:before{background:linear-gradient(var(--brand),var(--ok))}.milestone-card h2{margin:0 0 .3rem}.status-line{margin:0;font-family:var(--font-mono);font-size:.78rem;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-soft)}.status-line.ok{color:var(--brand-ink)}.badge-row{display:flex;flex-wrap:wrap;gap:.5rem;margin:.85rem 0}.vantage-strip{margin-top:calc(var(--space) * 1.1)}.vantage-label{margin:0 0 .45rem;font-family:var(--font-mono);font-size:.74rem;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-faint)}.vantage-photos{display:flex;gap:.6rem;overflow-x:auto;padding-bottom:.5rem;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}.vantage-photo{margin:0;flex:0 0 auto;width:46%;max-width:220px;scroll-snap-align:start}.vantage-media{width:100%;aspect-ratio:3 / 4;object-fit:cover;border-radius:12px;background:#1a1512;border:1px solid var(--line);box-shadow:var(--shadow-sm)}.vantage-missing{display:flex;align-items:center;justify-content:center;color:var(--ink-faint);font-size:.85rem;text-align:center;padding:.5rem;background:var(--paper-sunk);border-style:dashed}.vantage-photo figcaption{font-family:var(--font-mono);color:var(--ink-faint);font-size:.72rem;text-align:center;margin-top:.3rem;letter-spacing:.02em}.share-btn{width:100%;margin-top:var(--space)}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation:none!important;transition:none!important}}
