*{box-sizing:border-box;margin:0;padding:0}:root{--tg-theme-bg-color: #ffffff;--tg-theme-text-color: #000000;--tg-theme-hint-color: #999999;--tg-theme-link-color: #168acd;--tg-theme-button-color: #40a7e3;--tg-theme-button-text-color: #ffffff;--tg-theme-secondary-bg-color: #f1f1f1}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background-color:var(--tg-theme-bg-color);color:var(--tg-theme-text-color);line-height:1.6}.container{width:100%;max-width:100%;margin:0 auto;padding:1rem}@supports (padding: env(safe-area-inset-top)){.container{padding-left:max(1rem,env(safe-area-inset-left));padding-right:max(1rem,env(safe-area-inset-right))}}h1{font-size:1.5rem;font-weight:700;margin-bottom:.25rem;color:var(--tg-theme-text-color, #111827)}h2{font-size:1.125rem;font-weight:600;margin-bottom:.75rem;color:var(--tg-theme-text-color, #111827)}.subtitle{color:var(--tg-theme-hint-color, #6b7280);font-size:.875rem;margin-bottom:1.5rem}.card{background:var(--tg-theme-secondary-bg-color, white);border-radius:.75rem;padding:1rem;margin-bottom:1rem}.status-badge{padding:1rem;border-radius:.5rem;margin-top:1rem;background-color:#d1fae5;border:1px solid #6ee7b7}.status-badge p{color:#065f46;font-weight:600;margin:0}button{min-height:44px;padding:.75rem 1rem;border:none;border-radius:.5rem;font-weight:600;cursor:pointer;transition:background-color .2s,transform .1s;font-size:.9375rem;-webkit-tap-highlight-color:transparent}button:active{transform:scale(.98)}button:disabled{background-color:#d1d5db!important;cursor:not-allowed;opacity:.6;transform:none}.btn-primary{background-color:var(--tg-theme-button-color);color:var(--tg-theme-button-text-color)}.btn-primary:hover:not(:disabled){background-color:var(--tg-theme-button-color);filter:brightness(.9)}.btn-indigo{background-color:#4f46e5;color:#fff}.btn-indigo:hover:not(:disabled){background-color:#4338ca}.btn-purple{background-color:#7c3aed;color:#fff}.btn-purple:hover:not(:disabled){background-color:#6d28d9}.btn-pink{background-color:#db2777;color:#fff}.btn-pink:hover:not(:disabled){background-color:#be185d}.btn-red{background-color:#dc2626;color:#fff}.btn-red:hover:not(:disabled){background-color:#b91c1c}.btn-gray{background-color:#4b5563;color:#fff}.btn-gray:hover:not(:disabled){background-color:#374151}.button-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.action-buttons{display:flex;gap:1rem;align-items:center}.btn-large{font-size:1.25rem;padding:1rem 2rem;flex:1}.log-container{background-color:#1f2937;color:#10b981;padding:1rem;border-radius:.5rem;font-family:Courier New,monospace;font-size:.875rem;height:500px;overflow-y:auto}.log-container .empty{color:#6b7280}.log-container .log-entry{margin-bottom:.25rem}.info-box{background-color:#dbeafe;border:1px solid #93c5fd;padding:1.5rem;border-radius:.5rem;margin-top:2rem}.info-box h3{color:#1e3a8a;font-size:1.125rem;font-weight:600;margin-bottom:.5rem}.info-box ul{color:#1e40af;list-style:none}.info-box ul li{margin-bottom:.25rem;font-size:.875rem}.info-box ul li strong{font-weight:600}.test-status-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.test-status-item{display:flex;align-items:center;gap:.75rem;padding:1rem;border-radius:.5rem;border:2px solid #e5e7eb;background-color:#f9fafb;transition:all .3s}.test-status-item .status-icon{font-size:1.5rem}.test-status-item .status-text{flex:1}.test-status-item .status-text .status-name{font-weight:600;font-size:.875rem}.test-status-item .status-text .status-duration{font-size:.75rem;color:#6b7280;margin-top:.25rem}.test-status-item.status-running{border-color:#3b82f6;background-color:#eff6ff;animation:pulse 1.5s ease-in-out infinite}.test-status-item.status-success{border-color:#10b981;background-color:#d1fae5}.test-status-item.status-error{border-color:#ef4444;background-color:#fee2e2}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.visual-card{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.visual-card h2{color:#fff}.visual-flow{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:1rem}.visual-block{flex:1;min-width:200px;padding:1rem;border-radius:.5rem;animation:fadeInScale .3s ease-out}.visual-block .block-label{font-size:.75rem;font-weight:600;text-transform:uppercase;opacity:.8;margin-bottom:.5rem}.visual-block .block-content{font-family:Courier New,monospace;font-size:.875rem;word-break:break-all;padding:.5rem;background-color:#0003;border-radius:.25rem}.visual-block.plaintext{background-color:#3b82f6}.visual-block.encrypted{background-color:#8b5cf6}.visual-block.decrypted{background-color:#10b981}.visual-arrow{font-size:2rem;font-weight:700;opacity:.8}.visual-extra{margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.3)}.visual-extra .extra-item{margin-bottom:.5rem;font-size:.875rem}.visual-extra .extra-item strong{opacity:.8;margin-right:.5rem}.visual-extra .extra-item{font-family:Courier New,monospace}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}
