:root{--primary-color:#3498db;--primary-dark:#2980b9;--secondary-color:#2ecc71;--secondary-dark:#27ae60;--error-color:#e74c3c;--warning-color:#f39c12;--text-color:#333;--light-bg:#f5f5f5;--border-color:#ddd;--success-color:#2ecc71}*{box-sizing:border-box;margin:0;padding:0}body{background-color:#f5f5f5;background-color:var(--light-bg);color:#333;color:var(--text-color);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.6}.app{margin:0 auto;max-width:1200px;padding:20px}.app-header{background-color:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;margin-bottom:30px;padding:20px;text-align:center}.app-header h1{color:#3498db;color:var(--primary-color);margin-bottom:10px}.subtitle{color:#666;font-size:1.1rem}.mode-toggle{display:flex;justify-content:center;margin-bottom:30px}.mode-toggle button{background-color:#fff;border:1px solid #ddd;border:1px solid var(--border-color);cursor:pointer;font-size:1rem;padding:12px 24px;transition:all .3s ease}.mode-toggle button:first-child{border-radius:4px 0 0 4px}.mode-toggle button:last-child{border-radius:0 4px 4px 0}.mode-toggle button.active{background-color:#3498db;background-color:var(--primary-color);color:#fff}.app-content{background-color:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;padding:20px}.app-footer{color:#666;font-size:.9rem;margin-top:30px;text-align:center}.app-footer,.creator-container,.joiner-container,.keygen-demo-container{padding:20px}.demo-header{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;box-shadow:0 4px 15px #0000001a;color:#fff;margin-bottom:30px;padding:20px;text-align:center}.demo-header h2{font-size:2rem;margin-bottom:10px}.demo-header p{font-size:1.1rem;opacity:.9}.section{background-color:#fafafa;border:1px solid #ddd;border:1px solid var(--border-color);border-radius:8px;margin-bottom:30px;padding:20px;transition:all .3s ease}.section:hover{box-shadow:0 2px 8px #0000001a}.section h3{border-bottom:1px solid #ddd;border-bottom:1px solid var(--border-color);color:#2980b9;color:var(--primary-dark);font-size:1.3rem;margin-bottom:15px;padding-bottom:10px}.role-selector{display:flex;gap:15px;margin-bottom:20px}.role-selector button{background-color:#fff;border:2px solid #ddd;border:2px solid var(--border-color);border-radius:8px;cursor:pointer;flex:1 1;font-size:1rem;font-weight:500;padding:15px 20px;transition:all .3s ease}.role-selector button:hover{border-color:#3498db;border-color:var(--primary-color);transform:translateY(-2px)}.role-selector button.active{background-color:#3498db;background-color:var(--primary-color);border-color:#3498db;border-color:var(--primary-color);box-shadow:0 4px 12px #3498db4d;color:#fff}.role-info{background-color:#e8f4fd;border-left:4px solid #3498db;border-left:4px solid var(--primary-color);border-radius:6px;padding:15px}.role-info p{color:#2c3e50;font-style:italic;margin:0}button{background-color:#3498db;background-color:var(--primary-color);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;padding:10px 20px;transition:background-color .3s ease}button:hover{background-color:#2980b9;background-color:var(--primary-dark)}button:disabled{background-color:#ccc;cursor:not-allowed}.reset-button{background-color:#f39c12;background-color:var(--warning-color);border-radius:6px;font-size:1.1rem;padding:12px 24px}.reset-button:hover{background-color:#e67e22}.reconnect-button{background-color:#f39c12;background-color:var(--warning-color);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;margin-top:10px;padding:12px 24px;transition:background-color .3s ease}.reconnect-button:hover{background-color:#e67e22}.password-setup{display:flex;flex-direction:column;gap:15px}.password-setup button{align-self:flex-start;background-color:#3498db;background-color:var(--primary-color);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;padding:10px 20px;transition:background-color .3s ease}.password-setup button:hover:not(:disabled){background-color:#2980b9;background-color:var(--primary-dark)}.password-setup button:disabled{background-color:#ccc;cursor:not-allowed}.password-info{background-color:#f5f5f5;background-color:var(--light-bg);border-left:4px solid #2ecc71;border-left:4px solid var(--success-color);border-radius:4px;padding:15px}.password-status{color:#2ecc71;color:var(--success-color);font-weight:500;justify-content:space-between}.change-password-btn{background-color:#f39c12;background-color:var(--warning-color);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.9rem;padding:6px 12px;transition:background-color .3s ease}.change-password-btn:hover{background-color:#e67e22}.config-grid{grid-gap:30px;gap:30px;grid-template-columns:1fr 1fr;margin-top:20px}.config-group{background-color:#f5f5f5;background-color:var(--light-bg);border:1px solid #ddd;border:1px solid var(--border-color);border-radius:8px;padding:20px}.config-group h4{color:#3498db;color:var(--primary-color);font-size:1.1rem;margin-bottom:15px}.config-group p{color:#666;font-size:.9rem;margin-bottom:15px}.keyshare-options{display:flex;flex-direction:column;gap:20px}.existing-keyshares{background-color:#f5f5f5;background-color:var(--light-bg);border:1px solid #ddd;border:1px solid var(--border-color);border-radius:8px;padding:20px}.existing-keyshares h4{color:#3498db;color:var(--primary-color);font-size:1.1rem;margin-bottom:15px}.keyshare-option{align-items:center;background-color:#fff;border:1px solid #ddd;border:1px solid var(--border-color);border-radius:6px;display:flex;justify-content:space-between;margin-bottom:10px;padding:15px}.keyshare-info{flex:1 1}.keyshare-info div{font-size:.9rem;margin-bottom:5px}.keyshare-info strong{color:#3498db;color:var(--primary-color)}.load-keyshare-btn{background-color:#3498db;background-color:var(--primary-color);border-radius:4px;font-size:.9rem;padding:8px 16px;transition:background-color .3s ease;white-space:nowrap}.load-keyshare-btn:hover{background-color:#2980b9;background-color:var(--primary-dark)}.new-session-option{background-color:#f5f5f5;background-color:var(--light-bg);border:1px solid #ddd;border:1px solid var(--border-color);border-radius:8px;padding:20px;text-align:center}.new-session-option h4{color:#2ecc71;color:var(--secondary-color);font-size:1.1rem;margin-bottom:15px}.new-session-btn{background-color:#2ecc71;background-color:var(--secondary-color);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;padding:12px 24px;transition:background-color .3s ease}.new-session-btn:hover{background-color:#27ae60;background-color:var(--secondary-dark)}.status{background-color:#f8f9fa;border-radius:4px;font-size:.9rem;margin-top:10px;padding:8px}.status-disconnected{animation:pulse 2s infinite;background-color:#fff3cd;border:1px solid #ffeaa7;color:#856404}.info-box{background-color:#e8f4fd;border-left:4px solid #3498db;border-left:4px solid var(--primary-color);border-radius:4px;margin-top:15px;padding:15px}.info-box.success{background-color:#d4edda;border-left-color:#2ecc71;border-left-color:var(--success-color)}.info-box h4{color:#2ecc71;color:var(--success-color);margin-bottom:10px}.info-box div{margin-bottom:8px;word-break:break-all}.input-group{margin-bottom:15px}.input-group label{display:block;font-weight:500;margin-bottom:8px}.input-group input,.input-group textarea{border:1px solid #ddd;border:1px solid var(--border-color);border-radius:4px;font-size:1rem;padding:10px;width:100%}.share-options{display:flex;flex-wrap:wrap;gap:20px;margin-top:15px}.qr-code{margin-bottom:20px;text-align:center}.qr-details{background:#f8f9fa;border-radius:8px;font-size:12px;margin-left:auto;margin-right:auto;margin-top:10px;max-width:200px;padding:10px;text-align:left}.qr-details>div{color:#666;margin:2px 0}.qr-details>div:first-child{color:#333;font-weight:700;margin-bottom:5px}.qr-code p{color:#3498db;color:var(--primary-color);font-weight:500;margin-top:10px}.setup-data{flex:1 1;min-width:300px}.setup-data textarea{border:1px solid #ddd;border:1px solid var(--border-color);border-radius:4px;font-family:monospace;margin-bottom:10px;padding:10px;width:100%}.generated-qr-section{background-color:#f8f9fa;border:1px solid #ddd;border:1px solid var(--border-color);border-radius:8px;margin-top:20px;padding:20px}.generated-qr-section h4{color:#2980b9;color:var(--primary-dark);font-size:1.1rem;margin-bottom:10px}.qr-section{background-color:#f5f5f5;background-color:var(--light-bg);border:1px solid #ddd;border:1px solid var(--border-color);border-radius:8px;margin-top:20px;padding:20px;text-align:center}.qr-simple{align-items:center;display:flex;flex-direction:column;gap:15px}.qr-simple button{background-color:#3498db;background-color:var(--primary-color);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.9rem;padding:8px 16px;transition:background-color .3s ease}.qr-simple button:hover{background-color:#2980b9;background-color:var(--primary-dark)}.progress-indicator{background-color:#f8f9fa;border-radius:6px;margin:20px 0;padding:15px}.progress-bar{background-color:#e9ecef;border-radius:10px;height:20px}.progress-fill{background:linear-gradient(90deg,#3498db,#2ecc71);background:linear-gradient(90deg,var(--primary-color),var(--secondary-color));border-radius:10px;transition:width .3s ease}.progress-text{color:#2980b9;color:var(--primary-dark);font-weight:500;text-align:center}.logs-section{margin-bottom:20px}.logs{background-color:#2c3e50;border-radius:4px;color:#ecf0f1;font-family:monospace;margin-bottom:15px;max-height:200px;overflow-y:auto;padding:15px}.log-entry{word-wrap:break-word;font-size:.9rem;line-height:1.4;margin-bottom:5px;overflow-wrap:break-word}.loading-info{background-color:#f5f5f5;background-color:var(--light-bg);border-left:4px solid #f39c12;border-left:4px solid var(--warning-color);border-radius:4px;margin-bottom:15px;padding:20px;text-align:center}.loading-info h4{color:#f39c12;color:var(--warning-color);font-size:1.1rem;margin-bottom:15px}.loading-spinner{font-size:2rem}.group-info,.party-info{background-color:#f5f5f5;background-color:var(--light-bg);border-left:4px solid #3498db;border-left:4px solid var(--primary-color);border-radius:4px;margin-bottom:15px;padding:15px}.group-info h4,.party-info h4{color:#3498db;color:var(--primary-color);font-size:1.1rem;margin-bottom:15px}.info-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:15px}.info-grid div{background-color:#fff;border:1px solid #ddd;border:1px solid var(--border-color);border-radius:4px;font-size:.9rem;padding:8px}.info-grid strong{color:#3498db;color:var(--primary-color)}.keyshare-info,.members-info{margin-top:15px}.keyshare-info h5,.members-info h5{color:#2ecc71;color:var(--secondary-color);font-size:1rem;margin-bottom:10px}.keyshare-list,.members-list{grid-gap:10px;display:grid;gap:10px}.keyshare-item,.member-item{background-color:#fff;border:1px solid #ddd;border:1px solid var(--border-color);border-radius:4px;font-family:monospace;font-size:.85rem;padding:10px}.keyshare-item div,.member-item div{margin-bottom:5px}.keyshare-item strong,.member-item strong{color:#3498db;color:var(--primary-color)}.storage-controls{flex-wrap:wrap;gap:10px}.storage-controls button.nuclear-button{background-color:#8e44ad;color:#fff}.storage-controls button.nuclear-button:hover{background-color:#7d3c98}.storage-info{border-left:4px solid #3498db;border-left:4px solid var(--primary-color);border-radius:4px;margin-bottom:15px}.storage-info h4{color:#3498db;color:var(--primary-color)}.debug-info,.storage-info div{font-family:monospace}.debug-info{background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:4px;font-size:.8rem;margin-top:10px;max-height:200px;overflow-y:auto;padding:10px;word-break:break-all}@media (max-width:768px){.share-options{flex-direction:column}.qr-code{margin:0 auto}.role-selector{flex-direction:column}.role-selector button{margin-bottom:10px}.info-grid{grid-template-columns:1fr}.info-controls{flex-direction:column}.config-grid{gap:20px;grid-template-columns:1fr}}.signing-section{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;box-shadow:0 8px 32px #0000001a;color:#fff;margin:20px 0;padding:30px}.signing-section h3{color:#fff;font-size:1.5rem;margin-bottom:25px;text-align:center}.signing-status{margin-bottom:25px}.status-indicator{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;justify-content:center;padding:15px}.status-indicator.completed{background:#2ecc7133;border-color:#2ecc7166}.status-indicator.in-progress{background:#3498db33;border-color:#3498db66}.status-indicator.error{background:#e74c3c33;border-color:#e74c3c66}.status-indicator.idle{background:#ffffff1a;border-color:#fff3}.status-icon{font-size:1.5rem;margin-right:10px}.status-text{font-size:1.1rem}.message-input-section{margin-bottom:25px}.message-input-section h4{color:#fff;font-size:1.2rem;margin-bottom:15px}.message-input-container{background:#ffffff1a;border:1px solid #fff3;border-radius:8px;padding:15px}.message-textarea{background:#ffffffe6;border:none;color:#333;font-size:14px;margin-bottom:10px}.message-textarea:focus{box-shadow:0 0 0 2px #ffffff4d}.message-textarea:disabled{cursor:not-allowed;opacity:.6}.message-actions{display:flex;gap:10px}.secondary-button{background:#ffffff1a;border:1px solid #ffffff4d;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;padding:8px 16px;transition:all .3s ease}.secondary-button:hover:not(:disabled){background:#fff3;transform:translateY(-1px)}.secondary-button:disabled{cursor:not-allowed;opacity:.5}.signing-controls{margin-bottom:25px}.control-group{display:flex;flex-wrap:wrap;gap:15px;justify-content:center}.sign-button{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:10px;color:#fff;cursor:pointer;display:flex;flex-direction:column;font-size:16px;font-weight:600;min-width:180px;padding:20px;transition:all .3s ease}.sign-button:hover:not(:disabled){background:#ffffff26;box-shadow:0 8px 25px #0003;transform:translateY(-3px)}.sign-button:disabled{cursor:not-allowed;opacity:.5;transform:none}.sign-button.primary{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#ffffff4d}.sign-button.primary:hover:not(:disabled){background:linear-gradient(135deg,#5a6fd8,#6a4190)}.button-icon{font-size:2rem;margin-bottom:8px}.button-text{font-size:1rem;margin-bottom:4px}.button-subtitle{font-size:.8rem;font-weight:400;opacity:.8}.signing-progress{margin:20px 0;text-align:center}.progress-bar{background:#fff3;border-radius:3px;height:6px;margin-bottom:10px;overflow:hidden;width:100%}.progress-fill{animation:progress-animation 2s ease-in-out infinite;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:3px;height:100%}@keyframes progress-animation{0%{width:0}50%{width:70%}to{width:100%}}.progress-text{align-items:center;color:#fff;display:flex;font-size:14px;gap:8px;justify-content:center}.progress-icon{animation:spin 1s linear infinite}.signature-result{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:12px;padding:25px}.signature-result h4{color:#fff;font-size:1.3rem;margin-bottom:20px;text-align:center}.signature-details{margin-bottom:20px}.detail-group{margin-bottom:15px}.detail-group label{color:#ffffffe6;display:block;font-size:14px;font-weight:600;margin-bottom:5px}.detail-value{background:#ffffff1a;border:1px solid #fff3;border-radius:6px;font-family:Courier New,monospace;font-size:12px;justify-content:space-between;padding:10px;word-break:break-all}.message-value{color:#fff;font-style:italic}.signature-value{color:#2ecc71;font-weight:700}.signature-components{grid-gap:15px;display:grid;gap:15px;grid-template-columns:1fr 1fr;margin-top:15px}.copy-button{background:#fff3;border:1px solid #ffffff4d;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;margin-left:10px;padding:4px 8px;transition:all .3s ease}.copy-button:hover{background:#ffffff4d;transform:translateY(-1px)}.copy-button.small{font-size:10px;padding:2px 6px}.signature-actions{flex-wrap:wrap;gap:15px;justify-content:center}.action-button{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;min-width:150px;padding:12px 24px;transition:all .3s ease}.action-button.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.action-button.primary:hover{box-shadow:0 6px 20px #0003;transform:translateY(-2px)}.action-button.secondary{background:#fff3;border:1px solid #ffffff4d;color:#fff}.action-button.secondary:hover{background:#ffffff4d;transform:translateY(-2px)}.error-display{background:#e74c3c33;border:1px solid #e74c3c66;border-radius:8px;padding:20px;text-align:center}.error-display h4{color:#e74c3c;margin-bottom:10px}.error-display p{color:#ffffffe6;margin-bottom:15px}@media (max-width:768px){.signing-section{padding:20px}.control-group{align-items:center;flex-direction:column}.sign-button{min-width:200px}.signature-components{grid-template-columns:1fr}.signature-actions{align-items:center;flex-direction:column}.action-button{min-width:200px}}.signing-setup-section{background-color:#f5f5f5;background-color:var(--light-bg);border:1px solid #ddd;border:1px solid var(--border-color);border-radius:8px;margin-bottom:20px;padding:20px}.signing-setup-section h4{color:#3498db;color:var(--primary-color);font-size:1.1rem;margin-bottom:10px}.signing-setup-section p{color:#666;font-size:.9rem;margin-bottom:15px}.setup-controls{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px}.setup-button{align-items:center;background-color:#3498db;background-color:var(--primary-color);border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;gap:8px;padding:10px 16px;transition:background-color .3s ease}.setup-button:hover{background-color:#2980b9;background-color:var(--primary-dark)}.setup-button.secondary{background-color:#2ecc71;background-color:var(--secondary-color)}.setup-button.secondary:hover{background-color:#27ae60;background-color:var(--secondary-dark)}.setup-button:disabled{background-color:#ccc;cursor:not-allowed}.button-icon{font-size:1.1rem}.button-text{font-weight:500}.qr-input-section{margin-bottom:20px}.qr-input-section h5{color:#333;color:var(--text-color);font-size:1rem;margin-bottom:10px}.qr-textarea{border:1px solid #ddd;border:1px solid var(--border-color);border-radius:4px;font-size:.9rem}.qr-textarea:focus{border-color:#3498db;border-color:var(--primary-color);box-shadow:0 0 0 2px #3498db33}.qr-textarea:disabled{background-color:#f5f5f5;color:#666;cursor:not-allowed}.signing-status{margin-bottom:20px}.status-indicator{background-color:#f8f9fa;border:1px solid #ddd;border:1px solid var(--border-color);border-radius:6px;gap:10px;padding:12px}.status-indicator.completed{background-color:#d4edda;border-color:#c3e6cb;color:#155724}.status-indicator.in-progress{animation:pulse 2s infinite;background-color:#fff3cd;border-color:#ffeaa7;color:#856404}.status-indicator.error{background-color:#f8d7da;border-color:#f5c6cb;color:#721c24}.status-indicator.idle{background-color:#e2e3e5;border-color:#d6d8db;color:#383d41}.status-icon{font-size:1.2rem}.main-layout{display:flex;gap:20px;margin-top:20px}.left-panel{flex-shrink:0;width:350px}.main-content{flex:1 1;min-width:0}.panel-section{background-color:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;margin-bottom:20px;padding:20px}.panel-section h3{border-bottom:2px solid #f5f5f5;border-bottom:2px solid var(--light-bg);color:#3498db;color:var(--primary-color);font-size:1.1rem;margin-bottom:15px;padding-bottom:8px}.info-controls{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:15px}.info-controls button{background-color:#3498db;background-color:var(--primary-color);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.9rem;padding:8px 12px;transition:background-color .3s ease;white-space:nowrap}.info-controls button:hover{background-color:#2980b9;background-color:var(--primary-dark)}.info-controls button:disabled{background-color:#ccc;cursor:not-allowed}.storage-controls{display:flex;gap:8px;margin-bottom:15px}.storage-controls button{background-color:#3498db;background-color:var(--primary-color);border:none;border-radius:4px;color:#fff;cursor:pointer;flex:1 1;font-size:.9rem;padding:8px 16px;transition:background-color .3s ease}.storage-controls button:hover{background-color:#2980b9;background-color:var(--primary-dark)}.storage-controls button.danger-button{background-color:#e74c3c;background-color:var(--error-color)}.storage-controls button.danger-button:hover{background-color:#c0392b}.storage-info{background-color:#f5f5f5;background-color:var(--light-bg);border:1px solid #ddd;border:1px solid var(--border-color);border-radius:6px;padding:15px}.storage-info h4{color:#333;color:var(--text-color);font-size:1rem;margin-bottom:10px}.storage-info div{font-size:.9rem;margin-bottom:5px}@media (max-width:768px){.main-layout{flex-direction:column}.left-panel{width:100%}}.main-content .section{margin-bottom:30px;position:relative}.main-content .section:last-child{margin-bottom:0}.tab-content{margin-bottom:20px}.signing-setup-section{margin-bottom:25px}.error-display,.message-input-section,.signature-result,.signing-controls,.signing-progress,.tab-navigation{margin-bottom:20px}.tab-navigation{border-bottom:2px solid #ddd;border-bottom:2px solid var(--border-color);display:flex;gap:5px;padding-bottom:0}.tab-button{align-items:center;background-color:#f8f9fa;border:none;border-bottom:3px solid #0000;border-radius:8px 8px 0 0;color:#666;cursor:pointer;display:flex;font-size:.95rem;font-weight:500;gap:8px;padding:12px 20px;position:relative;transition:all .3s ease}.tab-button:hover{background-color:#e9ecef}.tab-button.active,.tab-button:hover{color:#3498db;color:var(--primary-color)}.tab-button.active{background-color:#fff;border-bottom-color:#3498db;border-bottom-color:var(--primary-color);box-shadow:0 -2px 8px #0000001a}.tab-button:disabled{background-color:#f8f9fa;cursor:not-allowed;opacity:.5}.tab-icon{font-size:1.1rem}.tab-text{font-weight:500}.tab-badge{background-color:#f39c12;background-color:var(--warning-color);border-radius:10px;color:#fff;font-size:.7rem;margin-left:5px;padding:2px 6px}.tab-content{background-color:#fff;border-radius:0 8px 8px 8px;box-shadow:0 2px 10px #0000001a;padding:20px}.existing-keyshares-list{margin:15px 0}.loading-keyshare-details{color:#6c757d;font-style:italic;padding:20px;text-align:center}.keyshare-option-compact{align-items:center;background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;display:flex;justify-content:space-between;margin:8px 0;padding:10px;transition:all .2s ease}.keyshare-option-compact:hover{background-color:#e9ecef;border-color:#dee2e6}.keyshare-info-compact{flex:1 1;font-size:.85rem;line-height:1.3}.keyshare-info-compact div{margin:1px 0}.keyshare-info-compact strong{color:#3498db;color:var(--primary-color)}.load-keyshare-btn-compact{background-color:#3498db;background-color:var(--primary-color);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.8rem;padding:6px 12px;transition:background-color .2s ease;white-space:nowrap}.load-keyshare-btn-compact:hover{background-color:#2980b9;background-color:var(--primary-dark)}.new-session-option-compact{border-top:1px solid #e9ecef;margin-top:15px;padding-top:15px}.new-session-btn-compact{background-color:#2ecc71;background-color:var(--secondary-color);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;padding:10px;transition:background-color .2s ease;width:100%}.new-session-btn-compact:hover{background-color:#27ae60;background-color:var(--secondary-dark)}.storage-keys-list{margin-top:10px}.storage-key-item{align-items:center;display:flex;gap:8px;margin:4px 0;padding:2px 0}.click-hint{color:#6c757d;font-size:.75rem;font-style:italic}.formatted-id{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:3px;color:#495057;cursor:help;display:inline-block;font-family:Courier New,monospace;font-size:.85em;margin-left:4px;padding:2px 6px;position:relative}.formatted-id.clickable{cursor:pointer;transition:all .2s ease}.formatted-id.clickable:hover{background-color:#3498db;background-color:var(--primary-color);border-color:#3498db;border-color:var(--primary-color);box-shadow:0 2px 4px #0000001a;color:#fff;transform:translateY(-1px)}.formatted-id:hover{background-color:#e9ecef;border-color:#dee2e6}.formatted-id[title]:hover:after{background-color:#333;border-radius:4px;box-shadow:0 2px 8px #0000004d;color:#fff;content:attr(title);font-size:.8rem;margin-bottom:5px;padding:8px 12px;white-space:nowrap}.formatted-id[title]:hover:after,.formatted-id[title]:hover:before{bottom:100%;left:50%;position:absolute;transform:translateX(-50%);z-index:1000}.formatted-id[title]:hover:before{border:5px solid #0000;border-top-color:#333;content:"";margin-bottom:-5px}.modal-overlay{background-color:#00000080}.modal-content{background-color:#fff;border-radius:8px;box-shadow:0 4px 20px #0000004d;display:flex;flex-direction:column;max-height:90vh;max-width:800px}.modal-header{background-color:#f8f9fa;border-bottom:1px solid #e9ecef}.modal-header h3{color:#3498db;color:var(--primary-color)}.modal-close-btn{align-items:center;background:none;border:none;border-radius:4px;color:#6c757d;cursor:pointer;display:flex;font-size:1.5rem;height:30px;justify-content:center;padding:0;transition:background-color .2s ease;width:30px}.modal-close-btn:hover{background-color:#e9ecef;color:#495057}.modal-body{flex:1 1}.modal-footer{border-top:1px solid #e9ecef;display:flex;gap:10px;justify-content:flex-end;padding:20px}.modal-btn{border:none;border-radius:4px;cursor:pointer;font-size:.9rem;padding:8px 16px;transition:background-color .2s ease}.modal-btn.secondary{background-color:#6c757d;color:#fff}.modal-btn.secondary:hover{background-color:#5a6268}.file-info{display:flex;flex-direction:column;gap:20px}.file-data-section,.file-name-section{display:flex;flex-direction:column;gap:10px}.file-data-section h4,.file-name-section h4{color:#3498db;color:var(--primary-color);font-size:1rem;margin:0}.file-name-display{align-items:center;display:flex;gap:10px}.file-data-container{display:flex;flex-direction:column;gap:10px}.file-data-textarea{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;font-family:Courier New,monospace;font-size:.85rem;line-height:1.4;min-height:200px;padding:12px;resize:vertical;width:100%}.file-data-textarea:focus{border-color:#3498db;border-color:var(--primary-color);box-shadow:0 0 0 2px #3498db33;outline:none}.file-stats{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;display:flex;gap:20px;padding:15px}.stat-item{font-size:.9rem}.copy-btn{background-color:#3498db;background-color:var(--primary-color);border:none;border-radius:3px;color:#fff;font-size:.8rem;padding:4px 8px;transition:background-color .2s ease}.copy-btn:hover{background-color:#2980b9;background-color:var(--primary-dark)}.keygen-demo-container .main-content,.signing-tab{display:flex;flex-direction:column;gap:20px}.no-keyshare-message{background:#f8f9fa;border:2px dashed #dee2e6;border-radius:8px;padding:40px;text-align:center}.no-keyshare-message h4{color:#6c757d;margin-bottom:10px}.no-keyshare-message p{color:#6c757d;margin:0}.rotation-placeholder{background:#f8f9fa;border-radius:8px;padding:40px;text-align:center}.rotation-placeholder h2{color:#6c757d;margin-bottom:10px}.rotation-placeholder p{color:#6c757d;margin:0}.logs-section{margin-top:20px}.logs-container{background:#f8f9fa;border-radius:4px;font-family:Courier New,monospace;font-size:12px;padding:10px}.log-entry{color:#495057;margin-bottom:2px}.home-container{margin:0 auto;max-width:1200px;padding:40px 20px}.home-header{margin-bottom:60px}.home-icon{font-size:4rem;margin-bottom:20px}.home-header h1{color:#2c3e50;font-size:2.5rem;font-weight:700;margin-bottom:15px}.home-subtitle{color:#7f8c8d;font-size:1.1rem;line-height:1.6;margin:0 auto;max-width:600px}.home-options{grid-gap:30px;align-items:stretch;display:grid;gap:30px;grid-template-columns:1fr 1fr;margin-bottom:50px}.option-card{background:#fff;border:1px solid #e9ecef;border-radius:12px;box-shadow:0 4px 20px #00000014;height:100%;padding:30px;transition:transform .2s ease,box-shadow .2s ease}.option-card:hover{box-shadow:0 8px 30px #0000001f;transform:translateY(-2px)}.card-icon{align-items:center;border-radius:12px;display:flex;font-size:1.8rem;height:60px;justify-content:center;margin-bottom:20px;width:60px}.upload-icon{background:#e8f5e8;color:#27ae60}.create-icon{background:#f3e5f5;color:#9b59b6}.option-card h2{color:#2c3e50;font-size:1.5rem;font-weight:600;margin-bottom:15px}.option-card p{color:#7f8c8d;line-height:1.6}.features-list,.option-card p{margin-bottom:25px}.features-list h4{color:#2c3e50;font-size:1rem;font-weight:600;margin-bottom:10px}.features-list ul{list-style:none;padding:0}.features-list li{color:#7f8c8d;padding:5px 0 5px 20px;position:relative}.features-list li:before{color:#27ae60;content:"✓";font-weight:700;left:0;position:absolute}.keyshare-selection{margin-bottom:0}.keyshare-selection h4{color:#2c3e50;font-size:1rem;font-weight:600;margin-bottom:15px}.no-keyshares-state{background:#f8f9fa;border:2px dashed #dee2e6;border-radius:8px;padding:30px 20px;text-align:center}.no-keyshares-icon{font-size:2rem;margin-bottom:10px;opacity:.6}.no-keyshares-state p{color:#6c757d;font-weight:500;margin:0 0 5px}.no-keyshares-state small{color:#adb5bd;font-size:.85rem}.dropdown-container{display:flex;flex-direction:column;gap:15px}.keyshare-dropdown{background:#fff;border:2px solid #e9ecef;border-radius:8px;color:#495057;cursor:pointer;font-family:Courier New,monospace;font-size:.9rem;padding:12px 16px;transition:all .2s ease;width:100%}.keyshare-dropdown:focus{border-color:#3498db;box-shadow:0 0 0 3px #3498db1a;outline:none}.keyshare-dropdown:disabled{background:#f8f9fa;color:#6c757d;cursor:not-allowed}.keyshare-dropdown option{font-family:Courier New,monospace;padding:8px}.load-keyshare-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 4px 15px #667eea4d;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:8px;justify-content:center;padding:14px 20px;transition:all .3s ease;width:100%}.load-keyshare-btn:hover:not(:disabled){box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.load-keyshare-btn:disabled{background:#bdc3c7;box-shadow:none;cursor:not-allowed;transform:none}.loading-spinner{border:2px solid #ffffff4d;border-top-color:#fff;height:16px;width:16px}.password-section{margin-bottom:15px}.password-input{border:1px solid #ddd;border-radius:6px;font-size:.9rem;padding:12px;width:100%}.password-input:focus{border-color:#3498db;box-shadow:0 0 0 2px #3498db33}.primary-btn{background:#3498db;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:15px;transition:background-color .2s ease;width:100%}.primary-btn:hover{background:#2980b9}.error-message{background:#fdf2f2;border:1px solid #fecaca;border-radius:4px;color:#e74c3c;font-size:.9rem;margin-top:10px;padding:10px}.info-section{align-items:flex-start;background:#ebf3fd;border:1px solid #d1ecf1;border-radius:12px;display:flex;gap:20px;padding:25px}.info-icon{color:#3498db;flex-shrink:0;font-size:1.5rem;margin-top:2px}.info-content h3{color:#2c3e50;font-size:1.2rem;font-weight:600;margin-bottom:10px}.info-content p{color:#5a6c7d;line-height:1.6;margin:0}@media (max-width:768px){.home-options{gap:20px;grid-template-columns:1fr}.home-header h1{font-size:2rem}.option-card{padding:20px}.info-section{flex-direction:column;text-align:center}}.home-icon img{height:auto;width:120px}.card-icon img{height:28px;width:28px}.card-cta{align-items:center;display:flex;gap:12px;justify-content:flex-end;margin-top:auto}.option-card{display:flex;flex-direction:column}.option-card .features-list{margin-bottom:10px}.keygen-container{background:#fff;margin:0 auto;max-width:1200px;min-height:100vh;padding:20px}.keygen-content{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr;margin-top:20px}.config-section,.keygen-section,.logs-section,.qr-section{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:24px;transition:all .2s ease}.config-section:hover,.keygen-section:hover,.logs-section:hover,.qr-section:hover{border-color:#d1d5db;box-shadow:0 4px 6px #0000001a}.section-header{border-bottom:1px solid #f3f4f6;gap:12px;margin-bottom:20px;padding-bottom:12px}.section-header svg{color:#3b82f6;flex-shrink:0}.section-header h3,.section-header h4{color:#1f2937;font-size:1.125rem;font-weight:600;margin:0}.section-header h4{font-size:1rem}.config-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:24px}.config-item{display:flex;flex-direction:column;gap:8px}.config-item label{color:#374151;font-size:.875rem;font-weight:500}.config-input{border:1px solid #d1d5db;border-radius:8px;font-size:.875rem;padding:10px 12px;transition:border-color .2s ease}.config-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.password-section{border-top:1px solid #f3f4f6;padding-top:20px}.password-section .section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.password-section .section-header>div{align-items:center;display:flex;gap:8px}.password-status{align-items:center;background:#ecfdf5;border:1px solid #a7f3d0;border-radius:6px;display:flex;gap:6px;padding:4px 8px}.password-status-dot{background:#10b981;border-radius:50%;height:6px;width:6px}.password-status-text{color:#065f46;font-size:.75rem;font-weight:500}.password-inputs{grid-gap:12px;align-items:end;display:grid;gap:12px;grid-template-columns:1fr 1fr auto}.password-input{border:1px solid #d1d5db;border-radius:8px;font-size:.875rem;padding:10px 12px;transition:border-color .2s ease}.password-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.set-password-btn{align-items:center;background:#10b981;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:8px;padding:10px 16px;transition:all .2s ease}.set-password-btn:hover:not(:disabled){background:#059669;transform:translateY(-1px)}.set-password-btn:disabled{background:#9ca3af;cursor:not-allowed}.qr-content{gap:20px}.qr-content,.qr-input-area{display:flex;flex-direction:column}.qr-input-area{gap:12px}.qr-input-area label{color:#374151;font-size:.875rem;font-weight:500}.qr-textarea{border-radius:8px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;min-height:100px;transition:border-color .2s ease}.qr-textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.qr-actions{align-items:center;display:flex;gap:12px}.clear-btn,.copy-btn{align-items:center;background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:8px;padding:8px 16px;transition:all .2s ease}.clear-btn:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af}.copy-btn:hover{background:#f0f9ff;border-color:#3b82f6;color:#3b82f6}.clear-btn:disabled{cursor:not-allowed;opacity:.5}.qr-display{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:20px;text-align:center}.qr-display h4{color:#1f2937;font-weight:500;margin:0 0 16px}.qr-code-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:inline-block;padding:16px}.keygen-status{margin-bottom:20px}.status-indicator{align-items:center;border:1px solid;border-radius:8px;display:flex;gap:12px;padding:16px;transition:all .2s ease}.status-indicator.idle{background:#f8fafc;border-color:#e2e8f0;color:#64748b}.status-indicator.in-progress{background:#fef3c7;border-color:#f59e0b;color:#92400e}.status-indicator.completed{background:#d1fae5;border-color:#10b981;color:#065f46}.status-indicator.error{background:#fee2e2;border-color:#ef4444;color:#991b1b}.status-icon{flex-shrink:0}.status-icon svg{animation:spin 2s linear infinite}.status-indicator.completed .status-icon svg{animation:none}.status-text{font-size:.875rem;font-weight:500}.keygen-actions{display:flex;flex-wrap:wrap;gap:12px}.generate-qr-btn,.start-keygen-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:8px;padding:12px 20px;transition:all .2s ease}.start-keygen-btn{background:#3b82f6;color:#fff}.start-keygen-btn:hover:not(:disabled){background:#2563eb;box-shadow:0 4px 6px #3b82f633;transform:translateY(-1px)}.start-keygen-btn:disabled{background:#9ca3af;box-shadow:none;cursor:not-allowed;transform:none}.generate-qr-btn{background:#10b981;color:#fff}.generate-qr-btn:hover:not(:disabled){background:#059669;box-shadow:0 4px 6px #10b98133;transform:translateY(-1px)}.generate-qr-btn:disabled{background:#9ca3af;box-shadow:none;cursor:not-allowed;transform:none}.logs-container{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:12px}.log-entry{border-bottom:1px solid #f1f5f9;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.75rem;padding:4px 0}.log-entry:last-child{border-bottom:none}@media (max-width:768px){.keygen-container{padding:16px}.config-grid,.password-inputs{grid-template-columns:1fr}.qr-actions{align-items:stretch}.keygen-actions,.qr-actions{flex-direction:column}.generate-qr-btn,.start-keygen-btn{justify-content:center;width:100%}}.keyshare-details-section{animation:slideIn .3s ease-out;background:#fff;border:1px solid #e5e7eb;border-left:4px solid #10b981;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:24px;transition:all .2s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.keyshare-details-content{display:flex;flex-direction:column;gap:20px}.keyshare-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.keyshare-item{display:flex;flex-direction:column;gap:8px}.keyshare-item label{color:#374151;font-size:.875rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.keyshare-value{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;display:flex;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.875rem;gap:8px;padding:12px}.keyshare-value .formatted-id{color:#1f2937;cursor:help;flex:1 1}.copy-btn-small{padding:4px}.keyshare-actions{border-top:1px solid #f3f4f6;flex-direction:column;gap:12px;padding-top:16px}.proceed-btn{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:8px;box-shadow:0 2px 4px #3b82f633;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:600;gap:8px;padding:12px 24px;transition:all .2s ease}.proceed-btn:hover{box-shadow:0 4px 8px #3b82f64d;transform:translateY(-1px)}.auto-navigate-notice{align-items:center;color:#6b7280;display:flex;font-size:.75rem;font-style:italic;gap:8px}.auto-navigate-notice svg{animation:pulse 2s infinite;color:#f59e0b}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@media (max-width:768px){.keyshare-grid{grid-template-columns:1fr}.keyshare-value{align-items:flex-start;flex-direction:column;gap:8px}.copy-btn-small{align-self:flex-end}}.keyshare-status{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:20px;padding:12px 16px}.keyshare-status .status-indicator{align-items:center;-webkit-backdrop-filter:none;backdrop-filter:none;background:#0000;border:none;display:flex;gap:8px;padding:0}.keyshare-status .status-dot{border-radius:50%;flex-shrink:0;height:8px;width:8px}.keyshare-status .status-dot.loaded{background-color:#10b981;box-shadow:0 0 0 2px #10b98133}.keyshare-status .status-dot.not-loaded{background-color:#ef4444;box-shadow:0 0 0 2px #ef444433}.keyshare-status .status-text{color:#374151;font-size:.875rem;font-weight:500}.home-header{background-color:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;margin-bottom:30px;padding:20px;text-align:center}.header-content{flex-wrap:wrap;gap:20px;justify-content:space-between}.header-content,.header-left{align-items:center;display:flex}.header-left{gap:15px}.header-text{text-align:left}.header-text h1{color:#3498db;color:var(--primary-color);font-size:1.5rem;margin-bottom:5px}.header-navigation{display:flex;flex-wrap:wrap;gap:8px}.nav-btn{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;color:#64748b;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:6px;padding:8px 12px;text-decoration:none;transition:all .2s ease}.nav-btn:hover{background:#f1f5f9;border-color:#cbd5e1;color:#475569}.nav-btn.active{background:#3498db;background:var(--primary-color);border-color:#3498db;border-color:var(--primary-color);color:#fff}.nav-btn svg{height:16px;width:16px}.settings-container{margin:0 auto;max-width:1200px;padding:20px}.settings-content{display:flex;flex-direction:column;gap:30px}.relayer-config-section{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;overflow:hidden}.relayer-grid{grid-gap:12px 16px;display:grid;gap:12px 16px;grid-template-columns:160px 1fr;padding:20px}.relayer-grid label{align-self:center;color:#374151;font-weight:500}.relayer-grid input{border:1px solid #d1d5db;border-radius:8px;font-size:.95rem;padding:10px 12px;width:100%}.relayer-grid input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.test-btn{align-items:center;background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:6px;padding:8px 12px;transition:all .2s ease}.test-btn:hover:not(:disabled){background:#ecfeff;border-color:#06b6d4;color:#0e7490}.test-btn:disabled{cursor:not-allowed;opacity:.5}.health-status{border:1px solid #e5e7eb;border-radius:8px;font-size:.95rem;margin:0 20px 20px;padding:12px}.health-status.ok{background:#f0fdf4;border-color:#bbf7d0;color:#166534}.health-status.fail{background:#fef2f2;border-color:#fecaca;color:#b91c1c}@media (max-width:768px){.relayer-grid{grid-template-columns:1fr}}.keyshare-management-section,.logs-section{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;overflow:hidden}.section-header{align-items:center;background:#f8fafc;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:20px}.section-header-left{align-items:center;display:flex;gap:12px}.section-header-actions{align-items:center;display:flex;gap:8px}.section-header h3{color:#1f2937;font-size:1.25rem;font-weight:600;margin:0}.section-header svg{color:#6b7280}.clear-all-btn,.clear-btn,.refresh-btn{align-items:center;background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:6px;padding:8px 12px;transition:all .2s ease}.clear-btn:hover,.refresh-btn:hover{background:#f9fafb;border-color:#9ca3af}.clear-all-btn{background:#fef2f2;border-color:#fecaca;color:#dc2626}.clear-all-btn:hover{background:#fee2e2;border-color:#fca5a5;color:#b91c1c}.clear-all-btn:disabled,.clear-btn:disabled,.refresh-btn:disabled{cursor:not-allowed;opacity:.5}.clear-all-btn:disabled{background:#f9fafb;border-color:#e5e7eb;color:#9ca3af}.keyshares-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));padding:20px}.keyshare-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:16px;transition:all .2s ease}.keyshare-card:hover{border-color:#d1d5db;box-shadow:0 4px 12px #0000001a}.keyshare-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:12px}.keyshare-info h4{color:#1f2937;font-size:1rem;font-weight:600;margin:0 0 4px}.keyshare-key{color:#6b7280;font-family:monospace;font-size:.75rem;margin:0}.keyshare-actions{align-items:center;display:flex;gap:6px}.delete-btn,.view-btn{align-items:center;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 3px #0000001a;color:#6b7280;cursor:pointer;display:flex;height:36px;justify-content:center;padding:0;transition:all .2s ease;width:36px}.delete-btn svg,.view-btn svg{flex-shrink:0;height:16px;width:16px}.view-btn:hover{background:#e0f2fe;border-color:#0284c7;box-shadow:0 2px 6px #0284c733;color:#0369a1;transform:scale(1.05)}.delete-btn:hover{background:#fef2f2;border-color:#fecaca;box-shadow:0 2px 6px #dc262633;color:#dc2626;transform:scale(1.05)}.delete-btn:active,.view-btn:active{transform:scale(.95)}.keyshare-summary{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr 1fr}.summary-item{display:flex;flex-direction:column;gap:2px}.summary-item label{color:#6b7280;font-size:.75rem;font-weight:500}.summary-item span{color:#1f2937;font-size:.875rem;font-weight:500}.has-api-key{color:#059669}.no-api-key{color:#dc2626}.loading-state,.no-keyshares-state{align-items:center;color:#6b7280;display:flex;flex-direction:column;justify-content:center;padding:60px 20px}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #f3f4f6;border-radius:50%;border-top-color:#3b82f6;height:32px;margin-bottom:16px;width:32px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.no-keyshares-icon{font-size:3rem;margin-bottom:16px}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a;max-height:80vh;max-width:600px;overflow:hidden;width:100%}.modal-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:20px}.modal-header h3{color:#1f2937;font-size:1.25rem;font-weight:600;margin:0}.close-btn{align-items:center;background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;color:#6b7280;cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .2s ease;width:32px}.close-btn:hover{background:#f3f4f6;border-color:#d1d5db;color:#374151}.modal-body{max-height:60vh;overflow-y:auto;padding:20px}.detail-grid{grid-gap:16px;display:grid;gap:16px}.detail-item{display:flex;flex-direction:column;gap:4px}.detail-item label{color:#6b7280;font-size:.875rem;font-weight:500}.detail-value{align-items:center;display:flex;gap:8px}.formatted-id{background:#f9fafb;border:1px solid #e5e7eb;border-radius:4px;color:#1f2937;font-family:monospace;font-size:.875rem;padding:4px 8px;word-break:break-all}.copy-btn-small{align-items:center;background:#fff;border:1px solid #d1d5db;border-radius:4px;color:#6b7280;cursor:pointer;display:flex;flex-shrink:0;height:24px;justify-content:center;transition:all .2s ease;width:24px}.copy-btn-small:hover{background:#f3f4f6;border-color:#9ca3af;color:#374151}.copy-btn-small svg{height:12px;width:12px}.logs-container{background:#f9fafb;max-height:300px;overflow-y:auto;padding:20px}.log-entry{background:#fff;border:1px solid #e5e7eb;border-radius:6px;color:#374151;font-family:monospace;font-size:.875rem;margin-bottom:4px;padding:8px 12px}.no-logs{color:#6b7280;font-style:italic;text-align:center}@media (max-width:768px){.header-content{flex-direction:column;gap:15px}.header-navigation{justify-content:center}.keyshare-summary,.keyshares-grid{grid-template-columns:1fr}.modal-content{margin:10px;max-height:90vh}}.success-message{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;margin-bottom:20px;padding:24px;text-align:center}.success-icon{font-size:48px;margin-bottom:16px}.success-message h4{color:#166534;font-size:1.25rem;font-weight:600;margin:0 0 8px}.success-message p{color:#15803d;font-size:.875rem;margin:0}.signature-display{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:20px}.signature-field{margin-bottom:16px}.signature-field:last-child{margin-bottom:0}.signature-field label{color:#374151;display:block;font-size:.875rem;font-weight:600;margin-bottom:8px}.signature-value{align-items:center;background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;display:flex;gap:12px;padding:12px}.signature-value span{color:#1f2937;flex:1 1;font-family:monospace;font-size:.875rem;line-height:1.4;word-break:break-all}.copy-btn{align-items:center;background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#6b7280;cursor:pointer;display:flex;flex-shrink:0;height:32px;justify-content:center;transition:all .2s ease;width:32px}.copy-btn:hover{background:#f3f4f6;border-color:#9ca3af;color:#374151}.copy-btn svg{height:14px;width:14px}.signature-actions{border-top:1px solid #e5e7eb;display:flex;gap:12px;margin-top:20px;padding-top:20px}.signature-actions .primary-btn,.signature-actions .secondary-btn{flex:1 1;justify-content:center}@media (max-width:480px){.signature-actions,.signature-value{flex-direction:column}.signature-value{align-items:flex-start;gap:8px}.copy-btn{align-self:flex-end}}.message-section{margin-bottom:24px}.creator-content{display:flex;flex-direction:column;gap:24px}.qr-content{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:20px;text-align:center}.qr-code{margin-bottom:16px}.qr-data{text-align:left}.qr-data label{color:#374151;display:block;font-size:.875rem;font-weight:600;margin-bottom:8px}.qr-textarea{border:1px solid #d1d5db;border-radius:6px;font-family:monospace;font-size:.875rem;margin-bottom:12px;min-height:80px;padding:12px;resize:vertical;width:100%}.start-signing{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:20px;text-align:center}.primary-btn:disabled{cursor:not-allowed}.primary-btn:disabled,.primary-btn:disabled:hover{background-color:#f3f4f6;border-color:#e5e7eb;color:#9ca3af}.primary-btn:disabled .loading-spinner{display:none}.message-input{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:20px}.message-input label{color:#374151;display:block;font-size:.875rem;font-weight:600;margin-bottom:8px}.message-textarea{border:1px solid #d1d5db;border-radius:6px;font-family:inherit;font-size:.875rem;min-height:80px;padding:12px;resize:vertical;width:100%}.message-textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}
/*# sourceMappingURL=main.95a98635.css.map*/