:root{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--text-primary: #f8fafc;--text-secondary: #94a3b8;--text-muted: #64748b;--accent-primary: #3b82f6;--accent-secondary: #8b5cf6;--accent-success: #10b981;--accent-warning: #f59e0b;--accent-error: #ef4444;--border-color: #334155;--shadow: 0 4px 6px -1px rgba(0, 0, 0, .3);--radius: 8px;--radius-lg: 12px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh}#app{max-width:900px;margin:0 auto;padding:2rem}h1{font-size:2.5rem;font-weight:700;margin-bottom:.5rem;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}h2{font-size:1.5rem;font-weight:600;margin-bottom:1rem;color:var(--text-primary)}h3{font-size:1.125rem;font-weight:600;margin-bottom:.75rem;color:var(--text-secondary)}p{color:var(--text-secondary);margin-bottom:1rem}.header{text-align:center;margin-bottom:3rem}.header .subtitle{font-size:1.125rem;color:var(--text-muted)}.card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1.5rem;box-shadow:var(--shadow)}.card.highlight{border-color:var(--accent-primary);background:linear-gradient(135deg,#3b82f61a,#8b5cf61a)}.nav{display:flex;gap:.5rem;margin-bottom:2rem;flex-wrap:wrap}.nav-item{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius);color:var(--text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.nav-item:hover{background:var(--bg-tertiary);border-color:var(--accent-primary)}.nav-item.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.nav-item.completed{background:var(--accent-success);border-color:var(--accent-success);color:#fff}.nav-item .step-num{display:inline-flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;border-radius:50%;background:#fff3;font-size:.75rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:var(--radius);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary{background:var(--accent-primary);color:#fff}.btn-primary:hover{background:#2563eb}.btn-primary:disabled{background:var(--bg-tertiary);color:var(--text-muted);cursor:not-allowed}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary)}.btn-secondary:hover{background:var(--border-color)}.btn-success{background:var(--accent-success);color:#fff}.input-group{margin-bottom:1rem}.input-group label{display:block;margin-bottom:.5rem;color:var(--text-secondary);font-size:.875rem;font-weight:500}.input{width:100%;padding:.75rem 1rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius);color:var(--text-primary);font-size:1rem}.input:focus{outline:none;border-color:var(--accent-primary)}.code{font-family:SF Mono,Fira Code,monospace;background:var(--bg-primary);padding:1rem;border-radius:var(--radius);overflow-x:auto;font-size:.875rem;color:var(--text-secondary);border:1px solid var(--border-color)}.code-inline{font-family:SF Mono,Fira Code,monospace;background:var(--bg-tertiary);padding:.125rem .375rem;border-radius:4px;font-size:.875em}.progress-container{background:var(--bg-primary);border-radius:var(--radius);height:.5rem;overflow:hidden;margin:1rem 0}.progress-bar{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary));border-radius:var(--radius);transition:width .3s ease}.feature-viz{display:flex;gap:2px;align-items:flex-end;height:60px;padding:.5rem;background:var(--bg-primary);border-radius:var(--radius);margin:1rem 0}.feature-bar{flex:1;min-width:4px;background:linear-gradient(180deg,var(--accent-primary),var(--accent-secondary));border-radius:2px;transition:height .3s ease}.timing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin:1rem 0}.timing-item{background:var(--bg-primary);padding:1rem;border-radius:var(--radius);text-align:center}.timing-value{font-size:1.5rem;font-weight:700;color:var(--accent-primary)}.timing-label{font-size:.75rem;color:var(--text-muted);margin-top:.25rem}.proof-list{list-style:none}.proof-list li{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem 0;border-bottom:1px solid var(--border-color)}.proof-list li:last-child{border-bottom:none}.proof-list .icon{font-size:1.25rem;flex-shrink:0}.proven .icon{color:var(--accent-success)}.private .icon{color:var(--accent-secondary)}.tooltip{position:relative;cursor:help;border-bottom:1px dashed var(--text-muted)}.tooltip:after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translate(-50%);padding:.5rem .75rem;background:var(--bg-tertiary);border-radius:var(--radius);font-size:.75rem;white-space:nowrap;opacity:0;visibility:hidden;transition:all .2s;z-index:100}.tooltip:hover:after{opacity:1;visibility:visible}.badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .75rem;border-radius:999px;font-size:.75rem;font-weight:600}.badge-success{background:#10b98133;color:var(--accent-success)}.badge-warning{background:#f59e0b33;color:var(--accent-warning)}.badge-error{background:#ef444433;color:var(--accent-error)}.spinner{display:inline-block;width:1.25rem;height:1.25rem;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.verification-result{text-align:center;padding:2rem}.verification-result .icon{font-size:4rem;margin-bottom:1rem}.verification-result.success .icon{color:var(--accent-success)}.verification-result.failure .icon{color:var(--accent-error)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .3s ease-out}.webcam-container{margin:1rem 0}.webcam-preview-wrapper{position:relative;width:100%;max-width:640px;margin:0 auto;border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-primary);border:2px solid var(--border-color)}.webcam-preview{width:100%;height:auto;display:block;transform:scaleX(-1)}.palm-guide-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}.palm-guide-box{width:60%;aspect-ratio:1;max-width:280px;display:flex;align-items:center;justify-content:center;border:2px dashed rgba(59,130,246,.5);border-radius:var(--radius-lg);background:#3b82f60d}.palm-guide-icon{width:60%;height:60%;color:#3b82f699}.palm-guide-text{margin-top:1rem;padding:.5rem 1rem;background:#0009;border-radius:var(--radius);font-size:.875rem;color:var(--text-primary)}.captured-preview{position:relative;width:100%;max-width:640px;margin:0 auto;border-radius:var(--radius-lg);overflow:hidden;border:2px solid var(--accent-success)}.captured-image{width:100%;height:auto;display:block}.capture-info{position:absolute;bottom:0;left:0;right:0;padding:.75rem;background:linear-gradient(transparent,#000c);display:flex;align-items:center;justify-content:space-between}.capture-dimensions{font-size:.75rem;color:var(--text-muted);font-family:SF Mono,Fira Code,monospace}.webcam-controls{display:flex;gap:1rem;justify-content:center;margin-top:1rem}.capture-btn{display:inline-flex;align-items:center;gap:.5rem}.capture-btn svg{flex-shrink:0}.webcam-error{padding:1rem;background:#ef44441a;border:1px solid var(--accent-error);border-radius:var(--radius);color:var(--accent-error);text-align:center}.webcam-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;background:var(--bg-primary);border-radius:var(--radius-lg);border:2px solid var(--border-color)}.webcam-loading-text{margin-top:1rem;color:var(--text-secondary)}.webcam-overlay{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;transform:scaleX(-1)}.face-indicator{position:absolute;bottom:1rem;left:50%;transform:translate(-50%);padding:.5rem 1rem;background:#000000b3;border-radius:var(--radius);font-size:.875rem;color:var(--text-secondary);transition:all .2s ease}.face-indicator.detected{background:#10b981e6;color:#fff}.capture-confidence{font-size:.75rem;color:var(--text-muted)}.capture-hint{margin-top:.5rem;font-size:.875rem;color:var(--text-muted);text-align:center}.arch-diagram{margin:1rem 0;display:flex;flex-direction:column;align-items:center;gap:0}.arch-gov-row{display:flex;justify-content:center;margin-bottom:0}.arch-vert-arrow{display:flex;flex-direction:column;align-items:center;padding:.25rem 0;gap:.125rem}.arch-vert-line{width:2px;height:1.25rem;background:var(--border-color)}.arch-vert-label{font-size:.625rem;color:var(--text-muted);letter-spacing:.03em}.arch-vert-tip{width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:6px solid var(--border-color)}.arch-flow{display:grid;grid-template-columns:1fr auto 1fr auto 1fr;gap:.75rem;align-items:stretch;width:100%}.arch-node{background:var(--bg-primary);border-radius:var(--radius);padding:1.25rem 1rem;text-align:center;border:1px solid var(--border-color);display:flex;flex-direction:column;gap:.5rem}.arch-node-icon{font-size:1.75rem;line-height:1}.arch-node-title{font-size:.9rem;font-weight:600;color:var(--text-primary)}.arch-node-items{display:flex;flex-direction:column;gap:.25rem;font-size:.75rem;color:var(--text-muted)}.arch-node.gov{border-color:var(--accent-warning)}.arch-node.user{border-color:var(--accent-primary)}.arch-node.engine{border-color:var(--accent-secondary)}.arch-node.verifier{border-color:var(--accent-success)}.arch-node.gov .arch-node-icon{color:var(--accent-warning)}.arch-node.user .arch-node-icon{color:var(--accent-primary)}.arch-node.engine .arch-node-icon{color:var(--accent-secondary)}.arch-node.verifier .arch-node-icon{color:var(--accent-success)}.arch-arrow{display:flex;align-items:center;justify-content:center}.arch-arrow-line{width:2rem;height:2px;background:var(--border-color);position:relative}.arch-arrow-line:after{content:"";position:absolute;right:-1px;top:-4px;width:0;height:0;border-left:6px solid var(--border-color);border-top:5px solid transparent;border-bottom:5px solid transparent}.swimlane{margin:1rem 0}.swimlane-header{display:grid;grid-template-columns:4.5rem 1fr 1.25rem 1fr 1.25rem 1fr;gap:.375rem;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-color)}.swimlane-col-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);text-align:center}.swimlane-col-label.gov-label{color:var(--accent-warning)}.swimlane-col-label.user-label{color:var(--accent-primary)}.swimlane-col-label.verifier-label{color:var(--accent-success)}.swimlane-row{display:grid;grid-template-columns:4.5rem 1fr 1.25rem 1fr 1.25rem 1fr;gap:.375rem;align-items:center;margin-bottom:.625rem}.swimlane-row:last-child{margin-bottom:0}.swim-phase{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;text-align:right;padding-right:.375rem}.swim-phase.phase-issue{color:var(--accent-warning)}.swim-phase.phase-enroll{color:var(--accent-primary)}.swim-phase.phase-auth{color:var(--accent-secondary)}.swim-phase.phase-present{color:var(--accent-warning)}.swim-phase.phase-verify{color:var(--accent-success)}.swim-action{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius);padding:.5rem .625rem}.swim-action-title{font-size:.775rem;font-weight:600;color:var(--text-primary);margin-bottom:.125rem}.swim-action-detail{font-size:.675rem;color:var(--text-muted)}.swim-arrow{display:flex;align-items:center;justify-content:center}.swim-arrow-right,.swim-arrow-left{width:100%;height:2px;background:var(--border-color);position:relative}.swim-arrow-right:after{content:"";position:absolute;right:-1px;top:-4px;width:0;height:0;border-left:6px solid var(--border-color);border-top:5px solid transparent;border-bottom:5px solid transparent}.swim-arrow-left:after{content:"";position:absolute;left:-1px;top:-4px;width:0;height:0;border-right:6px solid var(--border-color);border-top:5px solid transparent;border-bottom:5px solid transparent}.arch-node.optional{border-style:dashed;opacity:.75}.arch-vert-arrow.optional{opacity:.6}.arch-vert-arrow.optional .arch-vert-line{background:repeating-linear-gradient(to bottom,var(--border-color) 0px,var(--border-color) 4px,transparent 4px,transparent 8px)}.swim-action.optional{border-style:dashed;opacity:.75}.swim-arrow.optional .swim-arrow-right,.swim-arrow.optional .swim-arrow-left{background:repeating-linear-gradient(to right,var(--border-color) 0px,var(--border-color) 4px,transparent 4px,transparent 8px)}.optional-tag{display:inline-block;font-size:.55rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:var(--bg-tertiary);padding:.075rem .35rem;border-radius:3px;vertical-align:middle;margin-left:.25rem}.disclosure-example{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius);overflow:hidden;margin-top:.75rem}.disclosure-header{display:flex;align-items:center;justify-content:space-between;padding:.625rem .75rem;border-bottom:1px solid var(--border-color);background:var(--bg-tertiary)}.disclosure-title{font-size:.8rem;font-weight:600;color:var(--text-primary)}.disclosure-fields{display:flex;flex-direction:column}.disclosure-field{display:grid;grid-template-columns:7rem 1fr auto;gap:.75rem;align-items:center;padding:.5rem .75rem;border-bottom:1px solid rgba(51,65,85,.5);font-size:.775rem}.disclosure-field:last-child{border-bottom:none}.disclosure-label{color:var(--text-muted);font-weight:500}.disclosure-value{color:var(--text-primary);font-family:SF Mono,Fira Code,monospace;font-size:.75rem}.disclosure-value.redacted{color:var(--bg-tertiary);letter-spacing:.05em;-webkit-user-select:none;user-select:none}.disclosure-status{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:.125rem .375rem;border-radius:3px}.disclosure-field.hidden .disclosure-status{color:var(--text-muted);background:var(--bg-tertiary)}.disclosure-field.revealed .disclosure-status{color:var(--accent-success);background:#10b98126}.disclosure-field.revealed .disclosure-value{color:var(--accent-success)}.disclosure-field.zk .disclosure-status{color:var(--accent-secondary);background:#8b5cf626}.disclosure-field.zk .disclosure-value{color:var(--accent-secondary)}.privacy-note{display:flex;align-items:center;gap:.5rem;margin-top:.75rem;padding:.625rem .75rem;background:#8b5cf61a;border:1px solid rgba(139,92,246,.3);border-radius:var(--radius);font-size:.8rem;color:var(--accent-secondary)}.spatial-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .875rem;border-radius:999px;font-size:.875rem;font-weight:600;margin-bottom:1rem}.spatial-badge-pass{background:#10b98133;color:var(--accent-success)}.spatial-badge-fail{background:#ef444433;color:var(--accent-error)}.spatial-badge-icon{font-size:1.125rem}.flash-rounds{margin-bottom:1.25rem}.flash-rounds-label{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.flash-cards-row{display:flex;gap:1rem}.flash-card{display:flex;flex-direction:column;width:40px;border-radius:4px;overflow:hidden;border:1px solid var(--border-color)}.flash-card-top,.flash-card-bottom{height:30px}.flash-card-label{font-size:.625rem;color:var(--text-muted);text-align:center;padding-top:.25rem}.region-scores-section{margin-bottom:1.25rem}.region-scores-label{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.region-score-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.region-score-label{font-size:.75rem;color:var(--text-secondary);width:4rem;flex-shrink:0}.region-score-bars{flex:1;display:flex;flex-direction:column;gap:.25rem}.region-score-bar-group{display:flex;align-items:center;gap:.5rem}.region-score-bar-label{font-size:.625rem;color:var(--text-muted);width:2.5rem;flex-shrink:0}.region-score-track{flex:1;height:6px;background:var(--bg-primary);border-radius:3px;overflow:hidden}.region-score-fill{height:100%;border-radius:3px;transition:width .4s ease}.region-score-pct{font-size:.625rem;color:var(--text-muted);width:2rem;text-align:right;flex-shrink:0}.spatial-diff-score{margin-bottom:.5rem}.spatial-diff-label{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.375rem}.spatial-diff-track{height:8px;background:var(--bg-primary);border-radius:4px;overflow:hidden;margin-bottom:.25rem}.spatial-diff-fill{height:100%;border-radius:4px;transition:width .4s ease}.spatial-diff-value{font-size:.875rem;font-weight:700}.liveness-steps{display:flex;flex-direction:column;gap:.75rem;margin:1rem 0}.liveness-step{display:flex;gap:.75rem;align-items:flex-start;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius);padding:.75rem}.liveness-step-num{display:flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;border-radius:50%;background:var(--accent-secondary);color:#fff;font-size:.75rem;font-weight:700;flex-shrink:0;margin-top:.125rem}.liveness-step-title{font-size:.85rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.liveness-step-detail{font-size:.775rem;color:var(--text-muted);line-height:1.5}.liveness-step-detail em{color:var(--text-secondary);font-style:italic}.liveness-step-detail strong{color:var(--accent-secondary)}.mode-toggle{display:flex;gap:.75rem;margin-bottom:1.5rem}.mode-option{flex:1;padding:1rem;background:var(--bg-primary);border:2px solid var(--border-color);border-radius:var(--radius);cursor:pointer;transition:all .2s}.mode-option:hover{border-color:var(--accent-primary)}.mode-option.active{border-color:var(--accent-primary);background:#3b82f61a}.mode-option-title{font-size:.9rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.mode-option.active .mode-option-title{color:var(--accent-primary)}.mode-option-desc{font-size:.75rem;color:var(--text-muted);line-height:1.4}@media (max-width: 640px){.mode-toggle{flex-direction:column}}.helper-data-container{position:relative}.helper-data-container .copy-btn{position:absolute;top:.5rem;right:.5rem;padding:.25rem .5rem;font-size:.7rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:4px;color:var(--text-secondary);cursor:pointer;transition:all .2s}.helper-data-container .copy-btn:hover{background:var(--accent-primary);color:#fff}.site-footer{text-align:center;padding:2rem 0 1rem;font-size:.8rem;color:var(--text-muted)}.site-footer a{color:var(--accent-primary);text-decoration:none}.site-footer a:hover{text-decoration:underline}@media (max-width: 640px){#app{padding:1rem}h1{font-size:1.75rem}.nav{flex-direction:column}.timing-grid{grid-template-columns:repeat(2,1fr)}.arch-flow{grid-template-columns:1fr;gap:.5rem}.arch-arrow{transform:rotate(90deg)}.swimlane-header,.swimlane-row{grid-template-columns:3rem 1fr .75rem 1fr .75rem 1fr;gap:.25rem}.swim-phase{font-size:.55rem;padding-right:.25rem}.swim-action{padding:.375rem .5rem}.swim-action-title{font-size:.7rem}.swim-action-detail{font-size:.6rem}}
