.jwt-card,.info-card{background-color:var(--card-bg);border:1px solid var(--border-color);border-radius:6px;margin-bottom:1rem;overflow:hidden;box-shadow:0 1px 3px #0000001a}.card-header{background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:.8rem 1rem;display:flex}.card-header h3{color:var(--text-color);margin:0;font-size:1rem}.card-actions{gap:.5rem;display:flex}.editor-container{padding:1rem;position:relative}.cm-editor-host{border:1px solid var(--border-color);background-color:var(--input-bg);border-radius:4px;width:100%;overflow:hidden}.decode-btn{margin:1rem auto 0;display:block}.jwt-visualization{border-radius:6px;margin-bottom:1rem;font-family:monospace;display:flex;overflow:hidden}.jwt-part{text-align:center;color:#fff;flex-direction:column;flex:1;justify-content:center;align-items:center;min-height:50px;padding:.6rem;display:flex;position:relative;overflow:hidden}.header-part{background-color:#4e73df}.payload-part{background-color:#1cc88a}.signature-part{background-color:#f6c23e}.part-label{margin-bottom:.3rem;font-size:.8rem;font-weight:700;display:block}.part-content{word-break:break-all;max-height:50px;font-size:.75rem;overflow:hidden;-webkit-mask-image:linear-gradient(#000 60%,#0000 100%);mask-image:linear-gradient(#000 60%,#0000 100%)}.token-status{border-radius:4px;margin-bottom:1rem;padding:.6rem 1rem;font-size:.9rem}.token-status.valid{color:#1cc88a;background-color:#1cc88a33;border:1px solid #1cc88a80}.token-status.expired{color:#ff9f43;background-color:#ff9f4333;border:1px solid #ff9f4380}.token-status.invalid{color:#e74a3b;background-color:#e74a3b33;border:1px solid #e74a3b80}.jwt-json{white-space:pre-wrap;color:var(--text-color);background:0 0;margin:0;padding:0;font-family:monospace;font-size:.9rem;overflow-x:auto}.jwt-hl-key{color:#e83e8c}.jwt-hl-str{color:#28a745}.jwt-hl-num{color:#fd7e14}.jwt-hl-bool{color:#007bff}.jwt-hl-null{color:#6c757d}.claims-container{padding:.5rem 1rem}.no-claims{color:var(--text-color-secondary);padding:.5rem 0}.claim-item{border-bottom:1px solid var(--border-color);margin-bottom:.8rem;padding-bottom:.8rem}.claim-item:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.claim-name{color:var(--primary-color);margin-bottom:.3rem;font-weight:700}.claim-value{background-color:var(--bg-secondary);border-radius:3px;padding:.2rem .4rem;font-family:monospace;font-size:.9rem}.claim-description{color:var(--text-color-secondary);margin-top:.3rem;font-size:.9rem}.signature-info{color:var(--text-color-secondary);font-size:.9rem}.signature-raw{word-break:break-all;margin-top:.5rem;font-family:monospace}#signature-value{color:var(--text-color)}.jwt-info-list,.jwt-claims-list{color:var(--text-color-secondary);margin:.5rem 0 1rem;padding-left:1.5rem}.jwt-info-list li,.jwt-claims-list li{margin-bottom:.3rem}.jwt-claims-list code{background-color:var(--bg-secondary);border-radius:3px;padding:.1rem .3rem;font-family:monospace;font-size:.9rem}.action-button{background-color:var(--bg-secondary);color:var(--text-color);cursor:pointer;border:none;border-radius:4px;padding:.5rem 1rem;font-size:.9rem;transition:background-color .2s}.action-button:hover{background-color:var(--hover-bg)}.action-button.primary{background-color:var(--primary-color);font-weight:500;color:#fff!important}.action-button.primary:hover{background-color:var(--primary-dark,#1565c0)}.action-button.secondary{border:1px solid var(--border-color)}.status-message{color:#fff;z-index:1000;background-color:#333;border-radius:4px;padding:.6rem 1rem;font-size:.9rem;display:none;position:fixed;bottom:20px;left:50%;transform:translate(-50%)}.status-message.success{background-color:#2ecc71}.status-message.error{background-color:#e74c3c}@media (width<=768px){.jwt-visualization{flex-direction:column}.jwt-part{padding:.8rem}.card-actions{gap:.3rem}.action-button{padding:.4rem .8rem;font-size:.85rem}}.notification{color:#fff;opacity:0;z-index:1000;border-radius:4px;padding:10px 20px;transition:all .3s;position:fixed;bottom:20px;right:20px;transform:translateY(100px)}.notification.show{opacity:1;transform:translateY(0)}.notification-success{background-color:#4caf50}.notification-error{background-color:#f44336}.notification-info{background-color:#2196f3}
