@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Inconsolata:wght@400;700&display=swap";:root{--color-bg: #0d1117;--color-bg-light: #161b22;--color-border: #30363d;--color-text: #e6edf3;--color-text-secondary: #9198a1;--color-alice: #79c0ff;--color-bob: #56d364;--color-danger: #ff7b72;--color-success: #56d364;--color-warning: #e3b341;--color-focus: #79c0ff;--color-on-alice: #0d1117;--color-on-bob: #0d1117;--font-mono: "Inconsolata", monospace;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--tap-min: 44px;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px);--safe-right: env(safe-area-inset-right, 0px)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;width:100%}body{background-color:var(--color-bg);color:var(--color-text);font-family:var(--font-sans);line-height:1.6;font-size:1rem;-webkit-text-size-adjust:100%;overflow-x:hidden}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.skip-link{position:absolute;top:-100%;left:1rem;background:var(--color-alice);color:var(--color-bg);padding:.75rem 1.5rem;border-radius:0 0 4px 4px;z-index:9999;font-weight:600;text-decoration:none;transition:top .2s}.skip-link:focus{top:0}:focus-visible{outline:3px solid var(--color-focus);outline-offset:2px}:focus:not(:focus-visible){outline:none}a{color:var(--color-alice);text-decoration:underline;text-underline-offset:2px}a:hover{text-decoration-thickness:2px}#app{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh}.header{background:linear-gradient(135deg,var(--color-alice),var(--color-bob));padding:1.5rem 1.5rem calc(1.5rem + var(--safe-top));padding-top:calc(1.5rem + var(--safe-top));text-align:center;color:var(--color-bg);border-bottom:1px solid var(--color-border)}.header h1{font-size:clamp(1.5rem,5vw,2.5rem);margin-bottom:.25rem;font-weight:700}.header .subtitle{font-size:clamp(.875rem,2.5vw,1.1rem);opacity:.9}.container{display:flex;flex-direction:column;flex:1;overflow:hidden}.tabs{border-bottom:1px solid var(--color-border);background-color:var(--color-bg-light);padding:0 var(--safe-left, .5rem);padding-right:var(--safe-right, .5rem);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tabs [role=tablist]{display:flex;gap:0;min-width:max-content}.tab-btn{min-height:var(--tap-min);padding:.75rem 1.25rem;background:none;border:none;color:var(--color-text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;border-bottom:3px solid transparent;transition:color .2s,border-color .2s;font-family:var(--font-sans);white-space:nowrap}.tab-btn:hover{color:var(--color-text)}.tab-btn[aria-selected=true]{color:var(--color-alice);border-bottom-color:var(--color-alice)}.tab-content{flex:1;overflow-y:auto;padding:1.5rem;padding-left:calc(1.5rem + var(--safe-left));padding-right:calc(1.5rem + var(--safe-right));animation:fadeIn .2s}.tab-content[hidden]{display:none}.tab-content:not([hidden]){display:block}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.conversation-layout{display:flex;flex-direction:column;gap:1.5rem}.conversation-panel{display:flex;flex-direction:column;gap:1rem}.messages-container{background-color:var(--color-bg-light);border:1px solid var(--color-border);border-radius:8px;padding:1.25rem;min-height:200px;max-height:50vh;overflow-y:auto;display:flex;flex-direction:column;gap:.75rem}.empty-state{color:var(--color-text-secondary);text-align:center;padding:2rem 0;font-style:italic}.message{display:flex;gap:.75rem;animation:slideIn .3s}.message.alice{justify-content:flex-start}.message.bob{justify-content:flex-end}@keyframes slideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.message-bubble{max-width:80%;padding:.75rem 1rem;border-radius:12px;word-wrap:break-word;overflow-wrap:break-word;font-size:.9375rem;line-height:1.5}.message.alice .message-bubble{background-color:var(--color-alice);color:var(--color-on-alice);border-bottom-left-radius:4px}.message.bob .message-bubble{background-color:var(--color-bob);color:var(--color-on-bob);border-bottom-right-radius:4px}.input-controls{display:flex;flex-direction:column;gap:.75rem}.sender-selector{border:none;display:flex;gap:1rem}.sender-option{display:flex;align-items:center;gap:.5rem;cursor:pointer;color:var(--color-text);min-height:var(--tap-min);padding:.25rem .5rem;border-radius:4px}.sender-option:has(input:checked) .sender-label-alice{color:var(--color-alice);font-weight:600}.sender-option:has(input:checked) .sender-label-bob{color:var(--color-bob);font-weight:600}.sender-option input[type=radio]{cursor:pointer;width:18px;height:18px;accent-color:var(--color-alice)}.input-row{display:flex;gap:.5rem}.message-input{flex:1;min-height:var(--tap-min);padding:.75rem;background-color:var(--color-bg-light);border:2px solid var(--color-border);border-radius:8px;color:var(--color-text);font-family:var(--font-sans);font-size:1rem}.message-input:focus-visible{border-color:var(--color-focus);outline:none;box-shadow:0 0 0 3px #79c0ff40}.message-input::placeholder{color:var(--color-text-secondary)}.state-panel{background-color:var(--color-bg-light);border:1px solid var(--color-border);border-radius:8px;padding:1.25rem;overflow-y:auto}.state-panel h3{margin-bottom:1rem;color:var(--color-text);font-size:1rem}.key-state{display:flex;flex-direction:column;gap:1.25rem}.party-state{border-radius:6px;padding:1rem;background-color:var(--color-bg)}.party-state.alice{border-left:4px solid var(--color-alice)}.party-state.bob{border-left:4px solid var(--color-bob)}.party-state h4{margin-bottom:.75rem;font-size:.875rem;font-weight:600}.state-info{display:flex;flex-direction:column;gap:.5rem}.state-item{display:flex;justify-content:space-between;align-items:baseline;font-size:.8125rem;gap:.5rem}.state-label{color:var(--color-text-secondary)}.state-value{font-family:var(--font-mono);color:var(--color-text);max-width:60%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:right}.btn{min-height:var(--tap-min);padding:.75rem 1.5rem;border:2px solid transparent;border-radius:8px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:background-color .15s,opacity .15s,box-shadow .15s;font-family:var(--font-sans);text-align:center;touch-action:manipulation}.btn-primary{background-color:var(--color-alice);color:var(--color-bg)}.btn-primary:hover:not(:disabled){background-color:#9ad0ff}.btn-danger{background-color:var(--color-danger);color:var(--color-bg)}.btn-danger:hover:not(:disabled){background-color:#ffa198}.btn-success{background-color:var(--color-success);color:var(--color-bg)}.btn-success:hover:not(:disabled){background-color:#7ee787}.btn:disabled{opacity:.4;cursor:not-allowed}.state-viz{display:flex;flex-direction:column;gap:2rem}.ratchet-diagram,.chain-diagram,.stats-panel{background-color:var(--color-bg-light);border:1px solid var(--color-border);border-radius:8px;padding:1.25rem}.ratchet-diagram h3,.chain-diagram h3,.stats-panel h3{margin-bottom:1.25rem;color:var(--color-alice);font-size:1.125rem}.ratchet-teeth{display:flex;gap:4px;margin-bottom:.75rem;height:48px}.tooth{flex:1;border-radius:4px;border:2px solid var(--color-border);transition:all .3s;position:relative;min-width:24px}.tooth.active{background:linear-gradient(135deg,var(--color-alice),var(--color-bob));border-color:var(--color-text)}.tooth.deleted{background-color:var(--color-text-secondary);opacity:.3}.tooth.empty{background-color:transparent}.diagram-note{font-size:.8125rem;color:var(--color-text-secondary);margin-top:.5rem}.chain-visual{background-color:var(--color-bg);padding:1rem;border-radius:6px;font-family:var(--font-mono);font-size:.8125rem;overflow-x:auto}.chain-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;flex-wrap:nowrap}.chain-label{color:var(--color-text-secondary);min-width:70px;flex-shrink:0}.chain-item{background-color:var(--color-alice);color:var(--color-on-alice);padding:.375rem .625rem;border-radius:4px;min-width:40px;text-align:center;flex-shrink:0}.arrow{color:var(--color-text-secondary);flex-shrink:0}.chain-branch{display:flex;gap:.5rem;flex:1}.chain-branch-item{background-color:var(--color-bob);color:var(--color-on-bob);padding:.375rem .625rem;border-radius:4px;min-width:60px;text-align:center;flex-shrink:0}.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.stat{background-color:var(--color-bg);padding:1rem;border-radius:6px;border-left:4px solid var(--color-alice)}.stat-label{color:var(--color-text-secondary);font-size:.8125rem;margin-bottom:.375rem}.stat-value{font-family:var(--font-mono);font-size:1.5rem;font-weight:700;color:var(--color-text)}.compromise-panel{background-color:var(--color-bg-light);border:1px solid var(--color-border);border-radius:8px;padding:1.25rem}.compromise-panel>h3{margin-bottom:.5rem;font-size:1.25rem}.panel-desc{margin-bottom:1.5rem;color:var(--color-text-secondary)}.sim-section{margin-bottom:1.5rem;padding:1.25rem;background-color:var(--color-bg);border-radius:6px;border-left:4px solid var(--color-warning)}.sim-section h4{margin-bottom:1rem;color:var(--color-text);font-size:1rem}.sim-state{margin-top:1rem;padding:1rem;background-color:var(--color-bg-light);border-radius:6px;border-left:4px solid var(--color-warning)}.sim-state p{margin-bottom:.5rem}.warning{color:var(--color-danger);font-weight:600}.success{color:var(--color-success);font-weight:600}.recovery-note,.recovery-explanation{color:var(--color-text-secondary);font-size:.875rem}.attacker-access{margin-top:.75rem;font-size:.875rem}.attacker-access ul{margin-left:1.5rem;margin-top:.5rem}.attacker-access li{margin-bottom:.25rem}.compromise-explanation{margin-top:1.5rem;padding:1.25rem;background-color:var(--color-bg);border-left:4px solid var(--color-success);border-radius:6px}.compromise-explanation h4{margin-bottom:1rem;color:var(--color-success)}.compromise-explanation ul{margin-left:1.5rem}.compromise-explanation li{margin-bottom:.75rem}.about-content{max-width:900px;margin:0 auto}.about-content h2{font-size:clamp(1.5rem,4vw,2rem);margin-bottom:1.5rem;color:var(--color-alice)}.about-content h3{font-size:1.25rem;margin-top:2rem;margin-bottom:.75rem;color:var(--color-alice)}.about-content h4{font-size:1rem;margin-top:1rem;margin-bottom:.5rem}.about-content section{margin-bottom:2rem}.about-content p{margin-bottom:.75rem;line-height:1.7}.about-content ul{margin-left:1.5rem;margin-bottom:1rem}.about-content li{margin-bottom:.5rem}.about-content pre{background-color:var(--color-bg-light);border:1px solid var(--color-border);border-radius:6px;padding:1rem;overflow-x:auto;margin:1rem 0;font-family:var(--font-mono);font-size:.8125rem}.about-content code{font-family:var(--font-mono);color:var(--color-alice)}.comparison-table{overflow-x:auto;margin:1.5rem 0;border-radius:6px}.comparison-table table{width:100%;border-collapse:collapse;background-color:var(--color-bg-light);border-radius:6px;overflow:hidden}.comparison-table th,.comparison-table td{padding:.75rem;text-align:left;border-bottom:1px solid var(--color-border)}.comparison-table thead th{background-color:var(--color-bg);border-bottom:2px solid var(--color-border);font-weight:600}.comparison-table tr:last-child td{border-bottom:none}@media (min-width: 769px){.conversation-layout{flex-direction:row;align-items:stretch}.conversation-panel{flex:1;min-width:0}.state-panel{width:320px;flex-shrink:0;max-height:calc(100vh - 200px)}.messages-container{min-height:400px;max-height:calc(100vh - 340px)}}@media (max-width: 768px){.tab-content{padding:1rem;padding-left:calc(1rem + var(--safe-left));padding-right:calc(1rem + var(--safe-right))}.state-panel{max-height:280px}.stats{grid-template-columns:1fr}}@media (max-width: 480px){.header{padding:1rem;padding-top:calc(1rem + var(--safe-top))}.tab-content{padding:.75rem;padding-left:calc(.75rem + var(--safe-left));padding-right:calc(.75rem + var(--safe-right))}.tab-btn{padding:.75rem .875rem;font-size:.8125rem}.message-bubble{max-width:90%}.sender-selector{flex-direction:row;gap:.5rem}.input-row{flex-direction:column}.btn{width:100%}.ratchet-teeth{height:36px}.tooth{min-width:16px}.chain-row{flex-wrap:wrap}.stats{grid-template-columns:1fr;gap:.75rem}.compromise-panel,.sim-section{padding:1rem}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}@media (forced-colors: active){.btn{border:2px solid ButtonText}.tab-btn[aria-selected=true]{border-bottom:3px solid Highlight;color:Highlight}.tooth.active{border:2px solid Highlight;background:Highlight}.message-bubble{border:1px solid CanvasText}.party-state{border-left-width:4px}}@supports (padding-bottom: env(safe-area-inset-bottom)){.input-controls{padding-bottom:var(--safe-bottom)}}
